From 157b64d2e431099a9e02bad5da95bd5e31c42e5a Mon Sep 17 00:00:00 2001 From: Matt Borgerson Date: Tue, 21 Jun 2022 20:00:54 -0700 Subject: [PATCH] Implement an Xbox dashboard style jumbotron anim --- resources/gl_logo.js | 6 +- resources/logo-green-jumbotron.svg | 83 +++++++++++++++++++++ resources/mesh_pattern.svg | 52 +++++++++++++ resources/three.min.js | 6 ++ resources/xbox_logo.png | Bin 75942 -> 96151 bytes templates/template_base.html | 10 +-- templates/template_index.html | 114 ++++++++++++++++++++++++----- theme.scss | 27 +++---- 8 files changed, 256 insertions(+), 42 deletions(-) create mode 100644 resources/logo-green-jumbotron.svg create mode 100644 resources/mesh_pattern.svg create mode 100644 resources/three.min.js diff --git a/resources/gl_logo.js b/resources/gl_logo.js index 1f1433c3..ec964e4c 100644 --- a/resources/gl_logo.js +++ b/resources/gl_logo.js @@ -40,7 +40,7 @@ const int numParticles = 35; const int numSpotlights = 5; const vec2 texSize = vec2(128.0,128.0); const vec4 bgColor = vec4(0.); -const vec4 fgColor = vec4(0.259, 0.890, 0.208, 1.); +const vec4 fgColor = vec4(0.384, 0.792, 0.075, 1.); const vec4 particleColor = fgColor; const vec4 textPos = vec4(0.01, 0, 0.98, 0.125); @@ -321,6 +321,8 @@ function render(ts) { requestAnimationFrame(render); return; } + if (!(gl = getRenderingContext())) + return; if (pending_disable_fallback) { document.getElementById("logo-canvas").style.visibility = "visible"; document.getElementById("logo-fallback").style.visibility = "hidden"; @@ -339,7 +341,7 @@ function render(ts) { } function getRenderingContext() { - var canvas = document.querySelector("canvas"); + var canvas = document.querySelector("#logo-canvas"); canvas.width = 512; canvas.height = 512; var gl = canvas.getContext("webgl"); diff --git a/resources/logo-green-jumbotron.svg b/resources/logo-green-jumbotron.svg new file mode 100644 index 00000000..98865b06 --- /dev/null +++ b/resources/logo-green-jumbotron.svg @@ -0,0 +1,83 @@ + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + diff --git a/resources/mesh_pattern.svg b/resources/mesh_pattern.svg new file mode 100644 index 00000000..caf8cff7 --- /dev/null +++ b/resources/mesh_pattern.svg @@ -0,0 +1,52 @@ + + + + + + + + + + + + + + + + diff --git a/resources/three.min.js b/resources/three.min.js new file mode 100644 index 00000000..63e198b9 --- /dev/null +++ b/resources/three.min.js @@ -0,0 +1,6 @@ +/** + * @license + * Copyright 2010-2021 Three.js Authors + * SPDX-License-Identifier: MIT + */ +!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).THREE={})}(this,(function(t){"use strict";const e="134",n=100,i=300,r=301,s=302,a=303,o=304,l=306,c=307,h=1e3,u=1001,d=1002,p=1003,m=1004,f=1005,g=1006,v=1007,y=1008,x=1009,_=1012,M=1014,b=1015,w=1016,S=1020,T=1022,E=1023,A=1026,L=1027,R=33776,C=33777,P=33778,I=33779,D=35840,N=35841,z=35842,B=35843,F=37492,O=37496,U=2300,H=2301,G=2302,k=2400,V=2401,W=2402,j=2500,q=2501,X=3e3,Y=3001,J=3007,Z=3002,Q=3004,K=3005,$=3006,tt=7680,et=35044,nt=35048,it="300 es";class rt{addEventListener(t,e){void 0===this._listeners&&(this._listeners={});const n=this._listeners;void 0===n[t]&&(n[t]=[]),-1===n[t].indexOf(e)&&n[t].push(e)}hasEventListener(t,e){if(void 0===this._listeners)return!1;const n=this._listeners;return void 0!==n[t]&&-1!==n[t].indexOf(e)}removeEventListener(t,e){if(void 0===this._listeners)return;const n=this._listeners[t];if(void 0!==n){const t=n.indexOf(e);-1!==t&&n.splice(t,1)}}dispatchEvent(t){if(void 0===this._listeners)return;const e=this._listeners[t.type];if(void 0!==e){t.target=this;const n=e.slice(0);for(let e=0,i=n.length;e>8&255]+lt[t>>16&255]+lt[t>>24&255]+"-"+lt[255&e]+lt[e>>8&255]+"-"+lt[e>>16&15|64]+lt[e>>24&255]+"-"+lt[63&n|128]+lt[n>>8&255]+"-"+lt[n>>16&255]+lt[n>>24&255]+lt[255&i]+lt[i>>8&255]+lt[i>>16&255]+lt[i>>24&255]).toUpperCase()}function ut(t,e,n){return Math.max(e,Math.min(n,t))}function dt(t,e){return(t%e+e)%e}function pt(t,e,n){return(1-n)*t+n*e}function mt(t){return 0==(t&t-1)&&0!==t}function ft(t){return Math.pow(2,Math.ceil(Math.log(t)/Math.LN2))}function gt(t){return Math.pow(2,Math.floor(Math.log(t)/Math.LN2))}var vt=Object.freeze({__proto__:null,DEG2RAD:at,RAD2DEG:ot,generateUUID:ht,clamp:ut,euclideanModulo:dt,mapLinear:function(t,e,n,i,r){return i+(t-e)*(r-i)/(n-e)},inverseLerp:function(t,e,n){return t!==e?(n-t)/(e-t):0},lerp:pt,damp:function(t,e,n,i){return pt(t,e,1-Math.exp(-n*i))},pingpong:function(t,e=1){return e-Math.abs(dt(t,2*e)-e)},smoothstep:function(t,e,n){return t<=e?0:t>=n?1:(t=(t-e)/(n-e))*t*(3-2*t)},smootherstep:function(t,e,n){return t<=e?0:t>=n?1:(t=(t-e)/(n-e))*t*t*(t*(6*t-15)+10)},randInt:function(t,e){return t+Math.floor(Math.random()*(e-t+1))},randFloat:function(t,e){return t+Math.random()*(e-t)},randFloatSpread:function(t){return t*(.5-Math.random())},seededRandom:function(t){return void 0!==t&&(st=t%2147483647),st=16807*st%2147483647,(st-1)/2147483646},degToRad:function(t){return t*at},radToDeg:function(t){return t*ot},isPowerOfTwo:mt,ceilPowerOfTwo:ft,floorPowerOfTwo:gt,setQuaternionFromProperEuler:function(t,e,n,i,r){const s=Math.cos,a=Math.sin,o=s(n/2),l=a(n/2),c=s((e+i)/2),h=a((e+i)/2),u=s((e-i)/2),d=a((e-i)/2),p=s((i-e)/2),m=a((i-e)/2);switch(r){case"XYX":t.set(o*h,l*u,l*d,o*c);break;case"YZY":t.set(l*d,o*h,l*u,o*c);break;case"ZXZ":t.set(l*u,l*d,o*h,o*c);break;case"XZX":t.set(o*h,l*m,l*p,o*c);break;case"YXY":t.set(l*p,o*h,l*m,o*c);break;case"ZYZ":t.set(l*m,l*p,o*h,o*c);break;default:console.warn("THREE.MathUtils: .setQuaternionFromProperEuler() encountered an unknown order: "+r)}}});class yt{constructor(t=0,e=0){this.x=t,this.y=e}get width(){return this.x}set width(t){this.x=t}get height(){return this.y}set height(t){this.y=t}set(t,e){return this.x=t,this.y=e,this}setScalar(t){return this.x=t,this.y=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;default:throw new Error("index is out of range: "+t)}}clone(){return new this.constructor(this.x,this.y)}copy(t){return this.x=t.x,this.y=t.y,this}add(t,e){return void 0!==e?(console.warn("THREE.Vector2: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(t,e)):(this.x+=t.x,this.y+=t.y,this)}addScalar(t){return this.x+=t,this.y+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this}sub(t,e){return void 0!==e?(console.warn("THREE.Vector2: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(t,e)):(this.x-=t.x,this.y-=t.y,this)}subScalar(t){return this.x-=t,this.y-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this}multiply(t){return this.x*=t.x,this.y*=t.y,this}multiplyScalar(t){return this.x*=t,this.y*=t,this}divide(t){return this.x/=t.x,this.y/=t.y,this}divideScalar(t){return this.multiplyScalar(1/t)}applyMatrix3(t){const e=this.x,n=this.y,i=t.elements;return this.x=i[0]*e+i[3]*n+i[6],this.y=i[1]*e+i[4]*n+i[7],this}min(t){return this.x=Math.min(this.x,t.x),this.y=Math.min(this.y,t.y),this}max(t){return this.x=Math.max(this.x,t.x),this.y=Math.max(this.y,t.y),this}clamp(t,e){return this.x=Math.max(t.x,Math.min(e.x,this.x)),this.y=Math.max(t.y,Math.min(e.y,this.y)),this}clampScalar(t,e){return this.x=Math.max(t,Math.min(e,this.x)),this.y=Math.max(t,Math.min(e,this.y)),this}clampLength(t,e){const n=this.length();return this.divideScalar(n||1).multiplyScalar(Math.max(t,Math.min(e,n)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this}roundToZero(){return this.x=this.x<0?Math.ceil(this.x):Math.floor(this.x),this.y=this.y<0?Math.ceil(this.y):Math.floor(this.y),this}negate(){return this.x=-this.x,this.y=-this.y,this}dot(t){return this.x*t.x+this.y*t.y}cross(t){return this.x*t.y-this.y*t.x}lengthSq(){return this.x*this.x+this.y*this.y}length(){return Math.sqrt(this.x*this.x+this.y*this.y)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)}normalize(){return this.divideScalar(this.length()||1)}angle(){return Math.atan2(-this.y,-this.x)+Math.PI}distanceTo(t){return Math.sqrt(this.distanceToSquared(t))}distanceToSquared(t){const e=this.x-t.x,n=this.y-t.y;return e*e+n*n}manhattanDistanceTo(t){return Math.abs(this.x-t.x)+Math.abs(this.y-t.y)}setLength(t){return this.normalize().multiplyScalar(t)}lerp(t,e){return this.x+=(t.x-this.x)*e,this.y+=(t.y-this.y)*e,this}lerpVectors(t,e,n){return this.x=t.x+(e.x-t.x)*n,this.y=t.y+(e.y-t.y)*n,this}equals(t){return t.x===this.x&&t.y===this.y}fromArray(t,e=0){return this.x=t[e],this.y=t[e+1],this}toArray(t=[],e=0){return t[e]=this.x,t[e+1]=this.y,t}fromBufferAttribute(t,e,n){return void 0!==n&&console.warn("THREE.Vector2: offset has been removed from .fromBufferAttribute()."),this.x=t.getX(e),this.y=t.getY(e),this}rotateAround(t,e){const n=Math.cos(e),i=Math.sin(e),r=this.x-t.x,s=this.y-t.y;return this.x=r*n-s*i+t.x,this.y=r*i+s*n+t.y,this}random(){return this.x=Math.random(),this.y=Math.random(),this}*[Symbol.iterator](){yield this.x,yield this.y}}yt.prototype.isVector2=!0;class xt{constructor(){this.elements=[1,0,0,0,1,0,0,0,1],arguments.length>0&&console.error("THREE.Matrix3: the constructor no longer reads arguments. use .set() instead.")}set(t,e,n,i,r,s,a,o,l){const c=this.elements;return c[0]=t,c[1]=i,c[2]=a,c[3]=e,c[4]=r,c[5]=o,c[6]=n,c[7]=s,c[8]=l,this}identity(){return this.set(1,0,0,0,1,0,0,0,1),this}copy(t){const e=this.elements,n=t.elements;return e[0]=n[0],e[1]=n[1],e[2]=n[2],e[3]=n[3],e[4]=n[4],e[5]=n[5],e[6]=n[6],e[7]=n[7],e[8]=n[8],this}extractBasis(t,e,n){return t.setFromMatrix3Column(this,0),e.setFromMatrix3Column(this,1),n.setFromMatrix3Column(this,2),this}setFromMatrix4(t){const e=t.elements;return this.set(e[0],e[4],e[8],e[1],e[5],e[9],e[2],e[6],e[10]),this}multiply(t){return this.multiplyMatrices(this,t)}premultiply(t){return this.multiplyMatrices(t,this)}multiplyMatrices(t,e){const n=t.elements,i=e.elements,r=this.elements,s=n[0],a=n[3],o=n[6],l=n[1],c=n[4],h=n[7],u=n[2],d=n[5],p=n[8],m=i[0],f=i[3],g=i[6],v=i[1],y=i[4],x=i[7],_=i[2],M=i[5],b=i[8];return r[0]=s*m+a*v+o*_,r[3]=s*f+a*y+o*M,r[6]=s*g+a*x+o*b,r[1]=l*m+c*v+h*_,r[4]=l*f+c*y+h*M,r[7]=l*g+c*x+h*b,r[2]=u*m+d*v+p*_,r[5]=u*f+d*y+p*M,r[8]=u*g+d*x+p*b,this}multiplyScalar(t){const e=this.elements;return e[0]*=t,e[3]*=t,e[6]*=t,e[1]*=t,e[4]*=t,e[7]*=t,e[2]*=t,e[5]*=t,e[8]*=t,this}determinant(){const t=this.elements,e=t[0],n=t[1],i=t[2],r=t[3],s=t[4],a=t[5],o=t[6],l=t[7],c=t[8];return e*s*c-e*a*l-n*r*c+n*a*o+i*r*l-i*s*o}invert(){const t=this.elements,e=t[0],n=t[1],i=t[2],r=t[3],s=t[4],a=t[5],o=t[6],l=t[7],c=t[8],h=c*s-a*l,u=a*o-c*r,d=l*r-s*o,p=e*h+n*u+i*d;if(0===p)return this.set(0,0,0,0,0,0,0,0,0);const m=1/p;return t[0]=h*m,t[1]=(i*l-c*n)*m,t[2]=(a*n-i*s)*m,t[3]=u*m,t[4]=(c*e-i*o)*m,t[5]=(i*r-a*e)*m,t[6]=d*m,t[7]=(n*o-l*e)*m,t[8]=(s*e-n*r)*m,this}transpose(){let t;const e=this.elements;return t=e[1],e[1]=e[3],e[3]=t,t=e[2],e[2]=e[6],e[6]=t,t=e[5],e[5]=e[7],e[7]=t,this}getNormalMatrix(t){return this.setFromMatrix4(t).invert().transpose()}transposeIntoArray(t){const e=this.elements;return t[0]=e[0],t[1]=e[3],t[2]=e[6],t[3]=e[1],t[4]=e[4],t[5]=e[7],t[6]=e[2],t[7]=e[5],t[8]=e[8],this}setUvTransform(t,e,n,i,r,s,a){const o=Math.cos(r),l=Math.sin(r);return this.set(n*o,n*l,-n*(o*s+l*a)+s+t,-i*l,i*o,-i*(-l*s+o*a)+a+e,0,0,1),this}scale(t,e){const n=this.elements;return n[0]*=t,n[3]*=t,n[6]*=t,n[1]*=e,n[4]*=e,n[7]*=e,this}rotate(t){const e=Math.cos(t),n=Math.sin(t),i=this.elements,r=i[0],s=i[3],a=i[6],o=i[1],l=i[4],c=i[7];return i[0]=e*r+n*o,i[3]=e*s+n*l,i[6]=e*a+n*c,i[1]=-n*r+e*o,i[4]=-n*s+e*l,i[7]=-n*a+e*c,this}translate(t,e){const n=this.elements;return n[0]+=t*n[2],n[3]+=t*n[5],n[6]+=t*n[8],n[1]+=e*n[2],n[4]+=e*n[5],n[7]+=e*n[8],this}equals(t){const e=this.elements,n=t.elements;for(let t=0;t<9;t++)if(e[t]!==n[t])return!1;return!0}fromArray(t,e=0){for(let n=0;n<9;n++)this.elements[n]=t[n+e];return this}toArray(t=[],e=0){const n=this.elements;return t[e]=n[0],t[e+1]=n[1],t[e+2]=n[2],t[e+3]=n[3],t[e+4]=n[4],t[e+5]=n[5],t[e+6]=n[6],t[e+7]=n[7],t[e+8]=n[8],t}clone(){return(new this.constructor).fromArray(this.elements)}}function _t(t){if(0===t.length)return-1/0;let e=t[0];for(let n=1,i=t.length;ne&&(e=t[n]);return e}xt.prototype.isMatrix3=!0;const Mt={Int8Array:Int8Array,Uint8Array:Uint8Array,Uint8ClampedArray:Uint8ClampedArray,Int16Array:Int16Array,Uint16Array:Uint16Array,Int32Array:Int32Array,Uint32Array:Uint32Array,Float32Array:Float32Array,Float64Array:Float64Array};function bt(t,e){return new Mt[t](e)}function wt(t){return document.createElementNS("http://www.w3.org/1999/xhtml",t)}function St(t,e=0){let n=3735928559^e,i=1103547991^e;for(let e,r=0;r>>16,2246822507)^Math.imul(i^i>>>13,3266489909),i=Math.imul(i^i>>>16,2246822507)^Math.imul(n^n>>>13,3266489909),4294967296*(2097151&i)+(n>>>0)}let Tt;class Et{static getDataURL(t){if(/^data:/i.test(t.src))return t.src;if("undefined"==typeof HTMLCanvasElement)return t.src;let e;if(t instanceof HTMLCanvasElement)e=t;else{void 0===Tt&&(Tt=wt("canvas")),Tt.width=t.width,Tt.height=t.height;const n=Tt.getContext("2d");t instanceof ImageData?n.putImageData(t,0,0):n.drawImage(t,0,0,t.width,t.height),e=Tt}return e.width>2048||e.height>2048?(console.warn("THREE.ImageUtils.getDataURL: Image converted to jpg for performance reasons",t),e.toDataURL("image/jpeg",.6)):e.toDataURL("image/png")}}let At=0;class Lt extends rt{constructor(t=Lt.DEFAULT_IMAGE,e=Lt.DEFAULT_MAPPING,n=1001,i=1001,r=1006,s=1008,a=1023,o=1009,l=1,c=3e3){super(),Object.defineProperty(this,"id",{value:At++}),this.uuid=ht(),this.name="",this.image=t,this.mipmaps=[],this.mapping=e,this.wrapS=n,this.wrapT=i,this.magFilter=r,this.minFilter=s,this.anisotropy=l,this.format=a,this.internalFormat=null,this.type=o,this.offset=new yt(0,0),this.repeat=new yt(1,1),this.center=new yt(0,0),this.rotation=0,this.matrixAutoUpdate=!0,this.matrix=new xt,this.generateMipmaps=!0,this.premultiplyAlpha=!1,this.flipY=!0,this.unpackAlignment=4,this.encoding=c,this.userData={},this.version=0,this.onUpdate=null,this.isRenderTargetTexture=!1}updateMatrix(){this.matrix.setUvTransform(this.offset.x,this.offset.y,this.repeat.x,this.repeat.y,this.rotation,this.center.x,this.center.y)}clone(){return(new this.constructor).copy(this)}copy(t){return this.name=t.name,this.image=t.image,this.mipmaps=t.mipmaps.slice(0),this.mapping=t.mapping,this.wrapS=t.wrapS,this.wrapT=t.wrapT,this.magFilter=t.magFilter,this.minFilter=t.minFilter,this.anisotropy=t.anisotropy,this.format=t.format,this.internalFormat=t.internalFormat,this.type=t.type,this.offset.copy(t.offset),this.repeat.copy(t.repeat),this.center.copy(t.center),this.rotation=t.rotation,this.matrixAutoUpdate=t.matrixAutoUpdate,this.matrix.copy(t.matrix),this.generateMipmaps=t.generateMipmaps,this.premultiplyAlpha=t.premultiplyAlpha,this.flipY=t.flipY,this.unpackAlignment=t.unpackAlignment,this.encoding=t.encoding,this.userData=JSON.parse(JSON.stringify(t.userData)),this}toJSON(t){const e=void 0===t||"string"==typeof t;if(!e&&void 0!==t.textures[this.uuid])return t.textures[this.uuid];const n={metadata:{version:4.5,type:"Texture",generator:"Texture.toJSON"},uuid:this.uuid,name:this.name,mapping:this.mapping,repeat:[this.repeat.x,this.repeat.y],offset:[this.offset.x,this.offset.y],center:[this.center.x,this.center.y],rotation:this.rotation,wrap:[this.wrapS,this.wrapT],format:this.format,type:this.type,encoding:this.encoding,minFilter:this.minFilter,magFilter:this.magFilter,anisotropy:this.anisotropy,flipY:this.flipY,premultiplyAlpha:this.premultiplyAlpha,unpackAlignment:this.unpackAlignment};if(void 0!==this.image){const i=this.image;if(void 0===i.uuid&&(i.uuid=ht()),!e&&void 0===t.images[i.uuid]){let e;if(Array.isArray(i)){e=[];for(let t=0,n=i.length;t1)switch(this.wrapS){case h:t.x=t.x-Math.floor(t.x);break;case u:t.x=t.x<0?0:1;break;case d:1===Math.abs(Math.floor(t.x)%2)?t.x=Math.ceil(t.x)-t.x:t.x=t.x-Math.floor(t.x)}if(t.y<0||t.y>1)switch(this.wrapT){case h:t.y=t.y-Math.floor(t.y);break;case u:t.y=t.y<0?0:1;break;case d:1===Math.abs(Math.floor(t.y)%2)?t.y=Math.ceil(t.y)-t.y:t.y=t.y-Math.floor(t.y)}return this.flipY&&(t.y=1-t.y),t}set needsUpdate(t){!0===t&&this.version++}}function Rt(t){return"undefined"!=typeof HTMLImageElement&&t instanceof HTMLImageElement||"undefined"!=typeof HTMLCanvasElement&&t instanceof HTMLCanvasElement||"undefined"!=typeof ImageBitmap&&t instanceof ImageBitmap?Et.getDataURL(t):t.data?{data:Array.prototype.slice.call(t.data),width:t.width,height:t.height,type:t.data.constructor.name}:(console.warn("THREE.Texture: Unable to serialize Texture."),{})}Lt.DEFAULT_IMAGE=void 0,Lt.DEFAULT_MAPPING=i,Lt.prototype.isTexture=!0;class Ct{constructor(t=0,e=0,n=0,i=1){this.x=t,this.y=e,this.z=n,this.w=i}get width(){return this.z}set width(t){this.z=t}get height(){return this.w}set height(t){this.w=t}set(t,e,n,i){return this.x=t,this.y=e,this.z=n,this.w=i,this}setScalar(t){return this.x=t,this.y=t,this.z=t,this.w=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setZ(t){return this.z=t,this}setW(t){return this.w=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;case 3:this.w=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;case 2:return this.z;case 3:return this.w;default:throw new Error("index is out of range: "+t)}}clone(){return new this.constructor(this.x,this.y,this.z,this.w)}copy(t){return this.x=t.x,this.y=t.y,this.z=t.z,this.w=void 0!==t.w?t.w:1,this}add(t,e){return void 0!==e?(console.warn("THREE.Vector4: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(t,e)):(this.x+=t.x,this.y+=t.y,this.z+=t.z,this.w+=t.w,this)}addScalar(t){return this.x+=t,this.y+=t,this.z+=t,this.w+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this.z=t.z+e.z,this.w=t.w+e.w,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this.z+=t.z*e,this.w+=t.w*e,this}sub(t,e){return void 0!==e?(console.warn("THREE.Vector4: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(t,e)):(this.x-=t.x,this.y-=t.y,this.z-=t.z,this.w-=t.w,this)}subScalar(t){return this.x-=t,this.y-=t,this.z-=t,this.w-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this.z=t.z-e.z,this.w=t.w-e.w,this}multiply(t){return this.x*=t.x,this.y*=t.y,this.z*=t.z,this.w*=t.w,this}multiplyScalar(t){return this.x*=t,this.y*=t,this.z*=t,this.w*=t,this}applyMatrix4(t){const e=this.x,n=this.y,i=this.z,r=this.w,s=t.elements;return this.x=s[0]*e+s[4]*n+s[8]*i+s[12]*r,this.y=s[1]*e+s[5]*n+s[9]*i+s[13]*r,this.z=s[2]*e+s[6]*n+s[10]*i+s[14]*r,this.w=s[3]*e+s[7]*n+s[11]*i+s[15]*r,this}divideScalar(t){return this.multiplyScalar(1/t)}setAxisAngleFromQuaternion(t){this.w=2*Math.acos(t.w);const e=Math.sqrt(1-t.w*t.w);return e<1e-4?(this.x=1,this.y=0,this.z=0):(this.x=t.x/e,this.y=t.y/e,this.z=t.z/e),this}setAxisAngleFromRotationMatrix(t){let e,n,i,r;const s=.01,a=.1,o=t.elements,l=o[0],c=o[4],h=o[8],u=o[1],d=o[5],p=o[9],m=o[2],f=o[6],g=o[10];if(Math.abs(c-u)o&&t>v?tv?o=0?1:-1,i=1-e*e;if(i>Number.EPSILON){const r=Math.sqrt(i),s=Math.atan2(r,e*n);t=Math.sin(t*s)/r,a=Math.sin(a*s)/r}const r=a*n;if(o=o*t+u*r,l=l*t+d*r,c=c*t+p*r,h=h*t+m*r,t===1-a){const t=1/Math.sqrt(o*o+l*l+c*c+h*h);o*=t,l*=t,c*=t,h*=t}}t[e]=o,t[e+1]=l,t[e+2]=c,t[e+3]=h}static multiplyQuaternionsFlat(t,e,n,i,r,s){const a=n[i],o=n[i+1],l=n[i+2],c=n[i+3],h=r[s],u=r[s+1],d=r[s+2],p=r[s+3];return t[e]=a*p+c*h+o*d-l*u,t[e+1]=o*p+c*u+l*h-a*d,t[e+2]=l*p+c*d+a*u-o*h,t[e+3]=c*p-a*h-o*u-l*d,t}get x(){return this._x}set x(t){this._x=t,this._onChangeCallback()}get y(){return this._y}set y(t){this._y=t,this._onChangeCallback()}get z(){return this._z}set z(t){this._z=t,this._onChangeCallback()}get w(){return this._w}set w(t){this._w=t,this._onChangeCallback()}set(t,e,n,i){return this._x=t,this._y=e,this._z=n,this._w=i,this._onChangeCallback(),this}clone(){return new this.constructor(this._x,this._y,this._z,this._w)}copy(t){return this._x=t.x,this._y=t.y,this._z=t.z,this._w=t.w,this._onChangeCallback(),this}setFromEuler(t,e){if(!t||!t.isEuler)throw new Error("THREE.Quaternion: .setFromEuler() now expects an Euler rotation rather than a Vector3 and order.");const n=t._x,i=t._y,r=t._z,s=t._order,a=Math.cos,o=Math.sin,l=a(n/2),c=a(i/2),h=a(r/2),u=o(n/2),d=o(i/2),p=o(r/2);switch(s){case"XYZ":this._x=u*c*h+l*d*p,this._y=l*d*h-u*c*p,this._z=l*c*p+u*d*h,this._w=l*c*h-u*d*p;break;case"YXZ":this._x=u*c*h+l*d*p,this._y=l*d*h-u*c*p,this._z=l*c*p-u*d*h,this._w=l*c*h+u*d*p;break;case"ZXY":this._x=u*c*h-l*d*p,this._y=l*d*h+u*c*p,this._z=l*c*p+u*d*h,this._w=l*c*h-u*d*p;break;case"ZYX":this._x=u*c*h-l*d*p,this._y=l*d*h+u*c*p,this._z=l*c*p-u*d*h,this._w=l*c*h+u*d*p;break;case"YZX":this._x=u*c*h+l*d*p,this._y=l*d*h+u*c*p,this._z=l*c*p-u*d*h,this._w=l*c*h-u*d*p;break;case"XZY":this._x=u*c*h-l*d*p,this._y=l*d*h-u*c*p,this._z=l*c*p+u*d*h,this._w=l*c*h+u*d*p;break;default:console.warn("THREE.Quaternion: .setFromEuler() encountered an unknown order: "+s)}return!1!==e&&this._onChangeCallback(),this}setFromAxisAngle(t,e){const n=e/2,i=Math.sin(n);return this._x=t.x*i,this._y=t.y*i,this._z=t.z*i,this._w=Math.cos(n),this._onChangeCallback(),this}setFromRotationMatrix(t){const e=t.elements,n=e[0],i=e[4],r=e[8],s=e[1],a=e[5],o=e[9],l=e[2],c=e[6],h=e[10],u=n+a+h;if(u>0){const t=.5/Math.sqrt(u+1);this._w=.25/t,this._x=(c-o)*t,this._y=(r-l)*t,this._z=(s-i)*t}else if(n>a&&n>h){const t=2*Math.sqrt(1+n-a-h);this._w=(c-o)/t,this._x=.25*t,this._y=(i+s)/t,this._z=(r+l)/t}else if(a>h){const t=2*Math.sqrt(1+a-n-h);this._w=(r-l)/t,this._x=(i+s)/t,this._y=.25*t,this._z=(o+c)/t}else{const t=2*Math.sqrt(1+h-n-a);this._w=(s-i)/t,this._x=(r+l)/t,this._y=(o+c)/t,this._z=.25*t}return this._onChangeCallback(),this}setFromUnitVectors(t,e){let n=t.dot(e)+1;return nMath.abs(t.z)?(this._x=-t.y,this._y=t.x,this._z=0,this._w=n):(this._x=0,this._y=-t.z,this._z=t.y,this._w=n)):(this._x=t.y*e.z-t.z*e.y,this._y=t.z*e.x-t.x*e.z,this._z=t.x*e.y-t.y*e.x,this._w=n),this.normalize()}angleTo(t){return 2*Math.acos(Math.abs(ut(this.dot(t),-1,1)))}rotateTowards(t,e){const n=this.angleTo(t);if(0===n)return this;const i=Math.min(1,e/n);return this.slerp(t,i),this}identity(){return this.set(0,0,0,1)}invert(){return this.conjugate()}conjugate(){return this._x*=-1,this._y*=-1,this._z*=-1,this._onChangeCallback(),this}dot(t){return this._x*t._x+this._y*t._y+this._z*t._z+this._w*t._w}lengthSq(){return this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w}length(){return Math.sqrt(this._x*this._x+this._y*this._y+this._z*this._z+this._w*this._w)}normalize(){let t=this.length();return 0===t?(this._x=0,this._y=0,this._z=0,this._w=1):(t=1/t,this._x=this._x*t,this._y=this._y*t,this._z=this._z*t,this._w=this._w*t),this._onChangeCallback(),this}multiply(t,e){return void 0!==e?(console.warn("THREE.Quaternion: .multiply() now only accepts one argument. Use .multiplyQuaternions( a, b ) instead."),this.multiplyQuaternions(t,e)):this.multiplyQuaternions(this,t)}premultiply(t){return this.multiplyQuaternions(t,this)}multiplyQuaternions(t,e){const n=t._x,i=t._y,r=t._z,s=t._w,a=e._x,o=e._y,l=e._z,c=e._w;return this._x=n*c+s*a+i*l-r*o,this._y=i*c+s*o+r*a-n*l,this._z=r*c+s*l+n*o-i*a,this._w=s*c-n*a-i*o-r*l,this._onChangeCallback(),this}slerp(t,e){if(0===e)return this;if(1===e)return this.copy(t);const n=this._x,i=this._y,r=this._z,s=this._w;let a=s*t._w+n*t._x+i*t._y+r*t._z;if(a<0?(this._w=-t._w,this._x=-t._x,this._y=-t._y,this._z=-t._z,a=-a):this.copy(t),a>=1)return this._w=s,this._x=n,this._y=i,this._z=r,this;const o=1-a*a;if(o<=Number.EPSILON){const t=1-e;return this._w=t*s+e*this._w,this._x=t*n+e*this._x,this._y=t*i+e*this._y,this._z=t*r+e*this._z,this.normalize(),this._onChangeCallback(),this}const l=Math.sqrt(o),c=Math.atan2(l,a),h=Math.sin((1-e)*c)/l,u=Math.sin(e*c)/l;return this._w=s*h+this._w*u,this._x=n*h+this._x*u,this._y=i*h+this._y*u,this._z=r*h+this._z*u,this._onChangeCallback(),this}slerpQuaternions(t,e,n){this.copy(t).slerp(e,n)}random(){const t=Math.random(),e=Math.sqrt(1-t),n=Math.sqrt(t),i=2*Math.PI*Math.random(),r=2*Math.PI*Math.random();return this.set(e*Math.cos(i),n*Math.sin(r),n*Math.cos(r),e*Math.sin(i))}equals(t){return t._x===this._x&&t._y===this._y&&t._z===this._z&&t._w===this._w}fromArray(t,e=0){return this._x=t[e],this._y=t[e+1],this._z=t[e+2],this._w=t[e+3],this._onChangeCallback(),this}toArray(t=[],e=0){return t[e]=this._x,t[e+1]=this._y,t[e+2]=this._z,t[e+3]=this._w,t}fromBufferAttribute(t,e){return this._x=t.getX(e),this._y=t.getY(e),this._z=t.getZ(e),this._w=t.getW(e),this}_onChange(t){return this._onChangeCallback=t,this}_onChangeCallback(){}}Nt.prototype.isQuaternion=!0;class zt{constructor(t=0,e=0,n=0){this.x=t,this.y=e,this.z=n}set(t,e,n){return void 0===n&&(n=this.z),this.x=t,this.y=e,this.z=n,this}setScalar(t){return this.x=t,this.y=t,this.z=t,this}setX(t){return this.x=t,this}setY(t){return this.y=t,this}setZ(t){return this.z=t,this}setComponent(t,e){switch(t){case 0:this.x=e;break;case 1:this.y=e;break;case 2:this.z=e;break;default:throw new Error("index is out of range: "+t)}return this}getComponent(t){switch(t){case 0:return this.x;case 1:return this.y;case 2:return this.z;default:throw new Error("index is out of range: "+t)}}clone(){return new this.constructor(this.x,this.y,this.z)}copy(t){return this.x=t.x,this.y=t.y,this.z=t.z,this}add(t,e){return void 0!==e?(console.warn("THREE.Vector3: .add() now only accepts one argument. Use .addVectors( a, b ) instead."),this.addVectors(t,e)):(this.x+=t.x,this.y+=t.y,this.z+=t.z,this)}addScalar(t){return this.x+=t,this.y+=t,this.z+=t,this}addVectors(t,e){return this.x=t.x+e.x,this.y=t.y+e.y,this.z=t.z+e.z,this}addScaledVector(t,e){return this.x+=t.x*e,this.y+=t.y*e,this.z+=t.z*e,this}sub(t,e){return void 0!==e?(console.warn("THREE.Vector3: .sub() now only accepts one argument. Use .subVectors( a, b ) instead."),this.subVectors(t,e)):(this.x-=t.x,this.y-=t.y,this.z-=t.z,this)}subScalar(t){return this.x-=t,this.y-=t,this.z-=t,this}subVectors(t,e){return this.x=t.x-e.x,this.y=t.y-e.y,this.z=t.z-e.z,this}multiply(t,e){return void 0!==e?(console.warn("THREE.Vector3: .multiply() now only accepts one argument. Use .multiplyVectors( a, b ) instead."),this.multiplyVectors(t,e)):(this.x*=t.x,this.y*=t.y,this.z*=t.z,this)}multiplyScalar(t){return this.x*=t,this.y*=t,this.z*=t,this}multiplyVectors(t,e){return this.x=t.x*e.x,this.y=t.y*e.y,this.z=t.z*e.z,this}applyEuler(t){return t&&t.isEuler||console.error("THREE.Vector3: .applyEuler() now expects an Euler rotation rather than a Vector3 and order."),this.applyQuaternion(Ft.setFromEuler(t))}applyAxisAngle(t,e){return this.applyQuaternion(Ft.setFromAxisAngle(t,e))}applyMatrix3(t){const e=this.x,n=this.y,i=this.z,r=t.elements;return this.x=r[0]*e+r[3]*n+r[6]*i,this.y=r[1]*e+r[4]*n+r[7]*i,this.z=r[2]*e+r[5]*n+r[8]*i,this}applyNormalMatrix(t){return this.applyMatrix3(t).normalize()}applyMatrix4(t){const e=this.x,n=this.y,i=this.z,r=t.elements,s=1/(r[3]*e+r[7]*n+r[11]*i+r[15]);return this.x=(r[0]*e+r[4]*n+r[8]*i+r[12])*s,this.y=(r[1]*e+r[5]*n+r[9]*i+r[13])*s,this.z=(r[2]*e+r[6]*n+r[10]*i+r[14])*s,this}applyQuaternion(t){const e=this.x,n=this.y,i=this.z,r=t.x,s=t.y,a=t.z,o=t.w,l=o*e+s*i-a*n,c=o*n+a*e-r*i,h=o*i+r*n-s*e,u=-r*e-s*n-a*i;return this.x=l*o+u*-r+c*-a-h*-s,this.y=c*o+u*-s+h*-r-l*-a,this.z=h*o+u*-a+l*-s-c*-r,this}project(t){return this.applyMatrix4(t.matrixWorldInverse).applyMatrix4(t.projectionMatrix)}unproject(t){return this.applyMatrix4(t.projectionMatrixInverse).applyMatrix4(t.matrixWorld)}transformDirection(t){const e=this.x,n=this.y,i=this.z,r=t.elements;return this.x=r[0]*e+r[4]*n+r[8]*i,this.y=r[1]*e+r[5]*n+r[9]*i,this.z=r[2]*e+r[6]*n+r[10]*i,this.normalize()}divide(t){return this.x/=t.x,this.y/=t.y,this.z/=t.z,this}divideScalar(t){return this.multiplyScalar(1/t)}min(t){return this.x=Math.min(this.x,t.x),this.y=Math.min(this.y,t.y),this.z=Math.min(this.z,t.z),this}max(t){return this.x=Math.max(this.x,t.x),this.y=Math.max(this.y,t.y),this.z=Math.max(this.z,t.z),this}clamp(t,e){return this.x=Math.max(t.x,Math.min(e.x,this.x)),this.y=Math.max(t.y,Math.min(e.y,this.y)),this.z=Math.max(t.z,Math.min(e.z,this.z)),this}clampScalar(t,e){return this.x=Math.max(t,Math.min(e,this.x)),this.y=Math.max(t,Math.min(e,this.y)),this.z=Math.max(t,Math.min(e,this.z)),this}clampLength(t,e){const n=this.length();return this.divideScalar(n||1).multiplyScalar(Math.max(t,Math.min(e,n)))}floor(){return this.x=Math.floor(this.x),this.y=Math.floor(this.y),this.z=Math.floor(this.z),this}ceil(){return this.x=Math.ceil(this.x),this.y=Math.ceil(this.y),this.z=Math.ceil(this.z),this}round(){return this.x=Math.round(this.x),this.y=Math.round(this.y),this.z=Math.round(this.z),this}roundToZero(){return this.x=this.x<0?Math.ceil(this.x):Math.floor(this.x),this.y=this.y<0?Math.ceil(this.y):Math.floor(this.y),this.z=this.z<0?Math.ceil(this.z):Math.floor(this.z),this}negate(){return this.x=-this.x,this.y=-this.y,this.z=-this.z,this}dot(t){return this.x*t.x+this.y*t.y+this.z*t.z}lengthSq(){return this.x*this.x+this.y*this.y+this.z*this.z}length(){return Math.sqrt(this.x*this.x+this.y*this.y+this.z*this.z)}manhattanLength(){return Math.abs(this.x)+Math.abs(this.y)+Math.abs(this.z)}normalize(){return this.divideScalar(this.length()||1)}setLength(t){return this.normalize().multiplyScalar(t)}lerp(t,e){return this.x+=(t.x-this.x)*e,this.y+=(t.y-this.y)*e,this.z+=(t.z-this.z)*e,this}lerpVectors(t,e,n){return this.x=t.x+(e.x-t.x)*n,this.y=t.y+(e.y-t.y)*n,this.z=t.z+(e.z-t.z)*n,this}cross(t,e){return void 0!==e?(console.warn("THREE.Vector3: .cross() now only accepts one argument. Use .crossVectors( a, b ) instead."),this.crossVectors(t,e)):this.crossVectors(this,t)}crossVectors(t,e){const n=t.x,i=t.y,r=t.z,s=e.x,a=e.y,o=e.z;return this.x=i*o-r*a,this.y=r*s-n*o,this.z=n*a-i*s,this}projectOnVector(t){const e=t.lengthSq();if(0===e)return this.set(0,0,0);const n=t.dot(this)/e;return this.copy(t).multiplyScalar(n)}projectOnPlane(t){return Bt.copy(this).projectOnVector(t),this.sub(Bt)}reflect(t){return this.sub(Bt.copy(t).multiplyScalar(2*this.dot(t)))}angleTo(t){const e=Math.sqrt(this.lengthSq()*t.lengthSq());if(0===e)return Math.PI/2;const n=this.dot(t)/e;return Math.acos(ut(n,-1,1))}distanceTo(t){return Math.sqrt(this.distanceToSquared(t))}distanceToSquared(t){const e=this.x-t.x,n=this.y-t.y,i=this.z-t.z;return e*e+n*n+i*i}manhattanDistanceTo(t){return Math.abs(this.x-t.x)+Math.abs(this.y-t.y)+Math.abs(this.z-t.z)}setFromSpherical(t){return this.setFromSphericalCoords(t.radius,t.phi,t.theta)}setFromSphericalCoords(t,e,n){const i=Math.sin(e)*t;return this.x=i*Math.sin(n),this.y=Math.cos(e)*t,this.z=i*Math.cos(n),this}setFromCylindrical(t){return this.setFromCylindricalCoords(t.radius,t.theta,t.y)}setFromCylindricalCoords(t,e,n){return this.x=t*Math.sin(e),this.y=n,this.z=t*Math.cos(e),this}setFromMatrixPosition(t){const e=t.elements;return this.x=e[12],this.y=e[13],this.z=e[14],this}setFromMatrixScale(t){const e=this.setFromMatrixColumn(t,0).length(),n=this.setFromMatrixColumn(t,1).length(),i=this.setFromMatrixColumn(t,2).length();return this.x=e,this.y=n,this.z=i,this}setFromMatrixColumn(t,e){return this.fromArray(t.elements,4*e)}setFromMatrix3Column(t,e){return this.fromArray(t.elements,3*e)}equals(t){return t.x===this.x&&t.y===this.y&&t.z===this.z}fromArray(t,e=0){return this.x=t[e],this.y=t[e+1],this.z=t[e+2],this}toArray(t=[],e=0){return t[e]=this.x,t[e+1]=this.y,t[e+2]=this.z,t}fromBufferAttribute(t,e,n){return void 0!==n&&console.warn("THREE.Vector3: offset has been removed from .fromBufferAttribute()."),this.x=t.getX(e),this.y=t.getY(e),this.z=t.getZ(e),this}random(){return this.x=Math.random(),this.y=Math.random(),this.z=Math.random(),this}randomDirection(){const t=2*(Math.random()-.5),e=Math.random()*Math.PI*2,n=Math.sqrt(1-t**2);return this.x=n*Math.cos(e),this.y=n*Math.sin(e),this.z=t,this}*[Symbol.iterator](){yield this.x,yield this.y,yield this.z}}zt.prototype.isVector3=!0;const Bt=new zt,Ft=new Nt;class Ot{constructor(t=new zt(1/0,1/0,1/0),e=new zt(-1/0,-1/0,-1/0)){this.min=t,this.max=e}set(t,e){return this.min.copy(t),this.max.copy(e),this}setFromArray(t){let e=1/0,n=1/0,i=1/0,r=-1/0,s=-1/0,a=-1/0;for(let o=0,l=t.length;or&&(r=l),c>s&&(s=c),h>a&&(a=h)}return this.min.set(e,n,i),this.max.set(r,s,a),this}setFromBufferAttribute(t){let e=1/0,n=1/0,i=1/0,r=-1/0,s=-1/0,a=-1/0;for(let o=0,l=t.count;or&&(r=l),c>s&&(s=c),h>a&&(a=h)}return this.min.set(e,n,i),this.max.set(r,s,a),this}setFromPoints(t){this.makeEmpty();for(let e=0,n=t.length;ethis.max.x||t.ythis.max.y||t.zthis.max.z)}containsBox(t){return this.min.x<=t.min.x&&t.max.x<=this.max.x&&this.min.y<=t.min.y&&t.max.y<=this.max.y&&this.min.z<=t.min.z&&t.max.z<=this.max.z}getParameter(t,e){return e.set((t.x-this.min.x)/(this.max.x-this.min.x),(t.y-this.min.y)/(this.max.y-this.min.y),(t.z-this.min.z)/(this.max.z-this.min.z))}intersectsBox(t){return!(t.max.xthis.max.x||t.max.ythis.max.y||t.max.zthis.max.z)}intersectsSphere(t){return this.clampPoint(t.center,Ht),Ht.distanceToSquared(t.center)<=t.radius*t.radius}intersectsPlane(t){let e,n;return t.normal.x>0?(e=t.normal.x*this.min.x,n=t.normal.x*this.max.x):(e=t.normal.x*this.max.x,n=t.normal.x*this.min.x),t.normal.y>0?(e+=t.normal.y*this.min.y,n+=t.normal.y*this.max.y):(e+=t.normal.y*this.max.y,n+=t.normal.y*this.min.y),t.normal.z>0?(e+=t.normal.z*this.min.z,n+=t.normal.z*this.max.z):(e+=t.normal.z*this.max.z,n+=t.normal.z*this.min.z),e<=-t.constant&&n>=-t.constant}intersectsTriangle(t){if(this.isEmpty())return!1;this.getCenter(Yt),Jt.subVectors(this.max,Yt),kt.subVectors(t.a,Yt),Vt.subVectors(t.b,Yt),Wt.subVectors(t.c,Yt),jt.subVectors(Vt,kt),qt.subVectors(Wt,Vt),Xt.subVectors(kt,Wt);let e=[0,-jt.z,jt.y,0,-qt.z,qt.y,0,-Xt.z,Xt.y,jt.z,0,-jt.x,qt.z,0,-qt.x,Xt.z,0,-Xt.x,-jt.y,jt.x,0,-qt.y,qt.x,0,-Xt.y,Xt.x,0];return!!Kt(e,kt,Vt,Wt,Jt)&&(e=[1,0,0,0,1,0,0,0,1],!!Kt(e,kt,Vt,Wt,Jt)&&(Zt.crossVectors(jt,qt),e=[Zt.x,Zt.y,Zt.z],Kt(e,kt,Vt,Wt,Jt)))}clampPoint(t,e){return e.copy(t).clamp(this.min,this.max)}distanceToPoint(t){return Ht.copy(t).clamp(this.min,this.max).sub(t).length()}getBoundingSphere(t){return this.getCenter(t.center),t.radius=.5*this.getSize(Ht).length(),t}intersect(t){return this.min.max(t.min),this.max.min(t.max),this.isEmpty()&&this.makeEmpty(),this}union(t){return this.min.min(t.min),this.max.max(t.max),this}applyMatrix4(t){return this.isEmpty()||(Ut[0].set(this.min.x,this.min.y,this.min.z).applyMatrix4(t),Ut[1].set(this.min.x,this.min.y,this.max.z).applyMatrix4(t),Ut[2].set(this.min.x,this.max.y,this.min.z).applyMatrix4(t),Ut[3].set(this.min.x,this.max.y,this.max.z).applyMatrix4(t),Ut[4].set(this.max.x,this.min.y,this.min.z).applyMatrix4(t),Ut[5].set(this.max.x,this.min.y,this.max.z).applyMatrix4(t),Ut[6].set(this.max.x,this.max.y,this.min.z).applyMatrix4(t),Ut[7].set(this.max.x,this.max.y,this.max.z).applyMatrix4(t),this.setFromPoints(Ut)),this}translate(t){return this.min.add(t),this.max.add(t),this}equals(t){return t.min.equals(this.min)&&t.max.equals(this.max)}}Ot.prototype.isBox3=!0;const Ut=[new zt,new zt,new zt,new zt,new zt,new zt,new zt,new zt],Ht=new zt,Gt=new Ot,kt=new zt,Vt=new zt,Wt=new zt,jt=new zt,qt=new zt,Xt=new zt,Yt=new zt,Jt=new zt,Zt=new zt,Qt=new zt;function Kt(t,e,n,i,r){for(let s=0,a=t.length-3;s<=a;s+=3){Qt.fromArray(t,s);const a=r.x*Math.abs(Qt.x)+r.y*Math.abs(Qt.y)+r.z*Math.abs(Qt.z),o=e.dot(Qt),l=n.dot(Qt),c=i.dot(Qt);if(Math.max(-Math.max(o,l,c),Math.min(o,l,c))>a)return!1}return!0}const $t=new Ot,te=new zt,ee=new zt,ne=new zt;class ie{constructor(t=new zt,e=-1){this.center=t,this.radius=e}set(t,e){return this.center.copy(t),this.radius=e,this}setFromPoints(t,e){const n=this.center;void 0!==e?n.copy(e):$t.setFromPoints(t).getCenter(n);let i=0;for(let e=0,r=t.length;ethis.radius*this.radius&&(e.sub(this.center).normalize(),e.multiplyScalar(this.radius).add(this.center)),e}getBoundingBox(t){return this.isEmpty()?(t.makeEmpty(),t):(t.set(this.center,this.center),t.expandByScalar(this.radius),t)}applyMatrix4(t){return this.center.applyMatrix4(t),this.radius=this.radius*t.getMaxScaleOnAxis(),this}translate(t){return this.center.add(t),this}expandByPoint(t){ne.subVectors(t,this.center);const e=ne.lengthSq();if(e>this.radius*this.radius){const t=Math.sqrt(e),n=.5*(t-this.radius);this.center.add(ne.multiplyScalar(n/t)),this.radius+=n}return this}union(t){return ee.subVectors(t.center,this.center).normalize().multiplyScalar(t.radius),this.expandByPoint(te.copy(t.center).add(ee)),this.expandByPoint(te.copy(t.center).sub(ee)),this}equals(t){return t.center.equals(this.center)&&t.radius===this.radius}clone(){return(new this.constructor).copy(this)}}const re=new zt,se=new zt,ae=new zt,oe=new zt,le=new zt,ce=new zt,he=new zt;class ue{constructor(t=new zt,e=new zt(0,0,-1)){this.origin=t,this.direction=e}set(t,e){return this.origin.copy(t),this.direction.copy(e),this}copy(t){return this.origin.copy(t.origin),this.direction.copy(t.direction),this}at(t,e){return e.copy(this.direction).multiplyScalar(t).add(this.origin)}lookAt(t){return this.direction.copy(t).sub(this.origin).normalize(),this}recast(t){return this.origin.copy(this.at(t,re)),this}closestPointToPoint(t,e){e.subVectors(t,this.origin);const n=e.dot(this.direction);return n<0?e.copy(this.origin):e.copy(this.direction).multiplyScalar(n).add(this.origin)}distanceToPoint(t){return Math.sqrt(this.distanceSqToPoint(t))}distanceSqToPoint(t){const e=re.subVectors(t,this.origin).dot(this.direction);return e<0?this.origin.distanceToSquared(t):(re.copy(this.direction).multiplyScalar(e).add(this.origin),re.distanceToSquared(t))}distanceSqToSegment(t,e,n,i){se.copy(t).add(e).multiplyScalar(.5),ae.copy(e).sub(t).normalize(),oe.copy(this.origin).sub(se);const r=.5*t.distanceTo(e),s=-this.direction.dot(ae),a=oe.dot(this.direction),o=-oe.dot(ae),l=oe.lengthSq(),c=Math.abs(1-s*s);let h,u,d,p;if(c>0)if(h=s*o-a,u=s*a-o,p=r*c,h>=0)if(u>=-p)if(u<=p){const t=1/c;h*=t,u*=t,d=h*(h+s*u+2*a)+u*(s*h+u+2*o)+l}else u=r,h=Math.max(0,-(s*u+a)),d=-h*h+u*(u+2*o)+l;else u=-r,h=Math.max(0,-(s*u+a)),d=-h*h+u*(u+2*o)+l;else u<=-p?(h=Math.max(0,-(-s*r+a)),u=h>0?-r:Math.min(Math.max(-r,-o),r),d=-h*h+u*(u+2*o)+l):u<=p?(h=0,u=Math.min(Math.max(-r,-o),r),d=u*(u+2*o)+l):(h=Math.max(0,-(s*r+a)),u=h>0?r:Math.min(Math.max(-r,-o),r),d=-h*h+u*(u+2*o)+l);else u=s>0?-r:r,h=Math.max(0,-(s*u+a)),d=-h*h+u*(u+2*o)+l;return n&&n.copy(this.direction).multiplyScalar(h).add(this.origin),i&&i.copy(ae).multiplyScalar(u).add(se),d}intersectSphere(t,e){re.subVectors(t.center,this.origin);const n=re.dot(this.direction),i=re.dot(re)-n*n,r=t.radius*t.radius;if(i>r)return null;const s=Math.sqrt(r-i),a=n-s,o=n+s;return a<0&&o<0?null:a<0?this.at(o,e):this.at(a,e)}intersectsSphere(t){return this.distanceSqToPoint(t.center)<=t.radius*t.radius}distanceToPlane(t){const e=t.normal.dot(this.direction);if(0===e)return 0===t.distanceToPoint(this.origin)?0:null;const n=-(this.origin.dot(t.normal)+t.constant)/e;return n>=0?n:null}intersectPlane(t,e){const n=this.distanceToPlane(t);return null===n?null:this.at(n,e)}intersectsPlane(t){const e=t.distanceToPoint(this.origin);if(0===e)return!0;return t.normal.dot(this.direction)*e<0}intersectBox(t,e){let n,i,r,s,a,o;const l=1/this.direction.x,c=1/this.direction.y,h=1/this.direction.z,u=this.origin;return l>=0?(n=(t.min.x-u.x)*l,i=(t.max.x-u.x)*l):(n=(t.max.x-u.x)*l,i=(t.min.x-u.x)*l),c>=0?(r=(t.min.y-u.y)*c,s=(t.max.y-u.y)*c):(r=(t.max.y-u.y)*c,s=(t.min.y-u.y)*c),n>s||r>i?null:((r>n||n!=n)&&(n=r),(s=0?(a=(t.min.z-u.z)*h,o=(t.max.z-u.z)*h):(a=(t.max.z-u.z)*h,o=(t.min.z-u.z)*h),n>o||a>i?null:((a>n||n!=n)&&(n=a),(o=0?n:i,e)))}intersectsBox(t){return null!==this.intersectBox(t,re)}intersectTriangle(t,e,n,i,r){le.subVectors(e,t),ce.subVectors(n,t),he.crossVectors(le,ce);let s,a=this.direction.dot(he);if(a>0){if(i)return null;s=1}else{if(!(a<0))return null;s=-1,a=-a}oe.subVectors(this.origin,t);const o=s*this.direction.dot(ce.crossVectors(oe,ce));if(o<0)return null;const l=s*this.direction.dot(le.cross(oe));if(l<0)return null;if(o+l>a)return null;const c=-s*oe.dot(he);return c<0?null:this.at(c/a,r)}applyMatrix4(t){return this.origin.applyMatrix4(t),this.direction.transformDirection(t),this}equals(t){return t.origin.equals(this.origin)&&t.direction.equals(this.direction)}clone(){return(new this.constructor).copy(this)}}class de{constructor(){this.elements=[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1],arguments.length>0&&console.error("THREE.Matrix4: the constructor no longer reads arguments. use .set() instead.")}set(t,e,n,i,r,s,a,o,l,c,h,u,d,p,m,f){const g=this.elements;return g[0]=t,g[4]=e,g[8]=n,g[12]=i,g[1]=r,g[5]=s,g[9]=a,g[13]=o,g[2]=l,g[6]=c,g[10]=h,g[14]=u,g[3]=d,g[7]=p,g[11]=m,g[15]=f,this}identity(){return this.set(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1),this}clone(){return(new de).fromArray(this.elements)}copy(t){const e=this.elements,n=t.elements;return e[0]=n[0],e[1]=n[1],e[2]=n[2],e[3]=n[3],e[4]=n[4],e[5]=n[5],e[6]=n[6],e[7]=n[7],e[8]=n[8],e[9]=n[9],e[10]=n[10],e[11]=n[11],e[12]=n[12],e[13]=n[13],e[14]=n[14],e[15]=n[15],this}copyPosition(t){const e=this.elements,n=t.elements;return e[12]=n[12],e[13]=n[13],e[14]=n[14],this}setFromMatrix3(t){const e=t.elements;return this.set(e[0],e[3],e[6],0,e[1],e[4],e[7],0,e[2],e[5],e[8],0,0,0,0,1),this}extractBasis(t,e,n){return t.setFromMatrixColumn(this,0),e.setFromMatrixColumn(this,1),n.setFromMatrixColumn(this,2),this}makeBasis(t,e,n){return this.set(t.x,e.x,n.x,0,t.y,e.y,n.y,0,t.z,e.z,n.z,0,0,0,0,1),this}extractRotation(t){const e=this.elements,n=t.elements,i=1/pe.setFromMatrixColumn(t,0).length(),r=1/pe.setFromMatrixColumn(t,1).length(),s=1/pe.setFromMatrixColumn(t,2).length();return e[0]=n[0]*i,e[1]=n[1]*i,e[2]=n[2]*i,e[3]=0,e[4]=n[4]*r,e[5]=n[5]*r,e[6]=n[6]*r,e[7]=0,e[8]=n[8]*s,e[9]=n[9]*s,e[10]=n[10]*s,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,this}makeRotationFromEuler(t){t&&t.isEuler||console.error("THREE.Matrix4: .makeRotationFromEuler() now expects a Euler rotation rather than a Vector3 and order.");const e=this.elements,n=t.x,i=t.y,r=t.z,s=Math.cos(n),a=Math.sin(n),o=Math.cos(i),l=Math.sin(i),c=Math.cos(r),h=Math.sin(r);if("XYZ"===t.order){const t=s*c,n=s*h,i=a*c,r=a*h;e[0]=o*c,e[4]=-o*h,e[8]=l,e[1]=n+i*l,e[5]=t-r*l,e[9]=-a*o,e[2]=r-t*l,e[6]=i+n*l,e[10]=s*o}else if("YXZ"===t.order){const t=o*c,n=o*h,i=l*c,r=l*h;e[0]=t+r*a,e[4]=i*a-n,e[8]=s*l,e[1]=s*h,e[5]=s*c,e[9]=-a,e[2]=n*a-i,e[6]=r+t*a,e[10]=s*o}else if("ZXY"===t.order){const t=o*c,n=o*h,i=l*c,r=l*h;e[0]=t-r*a,e[4]=-s*h,e[8]=i+n*a,e[1]=n+i*a,e[5]=s*c,e[9]=r-t*a,e[2]=-s*l,e[6]=a,e[10]=s*o}else if("ZYX"===t.order){const t=s*c,n=s*h,i=a*c,r=a*h;e[0]=o*c,e[4]=i*l-n,e[8]=t*l+r,e[1]=o*h,e[5]=r*l+t,e[9]=n*l-i,e[2]=-l,e[6]=a*o,e[10]=s*o}else if("YZX"===t.order){const t=s*o,n=s*l,i=a*o,r=a*l;e[0]=o*c,e[4]=r-t*h,e[8]=i*h+n,e[1]=h,e[5]=s*c,e[9]=-a*c,e[2]=-l*c,e[6]=n*h+i,e[10]=t-r*h}else if("XZY"===t.order){const t=s*o,n=s*l,i=a*o,r=a*l;e[0]=o*c,e[4]=-h,e[8]=l*c,e[1]=t*h+r,e[5]=s*c,e[9]=n*h-i,e[2]=i*h-n,e[6]=a*c,e[10]=r*h+t}return e[3]=0,e[7]=0,e[11]=0,e[12]=0,e[13]=0,e[14]=0,e[15]=1,this}makeRotationFromQuaternion(t){return this.compose(fe,t,ge)}lookAt(t,e,n){const i=this.elements;return xe.subVectors(t,e),0===xe.lengthSq()&&(xe.z=1),xe.normalize(),ve.crossVectors(n,xe),0===ve.lengthSq()&&(1===Math.abs(n.z)?xe.x+=1e-4:xe.z+=1e-4,xe.normalize(),ve.crossVectors(n,xe)),ve.normalize(),ye.crossVectors(xe,ve),i[0]=ve.x,i[4]=ye.x,i[8]=xe.x,i[1]=ve.y,i[5]=ye.y,i[9]=xe.y,i[2]=ve.z,i[6]=ye.z,i[10]=xe.z,this}multiply(t,e){return void 0!==e?(console.warn("THREE.Matrix4: .multiply() now only accepts one argument. Use .multiplyMatrices( a, b ) instead."),this.multiplyMatrices(t,e)):this.multiplyMatrices(this,t)}premultiply(t){return this.multiplyMatrices(t,this)}multiplyMatrices(t,e){const n=t.elements,i=e.elements,r=this.elements,s=n[0],a=n[4],o=n[8],l=n[12],c=n[1],h=n[5],u=n[9],d=n[13],p=n[2],m=n[6],f=n[10],g=n[14],v=n[3],y=n[7],x=n[11],_=n[15],M=i[0],b=i[4],w=i[8],S=i[12],T=i[1],E=i[5],A=i[9],L=i[13],R=i[2],C=i[6],P=i[10],I=i[14],D=i[3],N=i[7],z=i[11],B=i[15];return r[0]=s*M+a*T+o*R+l*D,r[4]=s*b+a*E+o*C+l*N,r[8]=s*w+a*A+o*P+l*z,r[12]=s*S+a*L+o*I+l*B,r[1]=c*M+h*T+u*R+d*D,r[5]=c*b+h*E+u*C+d*N,r[9]=c*w+h*A+u*P+d*z,r[13]=c*S+h*L+u*I+d*B,r[2]=p*M+m*T+f*R+g*D,r[6]=p*b+m*E+f*C+g*N,r[10]=p*w+m*A+f*P+g*z,r[14]=p*S+m*L+f*I+g*B,r[3]=v*M+y*T+x*R+_*D,r[7]=v*b+y*E+x*C+_*N,r[11]=v*w+y*A+x*P+_*z,r[15]=v*S+y*L+x*I+_*B,this}multiplyScalar(t){const e=this.elements;return e[0]*=t,e[4]*=t,e[8]*=t,e[12]*=t,e[1]*=t,e[5]*=t,e[9]*=t,e[13]*=t,e[2]*=t,e[6]*=t,e[10]*=t,e[14]*=t,e[3]*=t,e[7]*=t,e[11]*=t,e[15]*=t,this}determinant(){const t=this.elements,e=t[0],n=t[4],i=t[8],r=t[12],s=t[1],a=t[5],o=t[9],l=t[13],c=t[2],h=t[6],u=t[10],d=t[14];return t[3]*(+r*o*h-i*l*h-r*a*u+n*l*u+i*a*d-n*o*d)+t[7]*(+e*o*d-e*l*u+r*s*u-i*s*d+i*l*c-r*o*c)+t[11]*(+e*l*h-e*a*d-r*s*h+n*s*d+r*a*c-n*l*c)+t[15]*(-i*a*c-e*o*h+e*a*u+i*s*h-n*s*u+n*o*c)}transpose(){const t=this.elements;let e;return e=t[1],t[1]=t[4],t[4]=e,e=t[2],t[2]=t[8],t[8]=e,e=t[6],t[6]=t[9],t[9]=e,e=t[3],t[3]=t[12],t[12]=e,e=t[7],t[7]=t[13],t[13]=e,e=t[11],t[11]=t[14],t[14]=e,this}setPosition(t,e,n){const i=this.elements;return t.isVector3?(i[12]=t.x,i[13]=t.y,i[14]=t.z):(i[12]=t,i[13]=e,i[14]=n),this}invert(){const t=this.elements,e=t[0],n=t[1],i=t[2],r=t[3],s=t[4],a=t[5],o=t[6],l=t[7],c=t[8],h=t[9],u=t[10],d=t[11],p=t[12],m=t[13],f=t[14],g=t[15],v=h*f*l-m*u*l+m*o*d-a*f*d-h*o*g+a*u*g,y=p*u*l-c*f*l-p*o*d+s*f*d+c*o*g-s*u*g,x=c*m*l-p*h*l+p*a*d-s*m*d-c*a*g+s*h*g,_=p*h*o-c*m*o-p*a*u+s*m*u+c*a*f-s*h*f,M=e*v+n*y+i*x+r*_;if(0===M)return this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0);const b=1/M;return t[0]=v*b,t[1]=(m*u*r-h*f*r-m*i*d+n*f*d+h*i*g-n*u*g)*b,t[2]=(a*f*r-m*o*r+m*i*l-n*f*l-a*i*g+n*o*g)*b,t[3]=(h*o*r-a*u*r-h*i*l+n*u*l+a*i*d-n*o*d)*b,t[4]=y*b,t[5]=(c*f*r-p*u*r+p*i*d-e*f*d-c*i*g+e*u*g)*b,t[6]=(p*o*r-s*f*r-p*i*l+e*f*l+s*i*g-e*o*g)*b,t[7]=(s*u*r-c*o*r+c*i*l-e*u*l-s*i*d+e*o*d)*b,t[8]=x*b,t[9]=(p*h*r-c*m*r-p*n*d+e*m*d+c*n*g-e*h*g)*b,t[10]=(s*m*r-p*a*r+p*n*l-e*m*l-s*n*g+e*a*g)*b,t[11]=(c*a*r-s*h*r-c*n*l+e*h*l+s*n*d-e*a*d)*b,t[12]=_*b,t[13]=(c*m*i-p*h*i+p*n*u-e*m*u-c*n*f+e*h*f)*b,t[14]=(p*a*i-s*m*i-p*n*o+e*m*o+s*n*f-e*a*f)*b,t[15]=(s*h*i-c*a*i+c*n*o-e*h*o-s*n*u+e*a*u)*b,this}scale(t){const e=this.elements,n=t.x,i=t.y,r=t.z;return e[0]*=n,e[4]*=i,e[8]*=r,e[1]*=n,e[5]*=i,e[9]*=r,e[2]*=n,e[6]*=i,e[10]*=r,e[3]*=n,e[7]*=i,e[11]*=r,this}getMaxScaleOnAxis(){const t=this.elements,e=t[0]*t[0]+t[1]*t[1]+t[2]*t[2],n=t[4]*t[4]+t[5]*t[5]+t[6]*t[6],i=t[8]*t[8]+t[9]*t[9]+t[10]*t[10];return Math.sqrt(Math.max(e,n,i))}makeTranslation(t,e,n){return this.set(1,0,0,t,0,1,0,e,0,0,1,n,0,0,0,1),this}makeRotationX(t){const e=Math.cos(t),n=Math.sin(t);return this.set(1,0,0,0,0,e,-n,0,0,n,e,0,0,0,0,1),this}makeRotationY(t){const e=Math.cos(t),n=Math.sin(t);return this.set(e,0,n,0,0,1,0,0,-n,0,e,0,0,0,0,1),this}makeRotationZ(t){const e=Math.cos(t),n=Math.sin(t);return this.set(e,-n,0,0,n,e,0,0,0,0,1,0,0,0,0,1),this}makeRotationAxis(t,e){const n=Math.cos(e),i=Math.sin(e),r=1-n,s=t.x,a=t.y,o=t.z,l=r*s,c=r*a;return this.set(l*s+n,l*a-i*o,l*o+i*a,0,l*a+i*o,c*a+n,c*o-i*s,0,l*o-i*a,c*o+i*s,r*o*o+n,0,0,0,0,1),this}makeScale(t,e,n){return this.set(t,0,0,0,0,e,0,0,0,0,n,0,0,0,0,1),this}makeShear(t,e,n,i,r,s){return this.set(1,n,r,0,t,1,s,0,e,i,1,0,0,0,0,1),this}compose(t,e,n){const i=this.elements,r=e._x,s=e._y,a=e._z,o=e._w,l=r+r,c=s+s,h=a+a,u=r*l,d=r*c,p=r*h,m=s*c,f=s*h,g=a*h,v=o*l,y=o*c,x=o*h,_=n.x,M=n.y,b=n.z;return i[0]=(1-(m+g))*_,i[1]=(d+x)*_,i[2]=(p-y)*_,i[3]=0,i[4]=(d-x)*M,i[5]=(1-(u+g))*M,i[6]=(f+v)*M,i[7]=0,i[8]=(p+y)*b,i[9]=(f-v)*b,i[10]=(1-(u+m))*b,i[11]=0,i[12]=t.x,i[13]=t.y,i[14]=t.z,i[15]=1,this}decompose(t,e,n){const i=this.elements;let r=pe.set(i[0],i[1],i[2]).length();const s=pe.set(i[4],i[5],i[6]).length(),a=pe.set(i[8],i[9],i[10]).length();this.determinant()<0&&(r=-r),t.x=i[12],t.y=i[13],t.z=i[14],me.copy(this);const o=1/r,l=1/s,c=1/a;return me.elements[0]*=o,me.elements[1]*=o,me.elements[2]*=o,me.elements[4]*=l,me.elements[5]*=l,me.elements[6]*=l,me.elements[8]*=c,me.elements[9]*=c,me.elements[10]*=c,e.setFromRotationMatrix(me),n.x=r,n.y=s,n.z=a,this}makePerspective(t,e,n,i,r,s){void 0===s&&console.warn("THREE.Matrix4: .makePerspective() has been redefined and has a new signature. Please check the docs.");const a=this.elements,o=2*r/(e-t),l=2*r/(n-i),c=(e+t)/(e-t),h=(n+i)/(n-i),u=-(s+r)/(s-r),d=-2*s*r/(s-r);return a[0]=o,a[4]=0,a[8]=c,a[12]=0,a[1]=0,a[5]=l,a[9]=h,a[13]=0,a[2]=0,a[6]=0,a[10]=u,a[14]=d,a[3]=0,a[7]=0,a[11]=-1,a[15]=0,this}makeOrthographic(t,e,n,i,r,s){const a=this.elements,o=1/(e-t),l=1/(n-i),c=1/(s-r),h=(e+t)*o,u=(n+i)*l,d=(s+r)*c;return a[0]=2*o,a[4]=0,a[8]=0,a[12]=-h,a[1]=0,a[5]=2*l,a[9]=0,a[13]=-u,a[2]=0,a[6]=0,a[10]=-2*c,a[14]=-d,a[3]=0,a[7]=0,a[11]=0,a[15]=1,this}equals(t){const e=this.elements,n=t.elements;for(let t=0;t<16;t++)if(e[t]!==n[t])return!1;return!0}fromArray(t,e=0){for(let n=0;n<16;n++)this.elements[n]=t[n+e];return this}toArray(t=[],e=0){const n=this.elements;return t[e]=n[0],t[e+1]=n[1],t[e+2]=n[2],t[e+3]=n[3],t[e+4]=n[4],t[e+5]=n[5],t[e+6]=n[6],t[e+7]=n[7],t[e+8]=n[8],t[e+9]=n[9],t[e+10]=n[10],t[e+11]=n[11],t[e+12]=n[12],t[e+13]=n[13],t[e+14]=n[14],t[e+15]=n[15],t}}de.prototype.isMatrix4=!0;const pe=new zt,me=new de,fe=new zt(0,0,0),ge=new zt(1,1,1),ve=new zt,ye=new zt,xe=new zt,_e=new de,Me=new Nt;class be{constructor(t=0,e=0,n=0,i=be.DefaultOrder){this._x=t,this._y=e,this._z=n,this._order=i}get x(){return this._x}set x(t){this._x=t,this._onChangeCallback()}get y(){return this._y}set y(t){this._y=t,this._onChangeCallback()}get z(){return this._z}set z(t){this._z=t,this._onChangeCallback()}get order(){return this._order}set order(t){this._order=t,this._onChangeCallback()}set(t,e,n,i=this._order){return this._x=t,this._y=e,this._z=n,this._order=i,this._onChangeCallback(),this}clone(){return new this.constructor(this._x,this._y,this._z,this._order)}copy(t){return this._x=t._x,this._y=t._y,this._z=t._z,this._order=t._order,this._onChangeCallback(),this}setFromRotationMatrix(t,e=this._order,n=!0){const i=t.elements,r=i[0],s=i[4],a=i[8],o=i[1],l=i[5],c=i[9],h=i[2],u=i[6],d=i[10];switch(e){case"XYZ":this._y=Math.asin(ut(a,-1,1)),Math.abs(a)<.9999999?(this._x=Math.atan2(-c,d),this._z=Math.atan2(-s,r)):(this._x=Math.atan2(u,l),this._z=0);break;case"YXZ":this._x=Math.asin(-ut(c,-1,1)),Math.abs(c)<.9999999?(this._y=Math.atan2(a,d),this._z=Math.atan2(o,l)):(this._y=Math.atan2(-h,r),this._z=0);break;case"ZXY":this._x=Math.asin(ut(u,-1,1)),Math.abs(u)<.9999999?(this._y=Math.atan2(-h,d),this._z=Math.atan2(-s,l)):(this._y=0,this._z=Math.atan2(o,r));break;case"ZYX":this._y=Math.asin(-ut(h,-1,1)),Math.abs(h)<.9999999?(this._x=Math.atan2(u,d),this._z=Math.atan2(o,r)):(this._x=0,this._z=Math.atan2(-s,l));break;case"YZX":this._z=Math.asin(ut(o,-1,1)),Math.abs(o)<.9999999?(this._x=Math.atan2(-c,l),this._y=Math.atan2(-h,r)):(this._x=0,this._y=Math.atan2(a,d));break;case"XZY":this._z=Math.asin(-ut(s,-1,1)),Math.abs(s)<.9999999?(this._x=Math.atan2(u,l),this._y=Math.atan2(a,r)):(this._x=Math.atan2(-c,d),this._y=0);break;default:console.warn("THREE.Euler: .setFromRotationMatrix() encountered an unknown order: "+e)}return this._order=e,!0===n&&this._onChangeCallback(),this}setFromQuaternion(t,e,n){return _e.makeRotationFromQuaternion(t),this.setFromRotationMatrix(_e,e,n)}setFromVector3(t,e=this._order){return this.set(t.x,t.y,t.z,e)}reorder(t){return Me.setFromEuler(this),this.setFromQuaternion(Me,t)}equals(t){return t._x===this._x&&t._y===this._y&&t._z===this._z&&t._order===this._order}fromArray(t){return this._x=t[0],this._y=t[1],this._z=t[2],void 0!==t[3]&&(this._order=t[3]),this._onChangeCallback(),this}toArray(t=[],e=0){return t[e]=this._x,t[e+1]=this._y,t[e+2]=this._z,t[e+3]=this._order,t}toVector3(t){return t?t.set(this._x,this._y,this._z):new zt(this._x,this._y,this._z)}_onChange(t){return this._onChangeCallback=t,this}_onChangeCallback(){}}be.prototype.isEuler=!0,be.DefaultOrder="XYZ",be.RotationOrders=["XYZ","YZX","ZXY","XZY","YXZ","ZYX"];class we{constructor(){this.mask=1}set(t){this.mask=1<1){for(let t=0;t1){for(let t=0;t0){i.children=[];for(let e=0;e0){i.animations=[];for(let e=0;e0&&(n.geometries=e),i.length>0&&(n.materials=i),r.length>0&&(n.textures=r),a.length>0&&(n.images=a),o.length>0&&(n.shapes=o),l.length>0&&(n.skeletons=l),c.length>0&&(n.animations=c)}return n.object=i,n;function s(t){const e=[];for(const n in t){const i=t[n];delete i.metadata,e.push(i)}return e}}clone(t){return(new this.constructor).copy(this,t)}copy(t,e=!0){if(this.name=t.name,this.up.copy(t.up),this.position.copy(t.position),this.rotation.order=t.rotation.order,this.quaternion.copy(t.quaternion),this.scale.copy(t.scale),this.matrix.copy(t.matrix),this.matrixWorld.copy(t.matrixWorld),this.matrixAutoUpdate=t.matrixAutoUpdate,this.matrixWorldNeedsUpdate=t.matrixWorldNeedsUpdate,this.layers.mask=t.layers.mask,this.visible=t.visible,this.castShadow=t.castShadow,this.receiveShadow=t.receiveShadow,this.frustumCulled=t.frustumCulled,this.renderOrder=t.renderOrder,this.userData=JSON.parse(JSON.stringify(t.userData)),!0===e)for(let e=0;e0?i.multiplyScalar(1/Math.sqrt(r)):i.set(0,0,0)}static getBarycoord(t,e,n,i,r){Oe.subVectors(i,e),Ue.subVectors(n,e),He.subVectors(t,e);const s=Oe.dot(Oe),a=Oe.dot(Ue),o=Oe.dot(He),l=Ue.dot(Ue),c=Ue.dot(He),h=s*l-a*a;if(0===h)return r.set(-2,-1,-1);const u=1/h,d=(l*o-a*c)*u,p=(s*c-a*o)*u;return r.set(1-d-p,p,d)}static containsPoint(t,e,n,i){return this.getBarycoord(t,e,n,i,Ge),Ge.x>=0&&Ge.y>=0&&Ge.x+Ge.y<=1}static getUV(t,e,n,i,r,s,a,o){return this.getBarycoord(t,e,n,i,Ge),o.set(0,0),o.addScaledVector(r,Ge.x),o.addScaledVector(s,Ge.y),o.addScaledVector(a,Ge.z),o}static isFrontFacing(t,e,n,i){return Oe.subVectors(n,e),Ue.subVectors(t,e),Oe.cross(Ue).dot(i)<0}set(t,e,n){return this.a.copy(t),this.b.copy(e),this.c.copy(n),this}setFromPointsAndIndices(t,e,n,i){return this.a.copy(t[e]),this.b.copy(t[n]),this.c.copy(t[i]),this}setFromAttributeAndIndices(t,e,n,i){return this.a.fromBufferAttribute(t,e),this.b.fromBufferAttribute(t,n),this.c.fromBufferAttribute(t,i),this}clone(){return(new this.constructor).copy(this)}copy(t){return this.a.copy(t.a),this.b.copy(t.b),this.c.copy(t.c),this}getArea(){return Oe.subVectors(this.c,this.b),Ue.subVectors(this.a,this.b),.5*Oe.cross(Ue).length()}getMidpoint(t){return t.addVectors(this.a,this.b).add(this.c).multiplyScalar(1/3)}getNormal(t){return Ye.getNormal(this.a,this.b,this.c,t)}getPlane(t){return t.setFromCoplanarPoints(this.a,this.b,this.c)}getBarycoord(t,e){return Ye.getBarycoord(t,this.a,this.b,this.c,e)}getUV(t,e,n,i,r){return Ye.getUV(t,this.a,this.b,this.c,e,n,i,r)}containsPoint(t){return Ye.containsPoint(t,this.a,this.b,this.c)}isFrontFacing(t){return Ye.isFrontFacing(this.a,this.b,this.c,t)}intersectsBox(t){return t.intersectsTriangle(this)}closestPointToPoint(t,e){const n=this.a,i=this.b,r=this.c;let s,a;ke.subVectors(i,n),Ve.subVectors(r,n),je.subVectors(t,n);const o=ke.dot(je),l=Ve.dot(je);if(o<=0&&l<=0)return e.copy(n);qe.subVectors(t,i);const c=ke.dot(qe),h=Ve.dot(qe);if(c>=0&&h<=c)return e.copy(i);const u=o*h-c*l;if(u<=0&&o>=0&&c<=0)return s=o/(o-c),e.copy(n).addScaledVector(ke,s);Xe.subVectors(t,r);const d=ke.dot(Xe),p=Ve.dot(Xe);if(p>=0&&d<=p)return e.copy(r);const m=d*l-o*p;if(m<=0&&l>=0&&p<=0)return a=l/(l-p),e.copy(n).addScaledVector(Ve,a);const f=c*p-d*h;if(f<=0&&h-c>=0&&d-p>=0)return We.subVectors(r,i),a=(h-c)/(h-c+(d-p)),e.copy(i).addScaledVector(We,a);const g=1/(f+m+u);return s=m*g,a=u*g,e.copy(n).addScaledVector(ke,s).addScaledVector(Ve,a)}equals(t){return t.a.equals(this.a)&&t.b.equals(this.b)&&t.c.equals(this.c)}}let Je=0;class Ze extends rt{constructor(){super(),Object.defineProperty(this,"id",{value:Je++}),this.uuid=ht(),this.name="",this.type="Material",this.fog=!0,this.blending=1,this.side=0,this.vertexColors=!1,this.opacity=1,this.format=E,this.transparent=!1,this.blendSrc=204,this.blendDst=205,this.blendEquation=n,this.blendSrcAlpha=null,this.blendDstAlpha=null,this.blendEquationAlpha=null,this.depthFunc=3,this.depthTest=!0,this.depthWrite=!0,this.stencilWriteMask=255,this.stencilFunc=519,this.stencilRef=0,this.stencilFuncMask=255,this.stencilFail=tt,this.stencilZFail=tt,this.stencilZPass=tt,this.stencilWrite=!1,this.clippingPlanes=null,this.clipIntersection=!1,this.clipShadows=!1,this.shadowSide=null,this.colorWrite=!0,this.precision=null,this.polygonOffset=!1,this.polygonOffsetFactor=0,this.polygonOffsetUnits=0,this.dithering=!1,this.alphaToCoverage=!1,this.premultipliedAlpha=!1,this.visible=!0,this.toneMapped=!0,this.userData={},this.version=0,this._alphaTest=0}get alphaTest(){return this._alphaTest}set alphaTest(t){this._alphaTest>0!=t>0&&this.version++,this._alphaTest=t}onBuild(){}onBeforeRender(){}onBeforeCompile(){}customProgramCacheKey(){return this.onBeforeCompile.toString()}setValues(t){if(void 0!==t)for(const e in t){const n=t[e];if(void 0===n){console.warn("THREE.Material: '"+e+"' parameter is undefined.");continue}if("shading"===e){console.warn("THREE."+this.type+": .shading has been removed. Use the boolean .flatShading instead."),this.flatShading=1===n;continue}const i=this[e];void 0!==i?i&&i.isColor?i.set(n):i&&i.isVector3&&n&&n.isVector3?i.copy(n):this[e]=n:console.warn("THREE."+this.type+": '"+e+"' is not a property of this material.")}}toJSON(t){const e=void 0===t||"string"==typeof t;e&&(t={textures:{},images:{}});const n={metadata:{version:4.5,type:"Material",generator:"Material.toJSON"}};function i(t){const e=[];for(const n in t){const i=t[n];delete i.metadata,e.push(i)}return e}if(n.uuid=this.uuid,n.type=this.type,""!==this.name&&(n.name=this.name),this.color&&this.color.isColor&&(n.color=this.color.getHex()),void 0!==this.roughness&&(n.roughness=this.roughness),void 0!==this.metalness&&(n.metalness=this.metalness),void 0!==this.sheen&&(n.sheen=this.sheen),this.sheenColor&&this.sheenColor.isColor&&(n.sheenColor=this.sheenColor.getHex()),void 0!==this.sheenRoughness&&(n.sheenRoughness=this.sheenRoughness),this.emissive&&this.emissive.isColor&&(n.emissive=this.emissive.getHex()),this.emissiveIntensity&&1!==this.emissiveIntensity&&(n.emissiveIntensity=this.emissiveIntensity),this.specular&&this.specular.isColor&&(n.specular=this.specular.getHex()),void 0!==this.specularIntensity&&(n.specularIntensity=this.specularIntensity),this.specularColor&&this.specularColor.isColor&&(n.specularColor=this.specularColor.getHex()),void 0!==this.shininess&&(n.shininess=this.shininess),void 0!==this.clearcoat&&(n.clearcoat=this.clearcoat),void 0!==this.clearcoatRoughness&&(n.clearcoatRoughness=this.clearcoatRoughness),this.clearcoatMap&&this.clearcoatMap.isTexture&&(n.clearcoatMap=this.clearcoatMap.toJSON(t).uuid),this.clearcoatRoughnessMap&&this.clearcoatRoughnessMap.isTexture&&(n.clearcoatRoughnessMap=this.clearcoatRoughnessMap.toJSON(t).uuid),this.clearcoatNormalMap&&this.clearcoatNormalMap.isTexture&&(n.clearcoatNormalMap=this.clearcoatNormalMap.toJSON(t).uuid,n.clearcoatNormalScale=this.clearcoatNormalScale.toArray()),this.map&&this.map.isTexture&&(n.map=this.map.toJSON(t).uuid),this.matcap&&this.matcap.isTexture&&(n.matcap=this.matcap.toJSON(t).uuid),this.alphaMap&&this.alphaMap.isTexture&&(n.alphaMap=this.alphaMap.toJSON(t).uuid),this.lightMap&&this.lightMap.isTexture&&(n.lightMap=this.lightMap.toJSON(t).uuid,n.lightMapIntensity=this.lightMapIntensity),this.aoMap&&this.aoMap.isTexture&&(n.aoMap=this.aoMap.toJSON(t).uuid,n.aoMapIntensity=this.aoMapIntensity),this.bumpMap&&this.bumpMap.isTexture&&(n.bumpMap=this.bumpMap.toJSON(t).uuid,n.bumpScale=this.bumpScale),this.normalMap&&this.normalMap.isTexture&&(n.normalMap=this.normalMap.toJSON(t).uuid,n.normalMapType=this.normalMapType,n.normalScale=this.normalScale.toArray()),this.displacementMap&&this.displacementMap.isTexture&&(n.displacementMap=this.displacementMap.toJSON(t).uuid,n.displacementScale=this.displacementScale,n.displacementBias=this.displacementBias),this.roughnessMap&&this.roughnessMap.isTexture&&(n.roughnessMap=this.roughnessMap.toJSON(t).uuid),this.metalnessMap&&this.metalnessMap.isTexture&&(n.metalnessMap=this.metalnessMap.toJSON(t).uuid),this.emissiveMap&&this.emissiveMap.isTexture&&(n.emissiveMap=this.emissiveMap.toJSON(t).uuid),this.specularMap&&this.specularMap.isTexture&&(n.specularMap=this.specularMap.toJSON(t).uuid),this.specularIntensityMap&&this.specularIntensityMap.isTexture&&(n.specularIntensityMap=this.specularIntensityMap.toJSON(t).uuid),this.specularColorMap&&this.specularColorMap.isTexture&&(n.specularColorMap=this.specularColorMap.toJSON(t).uuid),this.envMap&&this.envMap.isTexture&&(n.envMap=this.envMap.toJSON(t).uuid,void 0!==this.combine&&(n.combine=this.combine)),void 0!==this.envMapIntensity&&(n.envMapIntensity=this.envMapIntensity),void 0!==this.reflectivity&&(n.reflectivity=this.reflectivity),void 0!==this.refractionRatio&&(n.refractionRatio=this.refractionRatio),this.gradientMap&&this.gradientMap.isTexture&&(n.gradientMap=this.gradientMap.toJSON(t).uuid),void 0!==this.transmission&&(n.transmission=this.transmission),this.transmissionMap&&this.transmissionMap.isTexture&&(n.transmissionMap=this.transmissionMap.toJSON(t).uuid),void 0!==this.thickness&&(n.thickness=this.thickness),this.thicknessMap&&this.thicknessMap.isTexture&&(n.thicknessMap=this.thicknessMap.toJSON(t).uuid),void 0!==this.attenuationDistance&&(n.attenuationDistance=this.attenuationDistance),void 0!==this.attenuationColor&&(n.attenuationColor=this.attenuationColor.getHex()),void 0!==this.size&&(n.size=this.size),null!==this.shadowSide&&(n.shadowSide=this.shadowSide),void 0!==this.sizeAttenuation&&(n.sizeAttenuation=this.sizeAttenuation),1!==this.blending&&(n.blending=this.blending),0!==this.side&&(n.side=this.side),this.vertexColors&&(n.vertexColors=!0),this.opacity<1&&(n.opacity=this.opacity),this.format!==E&&(n.format=this.format),!0===this.transparent&&(n.transparent=this.transparent),n.depthFunc=this.depthFunc,n.depthTest=this.depthTest,n.depthWrite=this.depthWrite,n.colorWrite=this.colorWrite,n.stencilWrite=this.stencilWrite,n.stencilWriteMask=this.stencilWriteMask,n.stencilFunc=this.stencilFunc,n.stencilRef=this.stencilRef,n.stencilFuncMask=this.stencilFuncMask,n.stencilFail=this.stencilFail,n.stencilZFail=this.stencilZFail,n.stencilZPass=this.stencilZPass,this.rotation&&0!==this.rotation&&(n.rotation=this.rotation),!0===this.polygonOffset&&(n.polygonOffset=!0),0!==this.polygonOffsetFactor&&(n.polygonOffsetFactor=this.polygonOffsetFactor),0!==this.polygonOffsetUnits&&(n.polygonOffsetUnits=this.polygonOffsetUnits),this.linewidth&&1!==this.linewidth&&(n.linewidth=this.linewidth),void 0!==this.dashSize&&(n.dashSize=this.dashSize),void 0!==this.gapSize&&(n.gapSize=this.gapSize),void 0!==this.scale&&(n.scale=this.scale),!0===this.dithering&&(n.dithering=!0),this.alphaTest>0&&(n.alphaTest=this.alphaTest),!0===this.alphaToCoverage&&(n.alphaToCoverage=this.alphaToCoverage),!0===this.premultipliedAlpha&&(n.premultipliedAlpha=this.premultipliedAlpha),!0===this.wireframe&&(n.wireframe=this.wireframe),this.wireframeLinewidth>1&&(n.wireframeLinewidth=this.wireframeLinewidth),"round"!==this.wireframeLinecap&&(n.wireframeLinecap=this.wireframeLinecap),"round"!==this.wireframeLinejoin&&(n.wireframeLinejoin=this.wireframeLinejoin),!0===this.flatShading&&(n.flatShading=this.flatShading),!1===this.visible&&(n.visible=!1),!1===this.toneMapped&&(n.toneMapped=!1),"{}"!==JSON.stringify(this.userData)&&(n.userData=this.userData),e){const e=i(t.textures),r=i(t.images);e.length>0&&(n.textures=e),r.length>0&&(n.images=r)}return n}clone(){return(new this.constructor).copy(this)}copy(t){this.name=t.name,this.fog=t.fog,this.blending=t.blending,this.side=t.side,this.vertexColors=t.vertexColors,this.opacity=t.opacity,this.format=t.format,this.transparent=t.transparent,this.blendSrc=t.blendSrc,this.blendDst=t.blendDst,this.blendEquation=t.blendEquation,this.blendSrcAlpha=t.blendSrcAlpha,this.blendDstAlpha=t.blendDstAlpha,this.blendEquationAlpha=t.blendEquationAlpha,this.depthFunc=t.depthFunc,this.depthTest=t.depthTest,this.depthWrite=t.depthWrite,this.stencilWriteMask=t.stencilWriteMask,this.stencilFunc=t.stencilFunc,this.stencilRef=t.stencilRef,this.stencilFuncMask=t.stencilFuncMask,this.stencilFail=t.stencilFail,this.stencilZFail=t.stencilZFail,this.stencilZPass=t.stencilZPass,this.stencilWrite=t.stencilWrite;const e=t.clippingPlanes;let n=null;if(null!==e){const t=e.length;n=new Array(t);for(let i=0;i!==t;++i)n[i]=e[i].clone()}return this.clippingPlanes=n,this.clipIntersection=t.clipIntersection,this.clipShadows=t.clipShadows,this.shadowSide=t.shadowSide,this.colorWrite=t.colorWrite,this.precision=t.precision,this.polygonOffset=t.polygonOffset,this.polygonOffsetFactor=t.polygonOffsetFactor,this.polygonOffsetUnits=t.polygonOffsetUnits,this.dithering=t.dithering,this.alphaTest=t.alphaTest,this.alphaToCoverage=t.alphaToCoverage,this.premultipliedAlpha=t.premultipliedAlpha,this.visible=t.visible,this.toneMapped=t.toneMapped,this.userData=JSON.parse(JSON.stringify(t.userData)),this}dispose(){this.dispatchEvent({type:"dispose"})}set needsUpdate(t){!0===t&&this.version++}}Ze.prototype.isMaterial=!0;const Qe={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074},Ke={h:0,s:0,l:0},$e={h:0,s:0,l:0};function tn(t,e,n){return n<0&&(n+=1),n>1&&(n-=1),n<1/6?t+6*(e-t)*n:n<.5?e:n<2/3?t+6*(e-t)*(2/3-n):t}function en(t){return t<.04045?.0773993808*t:Math.pow(.9478672986*t+.0521327014,2.4)}function nn(t){return t<.0031308?12.92*t:1.055*Math.pow(t,.41666)-.055}class rn{constructor(t,e,n){return void 0===e&&void 0===n?this.set(t):this.setRGB(t,e,n)}set(t){return t&&t.isColor?this.copy(t):"number"==typeof t?this.setHex(t):"string"==typeof t&&this.setStyle(t),this}setScalar(t){return this.r=t,this.g=t,this.b=t,this}setHex(t){return t=Math.floor(t),this.r=(t>>16&255)/255,this.g=(t>>8&255)/255,this.b=(255&t)/255,this}setRGB(t,e,n){return this.r=t,this.g=e,this.b=n,this}setHSL(t,e,n){if(t=dt(t,1),e=ut(e,0,1),n=ut(n,0,1),0===e)this.r=this.g=this.b=n;else{const i=n<=.5?n*(1+e):n+e-n*e,r=2*n-i;this.r=tn(r,i,t+1/3),this.g=tn(r,i,t),this.b=tn(r,i,t-1/3)}return this}setStyle(t){function e(e){void 0!==e&&parseFloat(e)<1&&console.warn("THREE.Color: Alpha component of "+t+" will be ignored.")}let n;if(n=/^((?:rgb|hsl)a?)\(([^\)]*)\)/.exec(t)){let t;const i=n[1],r=n[2];switch(i){case"rgb":case"rgba":if(t=/^\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(r))return this.r=Math.min(255,parseInt(t[1],10))/255,this.g=Math.min(255,parseInt(t[2],10))/255,this.b=Math.min(255,parseInt(t[3],10))/255,e(t[4]),this;if(t=/^\s*(\d+)\%\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(r))return this.r=Math.min(100,parseInt(t[1],10))/100,this.g=Math.min(100,parseInt(t[2],10))/100,this.b=Math.min(100,parseInt(t[3],10))/100,e(t[4]),this;break;case"hsl":case"hsla":if(t=/^\s*(\d*\.?\d+)\s*,\s*(\d+)\%\s*,\s*(\d+)\%\s*(?:,\s*(\d*\.?\d+)\s*)?$/.exec(r)){const n=parseFloat(t[1])/360,i=parseInt(t[2],10)/100,r=parseInt(t[3],10)/100;return e(t[4]),this.setHSL(n,i,r)}}}else if(n=/^\#([A-Fa-f\d]+)$/.exec(t)){const t=n[1],e=t.length;if(3===e)return this.r=parseInt(t.charAt(0)+t.charAt(0),16)/255,this.g=parseInt(t.charAt(1)+t.charAt(1),16)/255,this.b=parseInt(t.charAt(2)+t.charAt(2),16)/255,this;if(6===e)return this.r=parseInt(t.charAt(0)+t.charAt(1),16)/255,this.g=parseInt(t.charAt(2)+t.charAt(3),16)/255,this.b=parseInt(t.charAt(4)+t.charAt(5),16)/255,this}return t&&t.length>0?this.setColorName(t):this}setColorName(t){const e=Qe[t.toLowerCase()];return void 0!==e?this.setHex(e):console.warn("THREE.Color: Unknown color "+t),this}clone(){return new this.constructor(this.r,this.g,this.b)}copy(t){return this.r=t.r,this.g=t.g,this.b=t.b,this}copyGammaToLinear(t,e=2){return this.r=Math.pow(t.r,e),this.g=Math.pow(t.g,e),this.b=Math.pow(t.b,e),this}copyLinearToGamma(t,e=2){const n=e>0?1/e:1;return this.r=Math.pow(t.r,n),this.g=Math.pow(t.g,n),this.b=Math.pow(t.b,n),this}convertGammaToLinear(t){return this.copyGammaToLinear(this,t),this}convertLinearToGamma(t){return this.copyLinearToGamma(this,t),this}copySRGBToLinear(t){return this.r=en(t.r),this.g=en(t.g),this.b=en(t.b),this}copyLinearToSRGB(t){return this.r=nn(t.r),this.g=nn(t.g),this.b=nn(t.b),this}convertSRGBToLinear(){return this.copySRGBToLinear(this),this}convertLinearToSRGB(){return this.copyLinearToSRGB(this),this}getHex(){return 255*this.r<<16^255*this.g<<8^255*this.b<<0}getHexString(){return("000000"+this.getHex().toString(16)).slice(-6)}getHSL(t){const e=this.r,n=this.g,i=this.b,r=Math.max(e,n,i),s=Math.min(e,n,i);let a,o;const l=(s+r)/2;if(s===r)a=0,o=0;else{const t=r-s;switch(o=l<=.5?t/(r+s):t/(2-r-s),r){case e:a=(n-i)/t+(n65535?fn:pn)(t,1):this.index=t,this}getAttribute(t){return this.attributes[t]}setAttribute(t,e){return this.attributes[t]=e,this}deleteAttribute(t){return delete this.attributes[t],this}hasAttribute(t){return void 0!==this.attributes[t]}addGroup(t,e,n=0){this.groups.push({start:t,count:e,materialIndex:n})}clearGroups(){this.groups=[]}setDrawRange(t,e){this.drawRange.start=t,this.drawRange.count=e}applyMatrix4(t){const e=this.attributes.position;void 0!==e&&(e.applyMatrix4(t),e.needsUpdate=!0);const n=this.attributes.normal;if(void 0!==n){const e=(new xt).getNormalMatrix(t);n.applyNormalMatrix(e),n.needsUpdate=!0}const i=this.attributes.tangent;return void 0!==i&&(i.transformDirection(t),i.needsUpdate=!0),null!==this.boundingBox&&this.computeBoundingBox(),null!==this.boundingSphere&&this.computeBoundingSphere(),this}applyQuaternion(t){return _n.makeRotationFromQuaternion(t),this.applyMatrix4(_n),this}rotateX(t){return _n.makeRotationX(t),this.applyMatrix4(_n),this}rotateY(t){return _n.makeRotationY(t),this.applyMatrix4(_n),this}rotateZ(t){return _n.makeRotationZ(t),this.applyMatrix4(_n),this}translate(t,e,n){return _n.makeTranslation(t,e,n),this.applyMatrix4(_n),this}scale(t,e,n){return _n.makeScale(t,e,n),this.applyMatrix4(_n),this}lookAt(t){return Mn.lookAt(t),Mn.updateMatrix(),this.applyMatrix4(Mn.matrix),this}center(){return this.computeBoundingBox(),this.boundingBox.getCenter(bn).negate(),this.translate(bn.x,bn.y,bn.z),this}setFromPoints(t){const e=[];for(let n=0,i=t.length;n0&&(t.userData=this.userData),void 0!==this.parameters){const e=this.parameters;for(const n in e)void 0!==e[n]&&(t[n]=e[n]);return t}t.data={attributes:{}};const e=this.index;null!==e&&(t.data.index={type:e.array.constructor.name,array:Array.prototype.slice.call(e.array)});const n=this.attributes;for(const e in n){const i=n[e];t.data.attributes[e]=i.toJSON(t.data)}const i={};let r=!1;for(const e in this.morphAttributes){const n=this.morphAttributes[e],s=[];for(let e=0,i=n.length;e0&&(i[e]=s,r=!0)}r&&(t.data.morphAttributes=i,t.data.morphTargetsRelative=this.morphTargetsRelative);const s=this.groups;s.length>0&&(t.data.groups=JSON.parse(JSON.stringify(s)));const a=this.boundingSphere;return null!==a&&(t.data.boundingSphere={center:a.center.toArray(),radius:a.radius}),t}clone(){return(new this.constructor).copy(this)}copy(t){this.index=null,this.attributes={},this.morphAttributes={},this.groups=[],this.boundingBox=null,this.boundingSphere=null;const e={};this.name=t.name;const n=t.index;null!==n&&this.setIndex(n.clone(e));const i=t.attributes;for(const t in i){const n=i[t];this.setAttribute(t,n.clone(e))}const r=t.morphAttributes;for(const t in r){const n=[],i=r[t];for(let t=0,r=i.length;t0){const t=e[n[0]];if(void 0!==t){this.morphTargetInfluences=[],this.morphTargetDictionary={};for(let e=0,n=t.length;e0&&console.error("THREE.Mesh.updateMorphTargets() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}}raycast(t,e){const n=this.geometry,i=this.material,r=this.matrixWorld;if(void 0===i)return;if(null===n.boundingSphere&&n.computeBoundingSphere(),Rn.copy(n.boundingSphere),Rn.applyMatrix4(r),!1===t.ray.intersectsSphere(Rn))return;if(An.copy(r).invert(),Ln.copy(t.ray).applyMatrix4(An),null!==n.boundingBox&&!1===Ln.intersectsBox(n.boundingBox))return;let s;if(n.isBufferGeometry){const r=n.index,a=n.attributes.position,o=n.morphAttributes.position,l=n.morphTargetsRelative,c=n.attributes.uv,h=n.attributes.uv2,u=n.groups,d=n.drawRange;if(null!==r)if(Array.isArray(i))for(let n=0,p=u.length;nn.far?null:{distance:c,point:Vn.clone(),object:t}}(t,e,n,i,Cn,Pn,In,kn);if(p){o&&(Un.fromBufferAttribute(o,c),Hn.fromBufferAttribute(o,h),Gn.fromBufferAttribute(o,u),p.uv=Ye.getUV(kn,Cn,Pn,In,Un,Hn,Gn,new yt)),l&&(Un.fromBufferAttribute(l,c),Hn.fromBufferAttribute(l,h),Gn.fromBufferAttribute(l,u),p.uv2=Ye.getUV(kn,Cn,Pn,In,Un,Hn,Gn,new yt));const t={a:c,b:h,c:u,normal:new zt,materialIndex:0};Ye.getNormal(Cn,Pn,In,t.normal),p.face=t}return p}Wn.prototype.isMesh=!0;class qn extends En{constructor(t=1,e=1,n=1,i=1,r=1,s=1){super(),this.type="BoxGeometry",this.parameters={width:t,height:e,depth:n,widthSegments:i,heightSegments:r,depthSegments:s};const a=this;i=Math.floor(i),r=Math.floor(r),s=Math.floor(s);const o=[],l=[],c=[],h=[];let u=0,d=0;function p(t,e,n,i,r,s,p,m,f,g,v){const y=s/f,x=p/g,_=s/2,M=p/2,b=m/2,w=f+1,S=g+1;let T=0,E=0;const A=new zt;for(let s=0;s0?1:-1,c.push(A.x,A.y,A.z),h.push(o/f),h.push(1-s/g),T+=1}}for(let t=0;t0&&(e.defines=this.defines),e.vertexShader=this.vertexShader,e.fragmentShader=this.fragmentShader;const n={};for(const t in this.extensions)!0===this.extensions[t]&&(n[t]=!0);return Object.keys(n).length>0&&(e.extensions=n),e}}Zn.prototype.isShaderMaterial=!0;class Qn extends Fe{constructor(){super(),this.type="Camera",this.matrixWorldInverse=new de,this.projectionMatrix=new de,this.projectionMatrixInverse=new de}copy(t,e){return super.copy(t,e),this.matrixWorldInverse.copy(t.matrixWorldInverse),this.projectionMatrix.copy(t.projectionMatrix),this.projectionMatrixInverse.copy(t.projectionMatrixInverse),this}getWorldDirection(t){this.updateWorldMatrix(!0,!1);const e=this.matrixWorld.elements;return t.set(-e[8],-e[9],-e[10]).normalize()}updateMatrixWorld(t){super.updateMatrixWorld(t),this.matrixWorldInverse.copy(this.matrixWorld).invert()}updateWorldMatrix(t,e){super.updateWorldMatrix(t,e),this.matrixWorldInverse.copy(this.matrixWorld).invert()}clone(){return(new this.constructor).copy(this)}}Qn.prototype.isCamera=!0;class Kn extends Qn{constructor(t=50,e=1,n=.1,i=2e3){super(),this.type="PerspectiveCamera",this.fov=t,this.zoom=1,this.near=n,this.far=i,this.focus=10,this.aspect=e,this.view=null,this.filmGauge=35,this.filmOffset=0,this.updateProjectionMatrix()}copy(t,e){return super.copy(t,e),this.fov=t.fov,this.zoom=t.zoom,this.near=t.near,this.far=t.far,this.focus=t.focus,this.aspect=t.aspect,this.view=null===t.view?null:Object.assign({},t.view),this.filmGauge=t.filmGauge,this.filmOffset=t.filmOffset,this}setFocalLength(t){const e=.5*this.getFilmHeight()/t;this.fov=2*ot*Math.atan(e),this.updateProjectionMatrix()}getFocalLength(){const t=Math.tan(.5*at*this.fov);return.5*this.getFilmHeight()/t}getEffectiveFOV(){return 2*ot*Math.atan(Math.tan(.5*at*this.fov)/this.zoom)}getFilmWidth(){return this.filmGauge*Math.min(this.aspect,1)}getFilmHeight(){return this.filmGauge/Math.max(this.aspect,1)}setViewOffset(t,e,n,i,r,s){this.aspect=t/e,null===this.view&&(this.view={enabled:!0,fullWidth:1,fullHeight:1,offsetX:0,offsetY:0,width:1,height:1}),this.view.enabled=!0,this.view.fullWidth=t,this.view.fullHeight=e,this.view.offsetX=n,this.view.offsetY=i,this.view.width=r,this.view.height=s,this.updateProjectionMatrix()}clearViewOffset(){null!==this.view&&(this.view.enabled=!1),this.updateProjectionMatrix()}updateProjectionMatrix(){const t=this.near;let e=t*Math.tan(.5*at*this.fov)/this.zoom,n=2*e,i=this.aspect*n,r=-.5*i;const s=this.view;if(null!==this.view&&this.view.enabled){const t=s.fullWidth,a=s.fullHeight;r+=s.offsetX*i/t,e-=s.offsetY*n/a,i*=s.width/t,n*=s.height/a}const a=this.filmOffset;0!==a&&(r+=t*a/this.getFilmWidth()),this.projectionMatrix.makePerspective(r,r+i,e,e-n,t,this.far),this.projectionMatrixInverse.copy(this.projectionMatrix).invert()}toJSON(t){const e=super.toJSON(t);return e.object.fov=this.fov,e.object.zoom=this.zoom,e.object.near=this.near,e.object.far=this.far,e.object.focus=this.focus,e.object.aspect=this.aspect,null!==this.view&&(e.object.view=Object.assign({},this.view)),e.object.filmGauge=this.filmGauge,e.object.filmOffset=this.filmOffset,e}}Kn.prototype.isPerspectiveCamera=!0;const $n=90;class ti extends Fe{constructor(t,e,n){if(super(),this.type="CubeCamera",!0!==n.isWebGLCubeRenderTarget)return void console.error("THREE.CubeCamera: The constructor now expects an instance of WebGLCubeRenderTarget as third parameter.");this.renderTarget=n;const i=new Kn($n,1,t,e);i.layers=this.layers,i.up.set(0,-1,0),i.lookAt(new zt(1,0,0)),this.add(i);const r=new Kn($n,1,t,e);r.layers=this.layers,r.up.set(0,-1,0),r.lookAt(new zt(-1,0,0)),this.add(r);const s=new Kn($n,1,t,e);s.layers=this.layers,s.up.set(0,0,1),s.lookAt(new zt(0,1,0)),this.add(s);const a=new Kn($n,1,t,e);a.layers=this.layers,a.up.set(0,0,-1),a.lookAt(new zt(0,-1,0)),this.add(a);const o=new Kn($n,1,t,e);o.layers=this.layers,o.up.set(0,-1,0),o.lookAt(new zt(0,0,1)),this.add(o);const l=new Kn($n,1,t,e);l.layers=this.layers,l.up.set(0,-1,0),l.lookAt(new zt(0,0,-1)),this.add(l)}update(t,e){null===this.parent&&this.updateMatrixWorld();const n=this.renderTarget,[i,r,s,a,o,l]=this.children,c=t.xr.enabled,h=t.getRenderTarget();t.xr.enabled=!1;const u=n.texture.generateMipmaps;n.texture.generateMipmaps=!1,t.setRenderTarget(n,0),t.render(e,i),t.setRenderTarget(n,1),t.render(e,r),t.setRenderTarget(n,2),t.render(e,s),t.setRenderTarget(n,3),t.render(e,a),t.setRenderTarget(n,4),t.render(e,o),n.texture.generateMipmaps=u,t.setRenderTarget(n,5),t.render(e,l),t.setRenderTarget(h),t.xr.enabled=c}}class ei extends Lt{constructor(t,e,n,i,s,a,o,l,c,h){super(t=void 0!==t?t:[],e=void 0!==e?e:r,n,i,s,a,o,l,c,h),this.flipY=!1}get images(){return this.image}set images(t){this.image=t}}ei.prototype.isCubeTexture=!0;class ni extends Pt{constructor(t,e,n){Number.isInteger(e)&&(console.warn("THREE.WebGLCubeRenderTarget: constructor signature is now WebGLCubeRenderTarget( size, options )"),e=n),super(t,t,e),e=e||{},this.texture=new ei(void 0,e.mapping,e.wrapS,e.wrapT,e.magFilter,e.minFilter,e.format,e.type,e.anisotropy,e.encoding),this.texture.isRenderTargetTexture=!0,this.texture.generateMipmaps=void 0!==e.generateMipmaps&&e.generateMipmaps,this.texture.minFilter=void 0!==e.minFilter?e.minFilter:g,this.texture._needsFlipEnvMap=!1}fromEquirectangularTexture(t,e){this.texture.type=e.type,this.texture.format=E,this.texture.encoding=e.encoding,this.texture.generateMipmaps=e.generateMipmaps,this.texture.minFilter=e.minFilter,this.texture.magFilter=e.magFilter;const n={uniforms:{tEquirect:{value:null}},vertexShader:"\n\n\t\t\t\tvarying vec3 vWorldDirection;\n\n\t\t\t\tvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\n\n\t\t\t\t\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\n\n\t\t\t\t}\n\n\t\t\t\tvoid main() {\n\n\t\t\t\t\tvWorldDirection = transformDirection( position, modelMatrix );\n\n\t\t\t\t\t#include \n\t\t\t\t\t#include \n\n\t\t\t\t}\n\t\t\t",fragmentShader:"\n\n\t\t\t\tuniform sampler2D tEquirect;\n\n\t\t\t\tvarying vec3 vWorldDirection;\n\n\t\t\t\t#include \n\n\t\t\t\tvoid main() {\n\n\t\t\t\t\tvec3 direction = normalize( vWorldDirection );\n\n\t\t\t\t\tvec2 sampleUV = equirectUv( direction );\n\n\t\t\t\t\tgl_FragColor = texture2D( tEquirect, sampleUV );\n\n\t\t\t\t}\n\t\t\t"},i=new qn(5,5,5),r=new Zn({name:"CubemapFromEquirect",uniforms:Xn(n.uniforms),vertexShader:n.vertexShader,fragmentShader:n.fragmentShader,side:1,blending:0});r.uniforms.tEquirect.value=e;const s=new Wn(i,r),a=e.minFilter;e.minFilter===y&&(e.minFilter=g);return new ti(1,10,this).update(t,s),e.minFilter=a,s.geometry.dispose(),s.material.dispose(),this}clear(t,e,n,i){const r=t.getRenderTarget();for(let r=0;r<6;r++)t.setRenderTarget(this,r),t.clear(e,n,i);t.setRenderTarget(r)}}ni.prototype.isWebGLCubeRenderTarget=!0;const ii=new zt,ri=new zt,si=new xt;class ai{constructor(t=new zt(1,0,0),e=0){this.normal=t,this.constant=e}set(t,e){return this.normal.copy(t),this.constant=e,this}setComponents(t,e,n,i){return this.normal.set(t,e,n),this.constant=i,this}setFromNormalAndCoplanarPoint(t,e){return this.normal.copy(t),this.constant=-e.dot(this.normal),this}setFromCoplanarPoints(t,e,n){const i=ii.subVectors(n,e).cross(ri.subVectors(t,e)).normalize();return this.setFromNormalAndCoplanarPoint(i,t),this}copy(t){return this.normal.copy(t.normal),this.constant=t.constant,this}normalize(){const t=1/this.normal.length();return this.normal.multiplyScalar(t),this.constant*=t,this}negate(){return this.constant*=-1,this.normal.negate(),this}distanceToPoint(t){return this.normal.dot(t)+this.constant}distanceToSphere(t){return this.distanceToPoint(t.center)-t.radius}projectPoint(t,e){return e.copy(this.normal).multiplyScalar(-this.distanceToPoint(t)).add(t)}intersectLine(t,e){const n=t.delta(ii),i=this.normal.dot(n);if(0===i)return 0===this.distanceToPoint(t.start)?e.copy(t.start):null;const r=-(t.start.dot(this.normal)+this.constant)/i;return r<0||r>1?null:e.copy(n).multiplyScalar(r).add(t.start)}intersectsLine(t){const e=this.distanceToPoint(t.start),n=this.distanceToPoint(t.end);return e<0&&n>0||n<0&&e>0}intersectsBox(t){return t.intersectsPlane(this)}intersectsSphere(t){return t.intersectsPlane(this)}coplanarPoint(t){return t.copy(this.normal).multiplyScalar(-this.constant)}applyMatrix4(t,e){const n=e||si.getNormalMatrix(t),i=this.coplanarPoint(ii).applyMatrix4(t),r=this.normal.applyMatrix3(n).normalize();return this.constant=-i.dot(r),this}translate(t){return this.constant-=t.dot(this.normal),this}equals(t){return t.normal.equals(this.normal)&&t.constant===this.constant}clone(){return(new this.constructor).copy(this)}}ai.prototype.isPlane=!0;const oi=new ie,li=new zt;class ci{constructor(t=new ai,e=new ai,n=new ai,i=new ai,r=new ai,s=new ai){this.planes=[t,e,n,i,r,s]}set(t,e,n,i,r,s){const a=this.planes;return a[0].copy(t),a[1].copy(e),a[2].copy(n),a[3].copy(i),a[4].copy(r),a[5].copy(s),this}copy(t){const e=this.planes;for(let n=0;n<6;n++)e[n].copy(t.planes[n]);return this}setFromProjectionMatrix(t){const e=this.planes,n=t.elements,i=n[0],r=n[1],s=n[2],a=n[3],o=n[4],l=n[5],c=n[6],h=n[7],u=n[8],d=n[9],p=n[10],m=n[11],f=n[12],g=n[13],v=n[14],y=n[15];return e[0].setComponents(a-i,h-o,m-u,y-f).normalize(),e[1].setComponents(a+i,h+o,m+u,y+f).normalize(),e[2].setComponents(a+r,h+l,m+d,y+g).normalize(),e[3].setComponents(a-r,h-l,m-d,y-g).normalize(),e[4].setComponents(a-s,h-c,m-p,y-v).normalize(),e[5].setComponents(a+s,h+c,m+p,y+v).normalize(),this}intersectsObject(t){const e=t.geometry;return null===e.boundingSphere&&e.computeBoundingSphere(),oi.copy(e.boundingSphere).applyMatrix4(t.matrixWorld),this.intersectsSphere(oi)}intersectsSprite(t){return oi.center.set(0,0,0),oi.radius=.7071067811865476,oi.applyMatrix4(t.matrixWorld),this.intersectsSphere(oi)}intersectsSphere(t){const e=this.planes,n=t.center,i=-t.radius;for(let t=0;t<6;t++){if(e[t].distanceToPoint(n)0?t.max.x:t.min.x,li.y=i.normal.y>0?t.max.y:t.min.y,li.z=i.normal.z>0?t.max.z:t.min.z,i.distanceToPoint(li)<0)return!1}return!0}containsPoint(t){const e=this.planes;for(let n=0;n<6;n++)if(e[n].distanceToPoint(t)<0)return!1;return!0}clone(){return(new this.constructor).copy(this)}}function hi(){let t=null,e=!1,n=null,i=null;function r(e,s){n(e,s),i=t.requestAnimationFrame(r)}return{start:function(){!0!==e&&null!==n&&(i=t.requestAnimationFrame(r),e=!0)},stop:function(){t.cancelAnimationFrame(i),e=!1},setAnimationLoop:function(t){n=t},setContext:function(e){t=e}}}function ui(t,e){const n=e.isWebGL2,i=new WeakMap;return{get:function(t){return t.isInterleavedBufferAttribute&&(t=t.data),i.get(t)},remove:function(e){e.isInterleavedBufferAttribute&&(e=e.data);const n=i.get(e);n&&(t.deleteBuffer(n.buffer),i.delete(e))},update:function(e,r){if(e.isGLBufferAttribute){const t=i.get(e);return void((!t||t.version 0.0 ) ? v : 0.5 * inversesqrt( max( 1.0 - x * x, 1e-7 ) ) - v;\n\treturn cross( v1, v2 ) * theta_sintheta;\n}\nvec3 LTC_Evaluate( const in vec3 N, const in vec3 V, const in vec3 P, const in mat3 mInv, const in vec3 rectCoords[ 4 ] ) {\n\tvec3 v1 = rectCoords[ 1 ] - rectCoords[ 0 ];\n\tvec3 v2 = rectCoords[ 3 ] - rectCoords[ 0 ];\n\tvec3 lightNormal = cross( v1, v2 );\n\tif( dot( lightNormal, P - rectCoords[ 0 ] ) < 0.0 ) return vec3( 0.0 );\n\tvec3 T1, T2;\n\tT1 = normalize( V - N * dot( V, N ) );\n\tT2 = - cross( N, T1 );\n\tmat3 mat = mInv * transposeMat3( mat3( T1, T2, N ) );\n\tvec3 coords[ 4 ];\n\tcoords[ 0 ] = mat * ( rectCoords[ 0 ] - P );\n\tcoords[ 1 ] = mat * ( rectCoords[ 1 ] - P );\n\tcoords[ 2 ] = mat * ( rectCoords[ 2 ] - P );\n\tcoords[ 3 ] = mat * ( rectCoords[ 3 ] - P );\n\tcoords[ 0 ] = normalize( coords[ 0 ] );\n\tcoords[ 1 ] = normalize( coords[ 1 ] );\n\tcoords[ 2 ] = normalize( coords[ 2 ] );\n\tcoords[ 3 ] = normalize( coords[ 3 ] );\n\tvec3 vectorFormFactor = vec3( 0.0 );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 0 ], coords[ 1 ] );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 1 ], coords[ 2 ] );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 2 ], coords[ 3 ] );\n\tvectorFormFactor += LTC_EdgeVectorFormFactor( coords[ 3 ], coords[ 0 ] );\n\tfloat result = LTC_ClippedSphereFormFactor( vectorFormFactor );\n\treturn vec3( result );\n}\nfloat G_BlinnPhong_Implicit( ) {\n\treturn 0.25;\n}\nfloat D_BlinnPhong( const in float shininess, const in float dotNH ) {\n\treturn RECIPROCAL_PI * ( shininess * 0.5 + 1.0 ) * pow( dotNH, shininess );\n}\nvec3 BRDF_BlinnPhong( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, const in vec3 specularColor, const in float shininess ) {\n\tvec3 halfDir = normalize( lightDir + viewDir );\n\tfloat dotNH = saturate( dot( normal, halfDir ) );\n\tfloat dotVH = saturate( dot( viewDir, halfDir ) );\n\tvec3 F = F_Schlick( specularColor, 1.0, dotVH );\n\tfloat G = G_BlinnPhong_Implicit( );\n\tfloat D = D_BlinnPhong( shininess, dotNH );\n\treturn F * ( G * D );\n}\n#if defined( USE_SHEEN )\nfloat D_Charlie( float roughness, float dotNH ) {\n\tfloat alpha = pow2( roughness );\n\tfloat invAlpha = 1.0 / alpha;\n\tfloat cos2h = dotNH * dotNH;\n\tfloat sin2h = max( 1.0 - cos2h, 0.0078125 );\n\treturn ( 2.0 + invAlpha ) * pow( sin2h, invAlpha * 0.5 ) / ( 2.0 * PI );\n}\nfloat V_Neubelt( float dotNV, float dotNL ) {\n\treturn saturate( 1.0 / ( 4.0 * ( dotNL + dotNV - dotNL * dotNV ) ) );\n}\nvec3 BRDF_Sheen( const in vec3 lightDir, const in vec3 viewDir, const in vec3 normal, vec3 sheenColor, const in float sheenRoughness ) {\n\tvec3 halfDir = normalize( lightDir + viewDir );\n\tfloat dotNL = saturate( dot( normal, lightDir ) );\n\tfloat dotNV = saturate( dot( normal, viewDir ) );\n\tfloat dotNH = saturate( dot( normal, halfDir ) );\n\tfloat D = D_Charlie( sheenRoughness, dotNH );\n\tfloat V = V_Neubelt( dotNV, dotNL );\n\treturn sheenColor * ( D * V );\n}\n#endif",bumpmap_pars_fragment:"#ifdef USE_BUMPMAP\n\tuniform sampler2D bumpMap;\n\tuniform float bumpScale;\n\tvec2 dHdxy_fwd() {\n\t\tvec2 dSTdx = dFdx( vUv );\n\t\tvec2 dSTdy = dFdy( vUv );\n\t\tfloat Hll = bumpScale * texture2D( bumpMap, vUv ).x;\n\t\tfloat dBx = bumpScale * texture2D( bumpMap, vUv + dSTdx ).x - Hll;\n\t\tfloat dBy = bumpScale * texture2D( bumpMap, vUv + dSTdy ).x - Hll;\n\t\treturn vec2( dBx, dBy );\n\t}\n\tvec3 perturbNormalArb( vec3 surf_pos, vec3 surf_norm, vec2 dHdxy, float faceDirection ) {\n\t\tvec3 vSigmaX = vec3( dFdx( surf_pos.x ), dFdx( surf_pos.y ), dFdx( surf_pos.z ) );\n\t\tvec3 vSigmaY = vec3( dFdy( surf_pos.x ), dFdy( surf_pos.y ), dFdy( surf_pos.z ) );\n\t\tvec3 vN = surf_norm;\n\t\tvec3 R1 = cross( vSigmaY, vN );\n\t\tvec3 R2 = cross( vN, vSigmaX );\n\t\tfloat fDet = dot( vSigmaX, R1 ) * faceDirection;\n\t\tvec3 vGrad = sign( fDet ) * ( dHdxy.x * R1 + dHdxy.y * R2 );\n\t\treturn normalize( abs( fDet ) * surf_norm - vGrad );\n\t}\n#endif",clipping_planes_fragment:"#if NUM_CLIPPING_PLANES > 0\n\tvec4 plane;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < UNION_CLIPPING_PLANES; i ++ ) {\n\t\tplane = clippingPlanes[ i ];\n\t\tif ( dot( vClipPosition, plane.xyz ) > plane.w ) discard;\n\t}\n\t#pragma unroll_loop_end\n\t#if UNION_CLIPPING_PLANES < NUM_CLIPPING_PLANES\n\t\tbool clipped = true;\n\t\t#pragma unroll_loop_start\n\t\tfor ( int i = UNION_CLIPPING_PLANES; i < NUM_CLIPPING_PLANES; i ++ ) {\n\t\t\tplane = clippingPlanes[ i ];\n\t\t\tclipped = ( dot( vClipPosition, plane.xyz ) > plane.w ) && clipped;\n\t\t}\n\t\t#pragma unroll_loop_end\n\t\tif ( clipped ) discard;\n\t#endif\n#endif",clipping_planes_pars_fragment:"#if NUM_CLIPPING_PLANES > 0\n\tvarying vec3 vClipPosition;\n\tuniform vec4 clippingPlanes[ NUM_CLIPPING_PLANES ];\n#endif",clipping_planes_pars_vertex:"#if NUM_CLIPPING_PLANES > 0\n\tvarying vec3 vClipPosition;\n#endif",clipping_planes_vertex:"#if NUM_CLIPPING_PLANES > 0\n\tvClipPosition = - mvPosition.xyz;\n#endif",color_fragment:"#if defined( USE_COLOR_ALPHA )\n\tdiffuseColor *= vColor;\n#elif defined( USE_COLOR )\n\tdiffuseColor.rgb *= vColor;\n#endif",color_pars_fragment:"#if defined( USE_COLOR_ALPHA )\n\tvarying vec4 vColor;\n#elif defined( USE_COLOR )\n\tvarying vec3 vColor;\n#endif",color_pars_vertex:"#if defined( USE_COLOR_ALPHA )\n\tvarying vec4 vColor;\n#elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\n\tvarying vec3 vColor;\n#endif",color_vertex:"#if defined( USE_COLOR_ALPHA )\n\tvColor = vec4( 1.0 );\n#elif defined( USE_COLOR ) || defined( USE_INSTANCING_COLOR )\n\tvColor = vec3( 1.0 );\n#endif\n#ifdef USE_COLOR\n\tvColor *= color;\n#endif\n#ifdef USE_INSTANCING_COLOR\n\tvColor.xyz *= instanceColor.xyz;\n#endif",common:"#define PI 3.141592653589793\n#define PI2 6.283185307179586\n#define PI_HALF 1.5707963267948966\n#define RECIPROCAL_PI 0.3183098861837907\n#define RECIPROCAL_PI2 0.15915494309189535\n#define EPSILON 1e-6\n#ifndef saturate\n#define saturate( a ) clamp( a, 0.0, 1.0 )\n#endif\n#define whiteComplement( a ) ( 1.0 - saturate( a ) )\nfloat pow2( const in float x ) { return x*x; }\nfloat pow3( const in float x ) { return x*x*x; }\nfloat pow4( const in float x ) { float x2 = x*x; return x2*x2; }\nfloat max3( const in vec3 v ) { return max( max( v.x, v.y ), v.z ); }\nfloat average( const in vec3 color ) { return dot( color, vec3( 0.3333 ) ); }\nhighp float rand( const in vec2 uv ) {\n\tconst highp float a = 12.9898, b = 78.233, c = 43758.5453;\n\thighp float dt = dot( uv.xy, vec2( a,b ) ), sn = mod( dt, PI );\n\treturn fract( sin( sn ) * c );\n}\n#ifdef HIGH_PRECISION\n\tfloat precisionSafeLength( vec3 v ) { return length( v ); }\n#else\n\tfloat precisionSafeLength( vec3 v ) {\n\t\tfloat maxComponent = max3( abs( v ) );\n\t\treturn length( v / maxComponent ) * maxComponent;\n\t}\n#endif\nstruct IncidentLight {\n\tvec3 color;\n\tvec3 direction;\n\tbool visible;\n};\nstruct ReflectedLight {\n\tvec3 directDiffuse;\n\tvec3 directSpecular;\n\tvec3 indirectDiffuse;\n\tvec3 indirectSpecular;\n};\nstruct GeometricContext {\n\tvec3 position;\n\tvec3 normal;\n\tvec3 viewDir;\n#ifdef USE_CLEARCOAT\n\tvec3 clearcoatNormal;\n#endif\n};\nvec3 transformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( matrix * vec4( dir, 0.0 ) ).xyz );\n}\nvec3 inverseTransformDirection( in vec3 dir, in mat4 matrix ) {\n\treturn normalize( ( vec4( dir, 0.0 ) * matrix ).xyz );\n}\nmat3 transposeMat3( const in mat3 m ) {\n\tmat3 tmp;\n\ttmp[ 0 ] = vec3( m[ 0 ].x, m[ 1 ].x, m[ 2 ].x );\n\ttmp[ 1 ] = vec3( m[ 0 ].y, m[ 1 ].y, m[ 2 ].y );\n\ttmp[ 2 ] = vec3( m[ 0 ].z, m[ 1 ].z, m[ 2 ].z );\n\treturn tmp;\n}\nfloat linearToRelativeLuminance( const in vec3 color ) {\n\tvec3 weights = vec3( 0.2126, 0.7152, 0.0722 );\n\treturn dot( weights, color.rgb );\n}\nbool isPerspectiveMatrix( mat4 m ) {\n\treturn m[ 2 ][ 3 ] == - 1.0;\n}\nvec2 equirectUv( in vec3 dir ) {\n\tfloat u = atan( dir.z, dir.x ) * RECIPROCAL_PI2 + 0.5;\n\tfloat v = asin( clamp( dir.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;\n\treturn vec2( u, v );\n}",cube_uv_reflection_fragment:"#ifdef ENVMAP_TYPE_CUBE_UV\n\t#define cubeUV_maxMipLevel 8.0\n\t#define cubeUV_minMipLevel 4.0\n\t#define cubeUV_maxTileSize 256.0\n\t#define cubeUV_minTileSize 16.0\n\tfloat getFace( vec3 direction ) {\n\t\tvec3 absDirection = abs( direction );\n\t\tfloat face = - 1.0;\n\t\tif ( absDirection.x > absDirection.z ) {\n\t\t\tif ( absDirection.x > absDirection.y )\n\t\t\t\tface = direction.x > 0.0 ? 0.0 : 3.0;\n\t\t\telse\n\t\t\t\tface = direction.y > 0.0 ? 1.0 : 4.0;\n\t\t} else {\n\t\t\tif ( absDirection.z > absDirection.y )\n\t\t\t\tface = direction.z > 0.0 ? 2.0 : 5.0;\n\t\t\telse\n\t\t\t\tface = direction.y > 0.0 ? 1.0 : 4.0;\n\t\t}\n\t\treturn face;\n\t}\n\tvec2 getUV( vec3 direction, float face ) {\n\t\tvec2 uv;\n\t\tif ( face == 0.0 ) {\n\t\t\tuv = vec2( direction.z, direction.y ) / abs( direction.x );\n\t\t} else if ( face == 1.0 ) {\n\t\t\tuv = vec2( - direction.x, - direction.z ) / abs( direction.y );\n\t\t} else if ( face == 2.0 ) {\n\t\t\tuv = vec2( - direction.x, direction.y ) / abs( direction.z );\n\t\t} else if ( face == 3.0 ) {\n\t\t\tuv = vec2( - direction.z, direction.y ) / abs( direction.x );\n\t\t} else if ( face == 4.0 ) {\n\t\t\tuv = vec2( - direction.x, direction.z ) / abs( direction.y );\n\t\t} else {\n\t\t\tuv = vec2( direction.x, direction.y ) / abs( direction.z );\n\t\t}\n\t\treturn 0.5 * ( uv + 1.0 );\n\t}\n\tvec3 bilinearCubeUV( sampler2D envMap, vec3 direction, float mipInt ) {\n\t\tfloat face = getFace( direction );\n\t\tfloat filterInt = max( cubeUV_minMipLevel - mipInt, 0.0 );\n\t\tmipInt = max( mipInt, cubeUV_minMipLevel );\n\t\tfloat faceSize = exp2( mipInt );\n\t\tfloat texelSize = 1.0 / ( 3.0 * cubeUV_maxTileSize );\n\t\tvec2 uv = getUV( direction, face ) * ( faceSize - 1.0 );\n\t\tvec2 f = fract( uv );\n\t\tuv += 0.5 - f;\n\t\tif ( face > 2.0 ) {\n\t\t\tuv.y += faceSize;\n\t\t\tface -= 3.0;\n\t\t}\n\t\tuv.x += face * faceSize;\n\t\tif ( mipInt < cubeUV_maxMipLevel ) {\n\t\t\tuv.y += 2.0 * cubeUV_maxTileSize;\n\t\t}\n\t\tuv.y += filterInt * 2.0 * cubeUV_minTileSize;\n\t\tuv.x += 3.0 * max( 0.0, cubeUV_maxTileSize - 2.0 * faceSize );\n\t\tuv *= texelSize;\n\t\tvec3 tl = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tuv.x += texelSize;\n\t\tvec3 tr = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tuv.y += texelSize;\n\t\tvec3 br = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tuv.x -= texelSize;\n\t\tvec3 bl = envMapTexelToLinear( texture2D( envMap, uv ) ).rgb;\n\t\tvec3 tm = mix( tl, tr, f.x );\n\t\tvec3 bm = mix( bl, br, f.x );\n\t\treturn mix( tm, bm, f.y );\n\t}\n\t#define r0 1.0\n\t#define v0 0.339\n\t#define m0 - 2.0\n\t#define r1 0.8\n\t#define v1 0.276\n\t#define m1 - 1.0\n\t#define r4 0.4\n\t#define v4 0.046\n\t#define m4 2.0\n\t#define r5 0.305\n\t#define v5 0.016\n\t#define m5 3.0\n\t#define r6 0.21\n\t#define v6 0.0038\n\t#define m6 4.0\n\tfloat roughnessToMip( float roughness ) {\n\t\tfloat mip = 0.0;\n\t\tif ( roughness >= r1 ) {\n\t\t\tmip = ( r0 - roughness ) * ( m1 - m0 ) / ( r0 - r1 ) + m0;\n\t\t} else if ( roughness >= r4 ) {\n\t\t\tmip = ( r1 - roughness ) * ( m4 - m1 ) / ( r1 - r4 ) + m1;\n\t\t} else if ( roughness >= r5 ) {\n\t\t\tmip = ( r4 - roughness ) * ( m5 - m4 ) / ( r4 - r5 ) + m4;\n\t\t} else if ( roughness >= r6 ) {\n\t\t\tmip = ( r5 - roughness ) * ( m6 - m5 ) / ( r5 - r6 ) + m5;\n\t\t} else {\n\t\t\tmip = - 2.0 * log2( 1.16 * roughness );\t\t}\n\t\treturn mip;\n\t}\n\tvec4 textureCubeUV( sampler2D envMap, vec3 sampleDir, float roughness ) {\n\t\tfloat mip = clamp( roughnessToMip( roughness ), m0, cubeUV_maxMipLevel );\n\t\tfloat mipF = fract( mip );\n\t\tfloat mipInt = floor( mip );\n\t\tvec3 color0 = bilinearCubeUV( envMap, sampleDir, mipInt );\n\t\tif ( mipF == 0.0 ) {\n\t\t\treturn vec4( color0, 1.0 );\n\t\t} else {\n\t\t\tvec3 color1 = bilinearCubeUV( envMap, sampleDir, mipInt + 1.0 );\n\t\t\treturn vec4( mix( color0, color1, mipF ), 1.0 );\n\t\t}\n\t}\n#endif",defaultnormal_vertex:"vec3 transformedNormal = objectNormal;\n#ifdef USE_INSTANCING\n\tmat3 m = mat3( instanceMatrix );\n\ttransformedNormal /= vec3( dot( m[ 0 ], m[ 0 ] ), dot( m[ 1 ], m[ 1 ] ), dot( m[ 2 ], m[ 2 ] ) );\n\ttransformedNormal = m * transformedNormal;\n#endif\ntransformedNormal = normalMatrix * transformedNormal;\n#ifdef FLIP_SIDED\n\ttransformedNormal = - transformedNormal;\n#endif\n#ifdef USE_TANGENT\n\tvec3 transformedTangent = ( modelViewMatrix * vec4( objectTangent, 0.0 ) ).xyz;\n\t#ifdef FLIP_SIDED\n\t\ttransformedTangent = - transformedTangent;\n\t#endif\n#endif",displacementmap_pars_vertex:"#ifdef USE_DISPLACEMENTMAP\n\tuniform sampler2D displacementMap;\n\tuniform float displacementScale;\n\tuniform float displacementBias;\n#endif",displacementmap_vertex:"#ifdef USE_DISPLACEMENTMAP\n\ttransformed += normalize( objectNormal ) * ( texture2D( displacementMap, vUv ).x * displacementScale + displacementBias );\n#endif",emissivemap_fragment:"#ifdef USE_EMISSIVEMAP\n\tvec4 emissiveColor = texture2D( emissiveMap, vUv );\n\temissiveColor.rgb = emissiveMapTexelToLinear( emissiveColor ).rgb;\n\ttotalEmissiveRadiance *= emissiveColor.rgb;\n#endif",emissivemap_pars_fragment:"#ifdef USE_EMISSIVEMAP\n\tuniform sampler2D emissiveMap;\n#endif",encodings_fragment:"gl_FragColor = linearToOutputTexel( gl_FragColor );",encodings_pars_fragment:"\nvec4 LinearToLinear( in vec4 value ) {\n\treturn value;\n}\nvec4 GammaToLinear( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( gammaFactor ) ), value.a );\n}\nvec4 LinearToGamma( in vec4 value, in float gammaFactor ) {\n\treturn vec4( pow( value.rgb, vec3( 1.0 / gammaFactor ) ), value.a );\n}\nvec4 sRGBToLinear( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb * 0.9478672986 + vec3( 0.0521327014 ), vec3( 2.4 ) ), value.rgb * 0.0773993808, vec3( lessThanEqual( value.rgb, vec3( 0.04045 ) ) ) ), value.a );\n}\nvec4 LinearTosRGB( in vec4 value ) {\n\treturn vec4( mix( pow( value.rgb, vec3( 0.41666 ) ) * 1.055 - vec3( 0.055 ), value.rgb * 12.92, vec3( lessThanEqual( value.rgb, vec3( 0.0031308 ) ) ) ), value.a );\n}\nvec4 RGBEToLinear( in vec4 value ) {\n\treturn vec4( value.rgb * exp2( value.a * 255.0 - 128.0 ), 1.0 );\n}\nvec4 LinearToRGBE( in vec4 value ) {\n\tfloat maxComponent = max( max( value.r, value.g ), value.b );\n\tfloat fExp = clamp( ceil( log2( maxComponent ) ), -128.0, 127.0 );\n\treturn vec4( value.rgb / exp2( fExp ), ( fExp + 128.0 ) / 255.0 );\n}\nvec4 RGBMToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * value.a * maxRange, 1.0 );\n}\nvec4 LinearToRGBM( in vec4 value, in float maxRange ) {\n\tfloat maxRGB = max( value.r, max( value.g, value.b ) );\n\tfloat M = clamp( maxRGB / maxRange, 0.0, 1.0 );\n\tM = ceil( M * 255.0 ) / 255.0;\n\treturn vec4( value.rgb / ( M * maxRange ), M );\n}\nvec4 RGBDToLinear( in vec4 value, in float maxRange ) {\n\treturn vec4( value.rgb * ( ( maxRange / 255.0 ) / value.a ), 1.0 );\n}\nvec4 LinearToRGBD( in vec4 value, in float maxRange ) {\n\tfloat maxRGB = max( value.r, max( value.g, value.b ) );\n\tfloat D = max( maxRange / maxRGB, 1.0 );\n\tD = clamp( floor( D ) / 255.0, 0.0, 1.0 );\n\treturn vec4( value.rgb * ( D * ( 255.0 / maxRange ) ), D );\n}\nconst mat3 cLogLuvM = mat3( 0.2209, 0.3390, 0.4184, 0.1138, 0.6780, 0.7319, 0.0102, 0.1130, 0.2969 );\nvec4 LinearToLogLuv( in vec4 value ) {\n\tvec3 Xp_Y_XYZp = cLogLuvM * value.rgb;\n\tXp_Y_XYZp = max( Xp_Y_XYZp, vec3( 1e-6, 1e-6, 1e-6 ) );\n\tvec4 vResult;\n\tvResult.xy = Xp_Y_XYZp.xy / Xp_Y_XYZp.z;\n\tfloat Le = 2.0 * log2(Xp_Y_XYZp.y) + 127.0;\n\tvResult.w = fract( Le );\n\tvResult.z = ( Le - ( floor( vResult.w * 255.0 ) ) / 255.0 ) / 255.0;\n\treturn vResult;\n}\nconst mat3 cLogLuvInverseM = mat3( 6.0014, -2.7008, -1.7996, -1.3320, 3.1029, -5.7721, 0.3008, -1.0882, 5.6268 );\nvec4 LogLuvToLinear( in vec4 value ) {\n\tfloat Le = value.z * 255.0 + value.w;\n\tvec3 Xp_Y_XYZp;\n\tXp_Y_XYZp.y = exp2( ( Le - 127.0 ) / 2.0 );\n\tXp_Y_XYZp.z = Xp_Y_XYZp.y / value.y;\n\tXp_Y_XYZp.x = value.x * Xp_Y_XYZp.z;\n\tvec3 vRGB = cLogLuvInverseM * Xp_Y_XYZp.rgb;\n\treturn vec4( max( vRGB, 0.0 ), 1.0 );\n}",envmap_fragment:"#ifdef USE_ENVMAP\n\t#ifdef ENV_WORLDPOS\n\t\tvec3 cameraToFrag;\n\t\tif ( isOrthographic ) {\n\t\t\tcameraToFrag = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) );\n\t\t} else {\n\t\t\tcameraToFrag = normalize( vWorldPosition - cameraPosition );\n\t\t}\n\t\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvec3 reflectVec = reflect( cameraToFrag, worldNormal );\n\t\t#else\n\t\t\tvec3 reflectVec = refract( cameraToFrag, worldNormal, refractionRatio );\n\t\t#endif\n\t#else\n\t\tvec3 reflectVec = vReflect;\n\t#endif\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tvec4 envColor = textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) );\n\t\tenvColor = envMapTexelToLinear( envColor );\n\t#elif defined( ENVMAP_TYPE_CUBE_UV )\n\t\tvec4 envColor = textureCubeUV( envMap, reflectVec, 0.0 );\n\t#else\n\t\tvec4 envColor = vec4( 0.0 );\n\t#endif\n\t#ifdef ENVMAP_BLENDING_MULTIPLY\n\t\toutgoingLight = mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_MIX )\n\t\toutgoingLight = mix( outgoingLight, envColor.xyz, specularStrength * reflectivity );\n\t#elif defined( ENVMAP_BLENDING_ADD )\n\t\toutgoingLight += envColor.xyz * specularStrength * reflectivity;\n\t#endif\n#endif",envmap_common_pars_fragment:"#ifdef USE_ENVMAP\n\tuniform float envMapIntensity;\n\tuniform float flipEnvMap;\n\tuniform int maxMipLevel;\n\t#ifdef ENVMAP_TYPE_CUBE\n\t\tuniform samplerCube envMap;\n\t#else\n\t\tuniform sampler2D envMap;\n\t#endif\n\t\n#endif",envmap_pars_fragment:"#ifdef USE_ENVMAP\n\tuniform float reflectivity;\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) || defined( PHONG )\n\t\t#define ENV_WORLDPOS\n\t#endif\n\t#ifdef ENV_WORLDPOS\n\t\tvarying vec3 vWorldPosition;\n\t\tuniform float refractionRatio;\n\t#else\n\t\tvarying vec3 vReflect;\n\t#endif\n#endif",envmap_pars_vertex:"#ifdef USE_ENVMAP\n\t#if defined( USE_BUMPMAP ) || defined( USE_NORMALMAP ) ||defined( PHONG )\n\t\t#define ENV_WORLDPOS\n\t#endif\n\t#ifdef ENV_WORLDPOS\n\t\t\n\t\tvarying vec3 vWorldPosition;\n\t#else\n\t\tvarying vec3 vReflect;\n\t\tuniform float refractionRatio;\n\t#endif\n#endif",envmap_physical_pars_fragment:"#if defined( USE_ENVMAP )\n\t#ifdef ENVMAP_MODE_REFRACTION\n\t\tuniform float refractionRatio;\n\t#endif\n\tvec3 getIBLIrradiance( const in vec3 normal ) {\n\t\t#if defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\n\t\t\tvec4 envMapColor = textureCubeUV( envMap, worldNormal, 1.0 );\n\t\t\treturn PI * envMapColor.rgb * envMapIntensity;\n\t\t#else\n\t\t\treturn vec3( 0.0 );\n\t\t#endif\n\t}\n\tvec3 getIBLRadiance( const in vec3 viewDir, const in vec3 normal, const in float roughness ) {\n\t\t#if defined( ENVMAP_TYPE_CUBE_UV )\n\t\t\tvec3 reflectVec;\n\t\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\t\treflectVec = reflect( - viewDir, normal );\n\t\t\t\treflectVec = normalize( mix( reflectVec, normal, roughness * roughness) );\n\t\t\t#else\n\t\t\t\treflectVec = refract( - viewDir, normal, refractionRatio );\n\t\t\t#endif\n\t\t\treflectVec = inverseTransformDirection( reflectVec, viewMatrix );\n\t\t\tvec4 envMapColor = textureCubeUV( envMap, reflectVec, roughness );\n\t\t\treturn envMapColor.rgb * envMapIntensity;\n\t\t#else\n\t\t\treturn vec3( 0.0 );\n\t\t#endif\n\t}\n#endif",envmap_vertex:"#ifdef USE_ENVMAP\n\t#ifdef ENV_WORLDPOS\n\t\tvWorldPosition = worldPosition.xyz;\n\t#else\n\t\tvec3 cameraToVertex;\n\t\tif ( isOrthographic ) {\n\t\t\tcameraToVertex = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) );\n\t\t} else {\n\t\t\tcameraToVertex = normalize( worldPosition.xyz - cameraPosition );\n\t\t}\n\t\tvec3 worldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\n\t\t#ifdef ENVMAP_MODE_REFLECTION\n\t\t\tvReflect = reflect( cameraToVertex, worldNormal );\n\t\t#else\n\t\t\tvReflect = refract( cameraToVertex, worldNormal, refractionRatio );\n\t\t#endif\n\t#endif\n#endif",fog_vertex:"#ifdef USE_FOG\n\tvFogDepth = - mvPosition.z;\n#endif",fog_pars_vertex:"#ifdef USE_FOG\n\tvarying float vFogDepth;\n#endif",fog_fragment:"#ifdef USE_FOG\n\t#ifdef FOG_EXP2\n\t\tfloat fogFactor = 1.0 - exp( - fogDensity * fogDensity * vFogDepth * vFogDepth );\n\t#else\n\t\tfloat fogFactor = smoothstep( fogNear, fogFar, vFogDepth );\n\t#endif\n\tgl_FragColor.rgb = mix( gl_FragColor.rgb, fogColor, fogFactor );\n#endif",fog_pars_fragment:"#ifdef USE_FOG\n\tuniform vec3 fogColor;\n\tvarying float vFogDepth;\n\t#ifdef FOG_EXP2\n\t\tuniform float fogDensity;\n\t#else\n\t\tuniform float fogNear;\n\t\tuniform float fogFar;\n\t#endif\n#endif",gradientmap_pars_fragment:"#ifdef USE_GRADIENTMAP\n\tuniform sampler2D gradientMap;\n#endif\nvec3 getGradientIrradiance( vec3 normal, vec3 lightDirection ) {\n\tfloat dotNL = dot( normal, lightDirection );\n\tvec2 coord = vec2( dotNL * 0.5 + 0.5, 0.0 );\n\t#ifdef USE_GRADIENTMAP\n\t\treturn texture2D( gradientMap, coord ).rgb;\n\t#else\n\t\treturn ( coord.x < 0.7 ) ? vec3( 0.7 ) : vec3( 1.0 );\n\t#endif\n}",lightmap_fragment:"#ifdef USE_LIGHTMAP\n\tvec4 lightMapTexel = texture2D( lightMap, vUv2 );\n\tvec3 lightMapIrradiance = lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\tlightMapIrradiance *= PI;\n\t#endif\n\treflectedLight.indirectDiffuse += lightMapIrradiance;\n#endif",lightmap_pars_fragment:"#ifdef USE_LIGHTMAP\n\tuniform sampler2D lightMap;\n\tuniform float lightMapIntensity;\n#endif",lights_lambert_vertex:"vec3 diffuse = vec3( 1.0 );\nGeometricContext geometry;\ngeometry.position = mvPosition.xyz;\ngeometry.normal = normalize( transformedNormal );\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( -mvPosition.xyz );\nGeometricContext backGeometry;\nbackGeometry.position = geometry.position;\nbackGeometry.normal = -geometry.normal;\nbackGeometry.viewDir = geometry.viewDir;\nvLightFront = vec3( 0.0 );\nvIndirectFront = vec3( 0.0 );\n#ifdef DOUBLE_SIDED\n\tvLightBack = vec3( 0.0 );\n\tvIndirectBack = vec3( 0.0 );\n#endif\nIncidentLight directLight;\nfloat dotNL;\nvec3 directLightColor_Diffuse;\nvIndirectFront += getAmbientLightIrradiance( ambientLightColor );\nvIndirectFront += getLightProbeIrradiance( lightProbe, geometry.normal );\n#ifdef DOUBLE_SIDED\n\tvIndirectBack += getAmbientLightIrradiance( ambientLightColor );\n\tvIndirectBack += getLightProbeIrradiance( lightProbe, backGeometry.normal );\n#endif\n#if NUM_POINT_LIGHTS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\t\tgetPointLightInfo( pointLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = directLight.color;\n\t\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += saturate( - dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if NUM_SPOT_LIGHTS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\t\tgetSpotLightInfo( spotLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = directLight.color;\n\t\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += saturate( - dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if NUM_DIR_LIGHTS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\t\tgetDirectionalLightInfo( directionalLights[ i ], geometry, directLight );\n\t\tdotNL = dot( geometry.normal, directLight.direction );\n\t\tdirectLightColor_Diffuse = directLight.color;\n\t\tvLightFront += saturate( dotNL ) * directLightColor_Diffuse;\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvLightBack += saturate( - dotNL ) * directLightColor_Diffuse;\n\t\t#endif\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if NUM_HEMI_LIGHTS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n\t\tvIndirectFront += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry.normal );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\tvIndirectBack += getHemisphereLightIrradiance( hemisphereLights[ i ], backGeometry.normal );\n\t\t#endif\n\t}\n\t#pragma unroll_loop_end\n#endif",lights_pars_begin:"uniform bool receiveShadow;\nuniform vec3 ambientLightColor;\nuniform vec3 lightProbe[ 9 ];\nvec3 shGetIrradianceAt( in vec3 normal, in vec3 shCoefficients[ 9 ] ) {\n\tfloat x = normal.x, y = normal.y, z = normal.z;\n\tvec3 result = shCoefficients[ 0 ] * 0.886227;\n\tresult += shCoefficients[ 1 ] * 2.0 * 0.511664 * y;\n\tresult += shCoefficients[ 2 ] * 2.0 * 0.511664 * z;\n\tresult += shCoefficients[ 3 ] * 2.0 * 0.511664 * x;\n\tresult += shCoefficients[ 4 ] * 2.0 * 0.429043 * x * y;\n\tresult += shCoefficients[ 5 ] * 2.0 * 0.429043 * y * z;\n\tresult += shCoefficients[ 6 ] * ( 0.743125 * z * z - 0.247708 );\n\tresult += shCoefficients[ 7 ] * 2.0 * 0.429043 * x * z;\n\tresult += shCoefficients[ 8 ] * 0.429043 * ( x * x - y * y );\n\treturn result;\n}\nvec3 getLightProbeIrradiance( const in vec3 lightProbe[ 9 ], const in vec3 normal ) {\n\tvec3 worldNormal = inverseTransformDirection( normal, viewMatrix );\n\tvec3 irradiance = shGetIrradianceAt( worldNormal, lightProbe );\n\treturn irradiance;\n}\nvec3 getAmbientLightIrradiance( const in vec3 ambientLightColor ) {\n\tvec3 irradiance = ambientLightColor;\n\treturn irradiance;\n}\nfloat getDistanceAttenuation( const in float lightDistance, const in float cutoffDistance, const in float decayExponent ) {\n\t#if defined ( PHYSICALLY_CORRECT_LIGHTS )\n\t\tfloat distanceFalloff = 1.0 / max( pow( lightDistance, decayExponent ), 0.01 );\n\t\tif ( cutoffDistance > 0.0 ) {\n\t\t\tdistanceFalloff *= pow2( saturate( 1.0 - pow4( lightDistance / cutoffDistance ) ) );\n\t\t}\n\t\treturn distanceFalloff;\n\t#else\n\t\tif ( cutoffDistance > 0.0 && decayExponent > 0.0 ) {\n\t\t\treturn pow( saturate( - lightDistance / cutoffDistance + 1.0 ), decayExponent );\n\t\t}\n\t\treturn 1.0;\n\t#endif\n}\nfloat getSpotAttenuation( const in float coneCosine, const in float penumbraCosine, const in float angleCosine ) {\n\treturn smoothstep( coneCosine, penumbraCosine, angleCosine );\n}\n#if NUM_DIR_LIGHTS > 0\n\tstruct DirectionalLight {\n\t\tvec3 direction;\n\t\tvec3 color;\n\t};\n\tuniform DirectionalLight directionalLights[ NUM_DIR_LIGHTS ];\n\tvoid getDirectionalLightInfo( const in DirectionalLight directionalLight, const in GeometricContext geometry, out IncidentLight light ) {\n\t\tlight.color = directionalLight.color;\n\t\tlight.direction = directionalLight.direction;\n\t\tlight.visible = true;\n\t}\n#endif\n#if NUM_POINT_LIGHTS > 0\n\tstruct PointLight {\n\t\tvec3 position;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t};\n\tuniform PointLight pointLights[ NUM_POINT_LIGHTS ];\n\tvoid getPointLightInfo( const in PointLight pointLight, const in GeometricContext geometry, out IncidentLight light ) {\n\t\tvec3 lVector = pointLight.position - geometry.position;\n\t\tlight.direction = normalize( lVector );\n\t\tfloat lightDistance = length( lVector );\n\t\tlight.color = pointLight.color;\n\t\tlight.color *= getDistanceAttenuation( lightDistance, pointLight.distance, pointLight.decay );\n\t\tlight.visible = ( light.color != vec3( 0.0 ) );\n\t}\n#endif\n#if NUM_SPOT_LIGHTS > 0\n\tstruct SpotLight {\n\t\tvec3 position;\n\t\tvec3 direction;\n\t\tvec3 color;\n\t\tfloat distance;\n\t\tfloat decay;\n\t\tfloat coneCos;\n\t\tfloat penumbraCos;\n\t};\n\tuniform SpotLight spotLights[ NUM_SPOT_LIGHTS ];\n\tvoid getSpotLightInfo( const in SpotLight spotLight, const in GeometricContext geometry, out IncidentLight light ) {\n\t\tvec3 lVector = spotLight.position - geometry.position;\n\t\tlight.direction = normalize( lVector );\n\t\tfloat angleCos = dot( light.direction, spotLight.direction );\n\t\tfloat spotAttenuation = getSpotAttenuation( spotLight.coneCos, spotLight.penumbraCos, angleCos );\n\t\tif ( spotAttenuation > 0.0 ) {\n\t\t\tfloat lightDistance = length( lVector );\n\t\t\tlight.color = spotLight.color * spotAttenuation;\n\t\t\tlight.color *= getDistanceAttenuation( lightDistance, spotLight.distance, spotLight.decay );\n\t\t\tlight.visible = ( light.color != vec3( 0.0 ) );\n\t\t} else {\n\t\t\tlight.color = vec3( 0.0 );\n\t\t\tlight.visible = false;\n\t\t}\n\t}\n#endif\n#if NUM_RECT_AREA_LIGHTS > 0\n\tstruct RectAreaLight {\n\t\tvec3 color;\n\t\tvec3 position;\n\t\tvec3 halfWidth;\n\t\tvec3 halfHeight;\n\t};\n\tuniform sampler2D ltc_1;\tuniform sampler2D ltc_2;\n\tuniform RectAreaLight rectAreaLights[ NUM_RECT_AREA_LIGHTS ];\n#endif\n#if NUM_HEMI_LIGHTS > 0\n\tstruct HemisphereLight {\n\t\tvec3 direction;\n\t\tvec3 skyColor;\n\t\tvec3 groundColor;\n\t};\n\tuniform HemisphereLight hemisphereLights[ NUM_HEMI_LIGHTS ];\n\tvec3 getHemisphereLightIrradiance( const in HemisphereLight hemiLight, const in vec3 normal ) {\n\t\tfloat dotNL = dot( normal, hemiLight.direction );\n\t\tfloat hemiDiffuseWeight = 0.5 * dotNL + 0.5;\n\t\tvec3 irradiance = mix( hemiLight.groundColor, hemiLight.skyColor, hemiDiffuseWeight );\n\t\treturn irradiance;\n\t}\n#endif",lights_toon_fragment:"ToonMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb;",lights_toon_pars_fragment:"varying vec3 vViewPosition;\nstruct ToonMaterial {\n\tvec3 diffuseColor;\n};\nvoid RE_Direct_Toon( const in IncidentLight directLight, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) {\n\tvec3 irradiance = getGradientIrradiance( geometry.normal, directLight.direction ) * directLight.color;\n\treflectedLight.directDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\n}\nvoid RE_IndirectDiffuse_Toon( const in vec3 irradiance, const in GeometricContext geometry, const in ToonMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\n}\n#define RE_Direct\t\t\t\tRE_Direct_Toon\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_Toon\n#define Material_LightProbeLOD( material )\t(0)",lights_phong_fragment:"BlinnPhongMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb;\nmaterial.specularColor = specular;\nmaterial.specularShininess = shininess;\nmaterial.specularStrength = specularStrength;",lights_phong_pars_fragment:"varying vec3 vViewPosition;\nstruct BlinnPhongMaterial {\n\tvec3 diffuseColor;\n\tvec3 specularColor;\n\tfloat specularShininess;\n\tfloat specularStrength;\n};\nvoid RE_Direct_BlinnPhong( const in IncidentLight directLight, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\n\tvec3 irradiance = dotNL * directLight.color;\n\treflectedLight.directDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\n\treflectedLight.directSpecular += irradiance * BRDF_BlinnPhong( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularShininess ) * material.specularStrength;\n}\nvoid RE_IndirectDiffuse_BlinnPhong( const in vec3 irradiance, const in GeometricContext geometry, const in BlinnPhongMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\n}\n#define RE_Direct\t\t\t\tRE_Direct_BlinnPhong\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_BlinnPhong\n#define Material_LightProbeLOD( material )\t(0)",lights_physical_fragment:"PhysicalMaterial material;\nmaterial.diffuseColor = diffuseColor.rgb * ( 1.0 - metalnessFactor );\nvec3 dxy = max( abs( dFdx( geometryNormal ) ), abs( dFdy( geometryNormal ) ) );\nfloat geometryRoughness = max( max( dxy.x, dxy.y ), dxy.z );\nmaterial.roughness = max( roughnessFactor, 0.0525 );material.roughness += geometryRoughness;\nmaterial.roughness = min( material.roughness, 1.0 );\n#ifdef IOR\n\t#ifdef SPECULAR\n\t\tfloat specularIntensityFactor = specularIntensity;\n\t\tvec3 specularColorFactor = specularColor;\n\t\t#ifdef USE_SPECULARINTENSITYMAP\n\t\t\tspecularIntensityFactor *= texture2D( specularIntensityMap, vUv ).a;\n\t\t#endif\n\t\t#ifdef USE_SPECULARCOLORMAP\n\t\t\tspecularColorFactor *= specularColorMapTexelToLinear( texture2D( specularColorMap, vUv ) ).rgb;\n\t\t#endif\n\t\tmaterial.specularF90 = mix( specularIntensityFactor, 1.0, metalnessFactor );\n\t#else\n\t\tfloat specularIntensityFactor = 1.0;\n\t\tvec3 specularColorFactor = vec3( 1.0 );\n\t\tmaterial.specularF90 = 1.0;\n\t#endif\n\tmaterial.specularColor = mix( min( pow2( ( ior - 1.0 ) / ( ior + 1.0 ) ) * specularColorFactor, vec3( 1.0 ) ) * specularIntensityFactor, diffuseColor.rgb, metalnessFactor );\n#else\n\tmaterial.specularColor = mix( vec3( 0.04 ), diffuseColor.rgb, metalnessFactor );\n\tmaterial.specularF90 = 1.0;\n#endif\n#ifdef USE_CLEARCOAT\n\tmaterial.clearcoat = clearcoat;\n\tmaterial.clearcoatRoughness = clearcoatRoughness;\n\tmaterial.clearcoatF0 = vec3( 0.04 );\n\tmaterial.clearcoatF90 = 1.0;\n\t#ifdef USE_CLEARCOATMAP\n\t\tmaterial.clearcoat *= texture2D( clearcoatMap, vUv ).x;\n\t#endif\n\t#ifdef USE_CLEARCOAT_ROUGHNESSMAP\n\t\tmaterial.clearcoatRoughness *= texture2D( clearcoatRoughnessMap, vUv ).y;\n\t#endif\n\tmaterial.clearcoat = saturate( material.clearcoat );\tmaterial.clearcoatRoughness = max( material.clearcoatRoughness, 0.0525 );\n\tmaterial.clearcoatRoughness += geometryRoughness;\n\tmaterial.clearcoatRoughness = min( material.clearcoatRoughness, 1.0 );\n#endif\n#ifdef USE_SHEEN\n\tmaterial.sheenColor = sheenColor;\n\t#ifdef USE_SHEENCOLORMAP\n\t\tmaterial.sheenColor *= sheenColorMapTexelToLinear( texture2D( sheenColorMap, vUv ) ).rgb;\n\t#endif\n\tmaterial.sheenRoughness = clamp( sheenRoughness, 0.07, 1.0 );\n\t#ifdef USE_SHEENROUGHNESSMAP\n\t\tmaterial.sheenRoughness *= texture2D( sheenRoughnessMap, vUv ).a;\n\t#endif\n#endif",lights_physical_pars_fragment:"struct PhysicalMaterial {\n\tvec3 diffuseColor;\n\tfloat roughness;\n\tvec3 specularColor;\n\tfloat specularF90;\n\t#ifdef USE_CLEARCOAT\n\t\tfloat clearcoat;\n\t\tfloat clearcoatRoughness;\n\t\tvec3 clearcoatF0;\n\t\tfloat clearcoatF90;\n\t#endif\n\t#ifdef USE_SHEEN\n\t\tvec3 sheenColor;\n\t\tfloat sheenRoughness;\n\t#endif\n};\nvec3 clearcoatSpecular = vec3( 0.0 );\nvec2 DFGApprox( const in vec3 normal, const in vec3 viewDir, const in float roughness ) {\n\tfloat dotNV = saturate( dot( normal, viewDir ) );\n\tconst vec4 c0 = vec4( - 1, - 0.0275, - 0.572, 0.022 );\n\tconst vec4 c1 = vec4( 1, 0.0425, 1.04, - 0.04 );\n\tvec4 r = roughness * c0 + c1;\n\tfloat a004 = min( r.x * r.x, exp2( - 9.28 * dotNV ) ) * r.x + r.y;\n\tvec2 fab = vec2( - 1.04, 1.04 ) * a004 + r.zw;\n\treturn fab;\n}\nvec3 EnvironmentBRDF( const in vec3 normal, const in vec3 viewDir, const in vec3 specularColor, const in float specularF90, const in float roughness ) {\n\tvec2 fab = DFGApprox( normal, viewDir, roughness );\n\treturn specularColor * fab.x + specularF90 * fab.y;\n}\nvoid computeMultiscattering( const in vec3 normal, const in vec3 viewDir, const in vec3 specularColor, const in float specularF90, const in float roughness, inout vec3 singleScatter, inout vec3 multiScatter ) {\n\tvec2 fab = DFGApprox( normal, viewDir, roughness );\n\tvec3 FssEss = specularColor * fab.x + specularF90 * fab.y;\n\tfloat Ess = fab.x + fab.y;\n\tfloat Ems = 1.0 - Ess;\n\tvec3 Favg = specularColor + ( 1.0 - specularColor ) * 0.047619;\tvec3 Fms = FssEss * Favg / ( 1.0 - Ems * Favg );\n\tsingleScatter += FssEss;\n\tmultiScatter += Fms * Ems;\n}\n#if NUM_RECT_AREA_LIGHTS > 0\n\tvoid RE_Direct_RectArea_Physical( const in RectAreaLight rectAreaLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\t\tvec3 normal = geometry.normal;\n\t\tvec3 viewDir = geometry.viewDir;\n\t\tvec3 position = geometry.position;\n\t\tvec3 lightPos = rectAreaLight.position;\n\t\tvec3 halfWidth = rectAreaLight.halfWidth;\n\t\tvec3 halfHeight = rectAreaLight.halfHeight;\n\t\tvec3 lightColor = rectAreaLight.color;\n\t\tfloat roughness = material.roughness;\n\t\tvec3 rectCoords[ 4 ];\n\t\trectCoords[ 0 ] = lightPos + halfWidth - halfHeight;\t\trectCoords[ 1 ] = lightPos - halfWidth - halfHeight;\n\t\trectCoords[ 2 ] = lightPos - halfWidth + halfHeight;\n\t\trectCoords[ 3 ] = lightPos + halfWidth + halfHeight;\n\t\tvec2 uv = LTC_Uv( normal, viewDir, roughness );\n\t\tvec4 t1 = texture2D( ltc_1, uv );\n\t\tvec4 t2 = texture2D( ltc_2, uv );\n\t\tmat3 mInv = mat3(\n\t\t\tvec3( t1.x, 0, t1.y ),\n\t\t\tvec3(\t\t0, 1,\t\t0 ),\n\t\t\tvec3( t1.z, 0, t1.w )\n\t\t);\n\t\tvec3 fresnel = ( material.specularColor * t2.x + ( vec3( 1.0 ) - material.specularColor ) * t2.y );\n\t\treflectedLight.directSpecular += lightColor * fresnel * LTC_Evaluate( normal, viewDir, position, mInv, rectCoords );\n\t\treflectedLight.directDiffuse += lightColor * material.diffuseColor * LTC_Evaluate( normal, viewDir, position, mat3( 1.0 ), rectCoords );\n\t}\n#endif\nvoid RE_Direct_Physical( const in IncidentLight directLight, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\tfloat dotNL = saturate( dot( geometry.normal, directLight.direction ) );\n\tvec3 irradiance = dotNL * directLight.color;\n\t#ifdef USE_CLEARCOAT\n\t\tfloat dotNLcc = saturate( dot( geometry.clearcoatNormal, directLight.direction ) );\n\t\tvec3 ccIrradiance = dotNLcc * directLight.color;\n\t\tclearcoatSpecular += ccIrradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.clearcoatNormal, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\n\t#endif\n\t#ifdef USE_SHEEN\n\t\treflectedLight.directSpecular += irradiance * BRDF_Sheen( directLight.direction, geometry.viewDir, geometry.normal, material.sheenColor, material.sheenRoughness );\n\t#endif\n\treflectedLight.directSpecular += irradiance * BRDF_GGX( directLight.direction, geometry.viewDir, geometry.normal, material.specularColor, material.specularF90, material.roughness );\n\treflectedLight.directDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\n}\nvoid RE_IndirectDiffuse_Physical( const in vec3 irradiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight ) {\n\treflectedLight.indirectDiffuse += irradiance * BRDF_Lambert( material.diffuseColor );\n}\nvoid RE_IndirectSpecular_Physical( const in vec3 radiance, const in vec3 irradiance, const in vec3 clearcoatRadiance, const in GeometricContext geometry, const in PhysicalMaterial material, inout ReflectedLight reflectedLight) {\n\t#ifdef USE_CLEARCOAT\n\t\tclearcoatSpecular += clearcoatRadiance * EnvironmentBRDF( geometry.clearcoatNormal, geometry.viewDir, material.clearcoatF0, material.clearcoatF90, material.clearcoatRoughness );\n\t#endif\n\tvec3 singleScattering = vec3( 0.0 );\n\tvec3 multiScattering = vec3( 0.0 );\n\tvec3 cosineWeightedIrradiance = irradiance * RECIPROCAL_PI;\n\tcomputeMultiscattering( geometry.normal, geometry.viewDir, material.specularColor, material.specularF90, material.roughness, singleScattering, multiScattering );\n\tvec3 diffuse = material.diffuseColor * ( 1.0 - ( singleScattering + multiScattering ) );\n\treflectedLight.indirectSpecular += radiance * singleScattering;\n\treflectedLight.indirectSpecular += multiScattering * cosineWeightedIrradiance;\n\treflectedLight.indirectDiffuse += diffuse * cosineWeightedIrradiance;\n}\n#define RE_Direct\t\t\t\tRE_Direct_Physical\n#define RE_Direct_RectArea\t\tRE_Direct_RectArea_Physical\n#define RE_IndirectDiffuse\t\tRE_IndirectDiffuse_Physical\n#define RE_IndirectSpecular\t\tRE_IndirectSpecular_Physical\nfloat computeSpecularOcclusion( const in float dotNV, const in float ambientOcclusion, const in float roughness ) {\n\treturn saturate( pow( dotNV + ambientOcclusion, exp2( - 16.0 * roughness - 1.0 ) ) - 1.0 + ambientOcclusion );\n}",lights_fragment_begin:"\nGeometricContext geometry;\ngeometry.position = - vViewPosition;\ngeometry.normal = normal;\ngeometry.viewDir = ( isOrthographic ) ? vec3( 0, 0, 1 ) : normalize( vViewPosition );\n#ifdef USE_CLEARCOAT\n\tgeometry.clearcoatNormal = clearcoatNormal;\n#endif\nIncidentLight directLight;\n#if ( NUM_POINT_LIGHTS > 0 ) && defined( RE_Direct )\n\tPointLight pointLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_POINT_LIGHT_SHADOWS > 0\n\tPointLightShadow pointLightShadow;\n\t#endif\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_POINT_LIGHTS; i ++ ) {\n\t\tpointLight = pointLights[ i ];\n\t\tgetPointLightInfo( pointLight, geometry, directLight );\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_POINT_LIGHT_SHADOWS )\n\t\tpointLightShadow = pointLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getPointShadow( pointShadowMap[ i ], pointLightShadow.shadowMapSize, pointLightShadow.shadowBias, pointLightShadow.shadowRadius, vPointShadowCoord[ i ], pointLightShadow.shadowCameraNear, pointLightShadow.shadowCameraFar ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if ( NUM_SPOT_LIGHTS > 0 ) && defined( RE_Direct )\n\tSpotLight spotLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_SPOT_LIGHT_SHADOWS > 0\n\tSpotLightShadow spotLightShadow;\n\t#endif\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_SPOT_LIGHTS; i ++ ) {\n\t\tspotLight = spotLights[ i ];\n\t\tgetSpotLightInfo( spotLight, geometry, directLight );\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_SPOT_LIGHT_SHADOWS )\n\t\tspotLightShadow = spotLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( spotShadowMap[ i ], spotLightShadow.shadowMapSize, spotLightShadow.shadowBias, spotLightShadow.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if ( NUM_DIR_LIGHTS > 0 ) && defined( RE_Direct )\n\tDirectionalLight directionalLight;\n\t#if defined( USE_SHADOWMAP ) && NUM_DIR_LIGHT_SHADOWS > 0\n\tDirectionalLightShadow directionalLightShadow;\n\t#endif\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_DIR_LIGHTS; i ++ ) {\n\t\tdirectionalLight = directionalLights[ i ];\n\t\tgetDirectionalLightInfo( directionalLight, geometry, directLight );\n\t\t#if defined( USE_SHADOWMAP ) && ( UNROLLED_LOOP_INDEX < NUM_DIR_LIGHT_SHADOWS )\n\t\tdirectionalLightShadow = directionalLightShadows[ i ];\n\t\tdirectLight.color *= all( bvec2( directLight.visible, receiveShadow ) ) ? getShadow( directionalShadowMap[ i ], directionalLightShadow.shadowMapSize, directionalLightShadow.shadowBias, directionalLightShadow.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t\t#endif\n\t\tRE_Direct( directLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if ( NUM_RECT_AREA_LIGHTS > 0 ) && defined( RE_Direct_RectArea )\n\tRectAreaLight rectAreaLight;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_RECT_AREA_LIGHTS; i ++ ) {\n\t\trectAreaLight = rectAreaLights[ i ];\n\t\tRE_Direct_RectArea( rectAreaLight, geometry, material, reflectedLight );\n\t}\n\t#pragma unroll_loop_end\n#endif\n#if defined( RE_IndirectDiffuse )\n\tvec3 iblIrradiance = vec3( 0.0 );\n\tvec3 irradiance = getAmbientLightIrradiance( ambientLightColor );\n\tirradiance += getLightProbeIrradiance( lightProbe, geometry.normal );\n\t#if ( NUM_HEMI_LIGHTS > 0 )\n\t\t#pragma unroll_loop_start\n\t\tfor ( int i = 0; i < NUM_HEMI_LIGHTS; i ++ ) {\n\t\t\tirradiance += getHemisphereLightIrradiance( hemisphereLights[ i ], geometry.normal );\n\t\t}\n\t\t#pragma unroll_loop_end\n\t#endif\n#endif\n#if defined( RE_IndirectSpecular )\n\tvec3 radiance = vec3( 0.0 );\n\tvec3 clearcoatRadiance = vec3( 0.0 );\n#endif",lights_fragment_maps:"#if defined( RE_IndirectDiffuse )\n\t#ifdef USE_LIGHTMAP\n\t\tvec4 lightMapTexel = texture2D( lightMap, vUv2 );\n\t\tvec3 lightMapIrradiance = lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n\t\t#ifndef PHYSICALLY_CORRECT_LIGHTS\n\t\t\tlightMapIrradiance *= PI;\n\t\t#endif\n\t\tirradiance += lightMapIrradiance;\n\t#endif\n\t#if defined( USE_ENVMAP ) && defined( STANDARD ) && defined( ENVMAP_TYPE_CUBE_UV )\n\t\tiblIrradiance += getIBLIrradiance( geometry.normal );\n\t#endif\n#endif\n#if defined( USE_ENVMAP ) && defined( RE_IndirectSpecular )\n\tradiance += getIBLRadiance( geometry.viewDir, geometry.normal, material.roughness );\n\t#ifdef USE_CLEARCOAT\n\t\tclearcoatRadiance += getIBLRadiance( geometry.viewDir, geometry.clearcoatNormal, material.clearcoatRoughness );\n\t#endif\n#endif",lights_fragment_end:"#if defined( RE_IndirectDiffuse )\n\tRE_IndirectDiffuse( irradiance, geometry, material, reflectedLight );\n#endif\n#if defined( RE_IndirectSpecular )\n\tRE_IndirectSpecular( radiance, iblIrradiance, clearcoatRadiance, geometry, material, reflectedLight );\n#endif",logdepthbuf_fragment:"#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\n\tgl_FragDepthEXT = vIsPerspective == 0.0 ? gl_FragCoord.z : log2( vFragDepth ) * logDepthBufFC * 0.5;\n#endif",logdepthbuf_pars_fragment:"#if defined( USE_LOGDEPTHBUF ) && defined( USE_LOGDEPTHBUF_EXT )\n\tuniform float logDepthBufFC;\n\tvarying float vFragDepth;\n\tvarying float vIsPerspective;\n#endif",logdepthbuf_pars_vertex:"#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvarying float vFragDepth;\n\t\tvarying float vIsPerspective;\n\t#else\n\t\tuniform float logDepthBufFC;\n\t#endif\n#endif",logdepthbuf_vertex:"#ifdef USE_LOGDEPTHBUF\n\t#ifdef USE_LOGDEPTHBUF_EXT\n\t\tvFragDepth = 1.0 + gl_Position.w;\n\t\tvIsPerspective = float( isPerspectiveMatrix( projectionMatrix ) );\n\t#else\n\t\tif ( isPerspectiveMatrix( projectionMatrix ) ) {\n\t\t\tgl_Position.z = log2( max( EPSILON, gl_Position.w + 1.0 ) ) * logDepthBufFC - 1.0;\n\t\t\tgl_Position.z *= gl_Position.w;\n\t\t}\n\t#endif\n#endif",map_fragment:"#ifdef USE_MAP\n\tvec4 texelColor = texture2D( map, vUv );\n\ttexelColor = mapTexelToLinear( texelColor );\n\tdiffuseColor *= texelColor;\n#endif",map_pars_fragment:"#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif",map_particle_fragment:"#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\n\tvec2 uv = ( uvTransform * vec3( gl_PointCoord.x, 1.0 - gl_PointCoord.y, 1 ) ).xy;\n#endif\n#ifdef USE_MAP\n\tvec4 mapTexel = texture2D( map, uv );\n\tdiffuseColor *= mapTexelToLinear( mapTexel );\n#endif\n#ifdef USE_ALPHAMAP\n\tdiffuseColor.a *= texture2D( alphaMap, uv ).g;\n#endif",map_particle_pars_fragment:"#if defined( USE_MAP ) || defined( USE_ALPHAMAP )\n\tuniform mat3 uvTransform;\n#endif\n#ifdef USE_MAP\n\tuniform sampler2D map;\n#endif\n#ifdef USE_ALPHAMAP\n\tuniform sampler2D alphaMap;\n#endif",metalnessmap_fragment:"float metalnessFactor = metalness;\n#ifdef USE_METALNESSMAP\n\tvec4 texelMetalness = texture2D( metalnessMap, vUv );\n\tmetalnessFactor *= texelMetalness.b;\n#endif",metalnessmap_pars_fragment:"#ifdef USE_METALNESSMAP\n\tuniform sampler2D metalnessMap;\n#endif",morphnormal_vertex:"#ifdef USE_MORPHNORMALS\n\tobjectNormal *= morphTargetBaseInfluence;\n\t#ifdef MORPHTARGETS_TEXTURE\n\t\tfor ( int i = 0; i < MORPHTARGETS_COUNT; i ++ ) {\n\t\t\tif ( morphTargetInfluences[ i ] > 0.0 ) objectNormal += getMorph( gl_VertexID, i, 1, 2 ) * morphTargetInfluences[ i ];\n\t\t}\n\t#else\n\t\tobjectNormal += morphNormal0 * morphTargetInfluences[ 0 ];\n\t\tobjectNormal += morphNormal1 * morphTargetInfluences[ 1 ];\n\t\tobjectNormal += morphNormal2 * morphTargetInfluences[ 2 ];\n\t\tobjectNormal += morphNormal3 * morphTargetInfluences[ 3 ];\n\t#endif\n#endif",morphtarget_pars_vertex:"#ifdef USE_MORPHTARGETS\n\tuniform float morphTargetBaseInfluence;\n\t#ifdef MORPHTARGETS_TEXTURE\n\t\tuniform float morphTargetInfluences[ MORPHTARGETS_COUNT ];\n\t\tuniform sampler2DArray morphTargetsTexture;\n\t\tuniform vec2 morphTargetsTextureSize;\n\t\tvec3 getMorph( const in int vertexIndex, const in int morphTargetIndex, const in int offset, const in int stride ) {\n\t\t\tfloat texelIndex = float( vertexIndex * stride + offset );\n\t\t\tfloat y = floor( texelIndex / morphTargetsTextureSize.x );\n\t\t\tfloat x = texelIndex - y * morphTargetsTextureSize.x;\n\t\t\tvec3 morphUV = vec3( ( x + 0.5 ) / morphTargetsTextureSize.x, y / morphTargetsTextureSize.y, morphTargetIndex );\n\t\t\treturn texture( morphTargetsTexture, morphUV ).xyz;\n\t\t}\n\t#else\n\t\t#ifndef USE_MORPHNORMALS\n\t\t\tuniform float morphTargetInfluences[ 8 ];\n\t\t#else\n\t\t\tuniform float morphTargetInfluences[ 4 ];\n\t\t#endif\n\t#endif\n#endif",morphtarget_vertex:"#ifdef USE_MORPHTARGETS\n\ttransformed *= morphTargetBaseInfluence;\n\t#ifdef MORPHTARGETS_TEXTURE\n\t\tfor ( int i = 0; i < MORPHTARGETS_COUNT; i ++ ) {\n\t\t\t#ifndef USE_MORPHNORMALS\n\t\t\t\tif ( morphTargetInfluences[ i ] > 0.0 ) transformed += getMorph( gl_VertexID, i, 0, 1 ) * morphTargetInfluences[ i ];\n\t\t\t#else\n\t\t\t\tif ( morphTargetInfluences[ i ] > 0.0 ) transformed += getMorph( gl_VertexID, i, 0, 2 ) * morphTargetInfluences[ i ];\n\t\t\t#endif\n\t\t}\n\t#else\n\t\ttransformed += morphTarget0 * morphTargetInfluences[ 0 ];\n\t\ttransformed += morphTarget1 * morphTargetInfluences[ 1 ];\n\t\ttransformed += morphTarget2 * morphTargetInfluences[ 2 ];\n\t\ttransformed += morphTarget3 * morphTargetInfluences[ 3 ];\n\t\t#ifndef USE_MORPHNORMALS\n\t\t\ttransformed += morphTarget4 * morphTargetInfluences[ 4 ];\n\t\t\ttransformed += morphTarget5 * morphTargetInfluences[ 5 ];\n\t\t\ttransformed += morphTarget6 * morphTargetInfluences[ 6 ];\n\t\t\ttransformed += morphTarget7 * morphTargetInfluences[ 7 ];\n\t\t#endif\n\t#endif\n#endif",normal_fragment_begin:"float faceDirection = gl_FrontFacing ? 1.0 : - 1.0;\n#ifdef FLAT_SHADED\n\tvec3 fdx = vec3( dFdx( vViewPosition.x ), dFdx( vViewPosition.y ), dFdx( vViewPosition.z ) );\n\tvec3 fdy = vec3( dFdy( vViewPosition.x ), dFdy( vViewPosition.y ), dFdy( vViewPosition.z ) );\n\tvec3 normal = normalize( cross( fdx, fdy ) );\n#else\n\tvec3 normal = normalize( vNormal );\n\t#ifdef DOUBLE_SIDED\n\t\tnormal = normal * faceDirection;\n\t#endif\n\t#ifdef USE_TANGENT\n\t\tvec3 tangent = normalize( vTangent );\n\t\tvec3 bitangent = normalize( vBitangent );\n\t\t#ifdef DOUBLE_SIDED\n\t\t\ttangent = tangent * faceDirection;\n\t\t\tbitangent = bitangent * faceDirection;\n\t\t#endif\n\t\t#if defined( TANGENTSPACE_NORMALMAP ) || defined( USE_CLEARCOAT_NORMALMAP )\n\t\t\tmat3 vTBN = mat3( tangent, bitangent, normal );\n\t\t#endif\n\t#endif\n#endif\nvec3 geometryNormal = normal;",normal_fragment_maps:"#ifdef OBJECTSPACE_NORMALMAP\n\tnormal = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\t#ifdef FLIP_SIDED\n\t\tnormal = - normal;\n\t#endif\n\t#ifdef DOUBLE_SIDED\n\t\tnormal = normal * faceDirection;\n\t#endif\n\tnormal = normalize( normalMatrix * normal );\n#elif defined( TANGENTSPACE_NORMALMAP )\n\tvec3 mapN = texture2D( normalMap, vUv ).xyz * 2.0 - 1.0;\n\tmapN.xy *= normalScale;\n\t#ifdef USE_TANGENT\n\t\tnormal = normalize( vTBN * mapN );\n\t#else\n\t\tnormal = perturbNormal2Arb( - vViewPosition, normal, mapN, faceDirection );\n\t#endif\n#elif defined( USE_BUMPMAP )\n\tnormal = perturbNormalArb( - vViewPosition, normal, dHdxy_fwd(), faceDirection );\n#endif",normal_pars_fragment:"#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif",normal_pars_vertex:"#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n\t#ifdef USE_TANGENT\n\t\tvarying vec3 vTangent;\n\t\tvarying vec3 vBitangent;\n\t#endif\n#endif",normal_vertex:"#ifndef FLAT_SHADED\n\tvNormal = normalize( transformedNormal );\n\t#ifdef USE_TANGENT\n\t\tvTangent = normalize( transformedTangent );\n\t\tvBitangent = normalize( cross( vNormal, vTangent ) * tangent.w );\n\t#endif\n#endif",normalmap_pars_fragment:"#ifdef USE_NORMALMAP\n\tuniform sampler2D normalMap;\n\tuniform vec2 normalScale;\n#endif\n#ifdef OBJECTSPACE_NORMALMAP\n\tuniform mat3 normalMatrix;\n#endif\n#if ! defined ( USE_TANGENT ) && ( defined ( TANGENTSPACE_NORMALMAP ) || defined ( USE_CLEARCOAT_NORMALMAP ) )\n\tvec3 perturbNormal2Arb( vec3 eye_pos, vec3 surf_norm, vec3 mapN, float faceDirection ) {\n\t\tvec3 q0 = vec3( dFdx( eye_pos.x ), dFdx( eye_pos.y ), dFdx( eye_pos.z ) );\n\t\tvec3 q1 = vec3( dFdy( eye_pos.x ), dFdy( eye_pos.y ), dFdy( eye_pos.z ) );\n\t\tvec2 st0 = dFdx( vUv.st );\n\t\tvec2 st1 = dFdy( vUv.st );\n\t\tvec3 N = surf_norm;\n\t\tvec3 q1perp = cross( q1, N );\n\t\tvec3 q0perp = cross( N, q0 );\n\t\tvec3 T = q1perp * st0.x + q0perp * st1.x;\n\t\tvec3 B = q1perp * st0.y + q0perp * st1.y;\n\t\tfloat det = max( dot( T, T ), dot( B, B ) );\n\t\tfloat scale = ( det == 0.0 ) ? 0.0 : faceDirection * inversesqrt( det );\n\t\treturn normalize( T * ( mapN.x * scale ) + B * ( mapN.y * scale ) + N * mapN.z );\n\t}\n#endif",clearcoat_normal_fragment_begin:"#ifdef USE_CLEARCOAT\n\tvec3 clearcoatNormal = geometryNormal;\n#endif",clearcoat_normal_fragment_maps:"#ifdef USE_CLEARCOAT_NORMALMAP\n\tvec3 clearcoatMapN = texture2D( clearcoatNormalMap, vUv ).xyz * 2.0 - 1.0;\n\tclearcoatMapN.xy *= clearcoatNormalScale;\n\t#ifdef USE_TANGENT\n\t\tclearcoatNormal = normalize( vTBN * clearcoatMapN );\n\t#else\n\t\tclearcoatNormal = perturbNormal2Arb( - vViewPosition, clearcoatNormal, clearcoatMapN, faceDirection );\n\t#endif\n#endif",clearcoat_pars_fragment:"#ifdef USE_CLEARCOATMAP\n\tuniform sampler2D clearcoatMap;\n#endif\n#ifdef USE_CLEARCOAT_ROUGHNESSMAP\n\tuniform sampler2D clearcoatRoughnessMap;\n#endif\n#ifdef USE_CLEARCOAT_NORMALMAP\n\tuniform sampler2D clearcoatNormalMap;\n\tuniform vec2 clearcoatNormalScale;\n#endif",output_fragment:"#ifdef OPAQUE\ndiffuseColor.a = 1.0;\n#endif\n#ifdef USE_TRANSMISSION\ndiffuseColor.a *= transmissionAlpha + 0.1;\n#endif\ngl_FragColor = vec4( outgoingLight, diffuseColor.a );",packing:"vec3 packNormalToRGB( const in vec3 normal ) {\n\treturn normalize( normal ) * 0.5 + 0.5;\n}\nvec3 unpackRGBToNormal( const in vec3 rgb ) {\n\treturn 2.0 * rgb.xyz - 1.0;\n}\nconst float PackUpscale = 256. / 255.;const float UnpackDownscale = 255. / 256.;\nconst vec3 PackFactors = vec3( 256. * 256. * 256., 256. * 256., 256. );\nconst vec4 UnpackFactors = UnpackDownscale / vec4( PackFactors, 1. );\nconst float ShiftRight8 = 1. / 256.;\nvec4 packDepthToRGBA( const in float v ) {\n\tvec4 r = vec4( fract( v * PackFactors ), v );\n\tr.yzw -= r.xyz * ShiftRight8;\treturn r * PackUpscale;\n}\nfloat unpackRGBAToDepth( const in vec4 v ) {\n\treturn dot( v, UnpackFactors );\n}\nvec4 pack2HalfToRGBA( vec2 v ) {\n\tvec4 r = vec4( v.x, fract( v.x * 255.0 ), v.y, fract( v.y * 255.0 ) );\n\treturn vec4( r.x - r.y / 255.0, r.y, r.z - r.w / 255.0, r.w );\n}\nvec2 unpackRGBATo2Half( vec4 v ) {\n\treturn vec2( v.x + ( v.y / 255.0 ), v.z + ( v.w / 255.0 ) );\n}\nfloat viewZToOrthographicDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn ( viewZ + near ) / ( near - far );\n}\nfloat orthographicDepthToViewZ( const in float linearClipZ, const in float near, const in float far ) {\n\treturn linearClipZ * ( near - far ) - near;\n}\nfloat viewZToPerspectiveDepth( const in float viewZ, const in float near, const in float far ) {\n\treturn ( ( near + viewZ ) * far ) / ( ( far - near ) * viewZ );\n}\nfloat perspectiveDepthToViewZ( const in float invClipZ, const in float near, const in float far ) {\n\treturn ( near * far ) / ( ( far - near ) * invClipZ - far );\n}",premultiplied_alpha_fragment:"#ifdef PREMULTIPLIED_ALPHA\n\tgl_FragColor.rgb *= gl_FragColor.a;\n#endif",project_vertex:"vec4 mvPosition = vec4( transformed, 1.0 );\n#ifdef USE_INSTANCING\n\tmvPosition = instanceMatrix * mvPosition;\n#endif\nmvPosition = modelViewMatrix * mvPosition;\ngl_Position = projectionMatrix * mvPosition;",dithering_fragment:"#ifdef DITHERING\n\tgl_FragColor.rgb = dithering( gl_FragColor.rgb );\n#endif",dithering_pars_fragment:"#ifdef DITHERING\n\tvec3 dithering( vec3 color ) {\n\t\tfloat grid_position = rand( gl_FragCoord.xy );\n\t\tvec3 dither_shift_RGB = vec3( 0.25 / 255.0, -0.25 / 255.0, 0.25 / 255.0 );\n\t\tdither_shift_RGB = mix( 2.0 * dither_shift_RGB, -2.0 * dither_shift_RGB, grid_position );\n\t\treturn color + dither_shift_RGB;\n\t}\n#endif",roughnessmap_fragment:"float roughnessFactor = roughness;\n#ifdef USE_ROUGHNESSMAP\n\tvec4 texelRoughness = texture2D( roughnessMap, vUv );\n\troughnessFactor *= texelRoughness.g;\n#endif",roughnessmap_pars_fragment:"#ifdef USE_ROUGHNESSMAP\n\tuniform sampler2D roughnessMap;\n#endif",shadowmap_pars_fragment:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0\n\t\tuniform sampler2D directionalShadowMap[ NUM_DIR_LIGHT_SHADOWS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\n\t\tstruct DirectionalLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\n\t\t\tfloat shadowRadius;\n\t\t\tvec2 shadowMapSize;\n\t\t};\n\t\tuniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];\n\t#endif\n\t#if NUM_SPOT_LIGHT_SHADOWS > 0\n\t\tuniform sampler2D spotShadowMap[ NUM_SPOT_LIGHT_SHADOWS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ];\n\t\tstruct SpotLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\n\t\t\tfloat shadowRadius;\n\t\t\tvec2 shadowMapSize;\n\t\t};\n\t\tuniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];\n\t#endif\n\t#if NUM_POINT_LIGHT_SHADOWS > 0\n\t\tuniform sampler2D pointShadowMap[ NUM_POINT_LIGHT_SHADOWS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ];\n\t\tstruct PointLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\n\t\t\tfloat shadowRadius;\n\t\t\tvec2 shadowMapSize;\n\t\t\tfloat shadowCameraNear;\n\t\t\tfloat shadowCameraFar;\n\t\t};\n\t\tuniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];\n\t#endif\n\tfloat texture2DCompare( sampler2D depths, vec2 uv, float compare ) {\n\t\treturn step( compare, unpackRGBAToDepth( texture2D( depths, uv ) ) );\n\t}\n\tvec2 texture2DDistribution( sampler2D shadow, vec2 uv ) {\n\t\treturn unpackRGBATo2Half( texture2D( shadow, uv ) );\n\t}\n\tfloat VSMShadow (sampler2D shadow, vec2 uv, float compare ){\n\t\tfloat occlusion = 1.0;\n\t\tvec2 distribution = texture2DDistribution( shadow, uv );\n\t\tfloat hard_shadow = step( compare , distribution.x );\n\t\tif (hard_shadow != 1.0 ) {\n\t\t\tfloat distance = compare - distribution.x ;\n\t\t\tfloat variance = max( 0.00000, distribution.y * distribution.y );\n\t\t\tfloat softness_probability = variance / (variance + distance * distance );\t\t\tsoftness_probability = clamp( ( softness_probability - 0.3 ) / ( 0.95 - 0.3 ), 0.0, 1.0 );\t\t\tocclusion = clamp( max( hard_shadow, softness_probability ), 0.0, 1.0 );\n\t\t}\n\t\treturn occlusion;\n\t}\n\tfloat getShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord ) {\n\t\tfloat shadow = 1.0;\n\t\tshadowCoord.xyz /= shadowCoord.w;\n\t\tshadowCoord.z += shadowBias;\n\t\tbvec4 inFrustumVec = bvec4 ( shadowCoord.x >= 0.0, shadowCoord.x <= 1.0, shadowCoord.y >= 0.0, shadowCoord.y <= 1.0 );\n\t\tbool inFrustum = all( inFrustumVec );\n\t\tbvec2 frustumTestVec = bvec2( inFrustum, shadowCoord.z <= 1.0 );\n\t\tbool frustumTest = all( frustumTestVec );\n\t\tif ( frustumTest ) {\n\t\t#if defined( SHADOWMAP_TYPE_PCF )\n\t\t\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx0 = - texelSize.x * shadowRadius;\n\t\t\tfloat dy0 = - texelSize.y * shadowRadius;\n\t\t\tfloat dx1 = + texelSize.x * shadowRadius;\n\t\t\tfloat dy1 = + texelSize.y * shadowRadius;\n\t\t\tfloat dx2 = dx0 / 2.0;\n\t\t\tfloat dy2 = dy0 / 2.0;\n\t\t\tfloat dx3 = dx1 / 2.0;\n\t\t\tfloat dy3 = dy1 / 2.0;\n\t\t\tshadow = (\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy2 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy2 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy2 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx2, dy3 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy3 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx3, dy3 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( 0.0, dy1 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, shadowCoord.xy + vec2( dx1, dy1 ), shadowCoord.z )\n\t\t\t) * ( 1.0 / 17.0 );\n\t\t#elif defined( SHADOWMAP_TYPE_PCF_SOFT )\n\t\t\tvec2 texelSize = vec2( 1.0 ) / shadowMapSize;\n\t\t\tfloat dx = texelSize.x;\n\t\t\tfloat dy = texelSize.y;\n\t\t\tvec2 uv = shadowCoord.xy;\n\t\t\tvec2 f = fract( uv * shadowMapSize + 0.5 );\n\t\t\tuv -= f * texelSize;\n\t\t\tshadow = (\n\t\t\t\ttexture2DCompare( shadowMap, uv, shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, uv + vec2( dx, 0.0 ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, uv + vec2( 0.0, dy ), shadowCoord.z ) +\n\t\t\t\ttexture2DCompare( shadowMap, uv + texelSize, shadowCoord.z ) +\n\t\t\t\tmix( texture2DCompare( shadowMap, uv + vec2( -dx, 0.0 ), shadowCoord.z ), \n\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 0.0 ), shadowCoord.z ),\n\t\t\t\t\t f.x ) +\n\t\t\t\tmix( texture2DCompare( shadowMap, uv + vec2( -dx, dy ), shadowCoord.z ), \n\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( 2.0 * dx, dy ), shadowCoord.z ),\n\t\t\t\t\t f.x ) +\n\t\t\t\tmix( texture2DCompare( shadowMap, uv + vec2( 0.0, -dy ), shadowCoord.z ), \n\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( 0.0, 2.0 * dy ), shadowCoord.z ),\n\t\t\t\t\t f.y ) +\n\t\t\t\tmix( texture2DCompare( shadowMap, uv + vec2( dx, -dy ), shadowCoord.z ), \n\t\t\t\t\t texture2DCompare( shadowMap, uv + vec2( dx, 2.0 * dy ), shadowCoord.z ),\n\t\t\t\t\t f.y ) +\n\t\t\t\tmix( mix( texture2DCompare( shadowMap, uv + vec2( -dx, -dy ), shadowCoord.z ), \n\t\t\t\t\t\t\ttexture2DCompare( shadowMap, uv + vec2( 2.0 * dx, -dy ), shadowCoord.z ),\n\t\t\t\t\t\t\tf.x ),\n\t\t\t\t\t mix( texture2DCompare( shadowMap, uv + vec2( -dx, 2.0 * dy ), shadowCoord.z ), \n\t\t\t\t\t\t\ttexture2DCompare( shadowMap, uv + vec2( 2.0 * dx, 2.0 * dy ), shadowCoord.z ),\n\t\t\t\t\t\t\tf.x ),\n\t\t\t\t\t f.y )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#elif defined( SHADOWMAP_TYPE_VSM )\n\t\t\tshadow = VSMShadow( shadowMap, shadowCoord.xy, shadowCoord.z );\n\t\t#else\n\t\t\tshadow = texture2DCompare( shadowMap, shadowCoord.xy, shadowCoord.z );\n\t\t#endif\n\t\t}\n\t\treturn shadow;\n\t}\n\tvec2 cubeToUV( vec3 v, float texelSizeY ) {\n\t\tvec3 absV = abs( v );\n\t\tfloat scaleToCube = 1.0 / max( absV.x, max( absV.y, absV.z ) );\n\t\tabsV *= scaleToCube;\n\t\tv *= scaleToCube * ( 1.0 - 2.0 * texelSizeY );\n\t\tvec2 planar = v.xy;\n\t\tfloat almostATexel = 1.5 * texelSizeY;\n\t\tfloat almostOne = 1.0 - almostATexel;\n\t\tif ( absV.z >= almostOne ) {\n\t\t\tif ( v.z > 0.0 )\n\t\t\t\tplanar.x = 4.0 - v.x;\n\t\t} else if ( absV.x >= almostOne ) {\n\t\t\tfloat signX = sign( v.x );\n\t\t\tplanar.x = v.z * signX + 2.0 * signX;\n\t\t} else if ( absV.y >= almostOne ) {\n\t\t\tfloat signY = sign( v.y );\n\t\t\tplanar.x = v.x + 2.0 * signY + 2.0;\n\t\t\tplanar.y = v.z * signY - 2.0;\n\t\t}\n\t\treturn vec2( 0.125, 0.25 ) * planar + vec2( 0.375, 0.75 );\n\t}\n\tfloat getPointShadow( sampler2D shadowMap, vec2 shadowMapSize, float shadowBias, float shadowRadius, vec4 shadowCoord, float shadowCameraNear, float shadowCameraFar ) {\n\t\tvec2 texelSize = vec2( 1.0 ) / ( shadowMapSize * vec2( 4.0, 2.0 ) );\n\t\tvec3 lightToPosition = shadowCoord.xyz;\n\t\tfloat dp = ( length( lightToPosition ) - shadowCameraNear ) / ( shadowCameraFar - shadowCameraNear );\t\tdp += shadowBias;\n\t\tvec3 bd3D = normalize( lightToPosition );\n\t\t#if defined( SHADOWMAP_TYPE_PCF ) || defined( SHADOWMAP_TYPE_PCF_SOFT ) || defined( SHADOWMAP_TYPE_VSM )\n\t\t\tvec2 offset = vec2( - 1, 1 ) * shadowRadius * texelSize.y;\n\t\t\treturn (\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yyx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxy, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.xxx, texelSize.y ), dp ) +\n\t\t\t\ttexture2DCompare( shadowMap, cubeToUV( bd3D + offset.yxx, texelSize.y ), dp )\n\t\t\t) * ( 1.0 / 9.0 );\n\t\t#else\n\t\t\treturn texture2DCompare( shadowMap, cubeToUV( bd3D, texelSize.y ), dp );\n\t\t#endif\n\t}\n#endif",shadowmap_pars_vertex:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0\n\t\tuniform mat4 directionalShadowMatrix[ NUM_DIR_LIGHT_SHADOWS ];\n\t\tvarying vec4 vDirectionalShadowCoord[ NUM_DIR_LIGHT_SHADOWS ];\n\t\tstruct DirectionalLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\n\t\t\tfloat shadowRadius;\n\t\t\tvec2 shadowMapSize;\n\t\t};\n\t\tuniform DirectionalLightShadow directionalLightShadows[ NUM_DIR_LIGHT_SHADOWS ];\n\t#endif\n\t#if NUM_SPOT_LIGHT_SHADOWS > 0\n\t\tuniform mat4 spotShadowMatrix[ NUM_SPOT_LIGHT_SHADOWS ];\n\t\tvarying vec4 vSpotShadowCoord[ NUM_SPOT_LIGHT_SHADOWS ];\n\t\tstruct SpotLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\n\t\t\tfloat shadowRadius;\n\t\t\tvec2 shadowMapSize;\n\t\t};\n\t\tuniform SpotLightShadow spotLightShadows[ NUM_SPOT_LIGHT_SHADOWS ];\n\t#endif\n\t#if NUM_POINT_LIGHT_SHADOWS > 0\n\t\tuniform mat4 pointShadowMatrix[ NUM_POINT_LIGHT_SHADOWS ];\n\t\tvarying vec4 vPointShadowCoord[ NUM_POINT_LIGHT_SHADOWS ];\n\t\tstruct PointLightShadow {\n\t\t\tfloat shadowBias;\n\t\t\tfloat shadowNormalBias;\n\t\t\tfloat shadowRadius;\n\t\t\tvec2 shadowMapSize;\n\t\t\tfloat shadowCameraNear;\n\t\t\tfloat shadowCameraFar;\n\t\t};\n\t\tuniform PointLightShadow pointLightShadows[ NUM_POINT_LIGHT_SHADOWS ];\n\t#endif\n#endif",shadowmap_vertex:"#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0 || NUM_SPOT_LIGHT_SHADOWS > 0 || NUM_POINT_LIGHT_SHADOWS > 0\n\t\tvec3 shadowWorldNormal = inverseTransformDirection( transformedNormal, viewMatrix );\n\t\tvec4 shadowWorldPosition;\n\t#endif\n\t#if NUM_DIR_LIGHT_SHADOWS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) {\n\t\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * directionalLightShadows[ i ].shadowNormalBias, 0 );\n\t\tvDirectionalShadowCoord[ i ] = directionalShadowMatrix[ i ] * shadowWorldPosition;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#if NUM_SPOT_LIGHT_SHADOWS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) {\n\t\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * spotLightShadows[ i ].shadowNormalBias, 0 );\n\t\tvSpotShadowCoord[ i ] = spotShadowMatrix[ i ] * shadowWorldPosition;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#if NUM_POINT_LIGHT_SHADOWS > 0\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) {\n\t\tshadowWorldPosition = worldPosition + vec4( shadowWorldNormal * pointLightShadows[ i ].shadowNormalBias, 0 );\n\t\tvPointShadowCoord[ i ] = pointShadowMatrix[ i ] * shadowWorldPosition;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n#endif",shadowmask_pars_fragment:"float getShadowMask() {\n\tfloat shadow = 1.0;\n\t#ifdef USE_SHADOWMAP\n\t#if NUM_DIR_LIGHT_SHADOWS > 0\n\tDirectionalLightShadow directionalLight;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_DIR_LIGHT_SHADOWS; i ++ ) {\n\t\tdirectionalLight = directionalLightShadows[ i ];\n\t\tshadow *= receiveShadow ? getShadow( directionalShadowMap[ i ], directionalLight.shadowMapSize, directionalLight.shadowBias, directionalLight.shadowRadius, vDirectionalShadowCoord[ i ] ) : 1.0;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#if NUM_SPOT_LIGHT_SHADOWS > 0\n\tSpotLightShadow spotLight;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_SPOT_LIGHT_SHADOWS; i ++ ) {\n\t\tspotLight = spotLightShadows[ i ];\n\t\tshadow *= receiveShadow ? getShadow( spotShadowMap[ i ], spotLight.shadowMapSize, spotLight.shadowBias, spotLight.shadowRadius, vSpotShadowCoord[ i ] ) : 1.0;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#if NUM_POINT_LIGHT_SHADOWS > 0\n\tPointLightShadow pointLight;\n\t#pragma unroll_loop_start\n\tfor ( int i = 0; i < NUM_POINT_LIGHT_SHADOWS; i ++ ) {\n\t\tpointLight = pointLightShadows[ i ];\n\t\tshadow *= receiveShadow ? getPointShadow( pointShadowMap[ i ], pointLight.shadowMapSize, pointLight.shadowBias, pointLight.shadowRadius, vPointShadowCoord[ i ], pointLight.shadowCameraNear, pointLight.shadowCameraFar ) : 1.0;\n\t}\n\t#pragma unroll_loop_end\n\t#endif\n\t#endif\n\treturn shadow;\n}",skinbase_vertex:"#ifdef USE_SKINNING\n\tmat4 boneMatX = getBoneMatrix( skinIndex.x );\n\tmat4 boneMatY = getBoneMatrix( skinIndex.y );\n\tmat4 boneMatZ = getBoneMatrix( skinIndex.z );\n\tmat4 boneMatW = getBoneMatrix( skinIndex.w );\n#endif",skinning_pars_vertex:"#ifdef USE_SKINNING\n\tuniform mat4 bindMatrix;\n\tuniform mat4 bindMatrixInverse;\n\t#ifdef BONE_TEXTURE\n\t\tuniform highp sampler2D boneTexture;\n\t\tuniform int boneTextureSize;\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tfloat j = i * 4.0;\n\t\t\tfloat x = mod( j, float( boneTextureSize ) );\n\t\t\tfloat y = floor( j / float( boneTextureSize ) );\n\t\t\tfloat dx = 1.0 / float( boneTextureSize );\n\t\t\tfloat dy = 1.0 / float( boneTextureSize );\n\t\t\ty = dy * ( y + 0.5 );\n\t\t\tvec4 v1 = texture2D( boneTexture, vec2( dx * ( x + 0.5 ), y ) );\n\t\t\tvec4 v2 = texture2D( boneTexture, vec2( dx * ( x + 1.5 ), y ) );\n\t\t\tvec4 v3 = texture2D( boneTexture, vec2( dx * ( x + 2.5 ), y ) );\n\t\t\tvec4 v4 = texture2D( boneTexture, vec2( dx * ( x + 3.5 ), y ) );\n\t\t\tmat4 bone = mat4( v1, v2, v3, v4 );\n\t\t\treturn bone;\n\t\t}\n\t#else\n\t\tuniform mat4 boneMatrices[ MAX_BONES ];\n\t\tmat4 getBoneMatrix( const in float i ) {\n\t\t\tmat4 bone = boneMatrices[ int(i) ];\n\t\t\treturn bone;\n\t\t}\n\t#endif\n#endif",skinning_vertex:"#ifdef USE_SKINNING\n\tvec4 skinVertex = bindMatrix * vec4( transformed, 1.0 );\n\tvec4 skinned = vec4( 0.0 );\n\tskinned += boneMatX * skinVertex * skinWeight.x;\n\tskinned += boneMatY * skinVertex * skinWeight.y;\n\tskinned += boneMatZ * skinVertex * skinWeight.z;\n\tskinned += boneMatW * skinVertex * skinWeight.w;\n\ttransformed = ( bindMatrixInverse * skinned ).xyz;\n#endif",skinnormal_vertex:"#ifdef USE_SKINNING\n\tmat4 skinMatrix = mat4( 0.0 );\n\tskinMatrix += skinWeight.x * boneMatX;\n\tskinMatrix += skinWeight.y * boneMatY;\n\tskinMatrix += skinWeight.z * boneMatZ;\n\tskinMatrix += skinWeight.w * boneMatW;\n\tskinMatrix = bindMatrixInverse * skinMatrix * bindMatrix;\n\tobjectNormal = vec4( skinMatrix * vec4( objectNormal, 0.0 ) ).xyz;\n\t#ifdef USE_TANGENT\n\t\tobjectTangent = vec4( skinMatrix * vec4( objectTangent, 0.0 ) ).xyz;\n\t#endif\n#endif",specularmap_fragment:"float specularStrength;\n#ifdef USE_SPECULARMAP\n\tvec4 texelSpecular = texture2D( specularMap, vUv );\n\tspecularStrength = texelSpecular.r;\n#else\n\tspecularStrength = 1.0;\n#endif",specularmap_pars_fragment:"#ifdef USE_SPECULARMAP\n\tuniform sampler2D specularMap;\n#endif",tonemapping_fragment:"#if defined( TONE_MAPPING )\n\tgl_FragColor.rgb = toneMapping( gl_FragColor.rgb );\n#endif",tonemapping_pars_fragment:"#ifndef saturate\n#define saturate( a ) clamp( a, 0.0, 1.0 )\n#endif\nuniform float toneMappingExposure;\nvec3 LinearToneMapping( vec3 color ) {\n\treturn toneMappingExposure * color;\n}\nvec3 ReinhardToneMapping( vec3 color ) {\n\tcolor *= toneMappingExposure;\n\treturn saturate( color / ( vec3( 1.0 ) + color ) );\n}\nvec3 OptimizedCineonToneMapping( vec3 color ) {\n\tcolor *= toneMappingExposure;\n\tcolor = max( vec3( 0.0 ), color - 0.004 );\n\treturn pow( ( color * ( 6.2 * color + 0.5 ) ) / ( color * ( 6.2 * color + 1.7 ) + 0.06 ), vec3( 2.2 ) );\n}\nvec3 RRTAndODTFit( vec3 v ) {\n\tvec3 a = v * ( v + 0.0245786 ) - 0.000090537;\n\tvec3 b = v * ( 0.983729 * v + 0.4329510 ) + 0.238081;\n\treturn a / b;\n}\nvec3 ACESFilmicToneMapping( vec3 color ) {\n\tconst mat3 ACESInputMat = mat3(\n\t\tvec3( 0.59719, 0.07600, 0.02840 ),\t\tvec3( 0.35458, 0.90834, 0.13383 ),\n\t\tvec3( 0.04823, 0.01566, 0.83777 )\n\t);\n\tconst mat3 ACESOutputMat = mat3(\n\t\tvec3(\t1.60475, -0.10208, -0.00327 ),\t\tvec3( -0.53108,\t1.10813, -0.07276 ),\n\t\tvec3( -0.07367, -0.00605,\t1.07602 )\n\t);\n\tcolor *= toneMappingExposure / 0.6;\n\tcolor = ACESInputMat * color;\n\tcolor = RRTAndODTFit( color );\n\tcolor = ACESOutputMat * color;\n\treturn saturate( color );\n}\nvec3 CustomToneMapping( vec3 color ) { return color; }",transmission_fragment:"#ifdef USE_TRANSMISSION\n\tfloat transmissionAlpha = 1.0;\n\tfloat transmissionFactor = transmission;\n\tfloat thicknessFactor = thickness;\n\t#ifdef USE_TRANSMISSIONMAP\n\t\ttransmissionFactor *= texture2D( transmissionMap, vUv ).r;\n\t#endif\n\t#ifdef USE_THICKNESSMAP\n\t\tthicknessFactor *= texture2D( thicknessMap, vUv ).g;\n\t#endif\n\tvec3 pos = vWorldPosition;\n\tvec3 v = normalize( cameraPosition - pos );\n\tvec3 n = inverseTransformDirection( normal, viewMatrix );\n\tvec4 transmission = getIBLVolumeRefraction(\n\t\tn, v, roughnessFactor, material.diffuseColor, material.specularColor, material.specularF90,\n\t\tpos, modelMatrix, viewMatrix, projectionMatrix, ior, thicknessFactor,\n\t\tattenuationColor, attenuationDistance );\n\ttotalDiffuse = mix( totalDiffuse, transmission.rgb, transmissionFactor );\n\ttransmissionAlpha = mix( transmissionAlpha, transmission.a, transmissionFactor );\n#endif",transmission_pars_fragment:"#ifdef USE_TRANSMISSION\n\tuniform float transmission;\n\tuniform float thickness;\n\tuniform float attenuationDistance;\n\tuniform vec3 attenuationColor;\n\t#ifdef USE_TRANSMISSIONMAP\n\t\tuniform sampler2D transmissionMap;\n\t#endif\n\t#ifdef USE_THICKNESSMAP\n\t\tuniform sampler2D thicknessMap;\n\t#endif\n\tuniform vec2 transmissionSamplerSize;\n\tuniform sampler2D transmissionSamplerMap;\n\tuniform mat4 modelMatrix;\n\tuniform mat4 projectionMatrix;\n\tvarying vec3 vWorldPosition;\n\tvec3 getVolumeTransmissionRay( vec3 n, vec3 v, float thickness, float ior, mat4 modelMatrix ) {\n\t\tvec3 refractionVector = refract( - v, normalize( n ), 1.0 / ior );\n\t\tvec3 modelScale;\n\t\tmodelScale.x = length( vec3( modelMatrix[ 0 ].xyz ) );\n\t\tmodelScale.y = length( vec3( modelMatrix[ 1 ].xyz ) );\n\t\tmodelScale.z = length( vec3( modelMatrix[ 2 ].xyz ) );\n\t\treturn normalize( refractionVector ) * thickness * modelScale;\n\t}\n\tfloat applyIorToRoughness( float roughness, float ior ) {\n\t\treturn roughness * clamp( ior * 2.0 - 2.0, 0.0, 1.0 );\n\t}\n\tvec4 getTransmissionSample( vec2 fragCoord, float roughness, float ior ) {\n\t\tfloat framebufferLod = log2( transmissionSamplerSize.x ) * applyIorToRoughness( roughness, ior );\n\t\t#ifdef TEXTURE_LOD_EXT\n\t\t\treturn texture2DLodEXT( transmissionSamplerMap, fragCoord.xy, framebufferLod );\n\t\t#else\n\t\t\treturn texture2D( transmissionSamplerMap, fragCoord.xy, framebufferLod );\n\t\t#endif\n\t}\n\tvec3 applyVolumeAttenuation( vec3 radiance, float transmissionDistance, vec3 attenuationColor, float attenuationDistance ) {\n\t\tif ( attenuationDistance == 0.0 ) {\n\t\t\treturn radiance;\n\t\t} else {\n\t\t\tvec3 attenuationCoefficient = -log( attenuationColor ) / attenuationDistance;\n\t\t\tvec3 transmittance = exp( - attenuationCoefficient * transmissionDistance );\t\t\treturn transmittance * radiance;\n\t\t}\n\t}\n\tvec4 getIBLVolumeRefraction( vec3 n, vec3 v, float roughness, vec3 diffuseColor, vec3 specularColor, float specularF90,\n\t\tvec3 position, mat4 modelMatrix, mat4 viewMatrix, mat4 projMatrix, float ior, float thickness,\n\t\tvec3 attenuationColor, float attenuationDistance ) {\n\t\tvec3 transmissionRay = getVolumeTransmissionRay( n, v, thickness, ior, modelMatrix );\n\t\tvec3 refractedRayExit = position + transmissionRay;\n\t\tvec4 ndcPos = projMatrix * viewMatrix * vec4( refractedRayExit, 1.0 );\n\t\tvec2 refractionCoords = ndcPos.xy / ndcPos.w;\n\t\trefractionCoords += 1.0;\n\t\trefractionCoords /= 2.0;\n\t\tvec4 transmittedLight = getTransmissionSample( refractionCoords, roughness, ior );\n\t\tvec3 attenuatedColor = applyVolumeAttenuation( transmittedLight.rgb, length( transmissionRay ), attenuationColor, attenuationDistance );\n\t\tvec3 F = EnvironmentBRDF( n, v, specularColor, specularF90, roughness );\n\t\treturn vec4( ( 1.0 - F ) * attenuatedColor * diffuseColor, transmittedLight.a );\n\t}\n#endif",uv_pars_fragment:"#if ( defined( USE_UV ) && ! defined( UVS_VERTEX_ONLY ) )\n\tvarying vec2 vUv;\n#endif",uv_pars_vertex:"#ifdef USE_UV\n\t#ifdef UVS_VERTEX_ONLY\n\t\tvec2 vUv;\n\t#else\n\t\tvarying vec2 vUv;\n\t#endif\n\tuniform mat3 uvTransform;\n#endif",uv_vertex:"#ifdef USE_UV\n\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\n#endif",uv2_pars_fragment:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvarying vec2 vUv2;\n#endif",uv2_pars_vertex:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tattribute vec2 uv2;\n\tvarying vec2 vUv2;\n\tuniform mat3 uv2Transform;\n#endif",uv2_vertex:"#if defined( USE_LIGHTMAP ) || defined( USE_AOMAP )\n\tvUv2 = ( uv2Transform * vec3( uv2, 1 ) ).xy;\n#endif",worldpos_vertex:"#if defined( USE_ENVMAP ) || defined( DISTANCE ) || defined ( USE_SHADOWMAP ) || defined ( USE_TRANSMISSION )\n\tvec4 worldPosition = vec4( transformed, 1.0 );\n\t#ifdef USE_INSTANCING\n\t\tworldPosition = instanceMatrix * worldPosition;\n\t#endif\n\tworldPosition = modelMatrix * worldPosition;\n#endif",background_vert:"varying vec2 vUv;\nuniform mat3 uvTransform;\nvoid main() {\n\tvUv = ( uvTransform * vec3( uv, 1 ) ).xy;\n\tgl_Position = vec4( position.xy, 1.0, 1.0 );\n}",background_frag:"uniform sampler2D t2D;\nvarying vec2 vUv;\nvoid main() {\n\tvec4 texColor = texture2D( t2D, vUv );\n\tgl_FragColor = mapTexelToLinear( texColor );\n\t#include \n\t#include \n}",cube_vert:"varying vec3 vWorldDirection;\n#include \nvoid main() {\n\tvWorldDirection = transformDirection( position, modelMatrix );\n\t#include \n\t#include \n\tgl_Position.z = gl_Position.w;\n}",cube_frag:"#include \nuniform float opacity;\nvarying vec3 vWorldDirection;\n#include \nvoid main() {\n\tvec3 vReflect = vWorldDirection;\n\t#include \n\tgl_FragColor = envColor;\n\tgl_FragColor.a *= opacity;\n\t#include \n\t#include \n}",depth_vert:"#include \n#include \n#include \n#include \n#include \n#include \n#include \nvarying vec2 vHighPrecisionZW;\nvoid main() {\n\t#include \n\t#include \n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include \n\t\t#include \n\t\t#include \n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvHighPrecisionZW = gl_Position.zw;\n}",depth_frag:"#if DEPTH_PACKING == 3200\n\tuniform float opacity;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvarying vec2 vHighPrecisionZW;\nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( 1.0 );\n\t#if DEPTH_PACKING == 3200\n\t\tdiffuseColor.a = opacity;\n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\tfloat fragCoordZ = 0.5 * vHighPrecisionZW[0] / vHighPrecisionZW[1] + 0.5;\n\t#if DEPTH_PACKING == 3200\n\t\tgl_FragColor = vec4( vec3( 1.0 - fragCoordZ ), opacity );\n\t#elif DEPTH_PACKING == 3201\n\t\tgl_FragColor = packDepthToRGBA( fragCoordZ );\n\t#endif\n}",distanceRGBA_vert:"#define DISTANCE\nvarying vec3 vWorldPosition;\n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#ifdef USE_DISPLACEMENTMAP\n\t\t#include \n\t\t#include \n\t\t#include \n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvWorldPosition = worldPosition.xyz;\n}",distanceRGBA_frag:"#define DISTANCE\nuniform vec3 referencePosition;\nuniform float nearDistance;\nuniform float farDistance;\nvarying vec3 vWorldPosition;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main () {\n\t#include \n\tvec4 diffuseColor = vec4( 1.0 );\n\t#include \n\t#include \n\t#include \n\tfloat dist = length( vWorldPosition - referencePosition );\n\tdist = ( dist - nearDistance ) / ( farDistance - nearDistance );\n\tdist = saturate( dist );\n\tgl_FragColor = packDepthToRGBA( dist );\n}",equirect_vert:"varying vec3 vWorldDirection;\n#include \nvoid main() {\n\tvWorldDirection = transformDirection( position, modelMatrix );\n\t#include \n\t#include \n}",equirect_frag:"uniform sampler2D tEquirect;\nvarying vec3 vWorldDirection;\n#include \nvoid main() {\n\tvec3 direction = normalize( vWorldDirection );\n\tvec2 sampleUV = equirectUv( direction );\n\tvec4 texColor = texture2D( tEquirect, sampleUV );\n\tgl_FragColor = mapTexelToLinear( texColor );\n\t#include \n\t#include \n}",linedashed_vert:"uniform float scale;\nattribute float lineDistance;\nvarying float vLineDistance;\n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\tvLineDistance = scale * lineDistance;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",linedashed_frag:"uniform vec3 diffuse;\nuniform float opacity;\nuniform float dashSize;\nuniform float totalSize;\nvarying float vLineDistance;\n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tif ( mod( vLineDistance, totalSize ) > dashSize ) {\n\t\tdiscard;\n\t}\n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\toutgoingLight = diffuseColor.rgb;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",meshbasic_vert:"#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#if defined ( USE_ENVMAP ) || defined ( USE_SKINNING )\n\t\t#include \n\t\t#include \n\t\t#include \n\t\t#include \n\t\t#include \n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",meshbasic_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#ifndef FLAT_SHADED\n\tvarying vec3 vNormal;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\t#ifdef USE_LIGHTMAP\n\t\tvec4 lightMapTexel= texture2D( lightMap, vUv2 );\n\t\treflectedLight.indirectDiffuse += lightMapTexelToLinear( lightMapTexel ).rgb * lightMapIntensity;\n\t#else\n\t\treflectedLight.indirectDiffuse += vec3( 1.0 );\n\t#endif\n\t#include \n\treflectedLight.indirectDiffuse *= diffuseColor.rgb;\n\tvec3 outgoingLight = reflectedLight.indirectDiffuse;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",meshlambert_vert:"#define LAMBERT\nvarying vec3 vLightFront;\nvarying vec3 vIndirectFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n\tvarying vec3 vIndirectBack;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",meshlambert_frag:"uniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float opacity;\nvarying vec3 vLightFront;\nvarying vec3 vIndirectFront;\n#ifdef DOUBLE_SIDED\n\tvarying vec3 vLightBack;\n\tvarying vec3 vIndirectBack;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#ifdef DOUBLE_SIDED\n\t\treflectedLight.indirectDiffuse += ( gl_FrontFacing ) ? vIndirectFront : vIndirectBack;\n\t#else\n\t\treflectedLight.indirectDiffuse += vIndirectFront;\n\t#endif\n\t#include \n\treflectedLight.indirectDiffuse *= BRDF_Lambert( diffuseColor.rgb );\n\t#ifdef DOUBLE_SIDED\n\t\treflectedLight.directDiffuse = ( gl_FrontFacing ) ? vLightFront : vLightBack;\n\t#else\n\t\treflectedLight.directDiffuse = vLightFront;\n\t#endif\n\treflectedLight.directDiffuse *= BRDF_Lambert( diffuseColor.rgb ) * getShadowMask();\n\t#include \n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",meshmatcap_vert:"#define MATCAP\nvarying vec3 vViewPosition;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvViewPosition = - mvPosition.xyz;\n}",meshmatcap_frag:"#define MATCAP\nuniform vec3 diffuse;\nuniform float opacity;\nuniform sampler2D matcap;\nvarying vec3 vViewPosition;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvec3 viewDir = normalize( vViewPosition );\n\tvec3 x = normalize( vec3( viewDir.z, 0.0, - viewDir.x ) );\n\tvec3 y = cross( viewDir, x );\n\tvec2 uv = vec2( dot( x, normal ), dot( y, normal ) ) * 0.495 + 0.5;\n\t#ifdef USE_MATCAP\n\t\tvec4 matcapColor = texture2D( matcap, uv );\n\t\tmatcapColor = matcapTexelToLinear( matcapColor );\n\t#else\n\t\tvec4 matcapColor = vec4( 1.0 );\n\t#endif\n\tvec3 outgoingLight = diffuseColor.rgb * matcapColor.rgb;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",meshnormal_vert:"#define NORMAL\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\n\tvarying vec3 vViewPosition;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\n\tvViewPosition = - mvPosition.xyz;\n#endif\n}",meshnormal_frag:"#define NORMAL\nuniform float opacity;\n#if defined( FLAT_SHADED ) || defined( USE_BUMPMAP ) || defined( TANGENTSPACE_NORMALMAP )\n\tvarying vec3 vViewPosition;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\tgl_FragColor = vec4( packNormalToRGB( normal ), opacity );\n}",meshphong_vert:"#define PHONG\nvarying vec3 vViewPosition;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvViewPosition = - mvPosition.xyz;\n\t#include \n\t#include \n\t#include \n\t#include \n}",meshphong_frag:"#define PHONG\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform vec3 specular;\nuniform float shininess;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + reflectedLight.directSpecular + reflectedLight.indirectSpecular + totalEmissiveRadiance;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",meshphysical_vert:"#define STANDARD\nvarying vec3 vViewPosition;\n#ifdef USE_TRANSMISSION\n\tvarying vec3 vWorldPosition;\n#endif\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvViewPosition = - mvPosition.xyz;\n\t#include \n\t#include \n\t#include \n#ifdef USE_TRANSMISSION\n\tvWorldPosition = worldPosition.xyz;\n#endif\n}",meshphysical_frag:"#define STANDARD\n#ifdef PHYSICAL\n\t#define IOR\n\t#define SPECULAR\n#endif\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float roughness;\nuniform float metalness;\nuniform float opacity;\n#ifdef IOR\n\tuniform float ior;\n#endif\n#ifdef SPECULAR\n\tuniform float specularIntensity;\n\tuniform vec3 specularColor;\n\t#ifdef USE_SPECULARINTENSITYMAP\n\t\tuniform sampler2D specularIntensityMap;\n\t#endif\n\t#ifdef USE_SPECULARCOLORMAP\n\t\tuniform sampler2D specularColorMap;\n\t#endif\n#endif\n#ifdef USE_CLEARCOAT\n\tuniform float clearcoat;\n\tuniform float clearcoatRoughness;\n#endif\n#ifdef USE_SHEEN\n\tuniform vec3 sheenColor;\n\tuniform float sheenRoughness;\n\t#ifdef USE_SHEENCOLORMAP\n\t\tuniform sampler2D sheenColorMap;\n\t#endif\n\t#ifdef USE_SHEENROUGHNESSMAP\n\t\tuniform sampler2D sheenRoughnessMap;\n\t#endif\n#endif\nvarying vec3 vViewPosition;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvec3 totalDiffuse = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse;\n\tvec3 totalSpecular = reflectedLight.directSpecular + reflectedLight.indirectSpecular;\n\t#include \n\tvec3 outgoingLight = totalDiffuse + totalSpecular + totalEmissiveRadiance;\n\t#ifdef USE_CLEARCOAT\n\t\tfloat dotNVcc = saturate( dot( geometry.clearcoatNormal, geometry.viewDir ) );\n\t\tvec3 Fcc = F_Schlick( material.clearcoatF0, material.clearcoatF90, dotNVcc );\n\t\toutgoingLight = outgoingLight * ( 1.0 - clearcoat * Fcc ) + clearcoatSpecular * clearcoat;\n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",meshtoon_vert:"#define TOON\nvarying vec3 vViewPosition;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvViewPosition = - mvPosition.xyz;\n\t#include \n\t#include \n\t#include \n}",meshtoon_frag:"#define TOON\nuniform vec3 diffuse;\nuniform vec3 emissive;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\tReflectedLight reflectedLight = ReflectedLight( vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ), vec3( 0.0 ) );\n\tvec3 totalEmissiveRadiance = emissive;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\tvec3 outgoingLight = reflectedLight.directDiffuse + reflectedLight.indirectDiffuse + totalEmissiveRadiance;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",points_vert:"uniform float size;\nuniform float scale;\n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\tgl_PointSize = size;\n\t#ifdef USE_SIZEATTENUATION\n\t\tbool isPerspective = isPerspectiveMatrix( projectionMatrix );\n\t\tif ( isPerspective ) gl_PointSize *= ( scale / - mvPosition.z );\n\t#endif\n\t#include \n\t#include \n\t#include \n\t#include \n}",points_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\t#include \n\t#include \n\toutgoingLight = diffuseColor.rgb;\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",shadow_vert:"#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n\t#include \n}",shadow_frag:"uniform vec3 color;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\tgl_FragColor = vec4( color, opacity * ( 1.0 - getShadowMask() ) );\n\t#include \n\t#include \n\t#include \n}",sprite_vert:"uniform float rotation;\nuniform vec2 center;\n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec4 mvPosition = modelViewMatrix * vec4( 0.0, 0.0, 0.0, 1.0 );\n\tvec2 scale;\n\tscale.x = length( vec3( modelMatrix[ 0 ].x, modelMatrix[ 0 ].y, modelMatrix[ 0 ].z ) );\n\tscale.y = length( vec3( modelMatrix[ 1 ].x, modelMatrix[ 1 ].y, modelMatrix[ 1 ].z ) );\n\t#ifndef USE_SIZEATTENUATION\n\t\tbool isPerspective = isPerspectiveMatrix( projectionMatrix );\n\t\tif ( isPerspective ) scale *= - mvPosition.z;\n\t#endif\n\tvec2 alignedPosition = ( position.xy - ( center - vec2( 0.5 ) ) ) * scale;\n\tvec2 rotatedPosition;\n\trotatedPosition.x = cos( rotation ) * alignedPosition.x - sin( rotation ) * alignedPosition.y;\n\trotatedPosition.y = sin( rotation ) * alignedPosition.x + cos( rotation ) * alignedPosition.y;\n\tmvPosition.xy += rotatedPosition;\n\tgl_Position = projectionMatrix * mvPosition;\n\t#include \n\t#include \n\t#include \n}",sprite_frag:"uniform vec3 diffuse;\nuniform float opacity;\n#include \n#include \n#include \n#include \n#include \n#include \n#include \n#include \nvoid main() {\n\t#include \n\tvec3 outgoingLight = vec3( 0.0 );\n\tvec4 diffuseColor = vec4( diffuse, opacity );\n\t#include \n\t#include \n\t#include \n\t#include \n\toutgoingLight = diffuseColor.rgb;\n\t#include \n\t#include \n\t#include \n\t#include \n}"},mi={common:{diffuse:{value:new rn(16777215)},opacity:{value:1},map:{value:null},uvTransform:{value:new xt},uv2Transform:{value:new xt},alphaMap:{value:null},alphaTest:{value:0}},specularmap:{specularMap:{value:null}},envmap:{envMap:{value:null},flipEnvMap:{value:-1},reflectivity:{value:1},ior:{value:1.5},refractionRatio:{value:.98},maxMipLevel:{value:0}},aomap:{aoMap:{value:null},aoMapIntensity:{value:1}},lightmap:{lightMap:{value:null},lightMapIntensity:{value:1}},emissivemap:{emissiveMap:{value:null}},bumpmap:{bumpMap:{value:null},bumpScale:{value:1}},normalmap:{normalMap:{value:null},normalScale:{value:new yt(1,1)}},displacementmap:{displacementMap:{value:null},displacementScale:{value:1},displacementBias:{value:0}},roughnessmap:{roughnessMap:{value:null}},metalnessmap:{metalnessMap:{value:null}},gradientmap:{gradientMap:{value:null}},fog:{fogDensity:{value:25e-5},fogNear:{value:1},fogFar:{value:2e3},fogColor:{value:new rn(16777215)}},lights:{ambientLightColor:{value:[]},lightProbe:{value:[]},directionalLights:{value:[],properties:{direction:{},color:{}}},directionalLightShadows:{value:[],properties:{shadowBias:{},shadowNormalBias:{},shadowRadius:{},shadowMapSize:{}}},directionalShadowMap:{value:[]},directionalShadowMatrix:{value:[]},spotLights:{value:[],properties:{color:{},position:{},direction:{},distance:{},coneCos:{},penumbraCos:{},decay:{}}},spotLightShadows:{value:[],properties:{shadowBias:{},shadowNormalBias:{},shadowRadius:{},shadowMapSize:{}}},spotShadowMap:{value:[]},spotShadowMatrix:{value:[]},pointLights:{value:[],properties:{color:{},position:{},decay:{},distance:{}}},pointLightShadows:{value:[],properties:{shadowBias:{},shadowNormalBias:{},shadowRadius:{},shadowMapSize:{},shadowCameraNear:{},shadowCameraFar:{}}},pointShadowMap:{value:[]},pointShadowMatrix:{value:[]},hemisphereLights:{value:[],properties:{direction:{},skyColor:{},groundColor:{}}},rectAreaLights:{value:[],properties:{color:{},position:{},width:{},height:{}}},ltc_1:{value:null},ltc_2:{value:null}},points:{diffuse:{value:new rn(16777215)},opacity:{value:1},size:{value:1},scale:{value:1},map:{value:null},alphaMap:{value:null},alphaTest:{value:0},uvTransform:{value:new xt}},sprite:{diffuse:{value:new rn(16777215)},opacity:{value:1},center:{value:new yt(.5,.5)},rotation:{value:0},map:{value:null},alphaMap:{value:null},alphaTest:{value:0},uvTransform:{value:new xt}}},fi={basic:{uniforms:Yn([mi.common,mi.specularmap,mi.envmap,mi.aomap,mi.lightmap,mi.fog]),vertexShader:pi.meshbasic_vert,fragmentShader:pi.meshbasic_frag},lambert:{uniforms:Yn([mi.common,mi.specularmap,mi.envmap,mi.aomap,mi.lightmap,mi.emissivemap,mi.fog,mi.lights,{emissive:{value:new rn(0)}}]),vertexShader:pi.meshlambert_vert,fragmentShader:pi.meshlambert_frag},phong:{uniforms:Yn([mi.common,mi.specularmap,mi.envmap,mi.aomap,mi.lightmap,mi.emissivemap,mi.bumpmap,mi.normalmap,mi.displacementmap,mi.fog,mi.lights,{emissive:{value:new rn(0)},specular:{value:new rn(1118481)},shininess:{value:30}}]),vertexShader:pi.meshphong_vert,fragmentShader:pi.meshphong_frag},standard:{uniforms:Yn([mi.common,mi.envmap,mi.aomap,mi.lightmap,mi.emissivemap,mi.bumpmap,mi.normalmap,mi.displacementmap,mi.roughnessmap,mi.metalnessmap,mi.fog,mi.lights,{emissive:{value:new rn(0)},roughness:{value:1},metalness:{value:0},envMapIntensity:{value:1}}]),vertexShader:pi.meshphysical_vert,fragmentShader:pi.meshphysical_frag},toon:{uniforms:Yn([mi.common,mi.aomap,mi.lightmap,mi.emissivemap,mi.bumpmap,mi.normalmap,mi.displacementmap,mi.gradientmap,mi.fog,mi.lights,{emissive:{value:new rn(0)}}]),vertexShader:pi.meshtoon_vert,fragmentShader:pi.meshtoon_frag},matcap:{uniforms:Yn([mi.common,mi.bumpmap,mi.normalmap,mi.displacementmap,mi.fog,{matcap:{value:null}}]),vertexShader:pi.meshmatcap_vert,fragmentShader:pi.meshmatcap_frag},points:{uniforms:Yn([mi.points,mi.fog]),vertexShader:pi.points_vert,fragmentShader:pi.points_frag},dashed:{uniforms:Yn([mi.common,mi.fog,{scale:{value:1},dashSize:{value:1},totalSize:{value:2}}]),vertexShader:pi.linedashed_vert,fragmentShader:pi.linedashed_frag},depth:{uniforms:Yn([mi.common,mi.displacementmap]),vertexShader:pi.depth_vert,fragmentShader:pi.depth_frag},normal:{uniforms:Yn([mi.common,mi.bumpmap,mi.normalmap,mi.displacementmap,{opacity:{value:1}}]),vertexShader:pi.meshnormal_vert,fragmentShader:pi.meshnormal_frag},sprite:{uniforms:Yn([mi.sprite,mi.fog]),vertexShader:pi.sprite_vert,fragmentShader:pi.sprite_frag},background:{uniforms:{uvTransform:{value:new xt},t2D:{value:null}},vertexShader:pi.background_vert,fragmentShader:pi.background_frag},cube:{uniforms:Yn([mi.envmap,{opacity:{value:1}}]),vertexShader:pi.cube_vert,fragmentShader:pi.cube_frag},equirect:{uniforms:{tEquirect:{value:null}},vertexShader:pi.equirect_vert,fragmentShader:pi.equirect_frag},distanceRGBA:{uniforms:Yn([mi.common,mi.displacementmap,{referencePosition:{value:new zt},nearDistance:{value:1},farDistance:{value:1e3}}]),vertexShader:pi.distanceRGBA_vert,fragmentShader:pi.distanceRGBA_frag},shadow:{uniforms:Yn([mi.lights,mi.fog,{color:{value:new rn(0)},opacity:{value:1}}]),vertexShader:pi.shadow_vert,fragmentShader:pi.shadow_frag}};function gi(t,e,n,i,r){const s=new rn(0);let a,o,c=0,h=null,u=0,d=null;function p(t,e){n.buffers.color.setClear(t.r,t.g,t.b,e,r)}return{getClearColor:function(){return s},setClearColor:function(t,e=1){s.set(t),c=e,p(s,c)},getClearAlpha:function(){return c},setClearAlpha:function(t){c=t,p(s,c)},render:function(n,r){let m=!1,f=!0===r.isScene?r.background:null;f&&f.isTexture&&(f=e.get(f));const g=t.xr,v=g.getSession&&g.getSession();v&&"additive"===v.environmentBlendMode&&(f=null),null===f?p(s,c):f&&f.isColor&&(p(f,1),m=!0),(t.autoClear||m)&&t.clear(t.autoClearColor,t.autoClearDepth,t.autoClearStencil),f&&(f.isCubeTexture||f.mapping===l)?(void 0===o&&(o=new Wn(new qn(1,1,1),new Zn({name:"BackgroundCubeMaterial",uniforms:Xn(fi.cube.uniforms),vertexShader:fi.cube.vertexShader,fragmentShader:fi.cube.fragmentShader,side:1,depthTest:!1,depthWrite:!1,fog:!1})),o.geometry.deleteAttribute("normal"),o.geometry.deleteAttribute("uv"),o.onBeforeRender=function(t,e,n){this.matrixWorld.copyPosition(n.matrixWorld)},Object.defineProperty(o.material,"envMap",{get:function(){return this.uniforms.envMap.value}}),i.update(o)),o.material.uniforms.envMap.value=f,o.material.uniforms.flipEnvMap.value=f.isCubeTexture&&!1===f.isRenderTargetTexture?-1:1,h===f&&u===f.version&&d===t.toneMapping||(o.material.needsUpdate=!0,h=f,u=f.version,d=t.toneMapping),n.unshift(o,o.geometry,o.material,0,0,null)):f&&f.isTexture&&(void 0===a&&(a=new Wn(new di(2,2),new Zn({name:"BackgroundMaterial",uniforms:Xn(fi.background.uniforms),vertexShader:fi.background.vertexShader,fragmentShader:fi.background.fragmentShader,side:0,depthTest:!1,depthWrite:!1,fog:!1})),a.geometry.deleteAttribute("normal"),Object.defineProperty(a.material,"map",{get:function(){return this.uniforms.t2D.value}}),i.update(a)),a.material.uniforms.t2D.value=f,!0===f.matrixAutoUpdate&&f.updateMatrix(),a.material.uniforms.uvTransform.value.copy(f.matrix),h===f&&u===f.version&&d===t.toneMapping||(a.material.needsUpdate=!0,h=f,u=f.version,d=t.toneMapping),n.unshift(a,a.geometry,a.material,0,0,null))}}}function vi(t,e,n,i){const r=t.getParameter(34921),s=i.isWebGL2?null:e.get("OES_vertex_array_object"),a=i.isWebGL2||null!==s,o={},l=d(null);let c=l;function h(e){return i.isWebGL2?t.bindVertexArray(e):s.bindVertexArrayOES(e)}function u(e){return i.isWebGL2?t.deleteVertexArray(e):s.deleteVertexArrayOES(e)}function d(t){const e=[],n=[],i=[];for(let t=0;t=0){let s=l[e];if(void 0===s&&("instanceMatrix"===e&&r.instanceMatrix&&(s=r.instanceMatrix),"instanceColor"===e&&r.instanceColor&&(s=r.instanceColor)),void 0!==s){const e=s.normalized,a=s.itemSize,l=n.get(s);if(void 0===l)continue;const c=l.buffer,h=l.type,u=l.bytesPerElement;if(s.isInterleavedBufferAttribute){const n=s.data,l=n.stride,d=s.offset;if(n&&n.isInstancedInterleavedBuffer){for(let t=0;t0&&t.getShaderPrecisionFormat(35632,36338).precision>0)return"highp";e="mediump"}return"mediump"===e&&t.getShaderPrecisionFormat(35633,36337).precision>0&&t.getShaderPrecisionFormat(35632,36337).precision>0?"mediump":"lowp"}const s="undefined"!=typeof WebGL2RenderingContext&&t instanceof WebGL2RenderingContext||"undefined"!=typeof WebGL2ComputeRenderingContext&&t instanceof WebGL2ComputeRenderingContext;let a=void 0!==n.precision?n.precision:"highp";const o=r(a);o!==a&&(console.warn("THREE.WebGLRenderer:",a,"not supported, using",o,"instead."),a=o);const l=s||e.has("WEBGL_draw_buffers"),c=!0===n.logarithmicDepthBuffer,h=t.getParameter(34930),u=t.getParameter(35660),d=t.getParameter(3379),p=t.getParameter(34076),m=t.getParameter(34921),f=t.getParameter(36347),g=t.getParameter(36348),v=t.getParameter(36349),y=u>0,x=s||e.has("OES_texture_float");return{isWebGL2:s,drawBuffers:l,getMaxAnisotropy:function(){if(void 0!==i)return i;if(!0===e.has("EXT_texture_filter_anisotropic")){const n=e.get("EXT_texture_filter_anisotropic");i=t.getParameter(n.MAX_TEXTURE_MAX_ANISOTROPY_EXT)}else i=0;return i},getMaxPrecision:r,precision:a,logarithmicDepthBuffer:c,maxTextures:h,maxVertexTextures:u,maxTextureSize:d,maxCubemapSize:p,maxAttributes:m,maxVertexUniforms:f,maxVaryings:g,maxFragmentUniforms:v,vertexTextures:y,floatFragmentTextures:x,floatVertexTextures:y&&x,maxSamples:s?t.getParameter(36183):0}}function _i(t){const e=this;let n=null,i=0,r=!1,s=!1;const a=new ai,o=new xt,l={value:null,needsUpdate:!1};function c(){l.value!==n&&(l.value=n,l.needsUpdate=i>0),e.numPlanes=i,e.numIntersection=0}function h(t,n,i,r){const s=null!==t?t.length:0;let c=null;if(0!==s){if(c=l.value,!0!==r||null===c){const e=i+4*s,r=n.matrixWorldInverse;o.getNormalMatrix(r),(null===c||c.length0){const a=t.getRenderTarget(),o=new ni(s.height/2);return o.fromEquirectangularTexture(t,r),e.set(r,o),t.setRenderTarget(a),r.addEventListener("dispose",i),n(o.texture,r.mapping)}return null}}}return r},dispose:function(){e=new WeakMap}}}fi.physical={uniforms:Yn([fi.standard.uniforms,{clearcoat:{value:0},clearcoatMap:{value:null},clearcoatRoughness:{value:0},clearcoatRoughnessMap:{value:null},clearcoatNormalScale:{value:new yt(1,1)},clearcoatNormalMap:{value:null},sheen:{value:0},sheenColor:{value:new rn(0)},sheenColorMap:{value:null},sheenRoughness:{value:0},sheenRoughnessMap:{value:null},transmission:{value:0},transmissionMap:{value:null},transmissionSamplerSize:{value:new yt},transmissionSamplerMap:{value:null},thickness:{value:0},thicknessMap:{value:null},attenuationDistance:{value:0},attenuationColor:{value:new rn(0)},specularIntensity:{value:0},specularIntensityMap:{value:null},specularColor:{value:new rn(1,1,1)},specularColorMap:{value:null}}]),vertexShader:pi.meshphysical_vert,fragmentShader:pi.meshphysical_frag};class bi extends Qn{constructor(t=-1,e=1,n=1,i=-1,r=.1,s=2e3){super(),this.type="OrthographicCamera",this.zoom=1,this.view=null,this.left=t,this.right=e,this.top=n,this.bottom=i,this.near=r,this.far=s,this.updateProjectionMatrix()}copy(t,e){return super.copy(t,e),this.left=t.left,this.right=t.right,this.top=t.top,this.bottom=t.bottom,this.near=t.near,this.far=t.far,this.zoom=t.zoom,this.view=null===t.view?null:Object.assign({},t.view),this}setViewOffset(t,e,n,i,r,s){null===this.view&&(this.view={enabled:!0,fullWidth:1,fullHeight:1,offsetX:0,offsetY:0,width:1,height:1}),this.view.enabled=!0,this.view.fullWidth=t,this.view.fullHeight=e,this.view.offsetX=n,this.view.offsetY=i,this.view.width=r,this.view.height=s,this.updateProjectionMatrix()}clearViewOffset(){null!==this.view&&(this.view.enabled=!1),this.updateProjectionMatrix()}updateProjectionMatrix(){const t=(this.right-this.left)/(2*this.zoom),e=(this.top-this.bottom)/(2*this.zoom),n=(this.right+this.left)/2,i=(this.top+this.bottom)/2;let r=n-t,s=n+t,a=i+e,o=i-e;if(null!==this.view&&this.view.enabled){const t=(this.right-this.left)/this.view.fullWidth/this.zoom,e=(this.top-this.bottom)/this.view.fullHeight/this.zoom;r+=t*this.view.offsetX,s=r+t*this.view.width,a-=e*this.view.offsetY,o=a-e*this.view.height}this.projectionMatrix.makeOrthographic(r,s,a,o,this.near,this.far),this.projectionMatrixInverse.copy(this.projectionMatrix).invert()}toJSON(t){const e=super.toJSON(t);return e.object.zoom=this.zoom,e.object.left=this.left,e.object.right=this.right,e.object.top=this.top,e.object.bottom=this.bottom,e.object.near=this.near,e.object.far=this.far,null!==this.view&&(e.object.view=Object.assign({},this.view)),e}}bi.prototype.isOrthographicCamera=!0;class wi extends Zn{constructor(t){super(t),this.type="RawShaderMaterial"}}wi.prototype.isRawShaderMaterial=!0;const Si=Math.pow(2,8),Ti=[.125,.215,.35,.446,.526,.582],Ei=5+Ti.length,Ai=20,Li={[X]:0,[Y]:1,[Z]:2,[Q]:3,[K]:4,[$]:5,[J]:6},Ri=new bi,{_lodPlanes:Ci,_sizeLods:Pi,_sigmas:Ii}=Hi(),Di=new rn;let Ni=null;const zi=(1+Math.sqrt(5))/2,Bi=1/zi,Fi=[new zt(1,1,1),new zt(-1,1,1),new zt(1,1,-1),new zt(-1,1,-1),new zt(0,zi,Bi),new zt(0,zi,-Bi),new zt(Bi,0,zi),new zt(-Bi,0,zi),new zt(zi,Bi,0),new zt(-zi,Bi,0)];class Oi{constructor(t){this._renderer=t,this._pingPongRenderTarget=null,this._blurMaterial=function(t){const e=new Float32Array(t),n=new zt(0,1,0);return new wi({name:"SphericalGaussianBlur",defines:{n:t},uniforms:{envMap:{value:null},samples:{value:1},weights:{value:e},latitudinal:{value:!1},dTheta:{value:0},mipInt:{value:0},poleAxis:{value:n},inputEncoding:{value:Li[3e3]},outputEncoding:{value:Li[3e3]}},vertexShader:ji(),fragmentShader:`\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform sampler2D envMap;\n\t\t\tuniform int samples;\n\t\t\tuniform float weights[ n ];\n\t\t\tuniform bool latitudinal;\n\t\t\tuniform float dTheta;\n\t\t\tuniform float mipInt;\n\t\t\tuniform vec3 poleAxis;\n\n\t\t\t${qi()}\n\n\t\t\t#define ENVMAP_TYPE_CUBE_UV\n\t\t\t#include \n\n\t\t\tvec3 getSample( float theta, vec3 axis ) {\n\n\t\t\t\tfloat cosTheta = cos( theta );\n\t\t\t\t// Rodrigues' axis-angle rotation\n\t\t\t\tvec3 sampleDirection = vOutputDirection * cosTheta\n\t\t\t\t\t+ cross( axis, vOutputDirection ) * sin( theta )\n\t\t\t\t\t+ axis * dot( axis, vOutputDirection ) * ( 1.0 - cosTheta );\n\n\t\t\t\treturn bilinearCubeUV( envMap, sampleDirection, mipInt );\n\n\t\t\t}\n\n\t\t\tvoid main() {\n\n\t\t\t\tvec3 axis = latitudinal ? poleAxis : cross( poleAxis, vOutputDirection );\n\n\t\t\t\tif ( all( equal( axis, vec3( 0.0 ) ) ) ) {\n\n\t\t\t\t\taxis = vec3( vOutputDirection.z, 0.0, - vOutputDirection.x );\n\n\t\t\t\t}\n\n\t\t\t\taxis = normalize( axis );\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\t\t\t\tgl_FragColor.rgb += weights[ 0 ] * getSample( 0.0, axis );\n\n\t\t\t\tfor ( int i = 1; i < n; i++ ) {\n\n\t\t\t\t\tif ( i >= samples ) {\n\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\t}\n\n\t\t\t\t\tfloat theta = dTheta * float( i );\n\t\t\t\t\tgl_FragColor.rgb += weights[ i ] * getSample( -1.0 * theta, axis );\n\t\t\t\t\tgl_FragColor.rgb += weights[ i ] * getSample( theta, axis );\n\n\t\t\t\t}\n\n\t\t\t\tgl_FragColor = linearToOutputTexel( gl_FragColor );\n\n\t\t\t}\n\t\t`,blending:0,depthTest:!1,depthWrite:!1})}(Ai),this._equirectShader=null,this._cubemapShader=null,this._compileMaterial(this._blurMaterial)}fromScene(t,e=0,n=.1,i=100){Ni=this._renderer.getRenderTarget();const r=this._allocateTargets();return this._sceneToCubeUV(t,n,i,r),e>0&&this._blur(r,0,0,e),this._applyPMREM(r),this._cleanup(r),r}fromEquirectangular(t){return this._fromTexture(t)}fromCubemap(t){return this._fromTexture(t)}compileCubemapShader(){null===this._cubemapShader&&(this._cubemapShader=Wi(),this._compileMaterial(this._cubemapShader))}compileEquirectangularShader(){null===this._equirectShader&&(this._equirectShader=Vi(),this._compileMaterial(this._equirectShader))}dispose(){this._blurMaterial.dispose(),null!==this._cubemapShader&&this._cubemapShader.dispose(),null!==this._equirectShader&&this._equirectShader.dispose();for(let t=0;t2?Si:0,Si,Si),o.setRenderTarget(i),p&&o.render(d,r),o.render(t,r)}d.geometry.dispose(),d.material.dispose(),o.toneMapping=h,o.outputEncoding=c,o.autoClear=l,t.background=m}_setEncoding(t,e){!0===this._renderer.capabilities.isWebGL2&&e.format===E&&e.type===x&&e.encoding===Y?t.value=Li[3e3]:t.value=Li[e.encoding]}_textureToCubeUV(t,e){const n=this._renderer,i=t.mapping===r||t.mapping===s;i?null==this._cubemapShader&&(this._cubemapShader=Wi()):null==this._equirectShader&&(this._equirectShader=Vi());const a=i?this._cubemapShader:this._equirectShader,o=new Wn(Ci[0],a),l=a.uniforms;l.envMap.value=t,i||l.texelSize.value.set(1/t.image.width,1/t.image.height),this._setEncoding(l.inputEncoding,t),this._setEncoding(l.outputEncoding,e.texture),ki(e,0,0,3*Si,2*Si),n.setRenderTarget(e),n.render(o,Ri)}_applyPMREM(t){const e=this._renderer,n=e.autoClear;e.autoClear=!1;for(let e=1;eAi&&console.warn(`sigmaRadians, ${r}, is too large and will clip, as it requested ${m} samples when the maximum is set to 20`);const f=[];let g=0;for(let t=0;t4?i-8+4:0),3*v,2*v),o.setRenderTarget(e),o.render(c,Ri)}}function Ui(t){return void 0!==t&&t.type===x&&(t.encoding===X||t.encoding===Y||t.encoding===J)}function Hi(){const t=[],e=[],n=[];let i=8;for(let r=0;r4?a=Ti[r-8+4-1]:0==r&&(a=0),n.push(a);const o=1/(s-1),l=-o/2,c=1+o/2,h=[l,l,c,l,c,c,l,l,c,c,l,c],u=6,d=6,p=3,m=2,f=1,g=new Float32Array(p*d*u),v=new Float32Array(m*d*u),y=new Float32Array(f*d*u);for(let t=0;t2?0:-1,i=[e,n,0,e+2/3,n,0,e+2/3,n+1,0,e,n,0,e+2/3,n+1,0,e,n+1,0];g.set(i,p*d*t),v.set(h,m*d*t);const r=[t,t,t,t,t,t];y.set(r,f*d*t)}const x=new En;x.setAttribute("position",new ln(g,p)),x.setAttribute("uv",new ln(v,m)),x.setAttribute("faceIndex",new ln(y,f)),t.push(x),i>4&&i--}return{_lodPlanes:t,_sizeLods:e,_sigmas:n}}function Gi(t){const e=new Pt(3*Si,3*Si,t);return e.texture.mapping=l,e.texture.name="PMREM.cubeUv",e.scissorTest=!0,e}function ki(t,e,n,i,r){t.viewport.set(e,n,i,r),t.scissor.set(e,n,i,r)}function Vi(){const t=new yt(1,1);return new wi({name:"EquirectangularToCubeUV",uniforms:{envMap:{value:null},texelSize:{value:t},inputEncoding:{value:Li[3e3]},outputEncoding:{value:Li[3e3]}},vertexShader:ji(),fragmentShader:`\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform sampler2D envMap;\n\t\t\tuniform vec2 texelSize;\n\n\t\t\t${qi()}\n\n\t\t\t#include \n\n\t\t\tvoid main() {\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\n\t\t\t\tvec3 outputDirection = normalize( vOutputDirection );\n\t\t\t\tvec2 uv = equirectUv( outputDirection );\n\n\t\t\t\tvec2 f = fract( uv / texelSize - 0.5 );\n\t\t\t\tuv -= f * texelSize;\n\t\t\t\tvec3 tl = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\t\t\t\tuv.x += texelSize.x;\n\t\t\t\tvec3 tr = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\t\t\t\tuv.y += texelSize.y;\n\t\t\t\tvec3 br = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\t\t\t\tuv.x -= texelSize.x;\n\t\t\t\tvec3 bl = envMapTexelToLinear( texture2D ( envMap, uv ) ).rgb;\n\n\t\t\t\tvec3 tm = mix( tl, tr, f.x );\n\t\t\t\tvec3 bm = mix( bl, br, f.x );\n\t\t\t\tgl_FragColor.rgb = mix( tm, bm, f.y );\n\n\t\t\t\tgl_FragColor = linearToOutputTexel( gl_FragColor );\n\n\t\t\t}\n\t\t`,blending:0,depthTest:!1,depthWrite:!1})}function Wi(){return new wi({name:"CubemapToCubeUV",uniforms:{envMap:{value:null},inputEncoding:{value:Li[3e3]},outputEncoding:{value:Li[3e3]}},vertexShader:ji(),fragmentShader:`\n\n\t\t\tprecision mediump float;\n\t\t\tprecision mediump int;\n\n\t\t\tvarying vec3 vOutputDirection;\n\n\t\t\tuniform samplerCube envMap;\n\n\t\t\t${qi()}\n\n\t\t\tvoid main() {\n\n\t\t\t\tgl_FragColor = vec4( 0.0, 0.0, 0.0, 1.0 );\n\t\t\t\tgl_FragColor.rgb = envMapTexelToLinear( textureCube( envMap, vec3( - vOutputDirection.x, vOutputDirection.yz ) ) ).rgb;\n\t\t\t\tgl_FragColor = linearToOutputTexel( gl_FragColor );\n\n\t\t\t}\n\t\t`,blending:0,depthTest:!1,depthWrite:!1})}function ji(){return"\n\n\t\tprecision mediump float;\n\t\tprecision mediump int;\n\n\t\tattribute vec3 position;\n\t\tattribute vec2 uv;\n\t\tattribute float faceIndex;\n\n\t\tvarying vec3 vOutputDirection;\n\n\t\t// RH coordinate system; PMREM face-indexing convention\n\t\tvec3 getDirection( vec2 uv, float face ) {\n\n\t\t\tuv = 2.0 * uv - 1.0;\n\n\t\t\tvec3 direction = vec3( uv, 1.0 );\n\n\t\t\tif ( face == 0.0 ) {\n\n\t\t\t\tdirection = direction.zyx; // ( 1, v, u ) pos x\n\n\t\t\t} else if ( face == 1.0 ) {\n\n\t\t\t\tdirection = direction.xzy;\n\t\t\t\tdirection.xz *= -1.0; // ( -u, 1, -v ) pos y\n\n\t\t\t} else if ( face == 2.0 ) {\n\n\t\t\t\tdirection.x *= -1.0; // ( -u, v, 1 ) pos z\n\n\t\t\t} else if ( face == 3.0 ) {\n\n\t\t\t\tdirection = direction.zyx;\n\t\t\t\tdirection.xz *= -1.0; // ( -1, v, -u ) neg x\n\n\t\t\t} else if ( face == 4.0 ) {\n\n\t\t\t\tdirection = direction.xzy;\n\t\t\t\tdirection.xy *= -1.0; // ( -u, -1, v ) neg y\n\n\t\t\t} else if ( face == 5.0 ) {\n\n\t\t\t\tdirection.z *= -1.0; // ( u, v, -1 ) neg z\n\n\t\t\t}\n\n\t\t\treturn direction;\n\n\t\t}\n\n\t\tvoid main() {\n\n\t\t\tvOutputDirection = getDirection( uv, faceIndex );\n\t\t\tgl_Position = vec4( position, 1.0 );\n\n\t\t}\n\t"}function qi(){return"\n\n\t\tuniform int inputEncoding;\n\t\tuniform int outputEncoding;\n\n\t\t#include \n\n\t\tvec4 inputTexelToLinear( vec4 value ) {\n\n\t\t\tif ( inputEncoding == 0 ) {\n\n\t\t\t\treturn value;\n\n\t\t\t} else if ( inputEncoding == 1 ) {\n\n\t\t\t\treturn sRGBToLinear( value );\n\n\t\t\t} else if ( inputEncoding == 2 ) {\n\n\t\t\t\treturn RGBEToLinear( value );\n\n\t\t\t} else if ( inputEncoding == 3 ) {\n\n\t\t\t\treturn RGBMToLinear( value, 7.0 );\n\n\t\t\t} else if ( inputEncoding == 4 ) {\n\n\t\t\t\treturn RGBMToLinear( value, 16.0 );\n\n\t\t\t} else if ( inputEncoding == 5 ) {\n\n\t\t\t\treturn RGBDToLinear( value, 256.0 );\n\n\t\t\t} else {\n\n\t\t\t\treturn GammaToLinear( value, 2.2 );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvec4 linearToOutputTexel( vec4 value ) {\n\n\t\t\tif ( outputEncoding == 0 ) {\n\n\t\t\t\treturn value;\n\n\t\t\t} else if ( outputEncoding == 1 ) {\n\n\t\t\t\treturn LinearTosRGB( value );\n\n\t\t\t} else if ( outputEncoding == 2 ) {\n\n\t\t\t\treturn LinearToRGBE( value );\n\n\t\t\t} else if ( outputEncoding == 3 ) {\n\n\t\t\t\treturn LinearToRGBM( value, 7.0 );\n\n\t\t\t} else if ( outputEncoding == 4 ) {\n\n\t\t\t\treturn LinearToRGBM( value, 16.0 );\n\n\t\t\t} else if ( outputEncoding == 5 ) {\n\n\t\t\t\treturn LinearToRGBD( value, 256.0 );\n\n\t\t\t} else {\n\n\t\t\t\treturn LinearToGamma( value, 2.2 );\n\n\t\t\t}\n\n\t\t}\n\n\t\tvec4 envMapTexelToLinear( vec4 color ) {\n\n\t\t\treturn inputTexelToLinear( color );\n\n\t\t}\n\t"}function Xi(t){let e=new WeakMap,n=null;function i(t){const n=t.target;n.removeEventListener("dispose",i);const r=e.get(n);void 0!==r&&(e.delete(n),r.dispose())}return{get:function(l){if(l&&l.isTexture&&!1===l.isRenderTargetTexture){const c=l.mapping,h=c===a||c===o,u=c===r||c===s;if(h||u){if(e.has(l))return e.get(l).texture;{const r=l.image;if(h&&r&&r.height>0||u&&r&&function(t){let e=0;const n=6;for(let i=0;i65535?fn:pn)(n,1);o.version=a;const l=s.get(t);l&&e.remove(l),s.set(t,o)}return{get:function(t,e){return!0===r[e.id]||(e.addEventListener("dispose",a),r[e.id]=!0,n.memory.geometries++),e},update:function(t){const n=t.attributes;for(const t in n)e.update(n[t],34962);const i=t.morphAttributes;for(const t in i){const n=i[t];for(let t=0,i=n.length;te.maxTextureSize&&(u=Math.ceil(h/e.maxTextureSize),h=e.maxTextureSize);const d=new Float32Array(h*u*4*i),p=new Ki(d,h,u,i);p.format=E,p.type=b;const m=4*l;for(let e=0;e0)return t;const r=e*n;let s=cr[r];if(void 0===s&&(s=new Float32Array(r),cr[r]=s),0!==e){i.toArray(s,0);for(let i=1,r=0;i!==e;++i)r+=n,t[i].toArray(s,r)}return s}function fr(t,e){if(t.length!==e.length)return!1;for(let n=0,i=t.length;n/gm;function ys(t){return t.replace(vs,xs)}function xs(t,e){const n=pi[e];if(void 0===n)throw new Error("Can not resolve #include <"+e+">");return ys(n)}const _s=/#pragma unroll_loop[\s]+?for \( int i \= (\d+)\; i < (\d+)\; i \+\+ \) \{([\s\S]+?)(?=\})\}/g,Ms=/#pragma unroll_loop_start\s+for\s*\(\s*int\s+i\s*=\s*(\d+)\s*;\s*i\s*<\s*(\d+)\s*;\s*i\s*\+\+\s*\)\s*{([\s\S]+?)}\s+#pragma unroll_loop_end/g;function bs(t){return t.replace(Ms,Ss).replace(_s,ws)}function ws(t,e,n,i){return console.warn("WebGLProgram: #pragma unroll_loop shader syntax is deprecated. Please use #pragma unroll_loop_start syntax instead."),Ss(t,e,n,i)}function Ss(t,e,n,i){let r="";for(let t=parseInt(e);t0?t.gammaFactor:1,v=n.isWebGL2?"":function(t){return[t.extensionDerivatives||t.envMapCubeUV||t.bumpMap||t.tangentSpaceNormalMap||t.clearcoatNormalMap||t.flatShading||"physical"===t.shaderID?"#extension GL_OES_standard_derivatives : enable":"",(t.extensionFragDepth||t.logarithmicDepthBuffer)&&t.rendererExtensionFragDepth?"#extension GL_EXT_frag_depth : enable":"",t.extensionDrawBuffers&&t.rendererExtensionDrawBuffers?"#extension GL_EXT_draw_buffers : require":"",(t.extensionShaderTextureLOD||t.envMap||t.transmission)&&t.rendererExtensionShaderTextureLod?"#extension GL_EXT_shader_texture_lod : enable":""].filter(ms).join("\n")}(n),y=function(t){const e=[];for(const n in t){const i=t[n];!1!==i&&e.push("#define "+n+" "+i)}return e.join("\n")}(o),x=a.createProgram();let _,M,b=n.glslVersion?"#version "+n.glslVersion+"\n":"";n.isRawShaderMaterial?(_=[y].filter(ms).join("\n"),_.length>0&&(_+="\n"),M=[v,y].filter(ms).join("\n"),M.length>0&&(M+="\n")):(_=[Ts(n),"#define SHADER_NAME "+n.shaderName,y,n.instancing?"#define USE_INSTANCING":"",n.instancingColor?"#define USE_INSTANCING_COLOR":"",n.supportsVertexTextures?"#define VERTEX_TEXTURES":"","#define GAMMA_FACTOR "+g,"#define MAX_BONES "+n.maxBones,n.useFog&&n.fog?"#define USE_FOG":"",n.useFog&&n.fogExp2?"#define FOG_EXP2":"",n.map?"#define USE_MAP":"",n.envMap?"#define USE_ENVMAP":"",n.envMap?"#define "+m:"",n.lightMap?"#define USE_LIGHTMAP":"",n.aoMap?"#define USE_AOMAP":"",n.emissiveMap?"#define USE_EMISSIVEMAP":"",n.bumpMap?"#define USE_BUMPMAP":"",n.normalMap?"#define USE_NORMALMAP":"",n.normalMap&&n.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",n.normalMap&&n.tangentSpaceNormalMap?"#define TANGENTSPACE_NORMALMAP":"",n.clearcoatMap?"#define USE_CLEARCOATMAP":"",n.clearcoatRoughnessMap?"#define USE_CLEARCOAT_ROUGHNESSMAP":"",n.clearcoatNormalMap?"#define USE_CLEARCOAT_NORMALMAP":"",n.displacementMap&&n.supportsVertexTextures?"#define USE_DISPLACEMENTMAP":"",n.specularMap?"#define USE_SPECULARMAP":"",n.specularIntensityMap?"#define USE_SPECULARINTENSITYMAP":"",n.specularColorMap?"#define USE_SPECULARCOLORMAP":"",n.roughnessMap?"#define USE_ROUGHNESSMAP":"",n.metalnessMap?"#define USE_METALNESSMAP":"",n.alphaMap?"#define USE_ALPHAMAP":"",n.transmission?"#define USE_TRANSMISSION":"",n.transmissionMap?"#define USE_TRANSMISSIONMAP":"",n.thicknessMap?"#define USE_THICKNESSMAP":"",n.sheenColorMap?"#define USE_SHEENCOLORMAP":"",n.sheenRoughnessMap?"#define USE_SHEENROUGHNESSMAP":"",n.vertexTangents?"#define USE_TANGENT":"",n.vertexColors?"#define USE_COLOR":"",n.vertexAlphas?"#define USE_COLOR_ALPHA":"",n.vertexUvs?"#define USE_UV":"",n.uvsVertexOnly?"#define UVS_VERTEX_ONLY":"",n.flatShading?"#define FLAT_SHADED":"",n.skinning?"#define USE_SKINNING":"",n.useVertexTexture?"#define BONE_TEXTURE":"",n.morphTargets?"#define USE_MORPHTARGETS":"",n.morphNormals&&!1===n.flatShading?"#define USE_MORPHNORMALS":"",n.morphTargets&&n.isWebGL2?"#define MORPHTARGETS_TEXTURE":"",n.morphTargets&&n.isWebGL2?"#define MORPHTARGETS_COUNT "+n.morphTargetsCount:"",n.doubleSided?"#define DOUBLE_SIDED":"",n.flipSided?"#define FLIP_SIDED":"",n.shadowMapEnabled?"#define USE_SHADOWMAP":"",n.shadowMapEnabled?"#define "+d:"",n.sizeAttenuation?"#define USE_SIZEATTENUATION":"",n.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":"",n.logarithmicDepthBuffer&&n.rendererExtensionFragDepth?"#define USE_LOGDEPTHBUF_EXT":"","uniform mat4 modelMatrix;","uniform mat4 modelViewMatrix;","uniform mat4 projectionMatrix;","uniform mat4 viewMatrix;","uniform mat3 normalMatrix;","uniform vec3 cameraPosition;","uniform bool isOrthographic;","#ifdef USE_INSTANCING","\tattribute mat4 instanceMatrix;","#endif","#ifdef USE_INSTANCING_COLOR","\tattribute vec3 instanceColor;","#endif","attribute vec3 position;","attribute vec3 normal;","attribute vec2 uv;","#ifdef USE_TANGENT","\tattribute vec4 tangent;","#endif","#if defined( USE_COLOR_ALPHA )","\tattribute vec4 color;","#elif defined( USE_COLOR )","\tattribute vec3 color;","#endif","#if ( defined( USE_MORPHTARGETS ) && ! defined( MORPHTARGETS_TEXTURE ) )","\tattribute vec3 morphTarget0;","\tattribute vec3 morphTarget1;","\tattribute vec3 morphTarget2;","\tattribute vec3 morphTarget3;","\t#ifdef USE_MORPHNORMALS","\t\tattribute vec3 morphNormal0;","\t\tattribute vec3 morphNormal1;","\t\tattribute vec3 morphNormal2;","\t\tattribute vec3 morphNormal3;","\t#else","\t\tattribute vec3 morphTarget4;","\t\tattribute vec3 morphTarget5;","\t\tattribute vec3 morphTarget6;","\t\tattribute vec3 morphTarget7;","\t#endif","#endif","#ifdef USE_SKINNING","\tattribute vec4 skinIndex;","\tattribute vec4 skinWeight;","#endif","\n"].filter(ms).join("\n"),M=[v,Ts(n),"#define SHADER_NAME "+n.shaderName,y,"#define GAMMA_FACTOR "+g,n.useFog&&n.fog?"#define USE_FOG":"",n.useFog&&n.fogExp2?"#define FOG_EXP2":"",n.map?"#define USE_MAP":"",n.matcap?"#define USE_MATCAP":"",n.envMap?"#define USE_ENVMAP":"",n.envMap?"#define "+p:"",n.envMap?"#define "+m:"",n.envMap?"#define "+f:"",n.lightMap?"#define USE_LIGHTMAP":"",n.aoMap?"#define USE_AOMAP":"",n.emissiveMap?"#define USE_EMISSIVEMAP":"",n.bumpMap?"#define USE_BUMPMAP":"",n.normalMap?"#define USE_NORMALMAP":"",n.normalMap&&n.objectSpaceNormalMap?"#define OBJECTSPACE_NORMALMAP":"",n.normalMap&&n.tangentSpaceNormalMap?"#define TANGENTSPACE_NORMALMAP":"",n.clearcoat?"#define USE_CLEARCOAT":"",n.clearcoatMap?"#define USE_CLEARCOATMAP":"",n.clearcoatRoughnessMap?"#define USE_CLEARCOAT_ROUGHNESSMAP":"",n.clearcoatNormalMap?"#define USE_CLEARCOAT_NORMALMAP":"",n.specularMap?"#define USE_SPECULARMAP":"",n.specularIntensityMap?"#define USE_SPECULARINTENSITYMAP":"",n.specularColorMap?"#define USE_SPECULARCOLORMAP":"",n.roughnessMap?"#define USE_ROUGHNESSMAP":"",n.metalnessMap?"#define USE_METALNESSMAP":"",n.alphaMap?"#define USE_ALPHAMAP":"",n.alphaTest?"#define USE_ALPHATEST":"",n.sheen?"#define USE_SHEEN":"",n.sheenColorMap?"#define USE_SHEENCOLORMAP":"",n.sheenRoughnessMap?"#define USE_SHEENROUGHNESSMAP":"",n.transmission?"#define USE_TRANSMISSION":"",n.transmissionMap?"#define USE_TRANSMISSIONMAP":"",n.thicknessMap?"#define USE_THICKNESSMAP":"",n.vertexTangents?"#define USE_TANGENT":"",n.vertexColors||n.instancingColor?"#define USE_COLOR":"",n.vertexAlphas?"#define USE_COLOR_ALPHA":"",n.vertexUvs?"#define USE_UV":"",n.uvsVertexOnly?"#define UVS_VERTEX_ONLY":"",n.gradientMap?"#define USE_GRADIENTMAP":"",n.flatShading?"#define FLAT_SHADED":"",n.doubleSided?"#define DOUBLE_SIDED":"",n.flipSided?"#define FLIP_SIDED":"",n.shadowMapEnabled?"#define USE_SHADOWMAP":"",n.shadowMapEnabled?"#define "+d:"",n.premultipliedAlpha?"#define PREMULTIPLIED_ALPHA":"",n.physicallyCorrectLights?"#define PHYSICALLY_CORRECT_LIGHTS":"",n.logarithmicDepthBuffer?"#define USE_LOGDEPTHBUF":"",n.logarithmicDepthBuffer&&n.rendererExtensionFragDepth?"#define USE_LOGDEPTHBUF_EXT":"",(n.extensionShaderTextureLOD||n.envMap)&&n.rendererExtensionShaderTextureLod?"#define TEXTURE_LOD_EXT":"","uniform mat4 viewMatrix;","uniform vec3 cameraPosition;","uniform bool isOrthographic;",0!==n.toneMapping?"#define TONE_MAPPING":"",0!==n.toneMapping?pi.tonemapping_pars_fragment:"",0!==n.toneMapping?ps("toneMapping",n.toneMapping):"",n.dithering?"#define DITHERING":"",n.format===T?"#define OPAQUE":"",pi.encodings_pars_fragment,n.map?us("mapTexelToLinear",n.mapEncoding):"",n.matcap?us("matcapTexelToLinear",n.matcapEncoding):"",n.envMap?us("envMapTexelToLinear",n.envMapEncoding):"",n.emissiveMap?us("emissiveMapTexelToLinear",n.emissiveMapEncoding):"",n.specularColorMap?us("specularColorMapTexelToLinear",n.specularColorMapEncoding):"",n.sheenColorMap?us("sheenColorMapTexelToLinear",n.sheenColorMapEncoding):"",n.lightMap?us("lightMapTexelToLinear",n.lightMapEncoding):"",ds("linearToOutputTexel",n.outputEncoding),n.depthPacking?"#define DEPTH_PACKING "+n.depthPacking:"","\n"].filter(ms).join("\n")),h=ys(h),h=fs(h,n),h=gs(h,n),u=ys(u),u=fs(u,n),u=gs(u,n),h=bs(h),u=bs(u),n.isWebGL2&&!0!==n.isRawShaderMaterial&&(b="#version 300 es\n",_=["precision mediump sampler2DArray;","#define attribute in","#define varying out","#define texture2D texture"].join("\n")+"\n"+_,M=["#define varying in",n.glslVersion===it?"":"out highp vec4 pc_fragColor;",n.glslVersion===it?"":"#define gl_FragColor pc_fragColor","#define gl_FragDepthEXT gl_FragDepth","#define texture2D texture","#define textureCube texture","#define texture2DProj textureProj","#define texture2DLodEXT textureLod","#define texture2DProjLodEXT textureProjLod","#define textureCubeLodEXT textureLod","#define texture2DGradEXT textureGrad","#define texture2DProjGradEXT textureProjGrad","#define textureCubeGradEXT textureGrad"].join("\n")+"\n"+M);const w=b+M+u,S=os(a,35633,b+_+h),E=os(a,35632,w);if(a.attachShader(x,S),a.attachShader(x,E),void 0!==n.index0AttributeName?a.bindAttribLocation(x,0,n.index0AttributeName):!0===n.morphTargets&&a.bindAttribLocation(x,0,"position"),a.linkProgram(x),t.debug.checkShaderErrors){const t=a.getProgramInfoLog(x).trim(),e=a.getShaderInfoLog(S).trim(),n=a.getShaderInfoLog(E).trim();let i=!0,r=!0;if(!1===a.getProgramParameter(x,35714)){i=!1;const e=hs(a,S,"vertex"),n=hs(a,E,"fragment");console.error("THREE.WebGLProgram: Shader Error "+a.getError()+" - VALIDATE_STATUS "+a.getProgramParameter(x,35715)+"\n\nProgram Info Log: "+t+"\n"+e+"\n"+n)}else""!==t?console.warn("THREE.WebGLProgram: Program Info Log:",t):""!==e&&""!==n||(r=!1);r&&(this.diagnostics={runnable:i,programLog:t,vertexShader:{log:e,prefix:_},fragmentShader:{log:n,prefix:M}})}let A,L;return a.deleteShader(S),a.deleteShader(E),this.getUniforms=function(){return void 0===A&&(A=new as(a,x)),A},this.getAttributes=function(){return void 0===L&&(L=function(t,e){const n={},i=t.getProgramParameter(e,35721);for(let r=0;r0,C=s.clearcoat>0;return{isWebGL2:h,shaderID:S,shaderName:s.type,vertexShader:E,fragmentShader:A,defines:s.defines,isRawShaderMaterial:!0===s.isRawShaderMaterial,glslVersion:s.glslVersion,precision:f,instancing:!0===_.isInstancedMesh,instancingColor:!0===_.isInstancedMesh&&null!==_.instanceColor,supportsVertexTextures:m,outputEncoding:null!==L?y(L.texture):t.outputEncoding,map:!!s.map,mapEncoding:y(s.map),matcap:!!s.matcap,matcapEncoding:y(s.matcap),envMap:!!w,envMapMode:w&&w.mapping,envMapEncoding:y(w),envMapCubeUV:!!w&&(w.mapping===l||w.mapping===c),lightMap:!!s.lightMap,lightMapEncoding:y(s.lightMap),aoMap:!!s.aoMap,emissiveMap:!!s.emissiveMap,emissiveMapEncoding:y(s.emissiveMap),bumpMap:!!s.bumpMap,normalMap:!!s.normalMap,objectSpaceNormalMap:1===s.normalMapType,tangentSpaceNormalMap:0===s.normalMapType,clearcoat:C,clearcoatMap:C&&!!s.clearcoatMap,clearcoatRoughnessMap:C&&!!s.clearcoatRoughnessMap,clearcoatNormalMap:C&&!!s.clearcoatNormalMap,displacementMap:!!s.displacementMap,roughnessMap:!!s.roughnessMap,metalnessMap:!!s.metalnessMap,specularMap:!!s.specularMap,specularIntensityMap:!!s.specularIntensityMap,specularColorMap:!!s.specularColorMap,specularColorMapEncoding:y(s.specularColorMap),alphaMap:!!s.alphaMap,alphaTest:R,gradientMap:!!s.gradientMap,sheen:s.sheen>0,sheenColorMap:!!s.sheenColorMap,sheenColorMapEncoding:y(s.sheenColorMap),sheenRoughnessMap:!!s.sheenRoughnessMap,transmission:s.transmission>0,transmissionMap:!!s.transmissionMap,thicknessMap:!!s.thicknessMap,combine:s.combine,vertexTangents:!!s.normalMap&&!!_.geometry&&!!_.geometry.attributes.tangent,vertexColors:s.vertexColors,vertexAlphas:!0===s.vertexColors&&!!_.geometry&&!!_.geometry.attributes.color&&4===_.geometry.attributes.color.itemSize,vertexUvs:!!s.map||!!s.bumpMap||!!s.normalMap||!!s.specularMap||!!s.alphaMap||!!s.emissiveMap||!!s.roughnessMap||!!s.metalnessMap||!!s.clearcoatMap||!!s.clearcoatRoughnessMap||!!s.clearcoatNormalMap||!!s.displacementMap||!!s.transmissionMap||!!s.thicknessMap||!!s.specularIntensityMap||!!s.specularColorMap||!!s.sheenColorMap||s.sheenRoughnessMap,uvsVertexOnly:!(s.map||s.bumpMap||s.normalMap||s.specularMap||s.alphaMap||s.emissiveMap||s.roughnessMap||s.metalnessMap||s.clearcoatNormalMap||s.transmission>0||s.transmissionMap||s.thicknessMap||s.specularIntensityMap||s.specularColorMap||!!s.sheen>0||s.sheenColorMap||s.sheenRoughnessMap||!s.displacementMap),fog:!!M,useFog:s.fog,fogExp2:M&&M.isFogExp2,flatShading:!!s.flatShading,sizeAttenuation:s.sizeAttenuation,logarithmicDepthBuffer:u,skinning:!0===_.isSkinnedMesh&&T>0,maxBones:T,useVertexTexture:d,morphTargets:!!_.geometry&&!!_.geometry.morphAttributes.position,morphNormals:!!_.geometry&&!!_.geometry.morphAttributes.normal,morphTargetsCount:_.geometry&&_.geometry.morphAttributes.position?_.geometry.morphAttributes.position.length:0,numDirLights:o.directional.length,numPointLights:o.point.length,numSpotLights:o.spot.length,numRectAreaLights:o.rectArea.length,numHemiLights:o.hemi.length,numDirLightShadows:o.directionalShadowMap.length,numPointLightShadows:o.pointShadowMap.length,numSpotLightShadows:o.spotShadowMap.length,numClippingPlanes:a.numPlanes,numClipIntersection:a.numIntersection,format:s.format,dithering:s.dithering,shadowMapEnabled:t.shadowMap.enabled&&v.length>0,shadowMapType:t.shadowMap.type,toneMapping:s.toneMapped?t.toneMapping:0,physicallyCorrectLights:t.physicallyCorrectLights,premultipliedAlpha:s.premultipliedAlpha,doubleSided:2===s.side,flipSided:1===s.side,depthPacking:void 0!==s.depthPacking&&s.depthPacking,index0AttributeName:s.index0AttributeName,extensionDerivatives:s.extensions&&s.extensions.derivatives,extensionFragDepth:s.extensions&&s.extensions.fragDepth,extensionDrawBuffers:s.extensions&&s.extensions.drawBuffers,extensionShaderTextureLOD:s.extensions&&s.extensions.shaderTextureLOD,rendererExtensionFragDepth:h||i.has("EXT_frag_depth"),rendererExtensionDrawBuffers:h||i.has("WEBGL_draw_buffers"),rendererExtensionShaderTextureLod:h||i.has("EXT_shader_texture_lod"),customProgramCacheKey:s.customProgramCacheKey()}},getProgramCacheKey:function(e){const n=[];if(e.shaderID?n.push(e.shaderID):(n.push(St(e.fragmentShader)),n.push(St(e.vertexShader))),void 0!==e.defines)for(const t in e.defines)n.push(t),n.push(e.defines[t]);if(!1===e.isRawShaderMaterial){for(let t=0;t0?r.push(h):!0===n.transparent?s.push(h):i.push(h)},unshift:function(t,e,n,a,l,c){const h=o(t,e,n,a,l,c);n.transmission>0?r.unshift(h):!0===n.transparent?s.unshift(h):i.unshift(h)},finish:function(){for(let t=n,i=e.length;t1&&i.sort(t||Rs),r.length>1&&r.sort(e||Cs),s.length>1&&s.sort(e||Cs)}}}function Is(t){let e=new WeakMap;return{get:function(n,i){let r;return!1===e.has(n)?(r=new Ps(t),e.set(n,[r])):i>=e.get(n).length?(r=new Ps(t),e.get(n).push(r)):r=e.get(n)[i],r},dispose:function(){e=new WeakMap}}}function Ds(){const t={};return{get:function(e){if(void 0!==t[e.id])return t[e.id];let n;switch(e.type){case"DirectionalLight":n={direction:new zt,color:new rn};break;case"SpotLight":n={position:new zt,direction:new zt,color:new rn,distance:0,coneCos:0,penumbraCos:0,decay:0};break;case"PointLight":n={position:new zt,color:new rn,distance:0,decay:0};break;case"HemisphereLight":n={direction:new zt,skyColor:new rn,groundColor:new rn};break;case"RectAreaLight":n={color:new rn,position:new zt,halfWidth:new zt,halfHeight:new zt}}return t[e.id]=n,n}}}let Ns=0;function zs(t,e){return(e.castShadow?1:0)-(t.castShadow?1:0)}function Bs(t,e){const n=new Ds,i=function(){const t={};return{get:function(e){if(void 0!==t[e.id])return t[e.id];let n;switch(e.type){case"DirectionalLight":case"SpotLight":n={shadowBias:0,shadowNormalBias:0,shadowRadius:1,shadowMapSize:new yt};break;case"PointLight":n={shadowBias:0,shadowNormalBias:0,shadowRadius:1,shadowMapSize:new yt,shadowCameraNear:1,shadowCameraFar:1e3}}return t[e.id]=n,n}}}(),r={version:0,hash:{directionalLength:-1,pointLength:-1,spotLength:-1,rectAreaLength:-1,hemiLength:-1,numDirectionalShadows:-1,numPointShadows:-1,numSpotShadows:-1},ambient:[0,0,0],probe:[],directional:[],directionalShadow:[],directionalShadowMap:[],directionalShadowMatrix:[],spot:[],spotShadow:[],spotShadowMap:[],spotShadowMatrix:[],rectArea:[],rectAreaLTC1:null,rectAreaLTC2:null,point:[],pointShadow:[],pointShadowMap:[],pointShadowMatrix:[],hemi:[]};for(let t=0;t<9;t++)r.probe.push(new zt);const s=new zt,a=new de,o=new de;return{setup:function(s,a){let o=0,l=0,c=0;for(let t=0;t<9;t++)r.probe[t].set(0,0,0);let h=0,u=0,d=0,p=0,m=0,f=0,g=0,v=0;s.sort(zs);const y=!0!==a?Math.PI:1;for(let t=0,e=s.length;t0&&(e.isWebGL2||!0===t.has("OES_texture_float_linear")?(r.rectAreaLTC1=mi.LTC_FLOAT_1,r.rectAreaLTC2=mi.LTC_FLOAT_2):!0===t.has("OES_texture_half_float_linear")?(r.rectAreaLTC1=mi.LTC_HALF_1,r.rectAreaLTC2=mi.LTC_HALF_2):console.error("THREE.WebGLRenderer: Unable to use RectAreaLight. Missing WebGL extensions.")),r.ambient[0]=o,r.ambient[1]=l,r.ambient[2]=c;const x=r.hash;x.directionalLength===h&&x.pointLength===u&&x.spotLength===d&&x.rectAreaLength===p&&x.hemiLength===m&&x.numDirectionalShadows===f&&x.numPointShadows===g&&x.numSpotShadows===v||(r.directional.length=h,r.spot.length=d,r.rectArea.length=p,r.point.length=u,r.hemi.length=m,r.directionalShadow.length=f,r.directionalShadowMap.length=f,r.pointShadow.length=g,r.pointShadowMap.length=g,r.spotShadow.length=v,r.spotShadowMap.length=v,r.directionalShadowMatrix.length=f,r.pointShadowMatrix.length=g,r.spotShadowMatrix.length=v,x.directionalLength=h,x.pointLength=u,x.spotLength=d,x.rectAreaLength=p,x.hemiLength=m,x.numDirectionalShadows=f,x.numPointShadows=g,x.numSpotShadows=v,r.version=Ns++)},setupView:function(t,e){let n=0,i=0,l=0,c=0,h=0;const u=e.matrixWorldInverse;for(let e=0,d=t.length;e=n.get(i).length?(s=new Fs(t,e),n.get(i).push(s)):s=n.get(i)[r],s},dispose:function(){n=new WeakMap}}}class Us extends Ze{constructor(t){super(),this.type="MeshDepthMaterial",this.depthPacking=3200,this.map=null,this.alphaMap=null,this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.wireframe=!1,this.wireframeLinewidth=1,this.fog=!1,this.setValues(t)}copy(t){return super.copy(t),this.depthPacking=t.depthPacking,this.map=t.map,this.alphaMap=t.alphaMap,this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this}}Us.prototype.isMeshDepthMaterial=!0;class Hs extends Ze{constructor(t){super(),this.type="MeshDistanceMaterial",this.referencePosition=new zt,this.nearDistance=1,this.farDistance=1e3,this.map=null,this.alphaMap=null,this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.fog=!1,this.setValues(t)}copy(t){return super.copy(t),this.referencePosition.copy(t.referencePosition),this.nearDistance=t.nearDistance,this.farDistance=t.farDistance,this.map=t.map,this.alphaMap=t.alphaMap,this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this}}Hs.prototype.isMeshDistanceMaterial=!0;function Gs(t,e,n){let i=new ci;const r=new yt,s=new yt,a=new Ct,o=new Us({depthPacking:3201}),l=new Hs,c={},h=n.maxTextureSize,u={0:1,1:0,2:2},d=new Zn({defines:{VSM_SAMPLES:8},uniforms:{shadow_pass:{value:null},resolution:{value:new yt},radius:{value:4}},vertexShader:"void main() {\n\tgl_Position = vec4( position, 1.0 );\n}",fragmentShader:"uniform sampler2D shadow_pass;\nuniform vec2 resolution;\nuniform float radius;\n#include \nvoid main() {\n\tconst float samples = float( VSM_SAMPLES );\n\tfloat mean = 0.0;\n\tfloat squared_mean = 0.0;\n\tfloat uvStride = samples <= 1.0 ? 0.0 : 2.0 / ( samples - 1.0 );\n\tfloat uvStart = samples <= 1.0 ? 0.0 : - 1.0;\n\tfor ( float i = 0.0; i < samples; i ++ ) {\n\t\tfloat uvOffset = uvStart + i * uvStride;\n\t\t#ifdef HORIZONTAL_PASS\n\t\t\tvec2 distribution = unpackRGBATo2Half( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( uvOffset, 0.0 ) * radius ) / resolution ) );\n\t\t\tmean += distribution.x;\n\t\t\tsquared_mean += distribution.y * distribution.y + distribution.x * distribution.x;\n\t\t#else\n\t\t\tfloat depth = unpackRGBAToDepth( texture2D( shadow_pass, ( gl_FragCoord.xy + vec2( 0.0, uvOffset ) * radius ) / resolution ) );\n\t\t\tmean += depth;\n\t\t\tsquared_mean += depth * depth;\n\t\t#endif\n\t}\n\tmean = mean / samples;\n\tsquared_mean = squared_mean / samples;\n\tfloat std_dev = sqrt( squared_mean - mean * mean );\n\tgl_FragColor = pack2HalfToRGBA( vec2( mean, std_dev ) );\n}"}),m=d.clone();m.defines.HORIZONTAL_PASS=1;const f=new En;f.setAttribute("position",new ln(new Float32Array([-1,-1,.5,3,-1,.5,-1,3,.5]),3));const v=new Wn(f,d),y=this;function x(n,i){const r=e.update(v);d.defines.VSM_SAMPLES!==n.blurSamples&&(d.defines.VSM_SAMPLES=n.blurSamples,m.defines.VSM_SAMPLES=n.blurSamples,d.needsUpdate=!0,m.needsUpdate=!0),d.uniforms.shadow_pass.value=n.map.texture,d.uniforms.resolution.value=n.mapSize,d.uniforms.radius.value=n.radius,t.setRenderTarget(n.mapPass),t.clear(),t.renderBufferDirect(i,null,r,d,v,null),m.uniforms.shadow_pass.value=n.mapPass.texture,m.uniforms.resolution.value=n.mapSize,m.uniforms.radius.value=n.radius,t.setRenderTarget(n.map),t.clear(),t.renderBufferDirect(i,null,r,m,v,null)}function _(e,n,i,r,s,a,h){let d=null;const p=!0===r.isPointLight?e.customDistanceMaterial:e.customDepthMaterial;if(d=void 0!==p?p:!0===r.isPointLight?l:o,t.localClippingEnabled&&!0===i.clipShadows&&0!==i.clippingPlanes.length||i.displacementMap&&0!==i.displacementScale||i.alphaMap&&i.alphaTest>0){const t=d.uuid,e=i.uuid;let n=c[t];void 0===n&&(n={},c[t]=n);let r=n[e];void 0===r&&(r=d.clone(),n[e]=r),d=r}return d.visible=i.visible,d.wireframe=i.wireframe,d.side=3===h?null!==i.shadowSide?i.shadowSide:i.side:null!==i.shadowSide?i.shadowSide:u[i.side],d.alphaMap=i.alphaMap,d.alphaTest=i.alphaTest,d.clipShadows=i.clipShadows,d.clippingPlanes=i.clippingPlanes,d.clipIntersection=i.clipIntersection,d.displacementMap=i.displacementMap,d.displacementScale=i.displacementScale,d.displacementBias=i.displacementBias,d.wireframeLinewidth=i.wireframeLinewidth,d.linewidth=i.linewidth,!0===r.isPointLight&&!0===d.isMeshDistanceMaterial&&(d.referencePosition.setFromMatrixPosition(r.matrixWorld),d.nearDistance=s,d.farDistance=a),d}function M(n,r,s,a,o){if(!1===n.visible)return;if(n.layers.test(r.layers)&&(n.isMesh||n.isLine||n.isPoints)&&(n.castShadow||n.receiveShadow&&3===o)&&(!n.frustumCulled||i.intersectsObject(n))){n.modelViewMatrix.multiplyMatrices(s.matrixWorldInverse,n.matrixWorld);const i=e.update(n),r=n.material;if(Array.isArray(r)){const e=i.groups;for(let l=0,c=e.length;lh||r.y>h)&&(r.x>h&&(s.x=Math.floor(h/m.x),r.x=s.x*m.x,u.mapSize.x=s.x),r.y>h&&(s.y=Math.floor(h/m.y),r.y=s.y*m.y,u.mapSize.y=s.y)),null===u.map&&!u.isPointLightShadow&&3===this.type){const t={minFilter:g,magFilter:g,format:E};u.map=new Pt(r.x,r.y,t),u.map.texture.name=c.name+".shadowMap",u.mapPass=new Pt(r.x,r.y,t),u.camera.updateProjectionMatrix()}if(null===u.map){const t={minFilter:p,magFilter:p,format:E};u.map=new Pt(r.x,r.y,t),u.map.texture.name=c.name+".shadowMap",u.camera.updateProjectionMatrix()}t.setRenderTarget(u.map),t.clear();const f=u.getViewportCount();for(let t=0;t=1):-1!==R.indexOf("OpenGL ES")&&(L=parseFloat(/^OpenGL ES (\d)/.exec(R)[1]),A=L>=2);let C=null,P={};const I=t.getParameter(3088),D=t.getParameter(2978),N=(new Ct).fromArray(I),z=(new Ct).fromArray(D);function B(e,n,i){const r=new Uint8Array(4),s=t.createTexture();t.bindTexture(e,s),t.texParameteri(e,10241,9728),t.texParameteri(e,10240,9728);for(let e=0;ei||t.height>i)&&(r=i/Math.max(t.width,t.height)),r<1||!0===e){if("undefined"!=typeof HTMLImageElement&&t instanceof HTMLImageElement||"undefined"!=typeof HTMLCanvasElement&&t instanceof HTMLCanvasElement||"undefined"!=typeof ImageBitmap&&t instanceof ImageBitmap){const i=e?gt:Math.floor,s=i(r*t.width),a=i(r*t.height);void 0===P&&(P=D(s,a));const o=n?D(s,a):P;o.width=s,o.height=a;return o.getContext("2d").drawImage(t,0,0,s,a),console.warn("THREE.WebGLRenderer: Texture has been resized from ("+t.width+"x"+t.height+") to ("+s+"x"+a+")."),o}return"data"in t&&console.warn("THREE.WebGLRenderer: Image in DataTexture is too big ("+t.width+"x"+t.height+")."),t}return t}function z(t){return mt(t.width)&&mt(t.height)}function B(t,e){return t.generateMipmaps&&e&&t.minFilter!==p&&t.minFilter!==g}function F(e,n,r,s,a=1){t.generateMipmap(e);i.get(n).__maxMipLevel=Math.log2(Math.max(r,s,a))}function O(n,i,r,s){if(!1===o)return i;if(null!==n){if(void 0!==t[n])return t[n];console.warn("THREE.WebGLRenderer: Attempt to use non-existing WebGL internal format '"+n+"'")}let a=i;return 6403===i&&(5126===r&&(a=33326),5131===r&&(a=33325),5121===r&&(a=33321)),6407===i&&(5126===r&&(a=34837),5131===r&&(a=34843),5121===r&&(a=32849)),6408===i&&(5126===r&&(a=34836),5131===r&&(a=34842),5121===r&&(a=s===Y?35907:32856)),33325!==a&&33326!==a&&34842!==a&&34836!==a||e.get("EXT_color_buffer_float"),a}function U(t){return t===p||t===m||t===f?9728:9729}function H(e){const n=e.target;n.removeEventListener("dispose",H),function(e){const n=i.get(e);if(void 0===n.__webglInit)return;t.deleteTexture(n.__webglTexture),i.remove(e)}(n),n.isVideoTexture&&C.delete(n),a.memory.textures--}function G(e){const n=e.target;n.removeEventListener("dispose",G),function(e){const n=e.texture,r=i.get(e),s=i.get(n);if(!e)return;void 0!==s.__webglTexture&&(t.deleteTexture(s.__webglTexture),a.memory.textures--);e.depthTexture&&e.depthTexture.dispose();if(e.isWebGLCubeRenderTarget)for(let e=0;e<6;e++)t.deleteFramebuffer(r.__webglFramebuffer[e]),r.__webglDepthbuffer&&t.deleteRenderbuffer(r.__webglDepthbuffer[e]);else t.deleteFramebuffer(r.__webglFramebuffer),r.__webglDepthbuffer&&t.deleteRenderbuffer(r.__webglDepthbuffer),r.__webglMultisampledFramebuffer&&t.deleteFramebuffer(r.__webglMultisampledFramebuffer),r.__webglColorRenderbuffer&&t.deleteRenderbuffer(r.__webglColorRenderbuffer),r.__webglDepthRenderbuffer&&t.deleteRenderbuffer(r.__webglDepthRenderbuffer);if(e.isWebGLMultipleRenderTargets)for(let e=0,r=n.length;e0&&r.__version!==t.version){const n=t.image;if(void 0===n)console.warn("THREE.WebGLRenderer: Texture marked for update but image is undefined");else{if(!1!==n.complete)return void Z(r,t,e);console.warn("THREE.WebGLRenderer: Texture marked for update but image is incomplete")}}n.activeTexture(33984+e),n.bindTexture(3553,r.__webglTexture)}function W(e,r){const a=i.get(e);e.version>0&&a.__version!==e.version?function(e,i,r){if(6!==i.image.length)return;J(e,i),n.activeTexture(33984+r),n.bindTexture(34067,e.__webglTexture),t.pixelStorei(37440,i.flipY),t.pixelStorei(37441,i.premultiplyAlpha),t.pixelStorei(3317,i.unpackAlignment),t.pixelStorei(37443,0);const a=i&&(i.isCompressedTexture||i.image[0].isCompressedTexture),l=i.image[0]&&i.image[0].isDataTexture,h=[];for(let t=0;t<6;t++)h[t]=a||l?l?i.image[t].image:i.image[t]:N(i.image[t],!1,!0,c);const u=h[0],d=z(u)||o,p=s.convert(i.format),m=s.convert(i.type),f=O(i.internalFormat,p,m,i.encoding);let g;if(X(34067,i,d),a){for(let t=0;t<6;t++){g=h[t].mipmaps;for(let e=0;e1||i.get(s).__currentAnisotropy)&&(t.texParameterf(n,a.TEXTURE_MAX_ANISOTROPY_EXT,Math.min(s.anisotropy,r.getMaxAnisotropy())),i.get(s).__currentAnisotropy=s.anisotropy)}}function J(e,n){void 0===e.__webglInit&&(e.__webglInit=!0,n.addEventListener("dispose",H),e.__webglTexture=t.createTexture(),a.memory.textures++)}function Z(e,i,r){let a=3553;i.isDataTexture2DArray&&(a=35866),i.isDataTexture3D&&(a=32879),J(e,i),n.activeTexture(33984+r),n.bindTexture(a,e.__webglTexture),t.pixelStorei(37440,i.flipY),t.pixelStorei(37441,i.premultiplyAlpha),t.pixelStorei(3317,i.unpackAlignment),t.pixelStorei(37443,0);const l=function(t){return!o&&(t.wrapS!==u||t.wrapT!==u||t.minFilter!==p&&t.minFilter!==g)}(i)&&!1===z(i.image),c=N(i.image,l,!1,x),h=z(c)||o,d=s.convert(i.format);let m,f=s.convert(i.type),v=O(i.internalFormat,d,f,i.encoding);X(a,i,h);const y=i.mipmaps;if(i.isDepthTexture)v=6402,o?v=i.type===b?36012:i.type===M?33190:i.type===S?35056:33189:i.type===b&&console.error("WebGLRenderer: Floating point depth texture requires WebGL2."),i.format===A&&6402===v&&i.type!==_&&i.type!==M&&(console.warn("THREE.WebGLRenderer: Use UnsignedShortType or UnsignedIntType for DepthFormat DepthTexture."),i.type=_,f=s.convert(i.type)),i.format===L&&6402===v&&(v=34041,i.type!==S&&(console.warn("THREE.WebGLRenderer: Use UnsignedInt248Type for DepthStencilFormat DepthTexture."),i.type=S,f=s.convert(i.type))),n.texImage2D(3553,0,v,c.width,c.height,0,d,f,null);else if(i.isDataTexture)if(y.length>0&&h){for(let t=0,e=y.length;t0&&h){for(let t=0,e=y.length;t=l&&console.warn("THREE.WebGLTextures: Trying to use "+t+" texture units while this GPU supports only "+l),k+=1,t},this.resetTextureUnits=function(){k=0},this.setTexture2D=V,this.setTexture2DArray=function(t,e){const r=i.get(t);t.version>0&&r.__version!==t.version?Z(r,t,e):(n.activeTexture(33984+e),n.bindTexture(35866,r.__webglTexture))},this.setTexture3D=function(t,e){const r=i.get(t);t.version>0&&r.__version!==t.version?Z(r,t,e):(n.activeTexture(33984+e),n.bindTexture(32879,r.__webglTexture))},this.setTextureCube=W,this.setupRenderTarget=function(e){const l=e.texture,c=i.get(e),h=i.get(l);e.addEventListener("dispose",G),!0!==e.isWebGLMultipleRenderTargets&&(h.__webglTexture=t.createTexture(),h.__version=l.version,a.memory.textures++);const u=!0===e.isWebGLCubeRenderTarget,d=!0===e.isWebGLMultipleRenderTargets,p=!0===e.isWebGLMultisampleRenderTarget,m=l.isDataTexture3D||l.isDataTexture2DArray,f=z(e)||o;if(!o||l.format!==T||l.type!==b&&l.type!==w||(l.format=E,console.warn("THREE.WebGLRenderer: Rendering to textures with RGB format is not supported. Using RGBA format instead.")),u){c.__webglFramebuffer=[];for(let e=0;e<6;e++)c.__webglFramebuffer[e]=t.createFramebuffer()}else if(c.__webglFramebuffer=t.createFramebuffer(),d)if(r.drawBuffers){const n=e.texture;for(let e=0,r=n.length;eo+c?(l.inputState.pinching=!1,this.dispatchEvent({type:"pinchend",handedness:t.handedness,target:this})):!l.inputState.pinching&&a<=o-c&&(l.inputState.pinching=!0,this.dispatchEvent({type:"pinchstart",handedness:t.handedness,target:this}))}else null!==o&&t.gripSpace&&(r=e.getPose(t.gripSpace,n),null!==r&&(o.matrix.fromArray(r.transform.matrix),o.matrix.decompose(o.position,o.rotation,o.scale),r.linearVelocity?(o.hasLinearVelocity=!0,o.linearVelocity.copy(r.linearVelocity)):o.hasLinearVelocity=!1,r.angularVelocity?(o.hasAngularVelocity=!0,o.angularVelocity.copy(r.angularVelocity)):o.hasAngularVelocity=!1));return null!==a&&(a.visible=null!==i),null!==o&&(o.visible=null!==r),null!==l&&(l.visible=null!==s),this}}class Js extends rt{constructor(t,e){super();const n=this,i=t.state;let r=null,s=1,a=null,o="local-floor",l=null,c=null,h=null,u=null,d=null,p=!1,m=null,f=null,g=null,v=null,y=null,x=null;const _=[],M=new Map,b=new Kn;b.layers.enable(1),b.viewport=new Ct;const w=new Kn;w.layers.enable(2),w.viewport=new Ct;const S=[b,w],T=new js;T.layers.enable(1),T.layers.enable(2);let E=null,A=null;function L(t){const e=M.get(t.inputSource);e&&e.dispatchEvent({type:t.type,data:t.inputSource})}function R(){M.forEach((function(t,e){t.disconnect(e)})),M.clear(),E=null,A=null,i.bindXRFramebuffer(null),t.setRenderTarget(t.getRenderTarget()),h&&e.deleteFramebuffer(h),m&&e.deleteFramebuffer(m),f&&e.deleteRenderbuffer(f),g&&e.deleteRenderbuffer(g),h=null,m=null,f=null,g=null,d=null,u=null,c=null,r=null,z.stop(),n.isPresenting=!1,n.dispatchEvent({type:"sessionend"})}function C(t){const e=r.inputSources;for(let t=0;t<_.length;t++)M.set(e[t],_[t]);for(let e=0;e0&&(e.alphaTest.value=n.alphaTest);const i=t.get(n).envMap;if(i){e.envMap.value=i,e.flipEnvMap.value=i.isCubeTexture&&!1===i.isRenderTargetTexture?-1:1,e.reflectivity.value=n.reflectivity,e.ior.value=n.ior,e.refractionRatio.value=n.refractionRatio;const r=t.get(i).__maxMipLevel;void 0!==r&&(e.maxMipLevel.value=r)}let r,s;n.lightMap&&(e.lightMap.value=n.lightMap,e.lightMapIntensity.value=n.lightMapIntensity),n.aoMap&&(e.aoMap.value=n.aoMap,e.aoMapIntensity.value=n.aoMapIntensity),n.map?r=n.map:n.specularMap?r=n.specularMap:n.displacementMap?r=n.displacementMap:n.normalMap?r=n.normalMap:n.bumpMap?r=n.bumpMap:n.roughnessMap?r=n.roughnessMap:n.metalnessMap?r=n.metalnessMap:n.alphaMap?r=n.alphaMap:n.emissiveMap?r=n.emissiveMap:n.clearcoatMap?r=n.clearcoatMap:n.clearcoatNormalMap?r=n.clearcoatNormalMap:n.clearcoatRoughnessMap?r=n.clearcoatRoughnessMap:n.specularIntensityMap?r=n.specularIntensityMap:n.specularColorMap?r=n.specularColorMap:n.transmissionMap?r=n.transmissionMap:n.thicknessMap?r=n.thicknessMap:n.sheenColorMap?r=n.sheenColorMap:n.sheenRoughnessMap&&(r=n.sheenRoughnessMap),void 0!==r&&(r.isWebGLRenderTarget&&(r=r.texture),!0===r.matrixAutoUpdate&&r.updateMatrix(),e.uvTransform.value.copy(r.matrix)),n.aoMap?s=n.aoMap:n.lightMap&&(s=n.lightMap),void 0!==s&&(s.isWebGLRenderTarget&&(s=s.texture),!0===s.matrixAutoUpdate&&s.updateMatrix(),e.uv2Transform.value.copy(s.matrix))}function n(e,n){e.roughness.value=n.roughness,e.metalness.value=n.metalness,n.roughnessMap&&(e.roughnessMap.value=n.roughnessMap),n.metalnessMap&&(e.metalnessMap.value=n.metalnessMap),n.emissiveMap&&(e.emissiveMap.value=n.emissiveMap),n.bumpMap&&(e.bumpMap.value=n.bumpMap,e.bumpScale.value=n.bumpScale,1===n.side&&(e.bumpScale.value*=-1)),n.normalMap&&(e.normalMap.value=n.normalMap,e.normalScale.value.copy(n.normalScale),1===n.side&&e.normalScale.value.negate()),n.displacementMap&&(e.displacementMap.value=n.displacementMap,e.displacementScale.value=n.displacementScale,e.displacementBias.value=n.displacementBias);t.get(n).envMap&&(e.envMapIntensity.value=n.envMapIntensity)}return{refreshFogUniforms:function(t,e){t.fogColor.value.copy(e.color),e.isFog?(t.fogNear.value=e.near,t.fogFar.value=e.far):e.isFogExp2&&(t.fogDensity.value=e.density)},refreshMaterialUniforms:function(t,i,r,s,a){i.isMeshBasicMaterial?e(t,i):i.isMeshLambertMaterial?(e(t,i),function(t,e){e.emissiveMap&&(t.emissiveMap.value=e.emissiveMap)}(t,i)):i.isMeshToonMaterial?(e(t,i),function(t,e){e.gradientMap&&(t.gradientMap.value=e.gradientMap);e.emissiveMap&&(t.emissiveMap.value=e.emissiveMap);e.bumpMap&&(t.bumpMap.value=e.bumpMap,t.bumpScale.value=e.bumpScale,1===e.side&&(t.bumpScale.value*=-1));e.normalMap&&(t.normalMap.value=e.normalMap,t.normalScale.value.copy(e.normalScale),1===e.side&&t.normalScale.value.negate());e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isMeshPhongMaterial?(e(t,i),function(t,e){t.specular.value.copy(e.specular),t.shininess.value=Math.max(e.shininess,1e-4),e.emissiveMap&&(t.emissiveMap.value=e.emissiveMap);e.bumpMap&&(t.bumpMap.value=e.bumpMap,t.bumpScale.value=e.bumpScale,1===e.side&&(t.bumpScale.value*=-1));e.normalMap&&(t.normalMap.value=e.normalMap,t.normalScale.value.copy(e.normalScale),1===e.side&&t.normalScale.value.negate());e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isMeshStandardMaterial?(e(t,i),i.isMeshPhysicalMaterial?function(t,e,i){n(t,e),t.ior.value=e.ior,e.sheen>0&&(t.sheenColor.value.copy(e.sheenColor).multiplyScalar(e.sheen),t.sheenRoughness.value=e.sheenRoughness,e.sheenColorMap&&(t.sheenColorMap.value=e.sheenColorMap),e.sheenRoughnessMap&&(t.sheenRoughnessMap.value=e.sheenRoughnessMap));e.clearcoat>0&&(t.clearcoat.value=e.clearcoat,t.clearcoatRoughness.value=e.clearcoatRoughness,e.clearcoatMap&&(t.clearcoatMap.value=e.clearcoatMap),e.clearcoatRoughnessMap&&(t.clearcoatRoughnessMap.value=e.clearcoatRoughnessMap),e.clearcoatNormalMap&&(t.clearcoatNormalScale.value.copy(e.clearcoatNormalScale),t.clearcoatNormalMap.value=e.clearcoatNormalMap,1===e.side&&t.clearcoatNormalScale.value.negate()));e.transmission>0&&(t.transmission.value=e.transmission,t.transmissionSamplerMap.value=i.texture,t.transmissionSamplerSize.value.set(i.width,i.height),e.transmissionMap&&(t.transmissionMap.value=e.transmissionMap),t.thickness.value=e.thickness,e.thicknessMap&&(t.thicknessMap.value=e.thicknessMap),t.attenuationDistance.value=e.attenuationDistance,t.attenuationColor.value.copy(e.attenuationColor));t.specularIntensity.value=e.specularIntensity,t.specularColor.value.copy(e.specularColor),e.specularIntensityMap&&(t.specularIntensityMap.value=e.specularIntensityMap);e.specularColorMap&&(t.specularColorMap.value=e.specularColorMap)}(t,i,a):n(t,i)):i.isMeshMatcapMaterial?(e(t,i),function(t,e){e.matcap&&(t.matcap.value=e.matcap);e.bumpMap&&(t.bumpMap.value=e.bumpMap,t.bumpScale.value=e.bumpScale,1===e.side&&(t.bumpScale.value*=-1));e.normalMap&&(t.normalMap.value=e.normalMap,t.normalScale.value.copy(e.normalScale),1===e.side&&t.normalScale.value.negate());e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isMeshDepthMaterial?(e(t,i),function(t,e){e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isMeshDistanceMaterial?(e(t,i),function(t,e){e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias);t.referencePosition.value.copy(e.referencePosition),t.nearDistance.value=e.nearDistance,t.farDistance.value=e.farDistance}(t,i)):i.isMeshNormalMaterial?(e(t,i),function(t,e){e.bumpMap&&(t.bumpMap.value=e.bumpMap,t.bumpScale.value=e.bumpScale,1===e.side&&(t.bumpScale.value*=-1));e.normalMap&&(t.normalMap.value=e.normalMap,t.normalScale.value.copy(e.normalScale),1===e.side&&t.normalScale.value.negate());e.displacementMap&&(t.displacementMap.value=e.displacementMap,t.displacementScale.value=e.displacementScale,t.displacementBias.value=e.displacementBias)}(t,i)):i.isLineBasicMaterial?(function(t,e){t.diffuse.value.copy(e.color),t.opacity.value=e.opacity}(t,i),i.isLineDashedMaterial&&function(t,e){t.dashSize.value=e.dashSize,t.totalSize.value=e.dashSize+e.gapSize,t.scale.value=e.scale}(t,i)):i.isPointsMaterial?function(t,e,n,i){t.diffuse.value.copy(e.color),t.opacity.value=e.opacity,t.size.value=e.size*n,t.scale.value=.5*i,e.map&&(t.map.value=e.map);e.alphaMap&&(t.alphaMap.value=e.alphaMap);e.alphaTest>0&&(t.alphaTest.value=e.alphaTest);let r;e.map?r=e.map:e.alphaMap&&(r=e.alphaMap);void 0!==r&&(!0===r.matrixAutoUpdate&&r.updateMatrix(),t.uvTransform.value.copy(r.matrix))}(t,i,r,s):i.isSpriteMaterial?function(t,e){t.diffuse.value.copy(e.color),t.opacity.value=e.opacity,t.rotation.value=e.rotation,e.map&&(t.map.value=e.map);e.alphaMap&&(t.alphaMap.value=e.alphaMap);e.alphaTest>0&&(t.alphaTest.value=e.alphaTest);let n;e.map?n=e.map:e.alphaMap&&(n=e.alphaMap);void 0!==n&&(!0===n.matrixAutoUpdate&&n.updateMatrix(),t.uvTransform.value.copy(n.matrix))}(t,i):i.isShadowMaterial?(t.color.value.copy(i.color),t.opacity.value=i.opacity):i.isShaderMaterial&&(i.uniformsNeedUpdate=!1)}}}function Qs(t={}){const e=void 0!==t.canvas?t.canvas:function(){const t=wt("canvas");return t.style.display="block",t}(),n=void 0!==t.context?t.context:null,i=void 0!==t.alpha&&t.alpha,r=void 0===t.depth||t.depth,s=void 0===t.stencil||t.stencil,a=void 0!==t.antialias&&t.antialias,o=void 0===t.premultipliedAlpha||t.premultipliedAlpha,l=void 0!==t.preserveDrawingBuffer&&t.preserveDrawingBuffer,c=void 0!==t.powerPreference?t.powerPreference:"default",h=void 0!==t.failIfMajorPerformanceCaveat&&t.failIfMajorPerformanceCaveat;let d=null,m=null;const f=[],g=[];this.domElement=e,this.debug={checkShaderErrors:!0},this.autoClear=!0,this.autoClearColor=!0,this.autoClearDepth=!0,this.autoClearStencil=!0,this.sortObjects=!0,this.clippingPlanes=[],this.localClippingEnabled=!1,this.gammaFactor=2,this.outputEncoding=X,this.physicallyCorrectLights=!1,this.toneMapping=0,this.toneMappingExposure=1;const v=this;let _=!1,M=0,S=0,T=null,A=-1,L=null;const R=new Ct,C=new Ct;let P=null,I=e.width,D=e.height,N=1,z=null,B=null;const F=new Ct(0,0,I,D),O=new Ct(0,0,I,D);let U=!1;const H=[],G=new ci;let k=!1,V=!1,W=null;const j=new de,q=new zt,Y={background:null,fog:null,environment:null,overrideMaterial:null,isScene:!0};function J(){return null===T?N:1}let Z,Q,K,$,tt,et,nt,it,rt,st,at,ot,lt,ct,ht,ut,dt,pt,mt,ft,gt,vt,yt,xt=n;function _t(t,n){for(let i=0;i0&&function(t,e,n){if(null===W){const t=!0===a&&!0===Q.isWebGL2;W=new(t?Dt:Pt)(1024,1024,{generateMipmaps:!0,type:null!==vt.convert(w)?w:x,minFilter:y,magFilter:p,wrapS:u,wrapT:u})}const i=v.getRenderTarget();v.setRenderTarget(W),v.clear();const r=v.toneMapping;v.toneMapping=0,Ft(t,e,n),v.toneMapping=r,et.updateMultisampleRenderTarget(W),et.updateRenderTargetMipmap(W),v.setRenderTarget(i)}(r,e,n),i&&K.viewport(R.copy(i)),r.length>0&&Ft(r,e,n),s.length>0&&Ft(s,e,n),o.length>0&&Ft(o,e,n)}function Ft(t,e,n){const i=!0===e.isScene?e.overrideMaterial:null;for(let r=0,s=t.length;r0?g[g.length-1]:null,f.pop(),d=f.length>0?f[f.length-1]:null},this.getActiveCubeFace=function(){return M},this.getActiveMipmapLevel=function(){return S},this.getRenderTarget=function(){return T},this.setRenderTarget=function(t,e=0,n=0){T=t,M=e,S=n,t&&void 0===tt.get(t).__webglFramebuffer&&et.setupRenderTarget(t);let i=null,r=!1,s=!1;if(t){const n=t.texture;(n.isDataTexture3D||n.isDataTexture2DArray)&&(s=!0);const a=tt.get(t).__webglFramebuffer;t.isWebGLCubeRenderTarget?(i=a[e],r=!0):i=t.isWebGLMultisampleRenderTarget?tt.get(t).__webglMultisampledFramebuffer:a,R.copy(t.viewport),C.copy(t.scissor),P=t.scissorTest}else R.copy(F).multiplyScalar(N).floor(),C.copy(O).multiplyScalar(N).floor(),P=U;if(K.bindFramebuffer(36160,i)&&Q.drawBuffers){let e=!1;if(t)if(t.isWebGLMultipleRenderTargets){const n=t.texture;if(H.length!==n.length||36064!==H[0]){for(let t=0,e=n.length;t=0&&e<=t.width-i&&n>=0&&n<=t.height-r&&xt.readPixels(e,n,i,r,vt.convert(o),vt.convert(l),s):console.error("THREE.WebGLRenderer.readRenderTargetPixels: readPixels from renderTarget failed. Framebuffer not complete.")}finally{const t=null!==T?tt.get(T).__webglFramebuffer:null;K.bindFramebuffer(36160,t)}}},this.copyFramebufferToTexture=function(t,e,n=0){const i=Math.pow(2,-n),r=Math.floor(e.image.width*i),s=Math.floor(e.image.height*i);let a=vt.convert(e.format);Q.isWebGL2&&(6407===a&&(a=32849),6408===a&&(a=32856)),et.setTexture2D(e,0),xt.copyTexImage2D(3553,n,a,t.x,t.y,r,s,0),K.unbindTexture()},this.copyTextureToTexture=function(t,e,n,i=0){const r=e.image.width,s=e.image.height,a=vt.convert(n.format),o=vt.convert(n.type);et.setTexture2D(n,0),xt.pixelStorei(37440,n.flipY),xt.pixelStorei(37441,n.premultiplyAlpha),xt.pixelStorei(3317,n.unpackAlignment),e.isDataTexture?xt.texSubImage2D(3553,i,t.x,t.y,r,s,a,o,e.image.data):e.isCompressedTexture?xt.compressedTexSubImage2D(3553,i,t.x,t.y,e.mipmaps[0].width,e.mipmaps[0].height,a,e.mipmaps[0].data):xt.texSubImage2D(3553,i,t.x,t.y,a,o,e.image),0===i&&n.generateMipmaps&&xt.generateMipmap(3553),K.unbindTexture()},this.copyTextureToTexture3D=function(t,e,n,i,r=0){if(v.isWebGL1Renderer)return void console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: can only be used with WebGL2.");const s=t.max.x-t.min.x+1,a=t.max.y-t.min.y+1,o=t.max.z-t.min.z+1,l=vt.convert(i.format),c=vt.convert(i.type);let h;if(i.isDataTexture3D)et.setTexture3D(i,0),h=32879;else{if(!i.isDataTexture2DArray)return void console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: only supports THREE.DataTexture3D and THREE.DataTexture2DArray.");et.setTexture2DArray(i,0),h=35866}xt.pixelStorei(37440,i.flipY),xt.pixelStorei(37441,i.premultiplyAlpha),xt.pixelStorei(3317,i.unpackAlignment);const u=xt.getParameter(3314),d=xt.getParameter(32878),p=xt.getParameter(3316),m=xt.getParameter(3315),f=xt.getParameter(32877),g=n.isCompressedTexture?n.mipmaps[0]:n.image;xt.pixelStorei(3314,g.width),xt.pixelStorei(32878,g.height),xt.pixelStorei(3316,t.min.x),xt.pixelStorei(3315,t.min.y),xt.pixelStorei(32877,t.min.z),n.isDataTexture||n.isDataTexture3D?xt.texSubImage3D(h,r,e.x,e.y,e.z,s,a,o,l,c,g.data):n.isCompressedTexture?(console.warn("THREE.WebGLRenderer.copyTextureToTexture3D: untested support for compressed srcTexture."),xt.compressedTexSubImage3D(h,r,e.x,e.y,e.z,s,a,o,l,g.data)):xt.texSubImage3D(h,r,e.x,e.y,e.z,s,a,o,l,c,g),xt.pixelStorei(3314,u),xt.pixelStorei(32878,d),xt.pixelStorei(3316,p),xt.pixelStorei(3315,m),xt.pixelStorei(32877,f),0===r&&i.generateMipmaps&&xt.generateMipmap(h),K.unbindTexture()},this.initTexture=function(t){et.setTexture2D(t,0),K.unbindTexture()},this.resetState=function(){M=0,S=0,T=null,K.reset(),yt.reset()},"undefined"!=typeof __THREE_DEVTOOLS__&&__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe",{detail:this}))}Qs.prototype.isWebGLRenderer=!0;class Ks extends Qs{}Ks.prototype.isWebGL1Renderer=!0;class $s{constructor(t,e=25e-5){this.name="",this.color=new rn(t),this.density=e}clone(){return new $s(this.color,this.density)}toJSON(){return{type:"FogExp2",color:this.color.getHex(),density:this.density}}}$s.prototype.isFogExp2=!0;class ta{constructor(t,e=1,n=1e3){this.name="",this.color=new rn(t),this.near=e,this.far=n}clone(){return new ta(this.color,this.near,this.far)}toJSON(){return{type:"Fog",color:this.color.getHex(),near:this.near,far:this.far}}}ta.prototype.isFog=!0;class ea extends Fe{constructor(){super(),this.type="Scene",this.background=null,this.environment=null,this.fog=null,this.overrideMaterial=null,this.autoUpdate=!0,"undefined"!=typeof __THREE_DEVTOOLS__&&__THREE_DEVTOOLS__.dispatchEvent(new CustomEvent("observe",{detail:this}))}copy(t,e){return super.copy(t,e),null!==t.background&&(this.background=t.background.clone()),null!==t.environment&&(this.environment=t.environment.clone()),null!==t.fog&&(this.fog=t.fog.clone()),null!==t.overrideMaterial&&(this.overrideMaterial=t.overrideMaterial.clone()),this.autoUpdate=t.autoUpdate,this.matrixAutoUpdate=t.matrixAutoUpdate,this}toJSON(t){const e=super.toJSON(t);return null!==this.fog&&(e.object.fog=this.fog.toJSON()),e}}ea.prototype.isScene=!0;class na{constructor(t,e){this.array=t,this.stride=e,this.count=void 0!==t?t.length/e:0,this.usage=et,this.updateRange={offset:0,count:-1},this.version=0,this.uuid=ht()}onUploadCallback(){}set needsUpdate(t){!0===t&&this.version++}setUsage(t){return this.usage=t,this}copy(t){return this.array=new t.array.constructor(t.array),this.count=t.count,this.stride=t.stride,this.usage=t.usage,this}copyAt(t,e,n){t*=this.stride,n*=e.stride;for(let i=0,r=this.stride;it.far||e.push({distance:o,point:oa.clone(),uv:Ye.getUV(oa,pa,ma,fa,ga,va,ya,new yt),face:null,object:this})}copy(t){return super.copy(t),void 0!==t.center&&this.center.copy(t.center),this.material=t.material,this}}function _a(t,e,n,i,r,s){ha.subVectors(t,n).addScalar(.5).multiply(i),void 0!==r?(ua.x=s*ha.x-r*ha.y,ua.y=r*ha.x+s*ha.y):ua.copy(ha),t.copy(e),t.x+=ua.x,t.y+=ua.y,t.applyMatrix4(da)}xa.prototype.isSprite=!0;const Ma=new zt,ba=new zt;class wa extends Fe{constructor(){super(),this._currentLevel=0,this.type="LOD",Object.defineProperties(this,{levels:{enumerable:!0,value:[]},isLOD:{value:!0}}),this.autoUpdate=!0}copy(t){super.copy(t,!1);const e=t.levels;for(let t=0,n=e.length;t0){let n,i;for(n=1,i=e.length;n0){Ma.setFromMatrixPosition(this.matrixWorld);const n=t.ray.origin.distanceTo(Ma);this.getObjectForDistance(n).raycast(t,e)}}update(t){const e=this.levels;if(e.length>1){Ma.setFromMatrixPosition(t.matrixWorld),ba.setFromMatrixPosition(this.matrixWorld);const n=Ma.distanceTo(ba)/t.zoom;let i,r;for(e[0].object.visible=!0,i=1,r=e.length;i=e[i].distance;i++)e[i-1].object.visible=!1,e[i].object.visible=!0;for(this._currentLevel=i-1;io)continue;u.applyMatrix4(this.matrixWorld);const d=t.ray.origin.distanceTo(u);dt.far||e.push({distance:d,point:h.clone().applyMatrix4(this.matrixWorld),index:n,face:null,faceIndex:null,object:this})}}else{for(let n=Math.max(0,s.start),i=Math.min(r.count,s.start+s.count)-1;no)continue;u.applyMatrix4(this.matrixWorld);const i=t.ray.origin.distanceTo(u);it.far||e.push({distance:i,point:h.clone().applyMatrix4(this.matrixWorld),index:n,face:null,faceIndex:null,object:this})}}}else n.isGeometry&&console.error("THREE.Line.raycast() no longer supports THREE.Geometry. Use THREE.BufferGeometry instead.")}updateMorphTargets(){const t=this.geometry;if(t.isBufferGeometry){const e=t.morphAttributes,n=Object.keys(e);if(n.length>0){const t=e[n[0]];if(void 0!==t){this.morphTargetInfluences=[],this.morphTargetDictionary={};for(let e=0,n=t.length;e0&&console.error("THREE.Line.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead.")}}}Xa.prototype.isLine=!0;const Ya=new zt,Ja=new zt;class Za extends Xa{constructor(t,e){super(t,e),this.type="LineSegments"}computeLineDistances(){const t=this.geometry;if(t.isBufferGeometry)if(null===t.index){const e=t.attributes.position,n=[];for(let t=0,i=e.count;t0){const t=e[n[0]];if(void 0!==t){this.morphTargetInfluences=[],this.morphTargetDictionary={};for(let e=0,n=t.length;e0&&console.error("THREE.Points.updateMorphTargets() does not support THREE.Geometry. Use THREE.BufferGeometry instead.")}}}function ro(t,e,n,i,r,s,a){const o=to.distanceSqToPoint(t);if(or.far)return;s.push({distance:l,distanceToRay:Math.sqrt(o),point:n,index:e,face:null,object:a})}}io.prototype.isPoints=!0;class so extends Lt{constructor(t,e,n,i,r,s,a,o,l){super(t,e,n,i,r,s,a,o,l),this.format=void 0!==a?a:T,this.minFilter=void 0!==s?s:g,this.magFilter=void 0!==r?r:g,this.generateMipmaps=!1;const c=this;"requestVideoFrameCallback"in t&&t.requestVideoFrameCallback((function e(){c.needsUpdate=!0,t.requestVideoFrameCallback(e)}))}clone(){return new this.constructor(this.image).copy(this)}update(){const t=this.image;!1==="requestVideoFrameCallback"in t&&t.readyState>=t.HAVE_CURRENT_DATA&&(this.needsUpdate=!0)}}so.prototype.isVideoTexture=!0;class ao extends Lt{constructor(t,e,n,i,r,s,a,o,l,c,h,u){super(null,s,a,o,l,c,i,r,h,u),this.image={width:e,height:n},this.mipmaps=t,this.flipY=!1,this.generateMipmaps=!1}}ao.prototype.isCompressedTexture=!0;class oo extends Lt{constructor(t,e,n,i,r,s,a,o,l){super(t,e,n,i,r,s,a,o,l),this.needsUpdate=!0}}oo.prototype.isCanvasTexture=!0;class lo extends Lt{constructor(t,e,n,i,r,s,a,o,l,c){if((c=void 0!==c?c:A)!==A&&c!==L)throw new Error("DepthTexture format must be either THREE.DepthFormat or THREE.DepthStencilFormat");void 0===n&&c===A&&(n=_),void 0===n&&c===L&&(n=S),super(null,i,r,s,a,o,c,n,l),this.image={width:t,height:e},this.magFilter=void 0!==a?a:p,this.minFilter=void 0!==o?o:p,this.flipY=!1,this.generateMipmaps=!1}}lo.prototype.isDepthTexture=!0;class co extends En{constructor(t=1,e=8,n=0,i=2*Math.PI){super(),this.type="CircleGeometry",this.parameters={radius:t,segments:e,thetaStart:n,thetaLength:i},e=Math.max(3,e);const r=[],s=[],a=[],o=[],l=new zt,c=new yt;s.push(0,0,0),a.push(0,0,1),o.push(.5,.5);for(let r=0,h=3;r<=e;r++,h+=3){const u=n+r/e*i;l.x=t*Math.cos(u),l.y=t*Math.sin(u),s.push(l.x,l.y,l.z),a.push(0,0,1),c.x=(s[h]/t+1)/2,c.y=(s[h+1]/t+1)/2,o.push(c.x,c.y)}for(let t=1;t<=e;t++)r.push(t,t+1,0);this.setIndex(r),this.setAttribute("position",new vn(s,3)),this.setAttribute("normal",new vn(a,3)),this.setAttribute("uv",new vn(o,2))}static fromJSON(t){return new co(t.radius,t.segments,t.thetaStart,t.thetaLength)}}class ho extends En{constructor(t=1,e=1,n=1,i=8,r=1,s=!1,a=0,o=2*Math.PI){super(),this.type="CylinderGeometry",this.parameters={radiusTop:t,radiusBottom:e,height:n,radialSegments:i,heightSegments:r,openEnded:s,thetaStart:a,thetaLength:o};const l=this;i=Math.floor(i),r=Math.floor(r);const c=[],h=[],u=[],d=[];let p=0;const m=[],f=n/2;let g=0;function v(n){const r=p,s=new yt,m=new zt;let v=0;const y=!0===n?t:e,x=!0===n?1:-1;for(let t=1;t<=i;t++)h.push(0,f*x,0),u.push(0,x,0),d.push(.5,.5),p++;const _=p;for(let t=0;t<=i;t++){const e=t/i*o+a,n=Math.cos(e),r=Math.sin(e);m.x=y*r,m.y=f*x,m.z=y*n,h.push(m.x,m.y,m.z),u.push(0,x,0),s.x=.5*n+.5,s.y=.5*r*x+.5,d.push(s.x,s.y),p++}for(let t=0;t0&&v(!0),e>0&&v(!1)),this.setIndex(c),this.setAttribute("position",new vn(h,3)),this.setAttribute("normal",new vn(u,3)),this.setAttribute("uv",new vn(d,2))}static fromJSON(t){return new ho(t.radiusTop,t.radiusBottom,t.height,t.radialSegments,t.heightSegments,t.openEnded,t.thetaStart,t.thetaLength)}}class uo extends ho{constructor(t=1,e=1,n=8,i=1,r=!1,s=0,a=2*Math.PI){super(0,t,e,n,i,r,s,a),this.type="ConeGeometry",this.parameters={radius:t,height:e,radialSegments:n,heightSegments:i,openEnded:r,thetaStart:s,thetaLength:a}}static fromJSON(t){return new uo(t.radius,t.height,t.radialSegments,t.heightSegments,t.openEnded,t.thetaStart,t.thetaLength)}}class po extends En{constructor(t=[],e=[],n=1,i=0){super(),this.type="PolyhedronGeometry",this.parameters={vertices:t,indices:e,radius:n,detail:i};const r=[],s=[];function a(t,e,n,i){const r=i+1,s=[];for(let i=0;i<=r;i++){s[i]=[];const a=t.clone().lerp(n,i/r),o=e.clone().lerp(n,i/r),l=r-i;for(let t=0;t<=l;t++)s[i][t]=0===t&&i===r?a:a.clone().lerp(o,t/l)}for(let t=0;t.9&&a<.1&&(e<.2&&(s[t+0]+=1),n<.2&&(s[t+2]+=1),i<.2&&(s[t+4]+=1))}}()}(),this.setAttribute("position",new vn(r,3)),this.setAttribute("normal",new vn(r.slice(),3)),this.setAttribute("uv",new vn(s,2)),0===i?this.computeVertexNormals():this.normalizeNormals()}static fromJSON(t){return new po(t.vertices,t.indices,t.radius,t.details)}}class mo extends po{constructor(t=1,e=0){const n=(1+Math.sqrt(5))/2,i=1/n;super([-1,-1,-1,-1,-1,1,-1,1,-1,-1,1,1,1,-1,-1,1,-1,1,1,1,-1,1,1,1,0,-i,-n,0,-i,n,0,i,-n,0,i,n,-i,-n,0,-i,n,0,i,-n,0,i,n,0,-n,0,-i,n,0,-i,-n,0,i,n,0,i],[3,11,7,3,7,15,3,15,13,7,19,17,7,17,6,7,6,15,17,4,8,17,8,10,17,10,6,8,0,16,8,16,2,8,2,10,0,12,1,0,1,18,0,18,16,6,10,2,6,2,13,6,13,15,2,16,18,2,18,3,2,3,13,18,1,9,18,9,11,18,11,3,4,14,12,4,12,0,4,0,8,11,9,5,11,5,19,11,19,7,19,5,14,19,14,4,19,4,17,1,12,14,1,14,5,1,5,9],t,e),this.type="DodecahedronGeometry",this.parameters={radius:t,detail:e}}static fromJSON(t){return new mo(t.radius,t.detail)}}const fo=new zt,go=new zt,vo=new zt,yo=new Ye;class xo extends En{constructor(t=null,e=1){if(super(),this.type="EdgesGeometry",this.parameters={geometry:t,thresholdAngle:e},null!==t){const n=4,i=Math.pow(10,n),r=Math.cos(at*e),s=t.getIndex(),a=t.getAttribute("position"),o=s?s.count:a.count,l=[0,0,0],c=["a","b","c"],h=new Array(3),u={},d=[];for(let t=0;t0)){l=i;break}l=i-1}if(i=l,n[i]===s)return i/(r-1);const c=n[i];return(i+(s-c)/(n[i+1]-c))/(r-1)}getTangent(t,e){const n=1e-4;let i=t-n,r=t+n;i<0&&(i=0),r>1&&(r=1);const s=this.getPoint(i),a=this.getPoint(r),o=e||(s.isVector2?new yt:new zt);return o.copy(a).sub(s).normalize(),o}getTangentAt(t,e){const n=this.getUtoTmapping(t);return this.getTangent(n,e)}computeFrenetFrames(t,e){const n=new zt,i=[],r=[],s=[],a=new zt,o=new de;for(let e=0;e<=t;e++){const n=e/t;i[e]=this.getTangentAt(n,new zt)}r[0]=new zt,s[0]=new zt;let l=Number.MAX_VALUE;const c=Math.abs(i[0].x),h=Math.abs(i[0].y),u=Math.abs(i[0].z);c<=l&&(l=c,n.set(1,0,0)),h<=l&&(l=h,n.set(0,1,0)),u<=l&&n.set(0,0,1),a.crossVectors(i[0],n).normalize(),r[0].crossVectors(i[0],a),s[0].crossVectors(i[0],r[0]);for(let e=1;e<=t;e++){if(r[e]=r[e-1].clone(),s[e]=s[e-1].clone(),a.crossVectors(i[e-1],i[e]),a.length()>Number.EPSILON){a.normalize();const t=Math.acos(ut(i[e-1].dot(i[e]),-1,1));r[e].applyMatrix4(o.makeRotationAxis(a,t))}s[e].crossVectors(i[e],r[e])}if(!0===e){let e=Math.acos(ut(r[0].dot(r[t]),-1,1));e/=t,i[0].dot(a.crossVectors(r[0],r[t]))>0&&(e=-e);for(let n=1;n<=t;n++)r[n].applyMatrix4(o.makeRotationAxis(i[n],e*n)),s[n].crossVectors(i[n],r[n])}return{tangents:i,normals:r,binormals:s}}clone(){return(new this.constructor).copy(this)}copy(t){return this.arcLengthDivisions=t.arcLengthDivisions,this}toJSON(){const t={metadata:{version:4.5,type:"Curve",generator:"Curve.toJSON"}};return t.arcLengthDivisions=this.arcLengthDivisions,t.type=this.type,t}fromJSON(t){return this.arcLengthDivisions=t.arcLengthDivisions,this}}class Mo extends _o{constructor(t=0,e=0,n=1,i=1,r=0,s=2*Math.PI,a=!1,o=0){super(),this.type="EllipseCurve",this.aX=t,this.aY=e,this.xRadius=n,this.yRadius=i,this.aStartAngle=r,this.aEndAngle=s,this.aClockwise=a,this.aRotation=o}getPoint(t,e){const n=e||new yt,i=2*Math.PI;let r=this.aEndAngle-this.aStartAngle;const s=Math.abs(r)i;)r-=i;r0?0:(Math.floor(Math.abs(l)/r)+1)*r:0===c&&l===r-1&&(l=r-2,c=1),this.closed||l>0?a=i[(l-1)%r]:(So.subVectors(i[0],i[1]).add(i[0]),a=So);const h=i[l%r],u=i[(l+1)%r];if(this.closed||l+2i.length-2?i.length-1:s+1],h=i[s>i.length-3?i.length-1:s+2];return n.set(Ro(a,o.x,l.x,c.x,h.x),Ro(a,o.y,l.y,c.y,h.y)),n}copy(t){super.copy(t),this.points=[];for(let e=0,n=t.points.length;e=n){const t=i[r]-n,s=this.curves[r],a=s.getLength(),o=0===a?0:1-t/a;return s.getPointAt(o,e)}r++}return null}getLength(){const t=this.getCurveLengths();return t[t.length-1]}updateArcLengths(){this.needsUpdate=!0,this.cacheLengths=null,this.getCurveLengths()}getCurveLengths(){if(this.cacheLengths&&this.cacheLengths.length===this.curves.length)return this.cacheLengths;const t=[];let e=0;for(let n=0,i=this.curves.length;n1&&!e[e.length-1].equals(e[0])&&e.push(e[0]),e}copy(t){super.copy(t),this.curves=[];for(let e=0,n=t.curves.length;e0){const t=l.getPoint(0);t.equals(this.currentPoint)||this.lineTo(t.x,t.y)}this.curves.push(l);const c=l.getPoint(1);return this.currentPoint.copy(c),this}copy(t){return super.copy(t),this.currentPoint.copy(t.currentPoint),this}toJSON(){const t=super.toJSON();return t.currentPoint=this.currentPoint.toArray(),t}fromJSON(t){return super.fromJSON(t),this.currentPoint.fromArray(t.currentPoint),this}}class ko extends Go{constructor(t){super(t),this.uuid=ht(),this.type="Shape",this.holes=[]}getPointsHoles(t){const e=[];for(let n=0,i=this.holes.length;n80*n){o=c=t[0],l=h=t[1];for(let e=n;ec&&(c=u),d>h&&(h=d);p=Math.max(c-o,h-l),p=0!==p?1/p:0}return qo(s,a,n,o,l,p),a};function Wo(t,e,n,i,r){let s,a;if(r===function(t,e,n,i){let r=0;for(let s=e,a=n-i;s0)for(s=e;s=e;s-=i)a=ul(s,t[s],t[s+1],a);return a&&sl(a,a.next)&&(dl(a),a=a.next),a}function jo(t,e){if(!t)return t;e||(e=t);let n,i=t;do{if(n=!1,i.steiner||!sl(i,i.next)&&0!==rl(i.prev,i,i.next))i=i.next;else{if(dl(i),i=e=i.prev,i===i.next)break;n=!0}}while(n||i!==e);return e}function qo(t,e,n,i,r,s,a){if(!t)return;!a&&s&&function(t,e,n,i){let r=t;do{null===r.z&&(r.z=tl(r.x,r.y,e,n,i)),r.prevZ=r.prev,r.nextZ=r.next,r=r.next}while(r!==t);r.prevZ.nextZ=null,r.prevZ=null,function(t){let e,n,i,r,s,a,o,l,c=1;do{for(n=t,t=null,s=null,a=0;n;){for(a++,i=n,o=0,e=0;e0||l>0&&i;)0!==o&&(0===l||!i||n.z<=i.z)?(r=n,n=n.nextZ,o--):(r=i,i=i.nextZ,l--),s?s.nextZ=r:t=r,r.prevZ=s,s=r;n=i}s.nextZ=null,c*=2}while(a>1)}(r)}(t,i,r,s);let o,l,c=t;for(;t.prev!==t.next;)if(o=t.prev,l=t.next,s?Yo(t,i,r,s):Xo(t))e.push(o.i/n),e.push(t.i/n),e.push(l.i/n),dl(t),t=l.next,c=l.next;else if((t=l)===c){a?1===a?qo(t=Jo(jo(t),e,n),e,n,i,r,s,2):2===a&&Zo(t,e,n,i,r,s):qo(jo(t),e,n,i,r,s,1);break}}function Xo(t){const e=t.prev,n=t,i=t.next;if(rl(e,n,i)>=0)return!1;let r=t.next.next;for(;r!==t.prev;){if(nl(e.x,e.y,n.x,n.y,i.x,i.y,r.x,r.y)&&rl(r.prev,r,r.next)>=0)return!1;r=r.next}return!0}function Yo(t,e,n,i){const r=t.prev,s=t,a=t.next;if(rl(r,s,a)>=0)return!1;const o=r.xs.x?r.x>a.x?r.x:a.x:s.x>a.x?s.x:a.x,h=r.y>s.y?r.y>a.y?r.y:a.y:s.y>a.y?s.y:a.y,u=tl(o,l,e,n,i),d=tl(c,h,e,n,i);let p=t.prevZ,m=t.nextZ;for(;p&&p.z>=u&&m&&m.z<=d;){if(p!==t.prev&&p!==t.next&&nl(r.x,r.y,s.x,s.y,a.x,a.y,p.x,p.y)&&rl(p.prev,p,p.next)>=0)return!1;if(p=p.prevZ,m!==t.prev&&m!==t.next&&nl(r.x,r.y,s.x,s.y,a.x,a.y,m.x,m.y)&&rl(m.prev,m,m.next)>=0)return!1;m=m.nextZ}for(;p&&p.z>=u;){if(p!==t.prev&&p!==t.next&&nl(r.x,r.y,s.x,s.y,a.x,a.y,p.x,p.y)&&rl(p.prev,p,p.next)>=0)return!1;p=p.prevZ}for(;m&&m.z<=d;){if(m!==t.prev&&m!==t.next&&nl(r.x,r.y,s.x,s.y,a.x,a.y,m.x,m.y)&&rl(m.prev,m,m.next)>=0)return!1;m=m.nextZ}return!0}function Jo(t,e,n){let i=t;do{const r=i.prev,s=i.next.next;!sl(r,s)&&al(r,i,i.next,s)&&cl(r,s)&&cl(s,r)&&(e.push(r.i/n),e.push(i.i/n),e.push(s.i/n),dl(i),dl(i.next),i=t=s),i=i.next}while(i!==t);return jo(i)}function Zo(t,e,n,i,r,s){let a=t;do{let t=a.next.next;for(;t!==a.prev;){if(a.i!==t.i&&il(a,t)){let o=hl(a,t);return a=jo(a,a.next),o=jo(o,o.next),qo(a,e,n,i,r,s),void qo(o,e,n,i,r,s)}t=t.next}a=a.next}while(a!==t)}function Qo(t,e){return t.x-e.x}function Ko(t,e){if(e=function(t,e){let n=e;const i=t.x,r=t.y;let s,a=-1/0;do{if(r<=n.y&&r>=n.next.y&&n.next.y!==n.y){const t=n.x+(r-n.y)*(n.next.x-n.x)/(n.next.y-n.y);if(t<=i&&t>a){if(a=t,t===i){if(r===n.y)return n;if(r===n.next.y)return n.next}s=n.x=n.x&&n.x>=l&&i!==n.x&&nl(rs.x||n.x===s.x&&$o(s,n)))&&(s=n,u=h)),n=n.next}while(n!==o);return s}(t,e),e){const n=hl(e,t);jo(e,e.next),jo(n,n.next)}}function $o(t,e){return rl(t.prev,t,e.prev)<0&&rl(e.next,t,t.next)<0}function tl(t,e,n,i,r){return(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=32767*(t-n)*r)|t<<8))|t<<4))|t<<2))|t<<1))|(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=32767*(e-i)*r)|e<<8))|e<<4))|e<<2))|e<<1))<<1}function el(t){let e=t,n=t;do{(e.x=0&&(t-a)*(i-o)-(n-a)*(e-o)>=0&&(n-a)*(s-o)-(r-a)*(i-o)>=0}function il(t,e){return t.next.i!==e.i&&t.prev.i!==e.i&&!function(t,e){let n=t;do{if(n.i!==t.i&&n.next.i!==t.i&&n.i!==e.i&&n.next.i!==e.i&&al(n,n.next,t,e))return!0;n=n.next}while(n!==t);return!1}(t,e)&&(cl(t,e)&&cl(e,t)&&function(t,e){let n=t,i=!1;const r=(t.x+e.x)/2,s=(t.y+e.y)/2;do{n.y>s!=n.next.y>s&&n.next.y!==n.y&&r<(n.next.x-n.x)*(s-n.y)/(n.next.y-n.y)+n.x&&(i=!i),n=n.next}while(n!==t);return i}(t,e)&&(rl(t.prev,t,e.prev)||rl(t,e.prev,e))||sl(t,e)&&rl(t.prev,t,t.next)>0&&rl(e.prev,e,e.next)>0)}function rl(t,e,n){return(e.y-t.y)*(n.x-e.x)-(e.x-t.x)*(n.y-e.y)}function sl(t,e){return t.x===e.x&&t.y===e.y}function al(t,e,n,i){const r=ll(rl(t,e,n)),s=ll(rl(t,e,i)),a=ll(rl(n,i,t)),o=ll(rl(n,i,e));return r!==s&&a!==o||(!(0!==r||!ol(t,n,e))||(!(0!==s||!ol(t,i,e))||(!(0!==a||!ol(n,t,i))||!(0!==o||!ol(n,e,i)))))}function ol(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 ll(t){return t>0?1:t<0?-1:0}function cl(t,e){return rl(t.prev,t,t.next)<0?rl(t,e,t.next)>=0&&rl(t,t.prev,e)>=0:rl(t,e,t.prev)<0||rl(t,t.next,e)<0}function hl(t,e){const n=new pl(t.i,t.x,t.y),i=new pl(e.i,e.x,e.y),r=t.next,s=e.prev;return t.next=e,e.prev=t,n.next=r,r.prev=n,i.next=n,n.prev=i,s.next=i,i.prev=s,i}function ul(t,e,n,i){const r=new pl(t,e,n);return i?(r.next=i.next,r.prev=i,i.next.prev=r,i.next=r):(r.prev=r,r.next=r),r}function dl(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 pl(t,e,n){this.i=t,this.x=e,this.y=n,this.prev=null,this.next=null,this.z=null,this.prevZ=null,this.nextZ=null,this.steiner=!1}class ml{static area(t){const e=t.length;let n=0;for(let i=e-1,r=0;r2&&t[e-1].equals(t[0])&&t.pop()}function gl(t,e){for(let n=0;nNumber.EPSILON){const u=Math.sqrt(h),d=Math.sqrt(l*l+c*c),p=e.x-o/u,m=e.y+a/u,f=((n.x-c/d-p)*c-(n.y+l/d-m)*l)/(a*c-o*l);i=p+a*f-t.x,r=m+o*f-t.y;const g=i*i+r*r;if(g<=2)return new yt(i,r);s=Math.sqrt(g/2)}else{let t=!1;a>Number.EPSILON?l>Number.EPSILON&&(t=!0):a<-Number.EPSILON?l<-Number.EPSILON&&(t=!0):Math.sign(o)===Math.sign(c)&&(t=!0),t?(i=-o,r=a,s=Math.sqrt(h)):(i=a,r=o,s=Math.sqrt(h/2))}return new yt(i/s,r/s)}const P=[];for(let t=0,e=E.length,n=e-1,i=t+1;t=0;t--){const e=t/p,n=h*Math.cos(e*Math.PI/2),i=u*Math.sin(e*Math.PI/2)+d;for(let t=0,e=E.length;t=0;){const i=n;let r=n-1;r<0&&(r=t.length-1);for(let t=0,n=o+2*p;t0)&&d.push(e,r,l),(t!==n-1||o0!=t>0&&this.version++,this._sheen=t}get clearcoat(){return this._clearcoat}set clearcoat(t){this._clearcoat>0!=t>0&&this.version++,this._clearcoat=t}get transmission(){return this._transmission}set transmission(t){this._transmission>0!=t>0&&this.version++,this._transmission=t}copy(t){return super.copy(t),this.defines={STANDARD:"",PHYSICAL:""},this.clearcoat=t.clearcoat,this.clearcoatMap=t.clearcoatMap,this.clearcoatRoughness=t.clearcoatRoughness,this.clearcoatRoughnessMap=t.clearcoatRoughnessMap,this.clearcoatNormalMap=t.clearcoatNormalMap,this.clearcoatNormalScale.copy(t.clearcoatNormalScale),this.ior=t.ior,this.sheen=t.sheen,this.sheenColor.copy(t.sheenColor),this.sheenColorMap=t.sheenColorMap,this.sheenRoughness=t.sheenRoughness,this.sheenRoughnessMap=t.sheenRoughnessMap,this.transmission=t.transmission,this.transmissionMap=t.transmissionMap,this.thickness=t.thickness,this.thicknessMap=t.thicknessMap,this.attenuationDistance=t.attenuationDistance,this.attenuationColor.copy(t.attenuationColor),this.specularIntensity=t.specularIntensity,this.specularIntensityMap=t.specularIntensityMap,this.specularColor.copy(t.specularColor),this.specularColorMap=t.specularColorMap,this}}Nl.prototype.isMeshPhysicalMaterial=!0;class zl extends Ze{constructor(t){super(),this.type="MeshPhongMaterial",this.color=new rn(16777215),this.specular=new rn(1118481),this.shininess=30,this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new rn(0),this.emissiveIntensity=1,this.emissiveMap=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new yt(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.specularMap=null,this.alphaMap=null,this.envMap=null,this.combine=0,this.reflectivity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.flatShading=!1,this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.specular.copy(t.specular),this.shininess=t.shininess,this.map=t.map,this.lightMap=t.lightMap,this.lightMapIntensity=t.lightMapIntensity,this.aoMap=t.aoMap,this.aoMapIntensity=t.aoMapIntensity,this.emissive.copy(t.emissive),this.emissiveMap=t.emissiveMap,this.emissiveIntensity=t.emissiveIntensity,this.bumpMap=t.bumpMap,this.bumpScale=t.bumpScale,this.normalMap=t.normalMap,this.normalMapType=t.normalMapType,this.normalScale.copy(t.normalScale),this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.specularMap=t.specularMap,this.alphaMap=t.alphaMap,this.envMap=t.envMap,this.combine=t.combine,this.reflectivity=t.reflectivity,this.refractionRatio=t.refractionRatio,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.wireframeLinecap=t.wireframeLinecap,this.wireframeLinejoin=t.wireframeLinejoin,this.flatShading=t.flatShading,this}}zl.prototype.isMeshPhongMaterial=!0;class Bl extends Ze{constructor(t){super(),this.defines={TOON:""},this.type="MeshToonMaterial",this.color=new rn(16777215),this.map=null,this.gradientMap=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new rn(0),this.emissiveIntensity=1,this.emissiveMap=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new yt(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.alphaMap=null,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.map=t.map,this.gradientMap=t.gradientMap,this.lightMap=t.lightMap,this.lightMapIntensity=t.lightMapIntensity,this.aoMap=t.aoMap,this.aoMapIntensity=t.aoMapIntensity,this.emissive.copy(t.emissive),this.emissiveMap=t.emissiveMap,this.emissiveIntensity=t.emissiveIntensity,this.bumpMap=t.bumpMap,this.bumpScale=t.bumpScale,this.normalMap=t.normalMap,this.normalMapType=t.normalMapType,this.normalScale.copy(t.normalScale),this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.alphaMap=t.alphaMap,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.wireframeLinecap=t.wireframeLinecap,this.wireframeLinejoin=t.wireframeLinejoin,this}}Bl.prototype.isMeshToonMaterial=!0;class Fl extends Ze{constructor(t){super(),this.type="MeshNormalMaterial",this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new yt(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.wireframe=!1,this.wireframeLinewidth=1,this.fog=!1,this.flatShading=!1,this.setValues(t)}copy(t){return super.copy(t),this.bumpMap=t.bumpMap,this.bumpScale=t.bumpScale,this.normalMap=t.normalMap,this.normalMapType=t.normalMapType,this.normalScale.copy(t.normalScale),this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.flatShading=t.flatShading,this}}Fl.prototype.isMeshNormalMaterial=!0;class Ol extends Ze{constructor(t){super(),this.type="MeshLambertMaterial",this.color=new rn(16777215),this.map=null,this.lightMap=null,this.lightMapIntensity=1,this.aoMap=null,this.aoMapIntensity=1,this.emissive=new rn(0),this.emissiveIntensity=1,this.emissiveMap=null,this.specularMap=null,this.alphaMap=null,this.envMap=null,this.combine=0,this.reflectivity=1,this.refractionRatio=.98,this.wireframe=!1,this.wireframeLinewidth=1,this.wireframeLinecap="round",this.wireframeLinejoin="round",this.setValues(t)}copy(t){return super.copy(t),this.color.copy(t.color),this.map=t.map,this.lightMap=t.lightMap,this.lightMapIntensity=t.lightMapIntensity,this.aoMap=t.aoMap,this.aoMapIntensity=t.aoMapIntensity,this.emissive.copy(t.emissive),this.emissiveMap=t.emissiveMap,this.emissiveIntensity=t.emissiveIntensity,this.specularMap=t.specularMap,this.alphaMap=t.alphaMap,this.envMap=t.envMap,this.combine=t.combine,this.reflectivity=t.reflectivity,this.refractionRatio=t.refractionRatio,this.wireframe=t.wireframe,this.wireframeLinewidth=t.wireframeLinewidth,this.wireframeLinecap=t.wireframeLinecap,this.wireframeLinejoin=t.wireframeLinejoin,this}}Ol.prototype.isMeshLambertMaterial=!0;class Ul extends Ze{constructor(t){super(),this.defines={MATCAP:""},this.type="MeshMatcapMaterial",this.color=new rn(16777215),this.matcap=null,this.map=null,this.bumpMap=null,this.bumpScale=1,this.normalMap=null,this.normalMapType=0,this.normalScale=new yt(1,1),this.displacementMap=null,this.displacementScale=1,this.displacementBias=0,this.alphaMap=null,this.flatShading=!1,this.setValues(t)}copy(t){return super.copy(t),this.defines={MATCAP:""},this.color.copy(t.color),this.matcap=t.matcap,this.map=t.map,this.bumpMap=t.bumpMap,this.bumpScale=t.bumpScale,this.normalMap=t.normalMap,this.normalMapType=t.normalMapType,this.normalScale.copy(t.normalScale),this.displacementMap=t.displacementMap,this.displacementScale=t.displacementScale,this.displacementBias=t.displacementBias,this.alphaMap=t.alphaMap,this.flatShading=t.flatShading,this}}Ul.prototype.isMeshMatcapMaterial=!0;class Hl extends Ga{constructor(t){super(),this.type="LineDashedMaterial",this.scale=1,this.dashSize=3,this.gapSize=1,this.setValues(t)}copy(t){return super.copy(t),this.scale=t.scale,this.dashSize=t.dashSize,this.gapSize=t.gapSize,this}}Hl.prototype.isLineDashedMaterial=!0;var Gl=Object.freeze({__proto__:null,ShadowMaterial:Il,SpriteMaterial:sa,RawShaderMaterial:wi,ShaderMaterial:Zn,PointsMaterial:Ka,MeshPhysicalMaterial:Nl,MeshStandardMaterial:Dl,MeshPhongMaterial:zl,MeshToonMaterial:Bl,MeshNormalMaterial:Fl,MeshLambertMaterial:Ol,MeshDepthMaterial:Us,MeshDistanceMaterial:Hs,MeshBasicMaterial:sn,MeshMatcapMaterial:Ul,LineDashedMaterial:Hl,LineBasicMaterial:Ga,Material:Ze});const kl={arraySlice:function(t,e,n){return kl.isTypedArray(t)?new t.constructor(t.subarray(e,void 0!==n?n:t.length)):t.slice(e,n)},convertArray:function(t,e,n){return!t||!n&&t.constructor===e?t:"number"==typeof e.BYTES_PER_ELEMENT?new e(t):Array.prototype.slice.call(t)},isTypedArray:function(t){return ArrayBuffer.isView(t)&&!(t instanceof DataView)},getKeyframeOrder:function(t){const e=t.length,n=new Array(e);for(let t=0;t!==e;++t)n[t]=t;return n.sort((function(e,n){return t[e]-t[n]})),n},sortedArray:function(t,e,n){const i=t.length,r=new t.constructor(i);for(let s=0,a=0;a!==i;++s){const i=n[s]*e;for(let n=0;n!==e;++n)r[a++]=t[i+n]}return r},flattenJSON:function(t,e,n,i){let r=1,s=t[0];for(;void 0!==s&&void 0===s[i];)s=t[r++];if(void 0===s)return;let a=s[i];if(void 0!==a)if(Array.isArray(a))do{a=s[i],void 0!==a&&(e.push(s.time),n.push.apply(n,a)),s=t[r++]}while(void 0!==s);else if(void 0!==a.toArray)do{a=s[i],void 0!==a&&(e.push(s.time),a.toArray(n,n.length)),s=t[r++]}while(void 0!==s);else do{a=s[i],void 0!==a&&(e.push(s.time),n.push(a)),s=t[r++]}while(void 0!==s)},subclip:function(t,e,n,i,r=30){const s=t.clone();s.name=e;const a=[];for(let t=0;t=i)){l.push(e.times[t]);for(let n=0;ns.tracks[t].times[0]&&(o=s.tracks[t].times[0]);for(let t=0;t=i.times[u]){const t=u*l+o,e=t+l-o;d=kl.arraySlice(i.values,t,e)}else{const t=i.createInterpolant(),e=o,n=l-o;t.evaluate(s),d=kl.arraySlice(t.resultBuffer,e,n)}if("quaternion"===r){(new Nt).fromArray(d).normalize().conjugate().toArray(d)}const p=a.times.length;for(let t=0;t=r)break t;{const a=e[1];t=r)break e}s=n,n=0}}for(;n>>1;te;)--s;if(++s,0!==r||s!==i){r>=s&&(s=Math.max(s,1),r=s-1);const t=this.getValueSize();this.times=kl.arraySlice(n,r,s),this.values=kl.arraySlice(this.values,r*t,s*t)}return this}validate(){let t=!0;const e=this.getValueSize();e-Math.floor(e)!=0&&(console.error("THREE.KeyframeTrack: Invalid value size in track.",this),t=!1);const n=this.times,i=this.values,r=n.length;0===r&&(console.error("THREE.KeyframeTrack: Track is empty.",this),t=!1);let s=null;for(let e=0;e!==r;e++){const i=n[e];if("number"==typeof i&&isNaN(i)){console.error("THREE.KeyframeTrack: Time is not a valid number.",this,e,i),t=!1;break}if(null!==s&&s>i){console.error("THREE.KeyframeTrack: Out of order keys.",this,e,i,s),t=!1;break}s=i}if(void 0!==i&&kl.isTypedArray(i))for(let e=0,n=i.length;e!==n;++e){const n=i[e];if(isNaN(n)){console.error("THREE.KeyframeTrack: Value is not a valid number.",this,e,n),t=!1;break}}return t}optimize(){const t=kl.arraySlice(this.times),e=kl.arraySlice(this.values),n=this.getValueSize(),i=this.getInterpolation()===G,r=t.length-1;let s=1;for(let a=1;a0){t[s]=t[r];for(let t=r*n,i=s*n,a=0;a!==n;++a)e[i+a]=e[t+a];++s}return s!==t.length?(this.times=kl.arraySlice(t,0,s),this.values=kl.arraySlice(e,0,s*n)):(this.times=t,this.values=e),this}clone(){const t=kl.arraySlice(this.times,0),e=kl.arraySlice(this.values,0),n=new(0,this.constructor)(this.name,t,e);return n.createInterpolant=this.createInterpolant,n}}Xl.prototype.TimeBufferType=Float32Array,Xl.prototype.ValueBufferType=Float32Array,Xl.prototype.DefaultInterpolation=H;class Yl extends Xl{}Yl.prototype.ValueTypeName="bool",Yl.prototype.ValueBufferType=Array,Yl.prototype.DefaultInterpolation=U,Yl.prototype.InterpolantFactoryMethodLinear=void 0,Yl.prototype.InterpolantFactoryMethodSmooth=void 0;class Jl extends Xl{}Jl.prototype.ValueTypeName="color";class Zl extends Xl{}Zl.prototype.ValueTypeName="number";class Ql extends Vl{constructor(t,e,n,i){super(t,e,n,i)}interpolate_(t,e,n,i){const r=this.resultBuffer,s=this.sampleValues,a=this.valueSize,o=(n-e)/(i-e);let l=t*a;for(let t=l+a;l!==t;l+=4)Nt.slerpFlat(r,0,s,l-a,s,l,o);return r}}class Kl extends Xl{InterpolantFactoryMethodLinear(t){return new Ql(this.times,this.values,this.getValueSize(),t)}}Kl.prototype.ValueTypeName="quaternion",Kl.prototype.DefaultInterpolation=H,Kl.prototype.InterpolantFactoryMethodSmooth=void 0;class $l extends Xl{}$l.prototype.ValueTypeName="string",$l.prototype.ValueBufferType=Array,$l.prototype.DefaultInterpolation=U,$l.prototype.InterpolantFactoryMethodLinear=void 0,$l.prototype.InterpolantFactoryMethodSmooth=void 0;class tc extends Xl{}tc.prototype.ValueTypeName="vector";class ec{constructor(t,e=-1,n,i=2500){this.name=t,this.tracks=n,this.duration=e,this.blendMode=i,this.uuid=ht(),this.duration<0&&this.resetDuration()}static parse(t){const e=[],n=t.tracks,i=1/(t.fps||1);for(let t=0,r=n.length;t!==r;++t)e.push(nc(n[t]).scale(i));const r=new this(t.name,t.duration,e,t.blendMode);return r.uuid=t.uuid,r}static toJSON(t){const e=[],n=t.tracks,i={name:t.name,duration:t.duration,tracks:e,uuid:t.uuid,blendMode:t.blendMode};for(let t=0,i=n.length;t!==i;++t)e.push(Xl.toJSON(n[t]));return i}static CreateFromMorphTargetSequence(t,e,n,i){const r=e.length,s=[];for(let t=0;t1){const t=s[1];let e=i[t];e||(i[t]=e=[]),e.push(n)}}const s=[];for(const t in i)s.push(this.CreateFromMorphTargetSequence(t,i[t],e,n));return s}static parseAnimation(t,e){if(!t)return console.error("THREE.AnimationClip: No animation in JSONLoader data."),null;const n=function(t,e,n,i,r){if(0!==n.length){const s=[],a=[];kl.flattenJSON(n,s,a,i),0!==s.length&&r.push(new t(e,s,a))}},i=[],r=t.name||"default",s=t.fps||30,a=t.blendMode;let o=t.length||-1;const l=t.hierarchy||[];for(let t=0;t{e&&e(r),this.manager.itemEnd(t)}),0),r;if(void 0!==oc[t])return void oc[t].push({onLoad:e,onProgress:n,onError:i});oc[t]=[],oc[t].push({onLoad:e,onProgress:n,onError:i});const s=new Request(t,{headers:new Headers(this.requestHeader),credentials:this.withCredentials?"include":"same-origin"});fetch(s).then((e=>{if(200===e.status||0===e.status){0===e.status&&console.warn("THREE.FileLoader: HTTP Status 0 received.");const n=oc[t],i=e.body.getReader(),r=e.headers.get("Content-Length"),s=r?parseInt(r):0,a=0!==s;let o=0;return new ReadableStream({start(t){!function e(){i.read().then((({done:i,value:r})=>{if(i)t.close();else{o+=r.byteLength;const i=new ProgressEvent("progress",{lengthComputable:a,loaded:o,total:s});for(let t=0,e=n.length;t{const e=new Response(t);switch(this.responseType){case"arraybuffer":return e.arrayBuffer();case"blob":return e.blob();case"document":return e.text().then((t=>(new DOMParser).parseFromString(t,this.mimeType)));case"json":return e.json();default:return e.text()}})).then((e=>{ic.add(t,e);const n=oc[t];delete oc[t];for(let t=0,i=n.length;t{const n=oc[t];delete oc[t];for(let t=0,i=n.length;t0:i.vertexColors=t.vertexColors),void 0!==t.uniforms)for(const e in t.uniforms){const r=t.uniforms[e];switch(i.uniforms[e]={},r.type){case"t":i.uniforms[e].value=n(r.value);break;case"c":i.uniforms[e].value=(new rn).setHex(r.value);break;case"v2":i.uniforms[e].value=(new yt).fromArray(r.value);break;case"v3":i.uniforms[e].value=(new zt).fromArray(r.value);break;case"v4":i.uniforms[e].value=(new Ct).fromArray(r.value);break;case"m3":i.uniforms[e].value=(new xt).fromArray(r.value);break;case"m4":i.uniforms[e].value=(new de).fromArray(r.value);break;default:i.uniforms[e].value=r.value}}if(void 0!==t.defines&&(i.defines=t.defines),void 0!==t.vertexShader&&(i.vertexShader=t.vertexShader),void 0!==t.fragmentShader&&(i.fragmentShader=t.fragmentShader),void 0!==t.extensions)for(const e in t.extensions)i.extensions[e]=t.extensions[e];if(void 0!==t.shading&&(i.flatShading=1===t.shading),void 0!==t.size&&(i.size=t.size),void 0!==t.sizeAttenuation&&(i.sizeAttenuation=t.sizeAttenuation),void 0!==t.map&&(i.map=n(t.map)),void 0!==t.matcap&&(i.matcap=n(t.matcap)),void 0!==t.alphaMap&&(i.alphaMap=n(t.alphaMap)),void 0!==t.bumpMap&&(i.bumpMap=n(t.bumpMap)),void 0!==t.bumpScale&&(i.bumpScale=t.bumpScale),void 0!==t.normalMap&&(i.normalMap=n(t.normalMap)),void 0!==t.normalMapType&&(i.normalMapType=t.normalMapType),void 0!==t.normalScale){let e=t.normalScale;!1===Array.isArray(e)&&(e=[e,e]),i.normalScale=(new yt).fromArray(e)}return void 0!==t.displacementMap&&(i.displacementMap=n(t.displacementMap)),void 0!==t.displacementScale&&(i.displacementScale=t.displacementScale),void 0!==t.displacementBias&&(i.displacementBias=t.displacementBias),void 0!==t.roughnessMap&&(i.roughnessMap=n(t.roughnessMap)),void 0!==t.metalnessMap&&(i.metalnessMap=n(t.metalnessMap)),void 0!==t.emissiveMap&&(i.emissiveMap=n(t.emissiveMap)),void 0!==t.emissiveIntensity&&(i.emissiveIntensity=t.emissiveIntensity),void 0!==t.specularMap&&(i.specularMap=n(t.specularMap)),void 0!==t.specularIntensityMap&&(i.specularIntensityMap=n(t.specularIntensityMap)),void 0!==t.specularColorMap&&(i.specularColorMap=n(t.specularColorMap)),void 0!==t.envMap&&(i.envMap=n(t.envMap)),void 0!==t.envMapIntensity&&(i.envMapIntensity=t.envMapIntensity),void 0!==t.reflectivity&&(i.reflectivity=t.reflectivity),void 0!==t.refractionRatio&&(i.refractionRatio=t.refractionRatio),void 0!==t.lightMap&&(i.lightMap=n(t.lightMap)),void 0!==t.lightMapIntensity&&(i.lightMapIntensity=t.lightMapIntensity),void 0!==t.aoMap&&(i.aoMap=n(t.aoMap)),void 0!==t.aoMapIntensity&&(i.aoMapIntensity=t.aoMapIntensity),void 0!==t.gradientMap&&(i.gradientMap=n(t.gradientMap)),void 0!==t.clearcoatMap&&(i.clearcoatMap=n(t.clearcoatMap)),void 0!==t.clearcoatRoughnessMap&&(i.clearcoatRoughnessMap=n(t.clearcoatRoughnessMap)),void 0!==t.clearcoatNormalMap&&(i.clearcoatNormalMap=n(t.clearcoatNormalMap)),void 0!==t.clearcoatNormalScale&&(i.clearcoatNormalScale=(new yt).fromArray(t.clearcoatNormalScale)),void 0!==t.transmissionMap&&(i.transmissionMap=n(t.transmissionMap)),void 0!==t.thicknessMap&&(i.thicknessMap=n(t.thicknessMap)),void 0!==t.sheenColorMap&&(i.sheenColorMap=n(t.sheenColorMap)),void 0!==t.sheenRoughnessMap&&(i.sheenRoughnessMap=n(t.sheenRoughnessMap)),i}setTextures(t){return this.textures=t,this}}class Dc{static decodeText(t){if("undefined"!=typeof TextDecoder)return(new TextDecoder).decode(t);let e="";for(let n=0,i=t.length;n0){this.source.connect(this.filters[0]);for(let t=1,e=this.filters.length;t0){this.source.disconnect(this.filters[0]);for(let t=1,e=this.filters.length;t0&&this._mixBufferRegionAdditive(n,i,this._addIndex*e,1,e);for(let t=e,r=e+e;t!==r;++t)if(n[t]!==n[t+e]){a.setValue(n,i);break}}saveOriginalState(){const t=this.binding,e=this.buffer,n=this.valueSize,i=n*this._origIndex;t.getValue(e,i);for(let t=n,r=i;t!==r;++t)e[t]=e[i+t%n];this._setIdentity(),this.cumulativeWeight=0,this.cumulativeWeightAdditive=0}restoreOriginalState(){const t=3*this.valueSize;this.binding.setValue(this.buffer,t)}_setAdditiveIdentityNumeric(){const t=this._addIndex*this.valueSize,e=t+this.valueSize;for(let n=t;n=.5)for(let i=0;i!==r;++i)t[e+i]=t[n+i]}_slerp(t,e,n,i){Nt.slerpFlat(t,e,t,e,t,n,i)}_slerpAdditive(t,e,n,i,r){const s=this._workIndex*r;Nt.multiplyQuaternionsFlat(t,s,t,e,t,n),Nt.slerpFlat(t,e,t,e,t,s,i)}_lerp(t,e,n,i,r){const s=1-i;for(let a=0;a!==r;++a){const r=e+a;t[r]=t[r]*s+t[n+a]*i}}_lerpAdditive(t,e,n,i,r){for(let s=0;s!==r;++s){const r=e+s;t[r]=t[r]+t[n+s]*i}}}const ah="\\[\\]\\.:\\/",oh=new RegExp("[\\[\\]\\.:\\/]","g"),lh="[^\\[\\]\\.:\\/]",ch="[^"+ah.replace("\\.","")+"]",hh=/((?:WC+[\/:])*)/.source.replace("WC",lh),uh=/(WCOD+)?/.source.replace("WCOD",ch),dh=/(?:\.(WC+)(?:\[(.+)\])?)?/.source.replace("WC",lh),ph=/\.(WC+)(?:\[(.+)\])?/.source.replace("WC",lh),mh=new RegExp("^"+hh+uh+dh+ph+"$"),fh=["material","materials","bones"];class gh{constructor(t,e,n){this.path=e,this.parsedPath=n||gh.parseTrackName(e),this.node=gh.findNode(t,this.parsedPath.nodeName)||t,this.rootNode=t,this.getValue=this._getValue_unbound,this.setValue=this._setValue_unbound}static create(t,e,n){return t&&t.isAnimationObjectGroup?new gh.Composite(t,e,n):new gh(t,e,n)}static sanitizeNodeName(t){return t.replace(/\s/g,"_").replace(oh,"")}static parseTrackName(t){const e=mh.exec(t);if(!e)throw new Error("PropertyBinding: Cannot parse trackName: "+t);const n={nodeName:e[2],objectName:e[3],objectIndex:e[4],propertyName:e[5],propertyIndex:e[6]},i=n.nodeName&&n.nodeName.lastIndexOf(".");if(void 0!==i&&-1!==i){const t=n.nodeName.substring(i+1);-1!==fh.indexOf(t)&&(n.nodeName=n.nodeName.substring(0,i),n.objectName=t)}if(null===n.propertyName||0===n.propertyName.length)throw new Error("PropertyBinding: can not parse propertyName from trackName: "+t);return n}static findNode(t,e){if(!e||""===e||"."===e||-1===e||e===t.name||e===t.uuid)return t;if(t.skeleton){const n=t.skeleton.getBoneByName(e);if(void 0!==n)return n}if(t.children){const n=function(t){for(let i=0;i=r){const s=r++,c=t[s];e[c.uuid]=l,t[l]=c,e[o]=s,t[s]=a;for(let t=0,e=i;t!==e;++t){const e=n[t],i=e[s],r=e[l];e[l]=i,e[s]=r}}}this.nCachedObjects_=r}uncache(){const t=this._objects,e=this._indicesByUUID,n=this._bindings,i=n.length;let r=this.nCachedObjects_,s=t.length;for(let a=0,o=arguments.length;a!==o;++a){const o=arguments[a].uuid,l=e[o];if(void 0!==l)if(delete e[o],l0&&(e[a.uuid]=l),t[l]=a,t.pop();for(let t=0,e=i;t!==e;++t){const e=n[t];e[l]=e[r],e.pop()}}}this.nCachedObjects_=r}subscribe_(t,e){const n=this._bindingsIndicesByPath;let i=n[t];const r=this._bindings;if(void 0!==i)return r[i];const s=this._paths,a=this._parsedPaths,o=this._objects,l=o.length,c=this.nCachedObjects_,h=new Array(l);i=r.length,n[t]=i,s.push(t),a.push(e),r.push(h);for(let n=c,i=o.length;n!==i;++n){const i=o[n];h[n]=new gh(i,t,e)}return h}unsubscribe_(t){const e=this._bindingsIndicesByPath,n=e[t];if(void 0!==n){const i=this._paths,r=this._parsedPaths,s=this._bindings,a=s.length-1,o=s[a];e[t[a]]=n,s[n]=o,s.pop(),r[n]=r[a],r.pop(),i[n]=i[a],i.pop()}}}vh.prototype.isAnimationObjectGroup=!0;class yh{constructor(t,e,n=null,i=e.blendMode){this._mixer=t,this._clip=e,this._localRoot=n,this.blendMode=i;const r=e.tracks,s=r.length,a=new Array(s),o={endingStart:k,endingEnd:k};for(let t=0;t!==s;++t){const e=r[t].createInterpolant(null);a[t]=e,e.settings=o}this._interpolantSettings=o,this._interpolants=a,this._propertyBindings=new Array(s),this._cacheIndex=null,this._byClipCacheIndex=null,this._timeScaleInterpolant=null,this._weightInterpolant=null,this.loop=2201,this._loopCount=-1,this._startTime=null,this.time=0,this.timeScale=1,this._effectiveTimeScale=1,this.weight=1,this._effectiveWeight=1,this.repetitions=1/0,this.paused=!1,this.enabled=!0,this.clampWhenFinished=!1,this.zeroSlopeAtStart=!0,this.zeroSlopeAtEnd=!0}play(){return this._mixer._activateAction(this),this}stop(){return this._mixer._deactivateAction(this),this.reset()}reset(){return this.paused=!1,this.enabled=!0,this.time=0,this._loopCount=-1,this._startTime=null,this.stopFading().stopWarping()}isRunning(){return this.enabled&&!this.paused&&0!==this.timeScale&&null===this._startTime&&this._mixer._isActiveAction(this)}isScheduled(){return this._mixer._isActiveAction(this)}startAt(t){return this._startTime=t,this}setLoop(t,e){return this.loop=t,this.repetitions=e,this}setEffectiveWeight(t){return this.weight=t,this._effectiveWeight=this.enabled?t:0,this.stopFading()}getEffectiveWeight(){return this._effectiveWeight}fadeIn(t){return this._scheduleFading(t,0,1)}fadeOut(t){return this._scheduleFading(t,1,0)}crossFadeFrom(t,e,n){if(t.fadeOut(e),this.fadeIn(e),n){const n=this._clip.duration,i=t._clip.duration,r=i/n,s=n/i;t.warp(1,r,e),this.warp(s,1,e)}return this}crossFadeTo(t,e,n){return t.crossFadeFrom(this,e,n)}stopFading(){const t=this._weightInterpolant;return null!==t&&(this._weightInterpolant=null,this._mixer._takeBackControlInterpolant(t)),this}setEffectiveTimeScale(t){return this.timeScale=t,this._effectiveTimeScale=this.paused?0:t,this.stopWarping()}getEffectiveTimeScale(){return this._effectiveTimeScale}setDuration(t){return this.timeScale=this._clip.duration/t,this.stopWarping()}syncWith(t){return this.time=t.time,this.timeScale=t.timeScale,this.stopWarping()}halt(t){return this.warp(this._effectiveTimeScale,0,t)}warp(t,e,n){const i=this._mixer,r=i.time,s=this.timeScale;let a=this._timeScaleInterpolant;null===a&&(a=i._lendControlInterpolant(),this._timeScaleInterpolant=a);const o=a.parameterPositions,l=a.sampleValues;return o[0]=r,o[1]=r+n,l[0]=t/s,l[1]=e/s,this}stopWarping(){const t=this._timeScaleInterpolant;return null!==t&&(this._timeScaleInterpolant=null,this._mixer._takeBackControlInterpolant(t)),this}getMixer(){return this._mixer}getClip(){return this._clip}getRoot(){return this._localRoot||this._mixer._root}_update(t,e,n,i){if(!this.enabled)return void this._updateWeight(t);const r=this._startTime;if(null!==r){const i=(t-r)*n;if(i<0||0===n)return;this._startTime=null,e=n*i}e*=this._updateTimeScale(t);const s=this._updateTime(e),a=this._updateWeight(t);if(a>0){const t=this._interpolants,e=this._propertyBindings;if(this.blendMode===q)for(let n=0,i=t.length;n!==i;++n)t[n].evaluate(s),e[n].accumulateAdditive(a);else for(let n=0,r=t.length;n!==r;++n)t[n].evaluate(s),e[n].accumulate(i,a)}}_updateWeight(t){let e=0;if(this.enabled){e=this.weight;const n=this._weightInterpolant;if(null!==n){const i=n.evaluate(t)[0];e*=i,t>n.parameterPositions[1]&&(this.stopFading(),0===i&&(this.enabled=!1))}}return this._effectiveWeight=e,e}_updateTimeScale(t){let e=0;if(!this.paused){e=this.timeScale;const n=this._timeScaleInterpolant;if(null!==n){e*=n.evaluate(t)[0],t>n.parameterPositions[1]&&(this.stopWarping(),0===e?this.paused=!0:this.timeScale=e)}}return this._effectiveTimeScale=e,e}_updateTime(t){const e=this._clip.duration,n=this.loop;let i=this.time+t,r=this._loopCount;const s=2202===n;if(0===t)return-1===r?i:s&&1==(1&r)?e-i:i;if(2200===n){-1===r&&(this._loopCount=0,this._setEndings(!0,!0,!1));t:{if(i>=e)i=e;else{if(!(i<0)){this.time=i;break t}i=0}this.clampWhenFinished?this.paused=!0:this.enabled=!1,this.time=i,this._mixer.dispatchEvent({type:"finished",action:this,direction:t<0?-1:1})}}else{if(-1===r&&(t>=0?(r=0,this._setEndings(!0,0===this.repetitions,s)):this._setEndings(0===this.repetitions,!0,s)),i>=e||i<0){const n=Math.floor(i/e);i-=e*n,r+=Math.abs(n);const a=this.repetitions-r;if(a<=0)this.clampWhenFinished?this.paused=!0:this.enabled=!1,i=t>0?e:0,this.time=i,this._mixer.dispatchEvent({type:"finished",action:this,direction:t>0?1:-1});else{if(1===a){const e=t<0;this._setEndings(e,!e,s)}else this._setEndings(!1,!1,s);this._loopCount=r,this.time=i,this._mixer.dispatchEvent({type:"loop",action:this,loopDelta:n})}}else this.time=i;if(s&&1==(1&r))return e-i}return i}_setEndings(t,e,n){const i=this._interpolantSettings;n?(i.endingStart=V,i.endingEnd=V):(i.endingStart=t?this.zeroSlopeAtStart?V:k:W,i.endingEnd=e?this.zeroSlopeAtEnd?V:k:W)}_scheduleFading(t,e,n){const i=this._mixer,r=i.time;let s=this._weightInterpolant;null===s&&(s=i._lendControlInterpolant(),this._weightInterpolant=s);const a=s.parameterPositions,o=s.sampleValues;return a[0]=r,o[0]=e,a[1]=r+t,o[1]=n,this}}class xh extends rt{constructor(t){super(),this._root=t,this._initMemoryManager(),this._accuIndex=0,this.time=0,this.timeScale=1}_bindAction(t,e){const n=t._localRoot||this._root,i=t._clip.tracks,r=i.length,s=t._propertyBindings,a=t._interpolants,o=n.uuid,l=this._bindingsByRootAndName;let c=l[o];void 0===c&&(c={},l[o]=c);for(let t=0;t!==r;++t){const r=i[t],l=r.name;let h=c[l];if(void 0!==h)s[t]=h;else{if(h=s[t],void 0!==h){null===h._cacheIndex&&(++h.referenceCount,this._addInactiveBinding(h,o,l));continue}const i=e&&e._propertyBindings[t].binding.parsedPath;h=new sh(gh.create(n,l,i),r.ValueTypeName,r.getValueSize()),++h.referenceCount,this._addInactiveBinding(h,o,l),s[t]=h}a[t].resultBuffer=h.buffer}}_activateAction(t){if(!this._isActiveAction(t)){if(null===t._cacheIndex){const e=(t._localRoot||this._root).uuid,n=t._clip.uuid,i=this._actionsByClip[n];this._bindAction(t,i&&i.knownActions[0]),this._addInactiveAction(t,n,e)}const e=t._propertyBindings;for(let t=0,n=e.length;t!==n;++t){const n=e[t];0==n.useCount++&&(this._lendBinding(n),n.saveOriginalState())}this._lendAction(t)}}_deactivateAction(t){if(this._isActiveAction(t)){const e=t._propertyBindings;for(let t=0,n=e.length;t!==n;++t){const n=e[t];0==--n.useCount&&(n.restoreOriginalState(),this._takeBackBinding(n))}this._takeBackAction(t)}}_initMemoryManager(){this._actions=[],this._nActiveActions=0,this._actionsByClip={},this._bindings=[],this._nActiveBindings=0,this._bindingsByRootAndName={},this._controlInterpolants=[],this._nActiveControlInterpolants=0;const t=this;this.stats={actions:{get total(){return t._actions.length},get inUse(){return t._nActiveActions}},bindings:{get total(){return t._bindings.length},get inUse(){return t._nActiveBindings}},controlInterpolants:{get total(){return t._controlInterpolants.length},get inUse(){return t._nActiveControlInterpolants}}}}_isActiveAction(t){const e=t._cacheIndex;return null!==e&&e=0;--e)t[e].stop();return this}update(t){t*=this.timeScale;const e=this._actions,n=this._nActiveActions,i=this.time+=t,r=Math.sign(t),s=this._accuIndex^=1;for(let a=0;a!==n;++a){e[a]._update(i,t,r,s)}const a=this._bindings,o=this._nActiveBindings;for(let t=0;t!==o;++t)a[t].apply(s);return this}setTime(t){this.time=0;for(let t=0;tthis.max.x||t.ythis.max.y)}containsBox(t){return this.min.x<=t.min.x&&t.max.x<=this.max.x&&this.min.y<=t.min.y&&t.max.y<=this.max.y}getParameter(t,e){return e.set((t.x-this.min.x)/(this.max.x-this.min.x),(t.y-this.min.y)/(this.max.y-this.min.y))}intersectsBox(t){return!(t.max.xthis.max.x||t.max.ythis.max.y)}clampPoint(t,e){return e.copy(t).clamp(this.min,this.max)}distanceToPoint(t){return Th.copy(t).clamp(this.min,this.max).sub(t).length()}intersect(t){return this.min.max(t.min),this.max.min(t.max),this}union(t){return this.min.min(t.min),this.max.max(t.max),this}translate(t){return this.min.add(t),this.max.add(t),this}equals(t){return t.min.equals(this.min)&&t.max.equals(this.max)}}Eh.prototype.isBox2=!0;const Ah=new zt,Lh=new zt;class Rh{constructor(t=new zt,e=new zt){this.start=t,this.end=e}set(t,e){return this.start.copy(t),this.end.copy(e),this}copy(t){return this.start.copy(t.start),this.end.copy(t.end),this}getCenter(t){return t.addVectors(this.start,this.end).multiplyScalar(.5)}delta(t){return t.subVectors(this.end,this.start)}distanceSq(){return this.start.distanceToSquared(this.end)}distance(){return this.start.distanceTo(this.end)}at(t,e){return this.delta(e).multiplyScalar(t).add(this.start)}closestPointToPointParameter(t,e){Ah.subVectors(t,this.start),Lh.subVectors(this.end,this.start);const n=Lh.dot(Lh);let i=Lh.dot(Ah)/n;return e&&(i=ut(i,0,1)),i}closestPointToPoint(t,e,n){const i=this.closestPointToPointParameter(t,e);return this.delta(n).multiplyScalar(i).add(this.start)}applyMatrix4(t){return this.start.applyMatrix4(t),this.end.applyMatrix4(t),this}equals(t){return t.start.equals(this.start)&&t.end.equals(this.end)}clone(){return(new this.constructor).copy(this)}}const Ch=new zt;const Ph=new zt,Ih=new de,Dh=new de;class Nh extends Za{constructor(t){const e=zh(t),n=new En,i=[],r=[],s=new rn(0,0,1),a=new rn(0,1,0);for(let t=0;t.99999)this.quaternion.set(0,0,0,1);else if(t.y<-.99999)this.quaternion.set(1,0,0,0);else{Yh.set(t.z,0,-t.x).normalize();const e=Math.acos(t.y);this.quaternion.setFromAxisAngle(Yh,e)}}setLength(t,e=.2*t,n=.2*e){this.line.scale.set(1,Math.max(1e-4,t-e),1),this.line.updateMatrix(),this.cone.scale.set(n,e,n),this.cone.position.y=t,this.cone.updateMatrix()}setColor(t){this.line.material.color.set(t),this.cone.material.color.set(t)}copy(t){return super.copy(t,!1),this.line.copy(t.line),this.cone.copy(t.cone),this}},t.Audio=$c,t.AudioAnalyser=rh,t.AudioContext=Gc,t.AudioListener=class extends Fe{constructor(){super(),this.type="AudioListener",this.context=Gc.getContext(),this.gain=this.context.createGain(),this.gain.connect(this.context.destination),this.filter=null,this.timeDelta=0,this._clock=new Xc}getInput(){return this.gain}removeFilter(){return null!==this.filter&&(this.gain.disconnect(this.filter),this.filter.disconnect(this.context.destination),this.gain.connect(this.context.destination),this.filter=null),this}getFilter(){return this.filter}setFilter(t){return null!==this.filter?(this.gain.disconnect(this.filter),this.filter.disconnect(this.context.destination)):this.gain.disconnect(this.context.destination),this.filter=t,this.gain.connect(this.filter),this.filter.connect(this.context.destination),this}getMasterVolume(){return this.gain.gain.value}setMasterVolume(t){return this.gain.gain.setTargetAtTime(t,this.context.currentTime,.01),this}updateMatrixWorld(t){super.updateMatrixWorld(t);const e=this.context.listener,n=this.up;if(this.timeDelta=this._clock.getDelta(),this.matrixWorld.decompose(Jc,Zc,Qc),Kc.set(0,0,-1).applyQuaternion(Zc),e.positionX){const t=this.context.currentTime+this.timeDelta;e.positionX.linearRampToValueAtTime(Jc.x,t),e.positionY.linearRampToValueAtTime(Jc.y,t),e.positionZ.linearRampToValueAtTime(Jc.z,t),e.forwardX.linearRampToValueAtTime(Kc.x,t),e.forwardY.linearRampToValueAtTime(Kc.y,t),e.forwardZ.linearRampToValueAtTime(Kc.z,t),e.upX.linearRampToValueAtTime(n.x,t),e.upY.linearRampToValueAtTime(n.y,t),e.upZ.linearRampToValueAtTime(n.z,t)}else e.setPosition(Jc.x,Jc.y,Jc.z),e.setOrientation(Kc.x,Kc.y,Kc.z,n.x,n.y,n.z)}},t.AudioLoader=kc,t.AxesHelper=Qh,t.AxisHelper=function(t){return console.warn("THREE.AxisHelper has been renamed to THREE.AxesHelper."),new Qh(t)},t.BackSide=1,t.BasicDepthPacking=3200,t.BasicShadowMap=0,t.BinaryTextureLoader=function(t){return console.warn("THREE.BinaryTextureLoader has been renamed to THREE.DataTextureLoader."),new uc(t)},t.Bone=Ca,t.BooleanKeyframeTrack=Yl,t.BoundingBoxHelper=function(t,e){return console.warn("THREE.BoundingBoxHelper has been deprecated. Creating a THREE.BoxHelper instead."),new Xh(t,e)},t.Box2=Eh,t.Box3=Ot,t.Box3Helper=class extends Za{constructor(t,e=16776960){const n=new Uint16Array([0,1,1,2,2,3,3,0,4,5,5,6,6,7,7,4,0,4,1,5,2,6,3,7]),i=new En;i.setIndex(new ln(n,1)),i.setAttribute("position",new vn([1,1,1,-1,1,1,-1,-1,1,1,-1,1,1,1,-1,-1,1,-1,-1,-1,-1,1,-1,-1],3)),super(i,new Ga({color:e,toneMapped:!1})),this.box=t,this.type="Box3Helper",this.geometry.computeBoundingSphere()}updateMatrixWorld(t){const e=this.box;e.isEmpty()||(e.getCenter(this.position),e.getSize(this.scale),this.scale.multiplyScalar(.5),super.updateMatrixWorld(t))}},t.BoxBufferGeometry=qn,t.BoxGeometry=qn,t.BoxHelper=Xh,t.BufferAttribute=ln,t.BufferGeometry=En,t.BufferGeometryLoader=zc,t.ByteType=1010,t.Cache=ic,t.Camera=Qn,t.CameraHelper=class extends Za{constructor(t){const e=new En,n=new Ga({color:16777215,vertexColors:!0,toneMapped:!1}),i=[],r=[],s={},a=new rn(16755200),o=new rn(16711680),l=new rn(43775),c=new rn(16777215),h=new rn(3355443);function u(t,e,n){d(t,n),d(e,n)}function d(t,e){i.push(0,0,0),r.push(e.r,e.g,e.b),void 0===s[t]&&(s[t]=[]),s[t].push(i.length/3-1)}u("n1","n2",a),u("n2","n4",a),u("n4","n3",a),u("n3","n1",a),u("f1","f2",a),u("f2","f4",a),u("f4","f3",a),u("f3","f1",a),u("n1","f1",a),u("n2","f2",a),u("n3","f3",a),u("n4","f4",a),u("p","n1",o),u("p","n2",o),u("p","n3",o),u("p","n4",o),u("u1","u2",l),u("u2","u3",l),u("u3","u1",l),u("c","t",c),u("p","c",h),u("cn1","cn2",h),u("cn3","cn4",h),u("cf1","cf2",h),u("cf3","cf4",h),e.setAttribute("position",new vn(i,3)),e.setAttribute("color",new vn(r,3)),super(e,n),this.type="CameraHelper",this.camera=t,this.camera.updateProjectionMatrix&&this.camera.updateProjectionMatrix(),this.matrix=t.matrixWorld,this.matrixAutoUpdate=!1,this.pointMap=s,this.update()}update(){const t=this.geometry,e=this.pointMap;Wh.projectionMatrixInverse.copy(this.camera.projectionMatrixInverse),jh("c",e,t,Wh,0,0,-1),jh("t",e,t,Wh,0,0,1),jh("n1",e,t,Wh,-1,-1,-1),jh("n2",e,t,Wh,1,-1,-1),jh("n3",e,t,Wh,-1,1,-1),jh("n4",e,t,Wh,1,1,-1),jh("f1",e,t,Wh,-1,-1,1),jh("f2",e,t,Wh,1,-1,1),jh("f3",e,t,Wh,-1,1,1),jh("f4",e,t,Wh,1,1,1),jh("u1",e,t,Wh,.7,1.1,-1),jh("u2",e,t,Wh,-.7,1.1,-1),jh("u3",e,t,Wh,0,2,-1),jh("cf1",e,t,Wh,-1,0,1),jh("cf2",e,t,Wh,1,0,1),jh("cf3",e,t,Wh,0,-1,1),jh("cf4",e,t,Wh,0,1,1),jh("cn1",e,t,Wh,-1,0,-1),jh("cn2",e,t,Wh,1,0,-1),jh("cn3",e,t,Wh,0,-1,-1),jh("cn4",e,t,Wh,0,1,-1),t.getAttribute("position").needsUpdate=!0}dispose(){this.geometry.dispose(),this.material.dispose()}},t.CanvasRenderer=function(){console.error("THREE.CanvasRenderer has been removed")},t.CanvasTexture=oo,t.CatmullRomCurve3=Lo,t.CineonToneMapping=3,t.CircleBufferGeometry=co,t.CircleGeometry=co,t.ClampToEdgeWrapping=u,t.Clock=Xc,t.Color=rn,t.ColorKeyframeTrack=Jl,t.CompressedTexture=ao,t.CompressedTextureLoader=class extends ac{constructor(t){super(t)}load(t,e,n,i){const r=this,s=[],a=new ao,o=new lc(this.manager);o.setPath(this.path),o.setResponseType("arraybuffer"),o.setRequestHeader(this.requestHeader),o.setWithCredentials(r.withCredentials);let l=0;function c(c){o.load(t[c],(function(t){const n=r.parse(t,!0);s[c]={width:n.width,height:n.height,format:n.format,mipmaps:n.mipmaps},l+=1,6===l&&(1===n.mipmapCount&&(a.minFilter=g),a.image=s,a.format=n.format,a.needsUpdate=!0,e&&e(a))}),n,i)}if(Array.isArray(t))for(let e=0,n=t.length;e65504&&(console.warn("THREE.DataUtils.toHalfFloat(): value exceeds 65504."),t=65504),Kh[0]=t;const e=$h[0];let n=e>>16&32768,i=e>>12&2047;const r=e>>23&255;return r<103?n:r>142?(n|=31744,n|=(255==r?0:1)&&8388607&e,n):r<113?(i|=2048,n|=(i>>114-r)+(i>>113-r&1),n):(n|=r-112<<10|i>>1,n+=1&i,n)}},t.DecrementStencilOp=7683,t.DecrementWrapStencilOp=34056,t.DefaultLoadingManager=sc,t.DepthFormat=A,t.DepthStencilFormat=L,t.DepthTexture=lo,t.DirectionalLight=Ac,t.DirectionalLightHelper=class extends Fe{constructor(t,e,n){super(),this.light=t,this.light.updateMatrixWorld(),this.matrix=t.matrixWorld,this.matrixAutoUpdate=!1,this.color=n,void 0===e&&(e=1);let i=new En;i.setAttribute("position",new vn([-e,e,0,e,e,0,e,-e,0,-e,-e,0,-e,e,0],3));const r=new Ga({fog:!1,toneMapped:!1});this.lightPlane=new Xa(i,r),this.add(this.lightPlane),i=new En,i.setAttribute("position",new vn([0,0,0,0,0,1],3)),this.targetLine=new Xa(i,r),this.add(this.targetLine),this.update()}dispose(){this.lightPlane.geometry.dispose(),this.lightPlane.material.dispose(),this.targetLine.geometry.dispose(),this.targetLine.material.dispose()}update(){Hh.setFromMatrixPosition(this.light.matrixWorld),Gh.setFromMatrixPosition(this.light.target.matrixWorld),kh.subVectors(Gh,Hh),this.lightPlane.lookAt(Gh),void 0!==this.color?(this.lightPlane.material.color.set(this.color),this.targetLine.material.color.set(this.color)):(this.lightPlane.material.color.copy(this.light.color),this.targetLine.material.color.copy(this.light.color)),this.targetLine.lookAt(Gh),this.targetLine.scale.z=kh.length()}},t.DiscreteInterpolant=ql,t.DodecahedronBufferGeometry=mo,t.DodecahedronGeometry=mo,t.DoubleSide=2,t.DstAlphaFactor=206,t.DstColorFactor=208,t.DynamicBufferAttribute=function(t,e){return console.warn("THREE.DynamicBufferAttribute has been removed. Use new THREE.BufferAttribute().setUsage( THREE.DynamicDrawUsage ) instead."),new ln(t,e).setUsage(nt)},t.DynamicCopyUsage=35050,t.DynamicDrawUsage=nt,t.DynamicReadUsage=35049,t.EdgesGeometry=xo,t.EdgesHelper=function(t,e){return console.warn("THREE.EdgesHelper has been removed. Use THREE.EdgesGeometry instead."),new Za(new xo(t.geometry),new Ga({color:void 0!==e?e:16777215}))},t.EllipseCurve=Mo,t.EqualDepth=4,t.EqualStencilFunc=514,t.EquirectangularReflectionMapping=a,t.EquirectangularRefractionMapping=o,t.Euler=be,t.EventDispatcher=rt,t.ExtrudeBufferGeometry=vl,t.ExtrudeGeometry=vl,t.FaceColors=1,t.FileLoader=lc,t.FlatShading=1,t.Float16BufferAttribute=gn,t.Float32Attribute=function(t,e){return console.warn("THREE.Float32Attribute has been removed. Use new THREE.Float32BufferAttribute() instead."),new vn(t,e)},t.Float32BufferAttribute=vn,t.Float64Attribute=function(t,e){return console.warn("THREE.Float64Attribute has been removed. Use new THREE.Float64BufferAttribute() instead."),new yn(t,e)},t.Float64BufferAttribute=yn,t.FloatType=b,t.Fog=ta,t.FogExp2=$s,t.Font=function(){console.error("THREE.Font has been moved to /examples/jsm/loaders/FontLoader.js")},t.FontLoader=function(){console.error("THREE.FontLoader has been moved to /examples/jsm/loaders/FontLoader.js")},t.FrontSide=0,t.Frustum=ci,t.GLBufferAttribute=bh,t.GLSL1="100",t.GLSL3=it,t.GammaEncoding=J,t.GreaterDepth=6,t.GreaterEqualDepth=5,t.GreaterEqualStencilFunc=518,t.GreaterStencilFunc=516,t.GridHelper=Uh,t.Group=qs,t.HalfFloatType=w,t.HemisphereLight=mc,t.HemisphereLightHelper=class extends Fe{constructor(t,e,n){super(),this.light=t,this.light.updateMatrixWorld(),this.matrix=t.matrixWorld,this.matrixAutoUpdate=!1,this.color=n;const i=new Ml(e);i.rotateY(.5*Math.PI),this.material=new sn({wireframe:!0,fog:!1,toneMapped:!1}),void 0===this.color&&(this.material.vertexColors=!0);const r=i.getAttribute("position"),s=new Float32Array(3*r.count);i.setAttribute("color",new ln(s,3)),this.add(new Wn(i,this.material)),this.update()}dispose(){this.children[0].geometry.dispose(),this.children[0].material.dispose()}update(){const t=this.children[0];if(void 0!==this.color)this.material.color.set(this.color);else{const e=t.geometry.getAttribute("color");Fh.copy(this.light.color),Oh.copy(this.light.groundColor);for(let t=0,n=e.count;t0){const n=new rc(e);r=new cc(n),r.setCrossOrigin(this.crossOrigin);for(let e=0,n=t.length;e0){i=new cc(this.manager),i.setCrossOrigin(this.crossOrigin);for(let e=0,i=t.length;eNumber.EPSILON){if(l<0&&(n=e[s],o=-o,a=e[r],l=-l),t.ya.y)continue;if(t.y===n.y){if(t.x===n.x)return!0}else{const e=l*(t.x-n.x)-o*(t.y-n.y);if(0===e)return!0;if(e<0)continue;i=!i}}else{if(t.y!==n.y)continue;if(a.x<=t.x&&t.x<=n.x||n.x<=t.x&&t.x<=a.x)return!0}}return i}const r=ml.isClockWise,s=this.subPaths;if(0===s.length)return[];if(!0===e)return n(s);let a,o,l;const c=[];if(1===s.length)return o=s[0],l=new ko,l.curves=o.curves,c.push(l),c;let h=!r(s[0].getPoints());h=t?!h:h;const u=[],d=[];let p,m,f=[],g=0;d[g]=void 0,f[g]=[];for(let e=0,n=s.length;e1){let t=!1;const e=[];for(let t=0,e=d.length;t0&&(t||(f=u))}for(let t=0,e=d.length;tos~P=Sc>kUNgHotyvw z9;26rj*FVHJDG!%y}6YQn9Rk~0Zaz=urdb#JQfR5b>k`c+$3LWkeQ&iV5*6t%@+fc ztDHAJE$Gf&&8US?1mjnIC`uDFJ>p85a?tEAD*KW++Jdf9NirB-Fs0fc- zs_6FcGk)<4YU1XN)GhuypV9O0`cKYC7e4;}!Y`qL{z~Z1FUz~Tz5Xx$l^}cE;{+2y zI?72?Ig!^g_qc`xf@~yr=(zBH;mkX1G!H3AP3u*hop*+ zEL6LaZ!;ZG|YxC}qv0?R`+g5chomXl))Nd>{Hf213fg%_uD< z&h9jmYd0=!?eTd4%X8t3|D6;yGO_lsqH?g=jzMu&Dj^rA9DPfoNkOuf7k)CMK3knN zbib=xjHTV_Z=}L-q4)#O-A0oIzILYAyA+T3pKxs#rjQ0B{E)YgK_D*z&Kv&D?q#!9_!aCNprGUNx#~@fv;ao<>G9EJ{>8 zK;9qFY;lMquiS^j;AgOKC-{XXP{sD$Xl|OIrE&;%H^s9+!h!k1Saqk~WAH8KIX+K2 zHd@0*!aFy2w>K{g<;^tPwn_AnMzmES^DXywYju9pWGBd2t57(&ZpIh3Xjcf_97(pb zHP}2k=%_)Zc-Xcm*0Hr^jhf4TQ@M1MKg4gsO}N~6%i&h(eAQNhSH}1%4kml6-qvE) zF#6pJ@q^V~l#<-wVeB;R!bh3N34DN(9mnyi&}FJp8TsUU!!i&95mo`JksX0FNFWaN zHeuD_J<;e+CI^y;WV~FPYXZ0sg)HGHagfvBNBQF09+}hTaqi5hW+f*A2lc>tEG0_z{iKkS6an}Kb=$V4vP-qHs6|e zkg+S~^%7T(GZf`z2F~KlbtZhU<-?hTWf5ylY&85TpKG0K?1jLC7bf}B^b?PC z4zGPK6GD8B=tWTi4%)B1JcV|>Dn>Z~i6wiB|i^gE5B^r|?8mH)jzZl_Xw$g}+ z3?+J==9j0vLTrV^iKG^D1z1{I7i@+Fb%8vYRag!1KG16sv4KC??at)&^Z z;MDkJwy?ox#_#OrRx2@FU5#Z`zf^2A6|>lBl_sE)eKF0r07~l=6t$u!DE%gmh(_7* z@6+Bj$rp9fO>#0%n-;yY7ej=n|A=_%)bb6Db^&HjyehcsX~OY)W_!c51KD1XboY_$ zR~FS$Y}J+^nA2u-daaUocHW5z?*S?M9D7hQQ{t8nMC}yXK9xbXJnH(5Y=p#NLDq7v#;q?GZ7t8Rs0zXc3a0K?^g8e`zCxU8-PrQj== z!Xto@PB~pURE$#F+e8D?A9G}g$;tAYnZlQ$NFj4bkuM%_=D*h66yA8E@_=;$s?|p7 z=?(pGtKl1=(wm~&mBrM9%gA#3-~gg3fc5%!&fm|>_X&{OX1W>F@pM_g3S3>o!$NIQ0d+`RLeuJRy2%Ax2AL^*Kd{?7)1nt#K zDrcFVgV1aM?GQ^4dL-?%WfCg%?B2Z*VzofPVFq>(F(FETk_-=;q4b1{U-7xlko-4n z`QB{FO(p8?wc)bZAKO#=Y?t(bA0uGixlD~RA=7k4e1_4&9*=>}`%s=MuOj-U6Xvrh zpL7G}epq=VySwqeEiFzApmk6+SXJc`!+e!zeYG1-F9esBI}Q&$n8cwKMN(YnRe`N> zX+9}`U`HqUD24@^LVnf|jpIj0igBEACxsjlnKTrVyM??E_kwLrI zYfS-mCi`#f)8Zikkp)QSgP7LtmU#Rt^wr6id_ib{ku==PR@j(U$wI&@bWV!qM(C?0 z<0<`s+6L|$$7%|(53B1_8%ufs~tmH8yrPsLMuUxpOW_NoM4|@a&4hN)B zo?eLsv|f5yQI@H9Im{rV!fuiso~bz?Ea-`y`X?V482&`4h^nvJE(v@kDFoMx!zoR_ zK0x(@kAJm@SB_jJAHkns%z-Un?;EX<(ZyXhqUT-bDvKzp4vxkSaJ}yfZa+Mi#)mJ= zv+#r(Z)tra)oo{>-qPt8sDBIa4v3#a#~c(#4&u$`!3qg=k(Q71QWK_j8pvN`m)&Xn zya^SzgFgV1CY7Y&fNWsG9xz=mZa1(Hq2B$HreK8>0&-^VJtI%jnAn@GrgrtBsjoom zIj8P;OskPvQ}rb(3>GE#ll7^nRv;h}m+HzR4U7vCx%;YyBHk3SfWZ|psQ#_g^%VD( zvFGa5A-S9Uo<+f0N-BUwd^(%5x@4mw$Br;R@D(&n)FR0bs2$etiLrTvPoxbT>ptz= z)!yn!?URF5P@-Gy^5j)Tf+=vS^kGP6%vC^i%Sg4|4A#ylGA|wh27?gr^m8nyk_i1VgOTQR~ zI*-hK6Ihp4o^UMRA*15IqT9S zF(f39e7OfCjWO@RaWMpvJWEE;Ua@ZJ{y;Oju$HtX3y7DJb%`rhe}z}Na z6s@kN?a>QqJEPZ^FFPGwFa%$h!uTe_IWOk+RP`g&b-Z`pWKcB29)~Tbw&oi;2oDqh zl;sFBNS;ZEOZL&eFGDu`QvbOE4E@PNLelE4eB}p&m?q7;l|cN&$VOw8scx8~Y#|Tc zuT-Fw%?73pj6G4!0sc~-+JSQJAn({hoCA9XjIxX^HQ{emiLiP|eB0E_C_7~p^l!e- zA(MGLaK34zCD(I)ho`p@y-DARAg2O+%em-9Mu~vKVSgEdGi>RT<5{ zp)pB(e(Qy$lFNsIPoqgsB^fsPN@*oHcW^k+RTPXp2rN*N6thvW8tVL(lB6=^udrMl zVj0ga*?kS%FdhQI4AdO*ORRVa05Ij$A)_MbshrPmsm~ zxxT)bZRdC(fRa~@x!zDMGi)`NRy@Ou%-8T{cUP+K)``hA6uGcZW!X{YmyT;z>dA9j zEkQGN+nY#lKoAe2YJ`sFy}Y@z1Zx2vytX&#&aVk?NKQ8h6 z*6(uV!O_a%crBSNl*O6WE^na=o|qgf=ce4-2hia+An|D2s}1m}EIdsOJ!``aR0)$5 zjxUPf((y&VVbSG}H7_`=;>J7frGuY5wl@TQA6bfu+(PbDnQGdPKuuF*b7axLRph$A z2;|zrwEDJ`-e^1d4JV)5*!F;fD~D}(xx0na_QYg}^_Gl<9y(5phs|FCd@%vHSRK_D zq4k68TRC}dmx~W(q>gXl)3hexGrVZSye!?$D$2I>J9_lqFE7Dn;iO~{9CWZ}$Fl2v zR(s`SF83M?wdF}HdW;02bbc?X-fnkW$;4icdzQwXKSVoaG?x0RWwn_#eh8bGivBEF zI5UYer4{okqE;!$Ga()x2kcksux1!AI^_tK^5L!1ZyXU$o4V4J3R@{-l7>Bg)R%^8 zPT1kLi7Vv)d@jymxTEE){je2BbxvaxO4+(7 z<0)dDe zNaS5Ze5DbE61$+RbF+19~z>ph}~05>NY(U(YLSg9cPolsNEie#h?k65ctOD?(N(C z_DagHUw66q#H^8?Li&9fBrM5q*P!`-&D>~jGqR2t{gfnH?JxE3l%c+?HF?kLk#Tf_ zLA(NZop0mpMfuA8aEO&GsGT^2Z3prG70Z`v*>%a93_3WDkzI+_T_N}CFPIjXJ9lY? z40_M_VAInC)&xP<6y>9kYHDj-ip(08%^iYO5<;?z`Onx+*qk56wt&T9wB)EB`rlVQ z7a2L-Ip|^KTAW!@@TGC+4D>L&#T9d!IGE5tYDFe(<+j)K8S`Yni~^fU`CePSPIeOL zR~Dm}vW+QApc4cMp)TN}p~2Zcr>(sP(Xts=>sD!fcpI=1+bfCSBKTUO zFf`+G1x58rX)Q;TVF(W|xcS_ut;}k_y%~Wv;1y}3Dgp87$4nA%%dH0`Ook|FG{V-) zB3!8f0E%f7r+(sB;6_RyJSveWap42KL?g`)RgPHDYw0Ou#UN@D!&lHmUyDBUQWV~1 z{ICw!G(Z>2*EPhqNQ1>X=dDNF(Sbun68IX5{_7Sa6VDX~+o*tlqwyF-xK`%y)o^cGf5M{VEesSoX5?kK&pqO<8R6jNQq}2!H2&?7F4%=RbUfb90 z%tQTpZWUAqoOvb{+*(|tebe$#&jTN!pVi^@3@P5hw=Aa`1j>jVHzHY8L-*-_w+bWL zWUfUoj%p|_Y#MBGu+t#Ot6WrZv^>HZAMTPf5YM8uHb*7vFYt>e1asG7^4i9`Fs_H~l?ybv9Pe zM;AK}Sj71Ip(I|AlY;q7KzoY2MNy7|G2cGC4`%aiHdpOi|-MTb5R zzAVvl$Bri1Rjt&cho1;n?18*K2)`Fcj_y>6475w875f^S=WM~=0hLMUV4OIC$lMt- zl`SVG&Q@;1{)OVS#GV+4(hc=-L<-K;ES8-}z#1*Ee$_3!h`IPATg?;dPH7!xYaAGgeU6wt^_-v)eiZSHLRCu)d+<+H@}`#!m`}=o$Lqlr9^PMvoNjxH|X^o>6(YdTk5-M5DCN2 ztb!l{5$xF4xqh_KeOUXfNc{a2+JjEwi_@;tq}u_RF(mqq10NW}@0CMpLuKp{pb}WdvaUR20LQvNsxDD*ore zDNoz`ErDv44Ay?Wa$;Ipo*@%$Y+r&_`ew3!zmKPW8+HqG_0== zn#}d|>uMuti(xzh99^8$Ts~pFe8$%6^Ke-H=zc@uegg3C7}KaTg;wDjm7&@cr*5N% zeLEE@c1Z!B)u-UAgq?6o^!DcT?237$u6^=}&nqc?7?33@IO@_1TqTRO)#Kmw-DG8u zLq6j>YZk+$^xJMdJSW@@>h;US=bkR{++?j$u{3Ro(VbF>EQ+M~P^#J~vQ_)lGpbIn zvi7IY9f|~>EjZ;Dr*vF5Fqup|Aevr|wpTn+D+c>D-Qq{@+i>D88RirNDpn`PZ0I-f zTL>?~Yb&XDC9*tp*a-Y@Z5~Xq5s#r`Qf>W7m)y2s5d~qi^+w;8z;I;c&+F-JBknE1 zGgs=Twj&rE10D4v5ijXuVgq zR#uKWp1cbe*3hlMPI-r&`yv3qt92{LIgXB^0>7!fEwiziy$P7v!`1aCtAV8cMgh4J0$RGbIPkNuxVyVEyK^wxJ6W)>@$vDou(GqTvok>;n4CTB zT#P-K?3^inqxcI42<&X?WaZ#uWp79J8>g{}y{n555D0lr_Rs!o9TXM+h2GBjZz(|J z!Qx@;z{1AN%3^EF^6x90T_oKgNdDf?|8|A52IM%5MGfq1@9Ja%gV-K3g(0m_%{^FPF4`BG`9KoUHwL720_Km%FAoY zZoMq8=rOC$4#l^?Y#>vUY z#m39Y{ukSSR%?NsoFSI@8z&npGsjQxqyw;pGRb5f6SKO*z_+V&c<$F zvp<9&>;8IVYH4g|0fzYZ-v;&1eXIYCve-De%vgEYOqkf%*-RnIGKQ#)jhB~+jg!aJ zjK_@6oX_}w!R~Bt?&5Cj1QxS^a0=lDVnBbmA*1~xO1l5ti@PQGx13lZzRk+b#LlL{ z#>daj%FoKh#LC0Z$_ixpzt18&E2p`c2`euXCl4R^w-K2z@v-xnGO>frO*p`8+#Gzo zJpZ}r|3enpIrupt%<=vI$09d7FDI)pn3ai*i_4se(}b0WiI2^ghlvAh%*$nF1~zBq z`pbO(Wh4JbEV65`vGKF9@^k(#EDEyxj?Mqrtsu+)%d-Ch__tsV(f(ieAV~s}b6EbB zbpAGr-_G!V@$YYs`oBm4g8F}m{I}%$KjQiyas9U>@ZSRdAM5%bas9U>@ZSRdAM5)6 zOkBwS)wY7|AhoPJq$wrd&w{+O2!J<{mj?Z5Z2@-@ZT^sNNDeZ(&HwE_aCPHN|f@)ja0hKE$nYBMwCV>=_cb-&nWSgZD?v3@ZV!etF_uP?M(gP zAhA~`vCT|wojWvlhPugst-*jjO@26bnqcu?b|z&eA;qZ`!vIVcm6jm|07#EJPFC0M zpMaK}1mpDWPG?lVuCErzXSi*9*JF(xa4~te7{ddIFnCS(paEpL2mm4g2L4X~0OK1p zfZ~pSJ0a@>JlT(ftZG$Xbh74~E@;l_lgVz3gSD)FXxLW(QP?-YR_20sjL@_E&(59C z=eK2=zEWHQ+rGP+3=Lgiy#ZKL8&cpa3h`F}03s|PBxX$l00kHdQyv6h_dfZzly*vs zp8EnoTr$G&K-!`;Wl_irqq3!xYtTUvr2v3hJUVPpKnQlNI4m$Wlyoo`2Tt{y$g=C! z&Y89Zgb;xuhYBfljQJouJrjre&AsBNgJQz&C$=>5#b{F!3|rW03^oKrA}C@}R?KdA zkUreCEOY=wRWPD7uh*SLtF@j6k*sCQpH_aHL<(;I6L(0zx zK@pD+&-g*~fXIPKd9j^`7v@m45duJfF@aE6&kaY|Rs=61B0T2Gr+DT_oy;mN>mt9i zP!Yb$D&V-=x_jrv)}$BTE+WqlzX1nSOz%K4>fAK7>3&|E-7VToc)+`8z6g&s?*zv& z9?w2!(CP65V{RFi8%X8@V!-;l)KeNbI9Py@@~!F$E&u~C0}M!_1MC?90Lt)g zG&TA?9sme^3PlD@1_i4L9RWqA01fql9o>@@5J8!gfR{M}B9m213NWEF)09IFiBrXs z(!`9kv~%k`eCYfkJGkm<*y+CZ4QjOJmGi_k#U>)K9#gC(NBGfIAvlF(cgzHpX&@y$K+35LCM?2JhQIJG z|MU}GJRr3cU_u@Mg-8N84{v_y7hQiXnz;N@EO#I*BdQ53#!`);)GWv^#m>bZ%*BFL zEhwsbYVE|e%?=8ajSta)oMC;NF*C*4r5 zIK9BfFm!jo}Ekh&cC6#=EdP7fMci1Vt<&*wbn6`c{i2MSi~gb1eyVbeimh5>PCE7Z9Z~6g$GomF64d!}jczl8j1;M~4M9>p?Vl=WDshluo;v8b2 zGKdRUDklae2TS(lVoBy6Xg{7G>AR2IGupCz=+EWjTy+1|IF2;1APgds4AGinYM~DO z9Ut&nPJHCGWw_oid$(J+Tz3?LiPYw&Nal8Q$Z{FfhET*X6jz(sUEQp#=%%G@yr)FI zrMWxXt#Y;uqGfJH@8AsznoQSdO`;-To(Jr4V`mTn9IAy^TQ?UlAs0T-GMR6#K9E+oCwI>p*-Sl=k1QUox~-2n)o$G9u~rJ}ke%SPE_u8WlvNJ|!^f~*^B zT7wNcrG^a(JmwbEEw&pDF+TN;-hi+y+e*bMuV(ZiRFLp?qs8R?v8&;}5BuFw*WHvv zXs-J=)>~N9=C`i1)t&y7+x>FG{tsUlMw>3DylVIMY~1x0KlESXhehD9*J}w5#yfIY z?9`ze%D6c*Qb`3YSftSVXwEh3CJK)t4owOV%Bayjp#D0r61suJUGXgZKblp;QeB51 zbsqRIr1J_N2ct)#uf28SCq}oXVT6LTi6j;#rE_QLXxy?(8LUQNzO_a&DCu5NJHiQj zpg@nSc)8utTQ&=A-2B@&riH3jDy9^>;XB%BnvV91n9qZ6EA}ZGAC9f&Y8Q88Cj1w7 zbTkZOFIq=)7Hr_d@1tTZb`?fx@zQrW;9An@hddF#$UmbS_14YWc_iPXO-{?{C8`Sq zYQ}2-=@`UEs4z#J#?e2wJ}g%5d8bOzkf&Do?RmLd;0`j5GCBpn;j>_}#x=S7`T0<+ zIT9L$AFy7UA7o+YBhG|!573au{@6{Urv!{B76*apiWx(6J^)p(85;Wc_gmEPU|UDZ z7m^QGc%}_$y`)hSlv(>aB6tCa(Ghm?vf3cVNv)CRl9%Ite|K@xij4l3v!gC=#?S5_ ziw$E{L5B#?vY;l)sU2Rdgo1*Dl2P2siM_mng;<@&aj%C~J)(K$FVvIH6H(Ufho6K8 zL*t@=$@0c{Os*~s2GbPf5Ifs5%VkTUr8GnuqYyQ6r4%d}Nqp}FBiDvG=fy>(JE7kY z1c^XaXRFiGD=nUeVpD>c*in+s9`*KL^^TLH&049n3*vTrSu@9WGVBjVHXB=|`IDTE z9?Ex^2W1LJKczR3rMCNlt<~K5IF*r8KGhjS!WFHZo^ejW2 z+2IhW3y)zJ`BxT+&B!1Xs9gMpSs#f$lMnGA$qPFYCq!x<4^mU!kcf_eA2Eo0K-z*2 zn#LFz-wj{In0qgiF16|D8_e5nz_U0_AgA2Yq9gLn1r9@rD;;%tFw8P0Y*WR2EVaHV z5QmiqY3Rj%>@&e0K&dzijaocaqahba)@JTZOv}<=v{*1t>(OO!(lQ%Gk`!~Lbh=V4 zO8S7SHm;>LeN9QZrMRQOt{N|%ys5)@U?!fo;2V8Jdc=giLLqp@v=9{lBM08s+B|2T zNRodpiQ27H*w1U=-a?RiIETAI$kI7U7kmXed{?>R}$J? zTpAkqD>XS$SHH$@7sSyW|0Lt^t2ALlPu@w4M5M14WY>bqji=X2q@0S!b`nEu!G@pm z@wPbI9NntYy8JXRJ7i9S{e5|C({G7w2{pKhZQuhv3JX9SDj_5{n;*MG(8kwYJY`H% zyCniwc8H36+XQa_Wv5`I{W|)aC1*^1W1~(mMaS!8Fo}73Oc`-#Zt1pRlDH9K@7~yW znL9Nu4vvIx`q=E}yfa=y)ZV?z1iy4n0!8P01h0$GWP@-k0;cpj98Hj&Zb8H{FEh2q zU_mZFGZm0tjNn36FJ6s#phgGLda7gMIQfF*V^`^kgt8vi`AGlgbZ>Y0aGRyW@)K27 z8|gkbSQpHkHyBaX*Mgf^n2ekgz!9C*m|PEL#N2|Cv>A8bwR!$!f*A7|RXGD)UrK!oQ419+Fn8T7e0*?oS>5mVn`kG4> zR8~!5m;h%q8WCUsmMHsiek*nqsGgRJNsb&hmo~HPZeufJiQ|Gl2O`j=JFy=;KZJ}c zE-PrwurrvCw++L?R#MKQr*-JAz(~CwP6t27^0n4yAfRvNT|Mpn-P^WwZ3~U-IVSY* zdvQQEVj(y(t<0W)u`*dgb>A`q%sgZaMmnwlw?BD}CGSnC?i~*JZjXoU(Ld8Ws+@ z!G=_@4d|ad^Z_eM?()evWhXY$_E8-VQms);tLj&VuezV3cYnw9iygHq;tt$A$U=@4 zAwwg1{T$m2ac?NVg(C9NjzW&FtXwOx29^j@R5ak zy~v3id24uy$6{iSIb14ls(d1ID#wjww;rF`ek;8JXlfhDi&YOaf%GB(fLtyIm&omw z!RphZ8~(*2x9kw^gzuyCki$ppa{)1?`(F@`%=osY0wGn`awyR3{tk`iRNj$tf|*G} z$*9G})~)VYv0>D4mi107Os=LhvhFdo?z89LtBY=X`)nyMX_q4M9du~)GnN` z%hy+9#2L?->I}XfVU{jCa56{`&zy(EF{!)-uUKJ@v!GwPFA~@T{wNr=`FQ3$p!I0@72kh=&P4kfLTAc z7t+Vs*J&X>cIT#DU(v3~y9gc!hMOijb6C)RbA^AHg-7TnVukBvP6A2N`A$P2> z^Qq^2oxfz?`J^!4S^t{HW_;Y5?^Ew&Q~l3pT=Jc!wa4q>weO!pAmETLH%97W&vP%s%0EWRih~&ah%xno^llgSOHw{`V*kefn@nnjvAI{H-bJu~D54~0)LVa| zD&x_?8o!gHtVbx8-A4(sh=Tm4&_vu`J(uHwxe{l6tK@=zC<)5`PWP7iCjmQO5O__u zqBmv&-rXjx`#+D(_+Nf*<3{p?kk3rKgo8BKCXQjw+_9+A7&QopuuzJ!vf7f2lXr9L z%SrM)l~%ISf9;1L=4TJYmttbkjvR%&g9vRPIWQ=|H=sMxGL_QsjkwV^yhum{MfApG zyWsOdvLY?Mz9%b)@mbnT!Jx(AqN$czQ&#JH+oW50UUZG>47=ZQZOm~|mH-~c6mbeA zQxWcorjkuzRMkH+t|P=FI$&vZZzN)8+N!2MN2d^18ZKUo3sRCazAO-E+FczUDQ;?P zd<^#uzkW=P*b#vWc)L(K-v-Wzd--*%?DMvB{ds0u?P{J{*@(Amb#0A^d7j^=DkqLY;{n5oB5BnS464dGvA@!P;5fRO@Dg* z{+e5!K+?=MmyP?KaLBKw1U)w%z1RF1f2Qv=9=Nl+O(Qk?Y#g8h#sJ+s0D!^#4uxrO zUhI3~ope%G#Vu*3(c9UJ6A>-yTtdoyYwUp{`;{+#0s_zfvJo3;$Qth(G-8=~?6?hH zV11#fruaxx9+}@2#GKSoP@*=dpJ!n8d8rz}vWU=5SEIHBohK-BSHD2|d zo4>D-2(b3u9FwNU$1@|5vuMdZFa56D3Rs-~Hl6V;%GYhjrl>dMn=-Y6uj(jw3TUz3 zRwO?Dsqb3gFdvc^+-+QGLP)MevT^1u#9Zb1`Ij=DdyXXv!3wMs*J*`kpBiJo7G?Us z)IdxY7$Qje{p-wUmSx`Eht6;IaR1QBBb(Xb{mQ!(9+8*AJg7;&J)V5=1Ow> z#9+;rc7eLn>v6)S&zDP*|M)+v%Z-btkS{TU;u7x|-qIw7G*pjLE0K#(?3PHy-NtbE z%Fd5rJmpQe95?yrynA%7`&MV64q|D=Q3&{PlkG+DQ?H@an#!&s-M$G?BnQex!D~WQ zTu8G1V-JEUhxo+SkheUDI28Q8un|f3L6Jp7?xiNW*oIJPW?R#tWBPM4rI6h+YT)C15WQ=*Av~V7uhwuk7Ep zvNGQ(8qbVOJ~8)rnyc+z(FGc%)a=XbgSH~ z2Id@dUYBF3>dKYMkTZx6$>9woIhCj_7DkRtD2T5^#mAY{ST?%WW7`alq)|_DOrS*P zgrf?9E-|__{F6$ulYwW74WV9a?B3Gc(QwF^!$q%F$@M=Mx<1 z7r|jxk1{>%Mr!m1JOzonxn#n=N9RWg^78VZ{N%0w64fEIR&gzX4>aarB9C-RL}ipt zC(i8GCg$`uH#ds20`O9KQBmExhubP=jNmS##lp{kBORlf{tNi9){X`f13+Ay4;wI- zUba+DR+A1y_W{IL9J=G}jw??XqiA(gYAQBk`*57eZ2zwLAsmwpVYI6qHb4g)&P7)O zG^xRZ-&Dc?B~6>Ow0{C;K)@zP+cLo^nUH~p=@^^hs_nv0na=f}tzJv%VZn+i329GX zpa7Vnv?08TY#m5|Zaz|}u&4A3+!&&lvtVf{30W6SIZtNP+}HCg${AC#zta;$DdQ7) zI*h5k-VYyj8XXha+ybadHE}SP@s9Ya*J4^r5l@6GR{ak?Y<0< z21O9EtZq^~y(9Ld~9=x9SPL zIVqC#rpz6w_{HHrwQX@SL7Be+3jlQgc%EAQ4vDq9<~W^BMX5ztItupwX zmW8`>b2^hN^vjR7Y(%cGy5fNG~DkMMqCY77v?hE|IFEp(>>EKa*YW( zj8+|&7E!L(Wt8nYJhXksG_sEpD6=By#fRem8rQ))auvfp|DG~YnD%B!P;`hSu>9;S zz0T(ldF7S^V%hXf(bV^TE~1+1sLcGH_3Oa4F48iRQW1sRLN=ZSG8z!)Bb3Y~_%8l3 zaHSvh@gCd=X=0dc`yYKx-$if(o2@@mE|GtN^koqv;?qcE9w_*YB^s)WhhZ%QUP4+8vznVJ!*8lf-&C1PaVzEBVH$#&!s-_>oz9;BJq`n(X(FuT9kl`R~Vib}=2_`MI5;XtNk* zEtSKZKzxYRGuAoN6jdlmbem(#2whMcceYOhd%zD{s;774`nzk6;V-^{A5cr&UG@(7 zgCsv@e5K`DX-yox?7TKynNZ6A(&L3?eC+D;M3EYoMv{vRbZUIi1SF-;>GKq>`TZzK z>dAS|wMuEU!ne~Ka?{k#>nQ7&z|*tO!YA8r*O;yK(v&MjCZ~6#q;IfRF{&c#n#wmf zvuUm?Yr7&P^8LAfL9@pHFyN#S-KI{=;9bo$>T`V_n%0$^x%a!IuWRd=gxI`uvW1{( zmD;exbwIh-X2j4WEox$($}&=K^Co2280nKLd->zxu!GULI!Gmcui8oUo+8*{&E z^o+2C34(#e1UTp{phZIU0D?UF-y1#?Md%RW0@ft^1WkX8Vjwhwh1W!uuTXp?GOqHs zkHc~j%%yFUazWek2Z*4L#CHvc&*{r_?oDOX9is+|=RNHKd ziq1Xf9RJ<`O*{&;INf%AVl4qm4c>g8ZI_z<^3bZ3v_)IOsCVVoB3$n}^VS~g#Ce$2 zC12%EWBt$N)j%b9M4Mn|S2ikKbxBBKkZs__L2;zCgKMZZVAd>6>sXq~Zg!ZhAImx- zJa`OU?TMwM+mAm^{5#{7D;3T-Do_zijO1;##+_?y55D!nmMbLAI8y42yMQDTLh4Dj z0iqf9R@=eLM2vVezyN`x#kDCCfL)fX`?Fedeqs`DZkr?HV=8GP{Z46@5mD-KS~Fh} zRSJd)-(dY>_|0{f#pJ3V3Pv<-wDM~eH$Go&mO>cO=}PfFt${BB00zhD)N775T8qhdG+&SI~Hyjlb7642fxt zwu2+{3FKzXTVD`BgiwrTU#i|ZFtBvq`$b}(V*w1*1gKV`H+Y-Ia38|kglBkWJ=Kx< ziNmG@cq$b#EYn$L|4zPGDpA{z(#%45e)d`=Nwm8|f`!Jxh#B zcq2Q+MR{#=D|Jn4V*{}c{yda-c!6b?z(kO|+E5BF&V~HV$UJ0xl_}Mi{5!m-;sJjo zMeV0JmYeAN1(3f=p?3GWUwWGuZzpLis9P3-%cI|5-I35f9Tl>JXL<+E5^wI*;nWa? z8=n!cH!Y@nd=O%+aaG3kV*KU}ft%cQTjkT!1A2@Du$77`? ziUpkr4mX`67Yt0pgdinp8a;G&(8dC+^MW#lqYBS<>|r5#3TtR5Yif}Gc`Ayh{^^V$BQ7l7J-}$Mi^Ec^#?9B z9jA}>{c2-C5;K@6Z%@C#B;Q^dd@FK=fc|jt&y0Cy$dN*pgk6457p`moM4P74XYE%d z2lCsL#2Ocjz#Z0GXxVLPJkldE9UI$8KlWMW^70Z8G_#}#D!De~Wgp`@j9(TB|8ks( zfk?OGDa#s(+J;dR?C3M%SaBlaVV0Okd0NtqzP4Pf8~b;Rck8XS5CDkh^nJWi_kXv*O-M{gRBKZ<&#I$MkjRrBUHC!EdZ92e z6XHTeJYMVs3HYNmL^GUDVLb**jrTxo;g9UN=TF087g73Hsx5ww z2?}Q6?{gJExsXclK$r#%#ayf-LfXPoy#5ku1A*yG{XO+BXi+0|7yrb*W3Q9kG99(}ytbf?mKO!6w` zu!q5-)Ui=83kDsXjDlf4>EKuN$LxDv+#U{k!^lW9i8N;;5G==jVKxk)@ZgcNln2A~ zM{vYSz>h%0ii4YW+E78<*{=yjYkdAvYsY{03#C^q!vDMrFp=LoDjaIx--ecIjP}rR|v9k>wA6+R>>rW)*Pswjcp6 zM(0FD@QK#X#txSXP{qg}z+ynD7Mmj_tZ7FS@FojmB0=&MY98(C&`J8I5`h7REYsVaT!tt}mm zO&xe+rptMhYjq8B@0kw^LcS|}lg=GrQmmi&@FxxiqjcCEN#`ACUHVv2&2u4 zKVK9PACmnUO)%}R`{ZWmu!Eb(a)Tq158m-Qyxh)>;5mY^L`MQx&ko~iv1q($cH~<0 ztO}d2it+IYk8R$w_&|nS0Cv0xinDo0ADBTK-Fd!G@%FCQFge8Mk_s|FijO#kZ`k{& z+{ty95q`%v?(z}ebXc5U0vF0gXE0LD5Vcc|pj2(76r&bPI=5EUKE45ufW*=`-7$$s zCpxE}ca%K02k+-}pQvHq{-NO(?_8@CALL{^S|~2QRFo_fLmmK7r5phO#F!wtrQfTK z=Dj90 z;xgJjwjc+vJlYS>8b4@a@&EvZgk2~A@2;fiyXYM4CSg$*4zZV3l>L+{D9X0B2F{I7 z@$?|on#4@M7yxuUeab@LkE=b7*DOC`?~Fl*%N4Ri zqlMtdki_%8v^C*7f4#=>>sa&{oyLV;zF*>f;tBc2TnIyY)|9j+x*tqcJ-^woGiVoH z%eRAaaW96;N%#ZaStL(?W;xwC)aKMx(WWq!v(QsZLJYyqrHnMe9M${lO^dvv_Q9S& ziLE@NRZsNYLquS#IZiKi9`IoHW(jQ27J21wjhW*H+#)1{%kC+EoSa$+Io%Z9a z(E}S2n8`@HhBx63jOZ2ni#BTp)N_FD%G*X}v}W6`jpFEW=eYbNtAIUoI00x*MZ-Gb7&y9Cgn zyE5f{)kf34#_DQrZOs@X%5!;&hrx|Z7>IRfDZ63V0+>NSG&>aQ`ZDt5&8x^ODNF8l zrPP*KOI8tU%8mvSIuUOA2*^lbYjJ;YXiR9fdWvenxiOU z8(`9CcbH$A*M*cc9IazJ@oM2p?weAvwsU9=lIQ? zdAlX{Cpj!wIJ`Kzk!M>I*3riatA`O0)JpazvMLkS))hyZ*3qSFlU`L z+f~Qo)!^Z@)%-|95hKOq@)hcF-#t0k)iv^|o;`ENm1v7678OjL@=Y-xUoD~|b)MgQ zHf_l@6IkY#;$NQoaS|w3c4~4ik3VPAO8f&qNb+kj zARsNsir5Dp=p?)B8P;ioja=!m<9NTH?6E{(1sUWU=%R94x%zJh66nZnLFVSHT7x`g{9xqVLam}CPta%Se9o1)-w08d`QM7@ClR*WcQTUPRt%S2}B#hKr{ zC<_#AkqKM0;O`sXtZ9jIsI#Lc%rlG}D2K>`?FjT4i2mjfi9vz^EX9r9sPYAG_LkAgccDmS{pC&kTa)I+JN5OJfk zQDuC4wF{4K4LSBKyL87Gq&S|qRw5kth26heTQ}8%;`*iAUcZoH9z1z0>W!{Ygx%^> z)L?^;He#zi7>{0)4y5}G?M6brDH?iAv&s)KBTTlyW1;+E{(<;?6VyuKJ)&j4(b@I% z!^yd^t~??IgER^lA3_q0wBX*SR9FdsnTo}3o>TsUc0CN=gnpIBJVP}N!G^b_T8r_z zNj7Q)gXDzqxO8fZPVix)5J{`;`IxpgK_dM4>O`aGs z{FRqsa?B<8kd?J_3e#4@MM+aeQ!O!RLUgPtLYxAA*SS=$mS0LKml6h8=E6F$*n+Hi_J0{Dy?WO?sf7b68WX)Kw*%DC55KauSe$L1HF9+;jkp zMo3wEcfh97*^@~#KAC5d4y061LfMAQ$vHKGwvyiwmukC5kRv^|f9tld{6iT(dbgVe z<{93kh77*AU2c-QWKEl#Vk$W$HGKT)%cSrjIb^uhV-9C=#W8_st+@aNsP2ldc5?Sk zj5g|M^gCRZ96*&4Ll2!lLCU7~%}oS-F|kjuG~H%yP!_pdOFBt|dTv^CzUZZ!2;`yE zAR9~w8y(g2v#S^I@b~<^S+4mHRI_L3b8$qwHB6mT-;fu6s`6GY9cmP>*1>q_O8#42 zEO{!opXyDEb(-4@HdpBcWDX@6WM!lyw1Cb8V?uZ?P>!36g1=MDob;XA3$|q-=W1O zHnI@kWCbx&2rfS8Da9;%MwZ6H@8T-`^S(|-RFLbr(GUbc7Pm8Asq5n4?%MhQbjD3$ zFcJz!k)s2?R|O;93;)9`MMfUa8xsk^Ua;Wbhq2 z4R?r^8Uv=UD*LcW%(3{VdVyL^6@a{?z*(nqEbFC5H}_Q1P1W|2zAxX!4;$w~G6a*f zqx?boqMOE=Jw6(!!`C}BoI=<)7y$tK4F06aNg&{RqGP%q7MOjt9-HjznPElSC}L+o zeH;Y{mgH&cRrvVwVZ2`?PfoqmfH?nR$&a%nDXO$Z&!XV29#I5MBDEG4+ZVHf69rlX zaivTl6%c+}n+h-rzqlK}XKd`oP{Vf zJUrZus(}9!5a>lhR(h+9WO|?6Oby9-U#TZE=0e^C6IKvwcA{qt5pkt+!`Nn|@^h@{ zx8zAn&fLF6o>g(Sb_>p-q|&Z)`Zp?FBy2_sT~hMbN$=^>nUGE1=SOlVTVa!x`}Q*N zHKDNF7WJx7IZTR|Cn&Prv?DgkD@r30vK(m_8APxCZSb-yg-Ubk7ji&s=$J1V20@%4 z!r&uo7@Xw`^@w-?ci|G#r~n!TD)e@7>@l4`D=Bf?k;&cUuralIIVp7r3NnQ{NIxUcPvfB-W?o%Z*@41vaZcfI*0urBlHT5B@m_QfRfy-iKw9!PvvKgRyjxSE8k^=TO zG1lxS&`;F?4`=5>)~g3>)~+^Ex#`iQn3pMORrQAa9%eE^?(Es)U$rbyWAGDhC@IPG zc9E^GJv1rtbUr>loxVqK?NdAlO;nI#*ByTfob3~x^$x^)qb7|b3z7ty4h8c@$h~gY z8?9*Z#T~D8=)B9yD?xTUL3tE(+1bO+K-Fy@PfbI>k}+xF2nlsL8Ap1tR&B}ap;uCH z0^y-AfAce3sJS{RVJ825<@0XSA^)w`+|WB6R`Wi&yhqHZQb+Fp0j7@^jA?|X?A0u~ zrto&D_!+c3%xrv^rxZ}#Yx?gZ4lAa!F6I&%y^p{q7!p-!;)N1`Pi||zNP8Z|0hvS~-(9Ub1 zu-e2&`*d!nt2`0TlzHLCc)sk$_$rFnQH|`OOxHJXkI0HFL9WOONb7hsfG{jA7yz1v zPMBOpIj8nag5R1j5$?r{k6tB|+ht-||fZNSd_8r3C>S(fK`3iUhUq@B+fF z+oeq!p1sR=8$g=kI2o${$)=kU=6Q43|BYwah0@8ll}~cGI+QDwJibE!~O$(DhUe3RiLm`Q9ud&oC#fN45&~IDoX8Q zpBfp;j7u<)S;Q;I0C7>Z=)}B^n{0EU_phz@Z$bk+r|Bw;zh@YH?b_Y>zwCn5`K<$P zjclVUP7cMhO7d-k{Z(N+pRhk&+vzd-OX5O1Qoon2|MhkrKYMqpW44#q^DT3&+>1!kE5tv0lkz}rPP=@$ax2U}@>3CZOe|r}f6I*ZP|CNymxi^+E zg={AkSAD$y#PzTDDdYgw`d6b}wRYYegyJ@rB{kG>(EXv2f6G)p#JX588mu1oD>7a_WKv!l#kkRBuBIZj zm5_Fkhw8P7tg!2(}gWmx;Hdwq2YEKGZPPPNmHGs~3sAZ?6tT3LrN@4c+VQNIzF zq_8=Wo73*EEu_jWn|s{w;I0d;tiU@z-r}(rvq+-%vz7(6%88mV5KXfS@&zJm# zNHds*L$eo|yVtr1Ov^v=Y|3Gjg4a7kp_htP7DD>pbCd{TQ7gdY{lFyua+CkRH3tf37tA4j&$Q#Q5zD zQaCsOG>M(8G^dVEw-=6Ke{}G#lK*Ur+B)847HRcQ)U zvs8R=(TLLXBIi^}X#fBSNuwk(X=)@Xz!HCFZGudolpiNbEOp5jMg{~xWPnQ*knb$u zQErWi@&Ph3$vIx%QApcJhZw;vA%+RX93w4tV0kMM(DLOF1zP=oI@LY`M3}t~w+zop zN?d=KHq@?U5wXbkLE&IF8G zcmfw9JJH+IGpI3MmRzXY*hF)%3O)sId@pt)R{%mVcMO}gi$L!Afndc&31c>nbO?nQ z8s^Bp2vb^B%$4c(H(CQfB{>MO3}2QFV+K{A&F&)_ASCm$9yAdbOVOPc04OPeMOIoH zm!iUokXon`!2$eriiE3OO8g7yp!|xRrb6tN1%7Hw>K=ft7|WNol1<-KUOu zr;Z6aZ*c6xloz;4`H5*#1BK&GR)8SfNS-AztUz=8GDGk(cX=K~zUN{g^e}@xl=$2^ z*Z(8O+40MmYAjW1uw`>7DPx*6fssBey$03yY^>`Lp8uT`Axe4^nqWp#lF!&66vg;6 zD~xZ#jX%k9mwoj?-M)YfsqsWy1REZ5!n z&pUN;Q`*v7h0%>sY6=MeSy~53x^~iGIp}R%*xyO!XZ{#$iYW(5Hix;p$@Rw`C&}X0 z_SV?Hys?Ld0{$Y;rl7m-IMIrj!^Hvsz%~E`AO-f?k_^&d96m3NTGBPU{Zf^QGl;Ks z;kA6d{cSeRQp9V7ke9swYG?@o)2v=)bBgfO+|0chnNTnQ3S3Mxh}fBINkE}6I2`%DDS9NAy+QYFmx1H@X^Y3w4|6T&R>HlbH@k{Mr4Q#zwmg)E57Ou96nvElTV+exq8R)4}b3Ubd z-WJ_)!UUc#11#%p2Jpd0vB?hk0(CPx7sGD)f_~p;SSC61E%4(>jhRqV0xi=bE}*3~ zr6y2;2_^hrd17WY-tlHQMk7kRdLw1 z4Z&?;;+EmZaG=oJYd0y(^Tyt&-}%&K&YQqw+v?HEAHsD`?~Xy<#UQWwV7N!!>FT{e zU_N@<$9FyN@!I3ZlH3eeM05bLzB`nb z#wS24jX=ReA2@`Ekq}ne4|d|SgtgJSaWD-hw$2MDB$0HHC*bz1*sdzBr*ETJ$r#Sb zzfm+{PI4|jBU>HEmA%Edwsp3p6H`((dF=agLz*yws^XvC)Gzdk@p7Mj za_rW%E4s0F6H!oJ-B<*f$A2aT$W$|PM79_Iw}`rE)gg%sDM!~r6P~|tTJZJ zyRKRLvY5NUb3}ABxq84Md7_;^Vvp!eg{`dz72- z+pr%gb#h6w6TZI(5XiXS)N@-q=6}x{68eqpZqV)X8s9c_zXVh>5iZaD zTeNumo_{Xl__h%uS;HUT{L&Tz1Vrqop3l9z>ZcR&H$4soM3gJ)JymUCt!jT^alP-k zikWTKpeAS3q%Ej}Jt;S?=)>Ece)|vCQ#aV&3;mL+JifxecvKCDswauh6%-NQa*=-@p%~be+R;C#9z@>+ipk;_S@K zoNd=i_!>ajJ1G z^GJY}A>RkG4-PYOQ~usmnwIXgqj`LHhK|7q`rWRtlkuk{>%b@C90%{oVCZi#aAHTN z#z!@p;EewZfo*k17aTy=4M}MKYE@o#yUKt_EmVBmJ2`TwL$A|I{Qc@GAw1$e7N57y zwhi_h4n=-8RS}-(7@7zJZ(k-v_*sRK|8MMBPc^ zR_j{mqn#R!8{#lGY~?9aq^xe^2`ngUwq$0r3jYOS0;jC!_v(zU^uAG%-lwqPfj%5K zZOKGOD9NvaCsm|PfQ>d@eFbN5&%cR{|EAj>enJ6>*~CHNDWv|ZOcVb*3qD?$=eO1P z_h{fX=zrg2^KVrTyzkcfuGqh%MyUx6?5rVyoYmIv&A2;><~iWDE7S>WD9$)#4)eDu zd+2IfHU5GLb>9mYF79>*%rD*cJa^;}K3J%lP=e<_&EcJUQ9iGPb}!N7RgiFW=Y(&R z>hr*<2a@9Tl@t)6!|@h(5pzz6h>uG&wV(S)Rzv{)FS~q8&|}A`CvHgbTxhT3;n9HC zcUi?m{>6n6>~7!|(N` z7P~uADMQ4xniGo?!3K_aQi$-SKUy`M8|nfJbU<~NxgE=an~_grW8pJ**Fs;bgn&%V zU0GYvP4d=Cl9xmQFSql^wP77(==cX&c$^Te@=b83y{2KGy z>BoH+t`Fzx5%K?ytp|n>ubaukZP)tCk=4pMcNnxdX@{(sht!-M%|1Qg4=l`^8B!dS zmtRc;MiS2_h7g%5vmOslK~&hPQ%%bx0HAamj4GYfEe>x{%%31)Oq$lLoP3C}dxgM9 zFZvv@AT>dJ3i-)w;>%W2g7T1~RA+GUbE9P{yb#5VPXbtrL@8n-+X8IiW z(DJjM<{U0o{u|igQO5RvS%`!)CZyvAs&OzJ|V=SxU1+`7O$PWbnvvbK#F&*Jkj-vNgj;a|5QBi}En5GCudz{{hb?tWBHw9ag zE_nDhNi2dt;%QR(Nk-<1Wk&dzQ7Oj)>7b#C6HS{B3Dk(YE+-%sni6?}Ta?7y7M%MpYhK;fS;V?bKQ3AS^S94Q#RpDh z=)~>Q&l~_#{1Jr%sjHfYh6dFftW%WY(c-#(LgW# z@Ue22b#R|i3^KoNkcq*2(WVR4r{@sN@$FmSLkCRiNA1l>|E&`=%qJZ4vaplf9a^Yy z+}H9+x-xY)zXc4ax%GE`j-S{ctP=bUAP*IdprD~qiqhWC6`bSbUNCIYUuT2ApcIwu zDJav?6T3<p6FTVW9uc~%3}0>}*^qqb6MDFXL5g2mF{?8^v9r|1M#3^&5Ji82_WVKmIm z(gf_+$uyfa-f4l$qXnfV1uJthD<0~Cr1eSwTNPhNK)`|vIN*DG$Dll()C2h z69AyHxx=fB&L1hDW)x~5N?>9i!byw9%HMD&c^G2V!q)^pfuK1Jq48%hwZ-Cy=FJ-q-k^#&0G@ocpLqCQ>sLh=|tLovxVKv@4QTbyv?!>m4UkNKP*h$h+0mhFte3b(%zG>swO^Hz#roAF)MvARBdV*Tpo=OVXosa zT=AdzwTvc}4JMCizG=0e*625fLQUuOg4ar%B>93LeL@{BHaGLpBc;C&Z@s)NNHp&y z<2DKA*#!SApkUq947RJt&7S03degK zcuwBUl;0TSf8Y&W{W28WwXH13eO-bTOrTiE!UaUf~%w6E6K-a_o2+O+x0KmVXTsM?Fs0;wG;o!DNIn6Qz4nT>20v?a;dcn@->Y)jYChhqJwya;QF^&9YjV?7l?^X=fd*l_a@eDAlzpsGh zATzBuM*l|D!A7&gYk1z~&4$0%QC7lC&PMKYcM1eDgRd1TK$LaX>=ec`9n7q}ue2GW>upHWFwz`E zpLcVfv&)-Y7J^X;wPs{@_rAKn9ndimzRWMW`-F!0qOq3+3{crQ`}QK0EsMz|E0(wR{mVV!DR5X2z~v^5UvVwlV~dex z{>R^!8Ah4gE=&0_qW-(--prbJNI(EE`TO;$xDQ=yP4}2(^T?ZUnhhJL9Ke*~hz?Yh zsV#w860@LKmc7KAzWmUJt|<_Xhx;c%!t`pOM2j(*n)){-;VcA?pb`CCa?^4_OrkI2 zpsTjfZAvS-)r?;|lIpeU$&e-v9qw8w=i+ueTzt}>?4Gx|%aLZ*O&`w$cU=M+M|WH# zQlNKpItwVn{kSh3%Ga&QZ#=v{zeIYw8v7SaWgshigbo+Tz{hFZLU0>7f}U`>(S0u; zNMyk6{c_7O4rzd_mjfMqRMBLc4>L|5t09Hho@K-X+mYVHs65lYcVLN|)mgRs zq-TRZE((p|Mu_s$)b^*0%Y+Q!p)GJCAuVyyHO(kxEd*7zDV(**uWq@9y*l4!aOt`X za_}3;gkFU7;A}MMg;$+nkK68aNpjn=7BxKH#L!iHNV^bM)c9}UC^T4zvqu~Jnd?xB}_g#MmOGZ82oY9D4X%}hzsERj) z3l3;CiggEjavCQ>mi(63r?tf1>F;mV5*FBJs;xq+B9M!O{RKy}tXk4px)PO|B<4^k zl_QGjL^k?N9uFi@SoCU!PxRyMz4;E`rVHOk{gcwBX)saO-R;+mu-8_MGihoF@Gh(` z$9jz#D-C7Ue;^>&Nd}oZT4bJzrwcQ=i)s}1 z0Dl&j4eDEKW;cLq;wmI6W%iT0CcNZjfA=V5r4hrEN%I+?pERzWt>9D-U~^CxbIxmt z%(n_snc##3%+GHdaa6yTxyYp+ND2ZVgG{6&GESH%phuwWAlZ3%a1<02rhnk`b@SHD zBG`OT&Clh72836`fB>#<;tgKkM`&A`JLRUCTVmt_e~(GM)|8NP6tU#0Jiuv*3^)DN zLZ#k_xQ!g!)jUj+;aNAAoaY#t)(X`lF?mFAomxhrvv#`H6rZ<#nJuWK1_Oi`=p9w3 zx}2OeUP;Y0rwFhD0?L}<6S?a5z=WT3sVE&Yhdt}DHkSz@?{#rd99*ai-$O)+K;{?> z;WR^$EkK3%oz73DuEWo@P(^cO#`RN{EjSN*-j8g`Kk0o(%CuS}_FCr+w;FABB|-j* zd9jy`wpMeEHuJoONK5B2XHf_PU-y#jn(OBJ*yeC~Mx*yFur!RnTv(86YOlB9pXW?6 z4sn$HA7*GU@B!+*CT@v;>Tg9aS>e(yT!Mlq?C|Gl`nP3rmPu-6i^MeY(PfPaqLDB- z%@a|;>3-#%&q{=8{NY_T9w#C^B3@a>UFka?#K^Alm|>TT%bVo<=6cd#2SC-$vzB_WtImz?uv%`K zQ(Zz!)3AH##Bcj-S9MFF%WUz~&}!$L){NSSfIjK2>P47-FuMqbizKjIOz>6IF6iO>7~k-69Uk{UDjNb4Jt+8wsXRYD6a~S_rbS(yEfk|o`aI?Nafy3gsr!)-7mkmgu zJcPA}bONB(X!peU6qch|U?|M?(FR4l$4Vu^cN7K0c9BINWmP&tEGcYMmuATWyE zn(+%ZB?-Q?CEUt(fIMN!^t_^&EuQQY(!7N(SvMi7g*I9-fN6tzr|$A4HT5Hi2>Wc3 z^_SKL`mh%g#+@pL+wzedJ5{NsiS#Q$k~Nt&`T3jd|LOx8 z{-~N}aT3!If&*V1^LN=o*V|pQ^o&RcVf2riJ|h%LJ#Lvam#snfR8!0{Tdct5Y^wjG zNiLrQG>L*Fi4b<^?7jImnRL5#=pLXNgD^y^+sLtvzHL?J54;jvmNFiNXruzoq-EEV zI5c)8uKTIGf(>UERGC<`A|?h-Di2SJ5;Ni`4=IV6uO=@>7neh!%+ToO!_kYtq2bD`DCEuoMYNQ7-4v8?E9w8vSZq9+5 zdHlJPI=OslyVZ5!G_}xnE2U?U;%CItM`L1}f;?xHRdSdpki8WYK`}ToLXE2FIZV}) zUPV=+&LB(ql9$RX6fw4F^%2fT;6$h~=M- ziU-42$|BeuK`i4Kh)7|gTMJ1n&PTyr+K2A%fpY50lq$9y#jCWk7 zF|j$^UN70zjg@@PSHmO#Zg6BgIn$;GU~U$))_K8$SM84mopGFw2d>$uq4UC~WA9+* z49$UVHvbxy2Yc?B;LQ0K>S|(pf5w_6@CqQ#38j&XMa>!80=2Y*O~$9E1fN1`VZjBq zG}OHAQy9@lF^xf#$1bZmcAx=UTq~)+yZ_3I5@+`@wDU*Rs!l~klm2s_7T89hogAc* zTXKWbSm%&Ir8eOiTHrEsesHu=iM0SSm196z|+~vFCc5E zdqDH+Xt%3SpzPRD)$v-U^vu_TW3Q6@H2dUL+WXDR1wC9iM_wHx5G;U<1EuO;6{p;N z?94l_7dpU)Z^?Z?OeJ>HyT*Hq+SVQWyqj(0mKX2>F5o$?y!r-qA+6%uW2UcFeEjc zgEgh=pn#(=!5S-9s6x{adtG+;VoZ2LHDD9@pvZm^Rrnh!e#<8B9>)_yCbh;!U_)yt=r>K8 z*Rs)8qRqhMV&S0Q{rK$vTy}`nl4y7(FXe6F=h1oOTfce;3HjRO{%d-APRD~cnzh|p znNo}g{t4l@T`x~Iy`~HTcx^ahwNsQwn_@-QSr|kkW*65F7VKckcnz;9`6Z+bpr^h; zQut0BnvpQy(E8D|j^`4nX(iI1RWG$iZI$BoJe?0u=-c@gOw-UE%k3zhhNZgxuJTxv zQ3$I-q;^Bpj&$qr5fTm*39{ypfNmk%5hskiRE$YC?NyYdufA?{D~| zlI&{`M#DDFpp=h}Mn{5%=wa52G?1nwL>gehz64Xb?b zvbWr2b$XXWzi|o6ECB^Gbx~lYBXj>%<&U@!4oj6!Ax%|toKH7yA-#xFJ+00%h_4jN zDjX}A+Jb7JU^K#JR9T@9;F#^-&(M~MEVH8jMm>vT<|)7I1p|^c$)`Bav z&I&QVH*7YCGJD4&DH`phzK&3QLFxAtimS5;gS-J=Mpykw=2+m*Q&xFj^6chj;PWtL zIVq2qWvEBHFgVOj6c+!Z zoa&7-)IsDrW?1K{@nBt2O_}Wt5k`XT8R+~$W5;hEz8P=#8afa^jqiCr{LfRd%&>je z@X6q*c7c;)B)H>(jptQB5;5lm>2@=uW}AI2-(iyf_9Qy|lV70eF2J~R(5s>Z&7LU39E4^H zqx3B6xQ4E>Vjm!m-eBdnpfZMqcma zj$aqGdycL!Nf^0`EVsr^_Q5HMb&+K(bh8k6>Ou#@;9x0sI@RXiY5Qj#Fhi(+(0i$fLF5 zS5j7qo`ZSmN7=h*);RkR?m6Yx(xve~+}Ip1z(sS1BpHZ~;qF^wi0_2&dPHptcpUt! zy_*&4U!GW!T>AXAC-zKN9+%(ius$I0+UCy<|KubS=?2W(OeK<>BgWrHFQ(#EWL)Hm zzum4Hz#|}GdO`9E{&@Zwt60mfIljM;fDXL4R=B=kB&GD<`_a0 zUW^`9bWQnhs^R)g`lpdL7m2^$&3ir?=nSF2kC%ADvWpg=o}!(L<;>YrMF%>;EXJreE#9!Apj~TVJ5K7KC)%J>@ST*SjYNbqL7&I& z@1Ld8r0UdqA3iG@?4pF0>ft4bg4R;vfjMyWIvm_FkNZ}ki%a+8|FHm>TG!jCdOa$% z8hxEQXRbt!WH*U2Bi{d33RS5tn_)a3t^!r_xB6^`prX-I9i}{*lSswMmf{dR+}ttz z{-t6ey|)7uU!OhTC*K{vzL~E=r7iBPn=!Zhqf(9U>3f6Uyrq9%f+txtUJ{6SZm)~Y z4j$IDe%C9pf4Zq7$v_VMC51R{!Ss!Ra;XhM@>~P^+K0phX~!{}Ul{T5k_3;_*p&+2 zK0CKDPRcm5h{|D-HAnS%S?g=;w}xE?#L*<-e^uu}mk<;)x9{Or3E$T_*SlQaFO_7L zd@XkmxB6|fztnZ%K$mL=gO6F8&%5k%P=P{VvmpObSB|C5X>8Hi5XR) zsww>@I@ul%KnLF$r`{3j^SVCpm@8}G2m|Wu0Kf!6OV)$n`d9$28FYCgguQK0l5RXT zAz(CEejM{(P_%Or!%s3o2GiX6_3h+Ff=N#J%}T^p8aHZ+%(8EGt3p5T;_z!mWk8wGUlBBbSz3oydj@ajk>a{mGlj zF3VeHPb-fxhXDbDW}zWjHI<4#69N;1hb9So!-oJzLYWl(&SD^Ij4bXm_c#RHnR>C6 zeJZc(_KS9tw-d4?#T*($AW_PmJgy}1O`zPT=EH?|I51eGhy)rOi-IJi{0y`>!W-?8 zl1kO+?JaQwlp=ZZw89_~Mr8vUv?8@WhftkB1)AbKCCLq3N(dkZdTj|zSb~0cXR?*+ zbHO9i0=jvoyt*FGZ?XM(vLatM=1bi&^t}F)-_nW^()G0gUooiUi$PSI#a;Xj=ZUep45L0_ zDqZOSOXweP5C-TG?I6PJ++-TJjo|U^Amg!q&S(j8){6HjaN*`0xn+&~B*PV9WK=d? zOK!Tiyo$bhOXUD$*g)}2m>sSqR}Y6xJR+ie=z|xo3Z2e6!cuZwO}h3ff!%mA(lBV` zf`OvHMJ3kze~{i+l^!1X``+`R19$uT-s>@cqnn6iCnys6Z-4H04lXn1b-UZT4rNi{ z6u&QiV|D{Wq4@CwWBSZ@OPm+=^C+~Lim5+AkU0(W ztNsF_F#Xt&vyGkLxH5fyAAjj2`x$5q`VYE3kmCE?Z?wGBR5y@HP)2lTayp*IudgHj zCT{8)NK&&LG}W#*`3`we+4T0ZYd^oX&=}-3*k#+T^gOT(E##M_@S}#KM+f&2^)Wlu zyFx<1-ot|fD(pcDMAj=fL6nMxC*v*f@=XwCep<>%Iohm0O9Xb%X7Cul!K=w9!NSIn z8c2Yv%?vEixV{8x83AJP~Acs&-fPt=fap+A7x!GpWE~6(CJINPTF-FlEcTO zf2Uk_!sDmpHd3Dz_Di13>Z^tcua&Ou;Mjh%J4a~_3SF7vY)%PbW>ZGaGy|Py5vi5B zhDH%7V@S8oW>c1k_J?*{W^oGhez-hLYie<5&-E;gQDpP$C%TQ0`c*Ye0_t?7sG+=n z(o*N7I(NU>YZwcaiGVzgZw&I0SfItv2>;Kuecf&Ok-|wNzDIjswE3ef;GDq6x$VqM zp6|MUEBkR@fhdWGP}{jaAVAW9?|sDePl7SymnZ0fEb1JNl;_2G<=bdKw3hb}x4~y# z4KaRr`|>h1)E^Qtn7FLqPviS8z#rWHU$hK+U@tZ0BSjDWKcc=mEUNc;dqq)F7D2iN z0qO2=N$HXfX=#vdLAtv`y1N_c?(XjH<~^&Q@9(`X{#r8x!Qm7d^ST|ug6v=7LTKJM`giUh8VDJNvCDCd1)$a27q?L~{%6?j7|c zRIk!^QA=j9>N5+#jV3DZS62_4g~R2;*nkUqf4|>6Zi?&uE&fPki8n9dCSfHTNhlt0 zvsUoCOBxpRI|ze0*ql77_`@qF)YEsN9ihid@efnCOqdoqp$nVA;iG9GLn&>;8Lhoc z?PpMZGPGL;7mf7FgEhQ^PSIskFq%M=1?F(SJXeZ@=b~!Dj6n+?yCh zbmzofek$Uc;%mp!VB(N{QZ=p)7>4w^k*{D`8I7dW(=Tl$9Z#rjGs(Fb z=v|B)vEIo_O3; z99O#y)ucH@)mH1nbpKc8kI~(1w$%N{A6lrlw&jEYXx@%qtVXQlX5KR}HZU^UA{X8< zz!#Bm;;@Lq^5JH+LM!EnIC6OV5?M`{SMF2&aDgePv-b@M7>(PtoC7m~K1i^Wf$Qs* z0#XJ>{yeIE#VejKtV%MKN`d8QvjPrGARe zKcJw)1hP^#5~{hGB>mCWubh{N*=QEmy>!d?t8+8XpnAd9rp?!Tr>5QtC5k!42NssV zZ$j&G?UF(o(v0{q^&#=bm;FDO?cOqF`G>zP%VIQH{V9gC$K?s4CGsigT(Y14fLp_f zy)OXz?fQLu+s&+wm6(vvWo6>Iega=#+M*`1mlL~vq9OsXDPt0z_c3`-!2GsZThu?U zVXO@S!up1Vo?{9Mj+qSIBQb0l@uoI8RU^L~)V%2@9mO3Zr`a>ge_Axof+o~9c&Q^3 zs;fO27+G)R0c1&ta@G@W9XQoQS$KKw#+iEE^^fxmsaxtve9mWMHENPs$m5yw_GUMw z$KG^=91d$?cQ-vdG9rfdtA~C&_9ZCuI|mSRkgx z9aU93&exOMXv`D5TBY*6B6R2A$*00SvpxOz<&Xx>qq~jBX|*k$>iLGAo_K($#l0NT6XrvaM3Q*Hv`wZ41lP2{&!^PJW0 z&XvknTF~&p1US6x3JE+iX?%#E07Wktgr+(lmxmTuZj{@BpPy?<+b7%850pvcj_1tk zxA+kTbb^H#8El+5--oAe(-Gvy)@=8{_5babL*5l`UU; zTBLH@J<0U_(X5-Pv^6D-tVo4<<+eT5p`I;X{d2131!e=h z_?642F?H7-z@F9z3s@Kgy={2^?498&l_JWDF;AfKECunix>?Csymb@}>?K)gU7^a(J= zTM(lH-Iqqx?aT?0mlndT`n_{4o8Jgg`#l32K7%zH93O`^xoVD`<_TsilNl3k2b0~; zqxC1fT-JJ=-HO;%9Lbhr91)2GWjpA6KHFq4tJJYXo`-Y(0f4H^Q0p<{>F{EeV8w>P zDYddmtDJB=Py!Y6@4~9W=q1)2l2Qd-#?*b8o0h=L z5~H7Hxgt#i7TRfUhTr^=BVEc?c7q0GbF6pcL1o$=%1O0KPOArb=WLOw%Z<7R8n5_U ze(Y{x;vQqa{N*~k^ryH+7BZLam&$3scNRM4W2fK5%WA4}Ut4UV1}?MNziTRCToErD87|0ltMK^9()rFIFLgT! zQ5r6Ydzub`)}e1Dml)eJx3W75tj5aDF}nf&uDvg(rhM-Ngc?HzGQ5D) z^lT-YFOE2|1S7wEQN%8LYxmLc`0moo{c;z2rce;j7aT$LesSBZdqET%o5*YC=TAA( z_awiyYFu+q*W?NoUsJsKwaa-d*cyUNvrzVqZs4v+N~he@&zyv23HH@fsgpOGLrpjQ zmU?3xI$nGW{NYGGP^A5uFbQN=mJ2j7e4iD1- z_h9+#ue<#=bE4T74G0*NEx5KcA)>rU=>mf=qG$&6Y)(UMmDd&rR*xV zM|tapbU7j{o$64T|D*oL5l#1?*BEjy5cY*dS2%90g7(Lu=TGil2^Gnqf?n(JLH#77 zLRU$@iqF}qw=ncDq;Fq^?%Ri2TXh!QkOS<1B0pspyM1f-%EE-d`3E5wQjdCSfOYmb zU9#k6#bSyJg|dD0m3`8<5{4L~pZbV?Z^x&eEiP%hu$~dtlxRY+s_;eCbkgpJ+C33YfzZLrygm z5DCJK|G8mtV}!YA3>}c*?X!g*Od*?5y+{{A<+DGU*mO6w8{!1m9jl{HHF9G2Q68N@ zSd&(fbHc7~gA5Wh?{q(ff+pi15_OvCB_hq|IP1Hag8_SC2QlSvmL$>??r5;KYR#9c z)*Gee8CLj`^1j-omkiGQYm&$=jk+hLCw!!8oCx zof+#)UR+)4-My~A+U1-t+I#q$EmQ&L{5RHGYIHkZrZY_F|Nm6ZDA~l$vTN47TM{n% zNaxSLGGYdnPxRWHR4ipNU>>36Tv)Q2HOIi+@4vmySR{ptR+JI~ZaiP{7+sPpm5$d- zw=OJD;m|zfr<1Xy0nHsAf~WIXrxe-hWQPwR1H)Z5D35e0-r2|K0NIN_6b$T^zrChQ zZn=VpIg6HomAP0KCa1#ZyD1I@T7gc8_RVtpx+0!?45Dusz6(Z{y{rJ5Pz0) zx9tlSBW_~fOhiL&OwziJc_|&R1K&}i`~nx60xc%!gCLyjZ>9t z%3bSW+Qg3=e9b3U!GM=wJ9_R7Z&51@q*LlKkdz<(j?+)yb>{U>#8}w$7NX=XEx!Hp zrbD-Ebesc;gbfMePAv6c(>!5?W26C2OLp)W>Z;NfL;H>3zB#Y4`3*+cGZ2BF2J~f@ zlE8pL^;eh$7sF?U4s{!cskARe7fqOh&G=hEuo&=U zupkhDzj%TEe5#Hk>*!%}9UDXN6FPAw3Tz5|`%WTC#b|(z9H}kMC*?TCy)XyAPb@T5 z>g9q0%vJCSf4mhYRTxJ`l-l(K!HhLDE9$Qhljo}qz7v(;*5~0S6zx+})v&P!`>xgb zc(6;zFQ0h@rL}RS0*N=k=21_gh{h-wnupR(>jC(%;dyPhBvlndvL_Ya=^CJATJGM2 zj~gbw-vAt!jYi;Mmk!~ka03Iw;IR+fia1+-063krmco~q4xqB&wQ#8<^b09X&rUh~ zsNU$MO!l5l=ZK?CZu|-{#76y4M-0!7>0$iZ;N3w^?q|nidErzdkg90`uG{vA$9hS& z2zjU6x5F7rr8Js`Xa-JEid`~(3Be?!U*FxC@IME(IbiB%0xL7Y=@h`6{Ka_gm?hk; z>z@|KpG-$>tEFV+y;|otYgZc>6P<&T8MLI~ciU&+PgxPD9nCFsN8eKk1?XRxy70XC z4e@)qTVZ7mCG$$)H3o#`osa$jLqM7{IvAu@yc-LBB5@=jitrk28rw(kd(yy=vK*=)1+0R82k<(bpzR4w5A$U~d2 zYXBDexzeMF6W9D)#V~0zTkO1VIfCXYD&3pU3ZG&>ZO%%BJKZ}ohUjulhJ?$C+~!8^g5<9g_44G>j#3Y5ajDnXkyNc?3%w>jGp~@(41{` z*^EVffVU%^B~peFm;p-sYEEWlmVS*+y~*L6%gD(#VDpA(e~0z}IHosnWne2tgj?I~{{EF7AcGY?H?*IddDl(Rt>OmioH@-CU%Kcb}Z(!<^ zRKKM4IN{rvGN4T{_1tA&L{rZK|*v{GMKD2 zc@LRvVnoYCZ}{fl_sIU|3NX=(D&#f1Q5lhnnYji+qT5Z8P~fufV~DV60^igwa!yOv_H z#Qw}U363$?=nS?*oHs+@=l60{A{x*4h9;x23m{38QF5>=dYckwSmtX|j?1EYHI+Lx zvcN=LldgeM>0UjTz@S-W@lX+^@TOd>{D-V@U-4+DAug6)n-52sRl zvZ3eZ$<|wwjh{=I;G7;(I_GRq^c@#G3Zi=zqm#@;CyYuL8+gPsed!rq=5bxC|Lj|> z%i9cotAaS`^+2m{gHN(V=7qkIzpDz+akIbSmMRtbX72 zS=8Hp`*Atl(HtU80uxGd^pE)!D^RKfpa^9+2)`iCc67Qnui(B@ST@RCxlM@bCih=k zmn)_gS7?eEp>)t%SG9p&pjyen;ccT5UO%1;bu_ItZPNE19PE|OaUmXN>)RLwRm%z^ zdWFG+F9^9)0ddi1}W2HiP(hoFp85mvXarbjhbUM?@TS zqpx(mlEV{WMjoHht){IX)3@*3>Nov;r?bsC6S_|zEr8j7j)!IMq z4K@@lDWLH!ffBV3$DZTrZQjsaDA*Q$@XPsU!POzf@;urao2*>OgH+A_F zD}VFh%Wp)>Z)H1TS^~PVbY3Y)y&+kXd;9wh5S#`v7ytl3x*rwQve%z*)_rzw)utTJ zGI76^jMkslyp;HIJb<&0X%Dj}9-UI8pR&NdRRV$C9LBewX3xGuLRyYdH0RyV_-I&Y zj03=$860_pUl3Lko5B)i^T-6yb=hbHr7dMcNHjx8R^Mo@(7whm#10OSNtcJ15%KG! zDI{mN)k>Rif7c(Ts!OL($|8ED2>MK+8av~s~Ei$*q0Pv7NjteC&a|Fc=g%g^eWgHGvVdsL2CV ziP+KZLFjgV6J9}Aoo|R!;@;0-?FB{v{jSFP8o2D$RAN&`0)M!jWQ>|ym&z&(d*g=% zksBu|MS{ys2cZ|4lrc^!3>qo>6d6qfk-;$wz?Z?1#Y`w*jbI_n)L)U7X9sw%L882Y z;iZt%tlTQX*{0J}T0zAg&(ShX*WDAt?Q@`^_#Mr++8=S{Nn_%}?Ydor@bQ zEre38P!TKpi-_=>H>TZqqs*+-ozrDRsA<$BZcK3LCice?>T3RWWk9=zl%c&^i}`og zpiu&di3;pb@Ts5HkHwWXC_f?RIvkyH>z^)jZ4JwaU6cGIuXQK`vaCIutI7V&rQC99 ziFr$ktor=^pWrTvLFP2uMU+kr4oz4;tWQn*I>ySXaGlnt{K@RdRn8gk^5sOuM4!xj zDMV1|XcTxF0fvy4t6jgfd+i3$%<{CdUA=`E&+|r;_pAzVkE1QwhN5hh1byE{ehJM~ zDmGeI!I^k>XuHg#RsW*k`!JT>NK#vi`+9WHB-TO`2dI+S@zft4Lf!hqIr;PIOav?O^W~&H zPtk5+qLEFJ%QtoSUpvBCYm4!c%3=V3x~^x|O>dK9{72kRlEN0wL&6gRJJRuk%?eb2 z(Fm5$ZOnu%+1P%sgu`c%M-J}$DxeV-B_}>U3m%`566*mvK8ZV?fYp&_qXOj8nId#T z0dKSp_I;+hu*@=|D!(4O=eX0ZFdq+JFVoF$Q3wT~gZ^WX)bt&oY7nKMspGxrg4x^bNIXF%-;mz2Zt7C}}CTbsrpb%007sO?;-lBnt zZ~3K`-DRActtMbNEbe!hz;NDEHRtA&CNeX~)4@o?a@MZt_J+gld3<4&HzTJgkyK?= za!Sqx?6~rYVmq9^OOr8<*sh|s0rc+GmyM$y{>KI2HK9VS`-?j@pmfuC-3>%5DmuR) zc`Y;O;V&=3k_^0?IoT_xOtKX=f~{B6=#+92-e&XEP2@SEWt_#AulpaY(AN~uPah{4 z>7pKL%=gP0=b9B^QFBcpaG?om9+1^mp;*k?j%yXH{cS(wWeXGSG`l6M~BySH5{i z^cz*~{r(3SAJ4%4%?Nwu<(S)OijDhiTxIs-j~nCN%h$(0!>EZA)BOl*9S@H}p;TNk zY4^v#)=FfN@wh>(Dm}Y^FK}31Vd}uD&aHyR{73UM62;>8e#(NcJYcB&u;7RrGuJV; zljt_;7@*b@pyB?l4;~2qg#Xhi{jp2@+48QV&SZC1I-CT!HcA4wiE@z{TzLLie(ra# zNA0Bvc&>kW-6h*pD2s1VKqgjH{1I`7XLKA(3=yc!z;t5l}l-veY&?&|;;?7SR2*9f2$ zJSY7Yups4p{yMLdj|KaxF_a=j%F=6K2;<1kZx+cE5eOb3NuP}!l;*M$)8sGKd5Ou` z0?~NIG?F`!FCS}k{zZ+8gf1l4`!e|_PL**04FSogz(oK>eK%h~g8=gl{frUBk0ofX zCUONYsaq1t({-wYes-+Ujovm_+ZX%TI zBaGaq7r;TxN-SvM7x+DzFQRZ1o+Ktq--1kgRt;cW8c|lULwO(QsO_PLcMml&neew8 zqt{PYvyrh+S8fiDQ19|_Uk^!s*qF0l46(ehlBmCRfx4$}%(Jkgjsi%*Y9yAw}`gJS;iFyc7no`-^6Tm{H6>>__iyk1@EEC(#!om9B3ccP->jNZRl2wNC7=<>a+6Wo zTs9#Y=)93&jqSx29^4cYR@U3X(v}TLE?$ERq}a%6MG@bW%W~m+``ye8R(G*0P0I236eb!P(@P{Z1WFlU?&MW_ z;{RSwF7r~L=rg^IMxtTGcvSLBxm-GIPF@lx?lm-7(go$3H6;V_L%BOWpkIzTxpPp0 zTY0#T9l7F;tLo@IWT=y7_;NUf-DwL3)Cv&yo+Axwc&|mor@YX~spvKk<5Sm@Qf;Z8 z@^FFde8ooUebE z{;RJyc{AQQf%u^=qxZf~PJ$7tiO`Edp<^|}$L-xps+ne>{Pe_!=X$tNcCj{0yNFhMY34p+{A!P&{zmDEjW&=(>!~S={vfTi3P?;^1 zg}8AxBriVe^&k%s{Rr2lge0&GUuFqRYl49zfQdm<^JBjueXA30{^~NN)4bDK-u2JJ zsDcTM7lUwxJj9lwR}S(9j?4t!!yMg#6)9s|-emEg;UMXB2`{~K<;v2-C6ORmgC*{8 zL|0D2fuRut)|ALMl&OyX;}oSN42noVM5O{wzpS;)_;3^-V}oA(1i$`VyG(!4cO-oq9uQW2vE))S$J5`IKuPJ-3(WNL{i1q?fyU~@&`b5?DKBf@-ntX7 z)}G2BxA6(L0J(a^7bJf=L&?eev^Z=Z4mK|&vi_5E44C5mv*|0sdj`;hgX#Krtu&r< zB;5nb;Icu_wNZLMw;jcY@u+vf491m;4nLCHrh~^OaCAql|eL)nbg&+q-R+ z143;4y`2Nv#$XvniJt=n42{Q5KM`no-A*RaT58^zsTgWc7odS~_YP-42}Pa8 z7S@7D6CZaz`<{rB2O2UbH~E9dLSdwRwJ!$IM21|+FWaR4lUHsy1?w*3&we!=+kEw| zx)1%B!&=QXBYY+Lxz-2jSxCO+Uf`D?uiR$ZLCRv@~cuP)@+Xd8| zYPq($vJpQoQ?*>YmNe8TX>vMv)1PHjipP|(uj*sOEI>Kf=R-`jSS=Wdi6&_?FnHjk zG0RL{uVK+2xbakUI8pf%ECw|GT)yf7!PI&N5=sWeHb=ci$o}svW8Oir*h7uF8YX}~ z0OEMn=nXTB(4mI-o~1NSUlF~DcZkoW?6nY3Q$!y5oQaG_OJoWqf41rd(uRpQT10x zuW=>5cuHY9x5}nBw@N+-y;*x&)E;2+yuiV7djn(Tn7`{b=WUAB&k=61f%p{YLVKnj zpNaJ1j|DqWoU~cs@i|>(G0V{Zv-6^5Nl>O&quC-a;OO(rMM$37ppRg;yB6(lpv6Q# z6RRJ@us9(psjC<`vZ*(AXG-Ik==K&ihF|53lMA_!={gLnZIH;nXIBL?-F zEW36iMa2H+2wTQj28{RU%BxAz09JADrc5gpC3cRVjRKHR>z(G^?mo;v?F|!rM~kT3 z#s?e@#+k5&xhx|T#i2*5hl;qw+JXxUf%*7@?njw{<}2LMkg$Rx&< zePoQ~AQIS!fAlH@^aVRi&(|X^XbHg@f){%1+Fwp)Vy2;Ok~@lLw~b3v;lrxc@qyku z)FPBteo+`<>~a}aT#j(g5n(nj%d3shu{)Ud^r5=AA7k#$Hd zP<#i5ODqIz7fl2OdQGhldW8`XpIEMV59g?b{?Ayo2mM7=xTd%$KRAO|-)=wn))X(^ z%M~259*e&v>_nLeM4$t|*aVlr0qrbr{rH}ZdricJukm|Ams6i8 z<_n$Pmp~cnrB`XR1p^FF#YcWmTjzGRII2waQ#|Li~Dac#m;}O zfl?9SFU!_u)7^*Riu6SfVn>DtCNEubja()FewsT=#xNesZ(yCUbnX`Nu zq23iM)KN@z1z@&FhUg8@^E6HtQlbE*>+8atUWrumvTdiVGy{c70_S5s=gZD^_p&4u zvHuu*op~8iSWz;Gj1iLA-otHgaDHbC{86@t(KlM$2f9Y!JlxQ&mVwB`TjCOm0s2f` zJw_FqSP(}QN?Y^%Pv35)aH!lHaxQtY$7V-`3-N>yJnVr=J<=$P+(hNVYs<%j~g}4tO z#S;#i_D;Y{BiN)1T1p7P$@;UmU^+hRK@cXRsbaHDe3Hu$>LA&nVZ2>H>C~D>VH}Oi zXH`Pc@|9?eTzL$b(F>HevgR9kE%v-Qaay4?rY8B{A(IFpdmJN1_ccRFd;phwo>}Am zHhlEy8Y%Qj17I+GSlgg3bc83VpUmdp3b7m_NA(avwFejsKqrcNuFWMUaebGmn17y8 z;UInGABm~*dZ)Q0!KM^uJ>!ls{lIVI^)A8#j(-!N9$2@VCFsx=``}cQnA^`3R{50c z)|`GapNT)I`}N-92}ZjV?+=9R%2SKLV|mH>f=AM(@CN3{IknftUl8$kfKfkzdSJWX zK`UYb;2mpP$na&LCnE3S@e&lA14!4p^_Ty7G`Y+;LRB-7V)e$`%Uz!lDC1N@H^B&7 zr7Ks8l7TYg?Td6-;c^f|av(TeK%zy-BfvV3n36;hL?kFk2j}`nUr27Ls@e z0PQ4^`-N4XgL+v1;7i3<+nsd=ZqSAWr2bM{pfyM~(5R3fu1xn?U*`(}p~dI`^H{Di zaxnTQt0D63F+6J4YSU%9+^ZzeyTcOB_)5riWl$sILoC2b! z?GTTSxJK!Io61?C&@%pi16AY)L-3Xo^OwxNJu^olOsJfF+|$5B)gU;9AM(cZX?*A4 z!G)`~uA&!+HHm}U+G2ZnG!3j{wsS6ae{y$u5HF!NMmy8ea-ANp|8s|>o55DRR^eYx#egJh;HL4wNt3bg8x*X#V~)SVi{P5=WP{q)C*NVHgI5jA>^1!Xuu z(X+*!<}TWwQ-deVfUNY=`!zeB?bKn86^Z;$8avY`wWN3JuM8l)uXpM19)OfdOZlii zaQ54`QaTgWY_qt84}+16QQ*LiwTHq5pH}KUs|b2Y1cjv6+vyaYH%mqP_U1raOo9FH zbJwKv3ZO^*v4}_OW+|PO*!^LQ>v{_z9wnm{*NgwfPZ`0+b`HMb4^}{)4J5O$pOy2X z7W%}H;Tj1kQb=?Uj9|VY5MRZLFD=vPlc)U6tpHswn=3WipAiKHC?x+4^m_$wfAk6F zrRCJjTa{PqV%2BtQ;Snp#R+p^>zcq5Cxa-!+MY6FTpXHD6Bft!V+Db8UM>$SC5`Qs z7xr3p4(IMl;fDpVPyww^ORP_u-O~e$Nz~nz{RCIQYamgOHF-tILPYsUG(#azMe*$Z ze^dLvPlJI8FL?x<mD8^gz{F zU|OZHQ-R?GL?3377XfbD4nG0tG%@1umGEN$7~>YolQOBlLVB?SU=RwQmN5U(w|oDW zkIGTgnL6vOE6y{x`^eou|I`}#25j>ii^*_;GKZFkzzco3WS$X4j_-uIG)V^L@-0*x{ z$5hc!(V%Se69gae4H&E|lPUPVk0l0OUQVxW{zuYUht&b;5L(V-Qe$tT=5nKd@=V!! zM+nV*uyf@5`3P}SvUF0h%$YBx{;#-1qdKqR>$b1EhhTnn(!zxS-?)9Q{IQgYi>sE) zdfVmLh$r=VKfckTi_8gIJx=_^*xb~+z|M>^%b9!zr1w;=bslGpn^A_BFFV}`unnXz zO=vOE#*&ll>t!q%fhiwsxSB~3GYr)20W+%!$_wTP%5&9il|h36xq%+2!{<-VD+42J zIgv=DaGpfKpE~Z<(cb)>86Q{6OwP^u@NI zz`{%I;c;IOmYa2()x4b!<YU;V)^=J)*qRCE_ zRDTtdNG(^O!xVoLdv}mknKK@nZ`W{oRb^2I*=l*Z2pE=B3mWJ_V{{;%#SawmF`Z|v zpQdh5qBKT$U>H)?&~BktCO%F|%`dhjBg66+PXCiapxC1hMo_ckMh#}6%MA^3T_Vdj z4Yp0w+j#t;k1f4ldDXbe@P6N6DB6LdUa4d!XnN)v+s6s}Wy;mXRQT!y8ww$}ov^vu zXYi}fV6Xke2>VRy+lZ~Z?1X6?pHngMykOP+!(E%Bvd0FLOO2y4E)2Rt7V35c@4{T| z+%U!{Gc4h@$^qC>Wm36i88pqxN)|Ut=jrEUmtWl7LZ2fi6ReBZH7UNv4{o2$?h3+4 z?%f;WRAuYa`gMMgZE;NhdS_E~+xDkPBy~a+<*laZ6=;TIvBh0DB`nm;y}ckRO(!kP zvHv^c`QcNnRI2f@@`!1Ik6A(=t3(E?Ov*F~WPlJ$*qeZ0vqfodceS2#zh2X>{xWzQ zXTCbPcrw}E7qay@rXT}-xmT-O#3QdxUu5O_#!GXBTrXz4xlfHl(RUMnyy`MNkG~{< zf0A-zbi)}KQjXW0#-*Iy%DEqYYeQ|Or5x#JPKmyNS+yNJlqqo>B-kUO<=|k=j8R7z zM2-562%&82bCGS!zSFiR4^MVMbungUV=+`g;5=p43@Fak@~-`iaEiq8-pWnL0Gpjq z!8-8@M`hQGSC@v_&Ij1uy83c;h^GlVeH)g07H^NZems1XYq+Kq+K;;p+OJ)XIII7w zZ*XjE%`^|E_4RYoxB70!c@~AYBiRj37I75V%V}W=szF6N5)++nT*-Z!Nxfx;8}PR^ zJQi+=`wrXJ2i&#$P6Q+37x#YeWP=$MP*7<|h|;Uvh!cDHj=EtH{(XNN>C}Z?NmWML zeY6}db`OJf%hiROfmAdk!Mx*%#AMq3Iw5BC4AG?J0vI}FD4YV;&%NRqKE7Y7x>;A9 zSJgR9P?n@%jydGB-Ca7nIv2tMJ-88K({|PB^GN5|{1NwoWE=Sm%txhPA_X}VUmuqMMoC@osfToV%M?3=qo0fcjuUP$ z^+I0X#npak^co~b`DxB!QFIpYBm-817Jb3Sn3;!DDa#>8XL#sW1M5=r6+V;W@W7py z0+!eA$jk&duSlA-O`A$PK{#ER7Ks?_{azN&OJ;T({lNnz*p)b_(LkzfOLj{A+u*Is zAN-!}XQ;!am1QlHW^{ zOJAivh03r$c*}ivpLyHFhYpYIka9h+Bf528C&6p0{f*w1gIMkJyecIEumuJeK`qeO zIOEhCpJu)KQZLcTvuSVu_BBGGqk=Q%X1yk3s(r)r@R?*|Z+fGh(o538E4Hs!P2Z`Gz z_)~linDfhx1dWg1)opZ6EE95CUSuwC{&)S+ay{FZ#rXHBFHR(shR-@#{C65uX( za_f|)yYJQJa6*`@8An9CXh(fKVe}oCRIN3gm%gX1s8eq&KEQ+wvB{h>2?29%#tOy zpa7XhqwM6pVozhLABNGOGXlppyjG!l#3y|RGZF-}KOfVT`ROGJkV=*bKB({g7kHasWQ3#WdwM=^tvyg1rKt()Fwhk1R!5>_^hx+vC{#qEKfj2R(izP+0E zewCOkn+fk8`w`mMs5J@dfw?C{}uHt@6qBh_;C2h(T0}~DG_sm?^|3~0lc51szrb1 zkI=(q>zz{dG2m+}M2@>s8rrn?FEhVmoA4$Kb7{?2xjrjmV*_4jHpB3+?|qrW265Je z8B!+q^nHm(g+S==c4um^eWC02@U_e8aZbhYMS9&(Ju(V^9uf$-;A9%H3Dc~PtY;6}zya(R+ zj|>C>EBR#2I^Mc|8{fLbO!B;+8Et+dr>oJc2Lz2iq$TXh{W0Z335&#fO0|$=iCSsy zY1EX97Yhok9bth~|IhXT?5U(t)f~XDhpcCv)j^DR)_Qi5hDMo25XaAey#gm(NI5Ib z7WdZ9PZ?uZLimUNqRe;|)Jz6(LZ`n2*3u?KOUK}&W6x~kIWVa=0bf=xN4dP#ZaGRt z)8FWeUi59y7ZLWFFRR8Ec=`iqY^OFediGlzM-9%8{>Fwg`u^1m^n$Wyy_JI#=XTVB zk12jno+PR-ey=#*wG5?VKa_hJ!+R19(C(Y7R56(P5-0>rF`Q#}pEf&Re0xUwtj&;j zQLIfGC0p6+PvL1rE|@jepo>F10%pjll5#AT;tEL|(m&fZ4sK)v4C|p{&qEJXzQ_(w zjr_x&?=bwN)95QiZZL~0_%(D6()}T z2*^LhT)=`!NYp4*g$40JGv^oXvly%gwfIkS`)JR6$!&$Rnj&i~VO%1$x zJ@oc*{8abx7k^p0_!loct{*NS3ZKsEYPM!2%01ZM+(qu(+;MmL=q~}65~rb9tXfSk zi|Z_ky+`}0x_oCk0fot$fd7xy%&_qwWlM%rmu=I51P-a972}Mc0-7abQ1pXjNTxfM zv>@ACln~zgM7rlI4{>~V)m7y_86WLjSpT`1eiTCXQ=x7v8+mJig%BZQ$??+Y&!_@< zUUKK4`uXNiQXB>srEO%3FxNK0M;0_&^QkX}NiWc=Eh3GjWpF znQV3)7h_eTou4|9U=RHG@kifr5vamc2F0aCnRySySat+-nH(sed)~o;UT(^MiA*F- z`1T#Wz2R)2r)4~0jWZuEaiRh}>YkTUAJw{-J4`2btyX{X~WGVLygvYF# z2uoN?6v#+9RLCU|F0VTROSuk=YAey9At89DYP^ z=K0$Bee;_Y=Pa2bQRWK|$wcSjp-mk=Ci0w$R7aZESvozFD?88OzM;?`tZ>p$vS-F{ z19Zxc{!Dcr^DUqbp-Kr2_GC%Cwyd^y6SFPnku%F#NS9|m*&Y4nCOeDCgBvZ?_S=6J z&jz9P=dH8-<>AZH67+n1)h&VkdQQz6o7=Xcc7Z$#^}tU)N?*OAyw#CwL+<0e)S;h8 z-t65fUU${a*E^5@oPYB?Uf?MgY|6UdbaHSc4Z0De^yk3{eK-c5o6KJWINKNwyN#RH zvJVc-;i4`}D3eaV0sTk-^n<6)bhV6!j$p>BYDixdB~<#*dB4O0kiBi%?U#MHh{l8W zK;mZwU-u3;8P{UcSr^XA>Z*=8F4ZG8$#q_m2`1eh>n3vP%T#w@(fj$X3aWHO2Q8p! zlW~Xns<;+f_aUiTkKQO6OsMbR>YU!c(3ajedv{C)h!tBDS>ikrZ!*E4t7)~9waq29 zmO7ADFd$trzW$N2{pesrdj88H*tNkZ{u))L0Eow(g*f#xrt8y z5*y{5a%r<#upnG;KJfix-jHUgT%_7`a3#~>#80`W{m-u$QbpxQbreU*!7dqo{Y#0^r`MU07 z)2EMFI~aVkF5RYNiPMvlJ~74WHYNJlYH$;UEXO^W)>?@nN?FdA0YeULZh#z0y%q*M z{A%y|HbG*rcP{_C`$a)NK*lTLAGZHpr#S`6HwkmCWkhO@M&(-;VXu1CAsPxPBm7x)v`J_VI~?> z$0l_@rm0$gf&^?5d_bWR!hH-YAeYADI@kDugATp=cm7^gg$?Vx{fvY}5GJPAXLW6c z_GZh^7p8d6KNRb;#VPOy5_QcGf(7@E6)yPDjI6Jf$KFV7miz`T&1eXQsVIY<|^lIkL^t=sLOJ7v1k+U zFia=0437J%Gxz0*F^*h@WEbtVNY%HTR9uE8Gex_8- zVmX!yHQ-}Yo0JCPS1^-R|7teUJ4fLv}=t}-4h=W2(>o4JwLABxxAOuDO^v=W1LhxK{8OyBj0 z*G0z+9>7QtNsz9RVr_VDrEk8}xY9K=Sa zzn>c)MncJY65uBMD-`M<6JsxTM4gJSf6eZVT2&dD8vEJUR5x{%58T6lA4{;$9G@*Y zT6WDn77N7})zRwX*Nm6}!jY|z_lwD9wwI?hR04~6EQAEuVy+vH_Po`RP&AIA=$2`~ z#axf#(rWjV7;5YyEzMjXkbUGzKr2RDkAP@CjYk)s4BOV6-L~4)S8Ej$sh5_X#zxE4 zfaswy8)MX6K6M+^*7H&+(Woh_5kBja7|RB@`S4a97qytjb@jhJ;<$3lD*z6XzTu{K z3y6!RenI1+BWPUIFm_vARYW$`oO{a)OiBFkThZhZ0>s02!RmFT1%|h434%62Fc8ZW zcFKL6=fNbfe86XAydf5{56GJ5vOiBg%W)rIn*Le6Su((jFPd;Y_X42_u!W@gaXcl* z{%?$;{~b`2Vm!XthhobaCwxj(*2LZ|Ykfa0>47XzL0HGrB{VgP{%bsEwb$`Y+`D9q z@m;fz!!6$b@OGcCbA6U)qz3LHR{D3v?JvRa34?m)bqHVTk2;s|ywjt}%0dBPWaBg= zr-k^-0q{Act~)iQ7Dn`Hw-|y$=Z*V#iKmjQMu%^{NP&PI8&H`TP5EwQ;gGD2bqxk< zZ>?wa4s^dg;BmPS3*n0Gon^z(|8n~wW&hEVHR7znDTYpJqH`(3FNR6xg!{PnJm<}S zKNH(sucl~LnX$T@CUQ@3tI4Z$l8GCVHb40X|crGWISCrs|w*JqqUjeuG! z#rL8bLSD-?LSJ7I1f?Gfb*3}+6%0zjIFF=P_P1XStcq^G(MCSEr6j+x@681yUOhqW zSos>!C+#Q;`hd*_yk`$n8ZG4QBml^U&quc|DJF}_B&^Z>*cD>t+~P*ojl@jj^3xB) zc+mOB>;oHcW|lcYHwQB4_Nz2vd6Gy3miWhSDn>I;V&RH({P-mW_w~h){ohwn0K<3cou`sO)&Unsr_o%SmquCENgtF7 z;-4E=^YxWmW*@UZC=9w=0Armiy_Bh7+1h6212MNFOMqES0VC4Z4XN;DL+d|UB*rL8vd;DYHin33112W1(9@j=f_J(R2 z0)x)zqn|*<+q;A*d`vf+iFq#NfJi75s#lq6yXp@5wp#9tHjAXZ`i%g)jYh}Ya_r2= z?MbvSU_+}lwlEUq&_h4L1Nt40@-_+o?gW}t#X3v;hno)DxdG{eLSH+FQ|YrmmC?u9 zX3NiwO&Pa5VtHz^5<1HXcv9}WVv*~BZ78-kuQR)BN(;LT1YN}aKepZiDy!y;9=`M= z(hbrj-5t{1jdV*(N=b)=L3bnF-Q6u6(kWfi^<8{_|1Z}1)9`^-HvbLO1A_nCp5 z2|NbkrY}D_;uC{ujO4@E&c{S>j8ml%A%A16Ma2s_D^ktPi^`hD?L83i?fpnnP!yl=G;&=MW<(q$vXMp8PX-~&uyyQ<2`jk7k zQ#|MDDrLHk0D6*9i*ZEbRx!fWabwRR~Yr)>}1Qez6@@M>dDDP zLj9)f$En55-MDPs@KMBzvHouKgO|0n-0g(tv;`@K6v9o84Yn|raPaftT3dHN({-Xh z?3LH6Q0r1d>2DV8pK@Ovc0FYM|GK1>=%9r+`L2eujZ`Xv6q+}^zYI< zwykrp!s+>6lA;iUOZkCN2s-R~h{<-5`D;wqN^U&aWn^KSoyQMK`VXgZcu~v63Cv+{ zvr*s3E)NP%UbK*ep?jE4);|xt0!TjE+1%RRXYbt0gN%)x%2fR9RS526;nEz4XS$f> z^$UPGxD3#K^0u;loZ~Cw5z#1W9h2?D$(F-i@k%>S>*2@zMco}7F8G~ET zbQqNeVzQ;nw_W~jGJpI)V?g_xT_78636y3CIj!|bF>@~nV4)Oi6elbbhijwKNC=kP z-q;5Hfz07zmj%+Jv{r*))1Lm*RETj)IE3@RZ{qq`*6up<7K|EjoW_0}S>Cw)_l2Wd z&wOcPX|~pdkJ9gSZ%)UK?lYp-F<{r5IMLoxr@RGS!A=}yN|2Urx$wcgRub}OG*XA~k8HGK;u2TJIEGoW?NpvYxP&)5ag6!}^r`H6@h zi5HmeID=WrRI?l5{HMlEf&n;pe3-JUzrJ!8yjd6#e2bVMuAuv{lo^_TSqFB9RbX6^snLD*3R+Fj>JY#Y3f zQWVr$1D+l`em{K;-5CG4eEH#D7-CiWTmiNQH+|vpn$4D*`6cB<2G5wWdo3YaXI!A1 zYZsEmkV~W2E6stFYm#6!EeVCEfou@)e!G;~Uo;LCF%W28lnS6h@uL$gdj&~HO=x9@ zjnp_Ahea#8`=GhHLvmfzWh7sVx31|+k%y>I> zKu(b@H?*@#?k%l5Dc$crjUDlvp#wlfW0}j1UCTJUu~6CA2Y>2a0iRnXd#|Hw<&21i zd1BF35|UYGoKQ?>aM1-rcbX`k=SXTJ!$g5Afksf)Z0fbZkve)xuxMFiY0Kz^Vg_GI z^uqeib{+qmw=iw(*-}#HHHpxyko#}_R^N^hnY$OJrWw0xrR``h?F8D7^PqXI*Cc9n zZp3S<@DR7GhRf3-F0|nMCw`rnN^Y!1Zvir`#zH8iM0_?~aRaPsxQQBG?F^DUS`>1T z$tlh^x#FP@$*}7By_eq>t@}Q>gv$sZMXHPrTs;@xB&i?iK|zDJr}c;StIjB>=}Yh8 zVdM^Rh1;xK(%$Z9)7vJ@=OaN#+#u6ReMqD84O0`~+NJ**jHw;=m-@3$Fv9oQroWNK zM|<+M2$D=GBS}4d(P?s;XpJ|wB~z}R zZJ_}3AiLG$w!m`;I@1>u?yFOr+-Yif)Q0cZf&UO4r=c_Z#g-?`l1u;HjD<%x?x7n> zj8`D3My<1bTSoq=A#brOo^5)bU5yqy&DuCTd|bMFmFpH?Q5hByH)Bd8BO<;XPgBEJ zvl{tfT&s;#O+(yN=2~Te%M>xoQWHHZ*Vk(3qL7JTMg!;D7#8^`RM8@`{beu9RmXsq zw>+){g%TM-u{&lIj8;7|p5D>I39EBm(}J=-p7p4e!?yEGNp%UmZ{Dolsepb#ivs_x zEt%SpnMHBO(7vnw@`U?VX}F~VU)Lmo#K0LaCX#FgwX5)@ge($R#v( zUqMSeK%g~5Lf=1aFey~&M`X2%p!4tS<%Hk=cqIcJ`~K1;oV+$!>sJBwQ^AcV=SPas z;G^ZXhFjG-H_oV?yDLs~G^kFqotVL>zX)>X2QL9Gwdm-8vS+@>-(PaOZ&Kz^`>YQy z0YzxP4BOiSIWX_WaIM@9$+9jFCV&CLT5({F%l<6?a{kbR@+kT1!Ya{P&c>@7Tn^#! zNsSdr#g>UH#p>&8I3M|wMqx%iPjaZE`t=9$-+d&EEmuJcdNV};3w7$0)TNEGq#jl? zhxvVT8I5&bEf~{4DV5*Nm_z$?`wGnERP2Sp#4Gxih5%XYlI3Dh7mR8;klyd`*X*SI zoR+<90u%CAXJwRD+Ari|(4L5_Yvt@0(fHfY^BA8{$hVh7il&?51#AU>x@)^3?*nLSpdGM*FT!>@2i_r8wy|U& z9`=vnH0ENJH_e&#B=N_&ArI0=V;G3`Ar9*K{MDo#L8VW`ewZSb#;Z*RT8QSJfJ}m@%O;tkP(@_b(Te=81oK^9UJz z6F*2WAKOwt6XjY`u}|jiYooAVV@`Cv-u-fy)F`Ba>y?I-^zXti>6Iv$sD2w+@^v)2 zfkkID+wp-FAHZixtqWGD->DkIMG|W*0Ob?{6ctvtlDJqHNeuTrws7JYAben>(JJgRTh%5xj6ncCDp00cpO@_2D9`57Q_Gt zij9On*e_jSjPsJYmo%Dhp9B<`pNgKFep5h3&$TSwY|wpG0W?sf z-rX=i5~|&76f~?V!S>Zrdvm`GLiZ#`dX;}j1D%bw03M`IiBT}s!(Wj)(yw@W0h{qR z<{`UH2D29~S&{T+>`Asy8^N8apQ%6tv*TxrD8I0=2Rmlrb_=WkO)r-qMn0tMC(s2ibNjlTC5hlH(1rSVKt7l?h1$Au4D|;-P2*&_-D| z&OunNFf^23rhGkLChZHi#E7&7ZV1s>YjZg{ilmri#G?#BM*V@MH|Mp)@eKi#8a!Qe ztaM9((7&(U-jKvKLC8Ki=>Ka02DmC=2owtxB9t-!3g^-2JQd^J+&WMno$v=>egV4x z3*LKp0W8Doj#SeQIEwx?Xus@v{ln25ILaJi3D^%%3#mQ97Fgr=l5fpBp18mXcMO7q3vf_ntu;Vlu zc-*m=j$i-I*rC{t`K&MYIs1kdMQ_$umWPJR(#-E7R|GB-MigQ+c30k*`vo(Q{pktL zf(bA(#Pa9dT{vmn@Gz+Qd;1c59%36ZdxosFpS|FgOC|vhm)cXmYZt$V)YIhJo0Ap` zJ_-c~RO@>29q|~@rHp-hagQ~T;|EE^&7hL3!5Hs??nl|*U&+j9QO3zb=}Nomo=p02 z?S@eb;o0I?WTf)qoO$L?)6rvf^)3un-k{jU*XyLL&D$v-5rlwMq`U$`A%HCXb8n-+ ze7Cac>w^$u%J2(3234%9-J0k#l5^Z$kxa|McT^p)nZoMH*Wu7cUD@6fWsKqQh5%X~ zyV7}scergw*=4w>kscOs$acYk#}rr%B)U4PWF)DLoN7DAzbwM3|KdR`M8!U5f!(eS zBf6AP&jj{15QVR0w!gLWi;+UP@*VbFfL==+(NmVdMGOH^k?z34_9B~t+lUq9<@ROY zheIL#v3+^2l*>D%RD#B2TosVLwmz`V2GGJnHpR_id&Ywzq*Ow~aS?BEQA25<19+)} z9$xzafqpDlGk3U}6Tj8eBiE}U`p=o`!n+ExC#o8F-Dz)E$owM63$conRg-fc**1ml z(sRg(6Z&bDc{Qh{% zQ&w{P>cW_+&~z^#;eEUZDy>duGAgJ?d5d~1c-1|ercUn&@5E~UF%9E z|M3q^%$lapXL+NoAN2a~*Y{#zlm;GX^=w|$L}bHk{YZ|!j=T*&%<<1?g9SU4!w;+A z!tlbc)c4$MmdfaeL&E9*K7Hze`N&lIr<;38%rt|e)19Px9284$p0LUW7{kLNKSh7T z(Hj|qIfXWWzTryh_k$Ugc_w}Ttj%=KrAyoO1s`r!!mGR{Q6B@QvtsdpHnsLerRXI! zT#hjjofR>N8b6i-$g$(f18}ilKLB4)2nA=VKW%69U|u2MxYc=^O+?S`3eNGbHG2MX zTw1rK7W%yN_jY~wJ#DHSNUp`mQ%mjq4&?qLs}{o674>WWo0*Q}*M~P|T?)FNx-nD~ z);_#ZZ;9&LIC;4K>hUGqq`1)~@P|iCAM23))p<(oLkQ#Y5<8P>h1q-ETRT0Z&XiNt z2|11R^l^e|G2^v0Rm#TH7oa2o zd+dvTf3c-YtSHi3V#5|IwF&Sh!Yvuj3A&Y;O*>}NeW-b3@A}0MzNgdq4un^})qA~p z{6cbxzAJY-ntw*}`@omLY*qHL$fMLM36){b)~niGib=r%n_rrf+32*9zte$B{i|?{ zKvM3&H<@x=WaHwlgDhG2QVD!Z|6a zjt5iuxo4aVajzb2kwdDL$1u}9x-wZ?YgeF=yg1aM29Io8xO*}66&rT1aRI|y&#q!EqdLPykj%!c}~V6Ag@Y245`!ZyV~@3yiDu*fFKKZGoz}vgRca-w&LLm$nWJTTy1!8&>gc9e`=(1 zG^A^ObUO|oL-7`wm?dQ1Elfdsndub;Ktt7rpj9eoUm2}4X5rNMLaXL}kyN{IXB!&L z%rxIf@-pVO*Za|5sHi=2@iuO-*s~WAC&n;8TvCFTqw-KAh7K=YEwmM)!9pjkf~h=l z`bvwH>u{(~az>-mVPPN9>W3jAF~MWRi;hb%Q8k%>Jc9rCF)QOHr+7^$J}#ilqt`a!s4P4WdT$ zP-2{hjv|>={v)|d1Belrw}|&jkTc}N6XAI*_=X$vT&E8hSXH|=)EksmmL67AZ*T>J!gM{8G=KX1;MeJ1H_ zw!aMg3^Pn9pH%pubVy1t%>zue@F;Xo)V59UA6cjxvwe+o+1&_Ghth01+ zXoKY8EQr7B-ySsTt?#`+0rBX`#PzGK#9;8|=FV~{m>iapjEP9>}l`NU?T~CZy5M4uizx{E?yQYBq zCG*&AA9V*;1i=rc+49Z=0%SO!CJ_yCXZYtXofKD+NOyiFbd9_sunZIL(wVLO6XzfF zcT=&`N z#ks9n$|9`Jt4|bf&3^X1qTYe=!>;SfvyxAY?YA~Sh*JozO2XdEpf4|ymqz;AYGRQq zvwC8u<`kpjkKtvSFCQZqJln&!h;5o8ra_Ej-DJvb&J35XEMiC3$;F%C_m=V@?k!;Q zIoKjvYqS)NTVJL^L3Zs!=9-s&vEo(SMpWRVZyttiCwBUaPS5(l6wJfUtf5794u}e) z4%?4k{AUaB{;-&wN4TeM$T@_6rjT(h&h@i~b(!|fJvXPG|9i+;4(#NlFg*%9PUY^`rxq(1z%VHkE-0C~1naN-(_XR8S6k5_|uBP&b}pP_xEl6-^3v#-EH zOeycT^NMvu56W#`O6=BgY&ukUt#Y}o3%C!SXCT3=M+P=OC3%7NM=vIH03QA}StHC)j!b!xr9kIoA6+un{bcAwf93$s0X* zj!ROqm}+E(zosoW=otagzJy>uS(J2A$OR;zFo{SFHzu4Gll5s|Y*>2`hge>v4leilAfJ3*(K*?BSC`x-R9xR0D{-a+#ersH}=2 ziU<-9($g=gXzb(odaqKFz9zBxY2^aP_cWK{Et5KD)$#tL7`e3=D^`g1f!MfE_5H`9 zqxS!)Uf9t&v+>|_ln;+oPX$^Zx8!!)IO6UbP0zX(`(~RGK-IO3xGRuZ`z{@181tvy zEo44OiFuoDd@@(AzWTcWRt(gSO&w2kjT#kzasiO0We%GY?`~tN@2@of&?V3s!= zm92;wS*q4VL&7#hkXs#O4s>zA4@_L`UVX0XVtpPFN{9Ay&PRAY?U8%?h3*l#ex>qQ z|7Srdp3uljuz!?qhHU1)n*jSLL75T@3YeSm*ygi`0_3M6xBeE(lV!~9j-xzMvG;v- zAh$MjlbdTEzSaj7-fUBBBuJ1*b&#gt0-4*GbBLykTU~7(_Y)PZj^=wm(o;uEh?MBb z@$$U$_13on5=`8f`WYIDdYVA{T$3s%D-wwy&nXTcr|u)0RlRlZTJf5SKciXN9)mrk zLz$Pd6Y%E0sB@=1`3dYJizPu|4;x1*1LVYbMN|i?4JgDsDf5)}t6o@A=j;m%2(Fzae^FV0KV@pN zo~9g0L&YGz4D~Bqx~sB`%=`YkZz$`^Z4Bg_T|~0aM{wmrrO%FoxD&#Up+1}ErbfNg zwy9cs8?CB?YKcF`xTvTF3a(G*F(#*(zO`bl|?!&v=4<@xyIDl)@BShrF2e@#+)uqfmMo%awoGm+|0d{*Np z5ZrsqoBE`?bH?^leA-xNr<-)1N+oI>`<(_OZ?m28#qcYi0nIaHT)J107|m{nzBs~} z;n)j4do_-<>LNk0K{mp)UxW4Zd4$~IdqcEx#d`A4a2ADTUBn@>w{ri(dtGTnr5Dyr z)YPZynTRA}n($t0B?aDpCtP*7Uwp2S-$W)25`p}1Ew^aUIoPGwsH8L2=^JKQ;niio z*jqssbn{G4_$%=h#4m9G0VQ0p{v2oRbH{8wDC6Xd_KK0B5B0O^U3?SbSZLp7eb=9g z*TlK}fc`&#`$;5R6p6=_9M(@Pyo-%vF8!s-aLCT>(q37-m|A;n&AHj_ueZw(^CuH3 zhTPaitV*$z@H-e3sPG8luhC~GP!-VB?N-T{e9B5xq5&o*BlH_?jVNv7NuuxdWas74 z7!n3ZK;XM!BC6{})v`(+gvPWGVgZ&zi~@R*p^>-3ps#&+N3d~lCiKBNp9Jg8%KmUwBuiYKCiN{t3LVW z7?~wSK~W%tZ1(T$WlxMZg+uW8KPf1b2)KNdC&UXeR{XsBv#N<5(w}^D`*JfudwOdB zI!=!t9RsE#O8U>7Jiycer#ek3=4`j%-oKckBEC!|wydO@uj-2?QS&!m!G_q~@%Ku9 zF`*~|11mV7?l$G=xRHP%Wl0{4a2P*TGXlv7`j-|O@7z0PT6RDl@k#UB^|hAgmfX3i(+x&;uZ{Y;-7Z>5}&3Kb3Xb5dcXu@ zJRyIR61_r<+4khT$`Oul_mASPzpF;(+?Wi{mtMj^YQZ$TLRCR}@*Ys8cn1!)&+HY$ zYcAvcsEw*|K_RNLP^nDu8&u$_d~a4Isi{L8zim6Z>m&#XkIJR?$+uAdZ{&W)Arn_H za+g1q2Z$lzewz5nHr?lCV{q%ze{e(5u1Akj!5WksqKSI@reZfibjFKb34JxWqZ4BO zfK@u7?^k~nbH5%>Ufb&Qfx70M?Nl{N!t}LTh$n~QRfb~vq0plZwnm`p_M=7L%I-B+ z656r(?>ZIQks^T;*o3i{arNR!cIqKkPz^wb8ldObC0_GVblZS5KGO@r9a)7t*P+T< zY;~N@tKcg2&_4MNX7|f;2!6LebA=t~UOv(Yf#(4Qt|nEG6j*H@+4$a7jnU)Kj^8`v zdpN$wIyGW(ZnI4=3Z}Q&JC~57C(0LH3Hy)odGTN`THDZH&{#23*uW1zNftx}#!DOX z&@!gtxpH?Qe;pXf``flw=0|gfjD+v04QqVIo2FR`K^0a>y74ZbIAE{&7kv2!bw~)= z=U<_Ba~wB=E3A;-i`G&B_TQp1)2c7nIVTpck$%m}s02%k2MLc1%Z4!;`~DiIC;Mzb zEbhA+*@-wfAYLXxm#Zu|0ti@~#4Tahk^wJLHf?8L8e4n#)2~QVGsdHL$F8!4m$~qP zBhp|wgl~#G_1n1Y<>rG^?%CDFM>=T6zsNUtU~Te=kWb0;kAQn3{?Gd)39gKH{Mp$R zWTLU5o?sZ@TWRI|5&mn*$6v)8yU_~5dNz;Hevi4EiShW!q|k}^GdY2wqKT21Y!jFp zo}R_IUwd=CV^t5hm)fpI5k8UJTC*?=BfiHJB4HpG|Hl%o^HE{3akF3GlkdaMUlf}{ zjWlG&F3yAMBSBw#QVKE7dQf&PZn|!WvgN-eICp>C=`HnLYq1@~#pUU)&n%ao(k8t^ zEv?2E7$%%}%q%}?~TEb*qb|`su zV%i6b?gXCs*$)QkOL9Tf&n+AARxQRyA!S~`SipJ!8uS3eB^ND`Y#9MahdEJlD}pt{ z(f_SMIkPP(eu_Xkbho)=G8PU?q+!j^OJn?^#(W#s-DLosJ;SumWAwA__?Vbs^1k3p z34rO&RIULDY~mTged{)8U8m1$H&N{ErGk&ChC6Q7FzM@YMNV-vN-P;zni~2++En9; zDnSlR4UaGP1BO0G?2`Sfun~}NAZmieNR|DG9Nc3vCKOHNE62-3Xh3-nmPfI`yjQg} zl|)3EgI%kfZH~)2b|E?`&a)Dj2k}qm`)fiz1~D$T!_UU6KcF7m^G*(Y_YO1WW@k7s z{N<+#7LCq9ykP_+e?jdgSZM*q`+^}^TmfiM1F%M!^CW%7eW7X&&j(v))k;bgTQ#2m zViQRWzbrv-Yfo}mGK-%e7X=UU1eu46ZO?nIZ#-KGjKFR?x z6dBrDwBCJf2N9Ot0!Q2(&VW134oU^d5Dff>$5m&VkiR@5 zsiq+oqxit7KpM1mbJ-YMH5hY@4f5XxY&Ni;;ed4^-K33T0eY(-L9P74A&SPE>loA9 zCQAl|B2B4t2@kQTS87LP)1YIaO90xWY+-0n!mw2;4`lFu%1ix#5xP;9HY=y<1IPKZ z#Qe!Uh_e}(SkM8dc&ExEWV1%Zv&lbxN=}jpzNnsFUF3vy^&Ead};c#9hLed(8`nIVI{wkvP#ulVxRS4LAE;h;mFTZ7 z+a&I<=+&K~`qad3zs;+bqoGSp12aO`gR}$BoXUZZWyeQ%2i~CCN6GaUh=|=QrP2kj zeAO$C$jhzeB|!PYFvTXOIZzWQ^BZIrKL=Z4b^`WpPzw0f|f=EKvYS z<8WVk6Bjz}97iHMVPRvLa7z85@sAxeaK`g$jvWNW zRAph%!sa@^@UKu*0??#8Z}x?a)|+Zfu{K{%W<@JRm`p2X4pB=4cy=59>5Jvk zb)E7ZQG7jbi*(aEfrsy_+h&=O1vsdnS-$&{EqjVv9|cuykqPVwunWwln)`tpEZo&; zCFASS@ZgW1rG9Q((_=p3__rs4X%wn^`cwH!E`Icy1=DEGtb^*SJ}}>!bCNM<_lIrM z@!ogUv%iVNe6sPaA)nLv{AYv83{=COmz)UUbjud4q?_|?yeTA;x(8Sv>ISPhCgIg?Rv~LyP1%TV1G$sz2 zRo%X9VsZ{?Buiw|%Y7+TsH@lmcfUPR78eANERf;^D!M=-+YOtrANdJIw4h}*lBG9z z2#*cvGF-!k|73RLUccY_YNYVBE^}oC#kw{(i|w zpXS!H@70PxQ`CXL>7%_y79w0E>8k+#S4^Z(CR7ca&AQR%gH?>WRpz}>w(sL@1&71l zhB-$kxLG&}d^~5{WsLE_9r0W3486m`ie=rXn*Az z0jTnWUodm4mie^0%ImENLxUAwzwdMXo0*IZ=m_eNJba2)-q^u}CIiS#<+)x#eZ@A{ zPbj829p45y(e=DDfoGk5Jfp~Aznu<*X6v8q9Y!hw;%;9~E5DEq@Gc5qI3z;CViSzkdm zjyhqfJpGmtb^))yB9F(m?3bKxhXdZ+%nX$HM*YLbd62`D5 z4DhHbk>L*j;6O-E4$IJ8l>~vpq|Xp06eXqJ5ot+>?d2Y_*u12yM9y_n9fSppHqeWX znj8ZLEqMqZ`3-f~(tbvWbU^tlpg^SeN4GIt>fpveFBg#g+1uWrF3B8UFkGYg?LHqH zh6Hm_DmOY*MX1Ovnw+_;-q+0Jph_K7*u`adS&i{1me13@N0oZ@+HJaB``?0_0SLGY z^QV12zaB9IVNy|PJzh#PL057r)yU}>X%z|^8w31k) z!e6SSkKz~I^ojE*LM5RNh3Z{|rl&RI%*?{`wZGdL;h9mu2H=_c@-TS2X1e{w(1+0W z`_IhO{;|GagaaBnUPG&y(wEPKcj3pIo($8E_>9D6aON2;RW=eox$*pLjV`!;0F!s9Z}mKb>gQYVN$8teuFw)+6q5!-tOmCigH2F-m9GMOm^+x5R1U! zK&1bq_$xiV?a4eJKDm3^D2VHJS&66#VE)!2$9y=6*ys|z>Myv9a4vl)w$O|nPJAhv zsyAJF27FrFggUGlXqHu(_bn^^K$=m{oHkim<-2o43I` zLfp@J&8&AUlW>_oIewUb!cJG;Kly|3)CNC&j|O|GEH zehN9DINF}N_@TKG{qQ^Xj8%3KG|&WKi?Eghy-_(FPGiYnfjM?+KS0~5V>N<#WW@D> zFeZ^5;c3Nw7=hY!qTt~o%74(gFiQT*Z);4~E`6kkeRNR?$E0>?NRlS)Rz3N(ersPL zVE}OU6;d^q`juHzH*9knMHJ{T%eSE>JIh|US#84pNFLKN3#C#Kz^##fr66ju8=vhY z9lu2bl)i5v;<0o&==-+$h}YN5hjiV@t(WN?3Z8IJ1`!1(?%7%d`7G9OFxzR(^jqnO0 zj0&mxMEp5co8{(6!lJ)RgWgmAe4`rmBkzLBp=xZ)GU8e{{}4&o`yMT3Y780oag7j6 zO5ApO*cjz~(d?Cv)U|<$MQ5Ev3dxUJic1Xzg5vvd=J_*5UH1ew)aZulE;Ly;g%m3M zr3hq$ragX0umQ#NZ=Rhq-Q3xhU9l3dEVgjBS9-1Hap1|M1Q-Yf|E!8d$5sY@KJqjp zQkm{sfbwCKEjziU)X0eld~me>FeEY`MS^hKx+VDr;nskL*3P^ghmAVRU1Z;1nPnx& z-T4RXo%~rlh99TMF9B0$jd$Nz+iGgjeb|3-vOoYd?$mn#u(mFit#)R6N(4$UYzw26^f?ig}-$D*cYBAqUz##OY$ARq+|Ao-&kQy1*~+51ap%j z^YoD{4VJ2E?CN$5jl=ZH`PLYgt%c}KL7V{A>x)V&*zb!r75Y7su>VI3K!hXi_qW6L zb*lK=%2rsEob##^CWlWaq&S)$Q{bPvDIeY}yh61<)A~IolJnnHD=9u3<(u|0y}rM? zF1s2za=}!quYzf)w&DIhN&nu0X>f>fpiNf;7lSGh)=c6SKi`<7(Y@_LP5oTOo+|&i zh+X$MeR{J_SJwXAo)*Q+%i$AyQ5nt?#$k?D|D{ZBisb{-(#*yF(olcNOs&{{1 zr)KkfQ5QIk@6~yq7?_1?<#)tj4Hb?cw|BHit-41hdG2<*j-S5JyF^;DY+D) zyt1mW8)1r_s=Jka--?dVc!t>sEbJj&x7Tygsnm(wr=pA|X_i_|x>{wH2`I`Z-)}m%BKtJzPW}Sn zZcAckoAa?XZE4cDnYOT*QP|tKDF^H2SC>fNf4z-%nhcdBpI;@mg!7x7tTGWZFdn<- zAUJ02sXzg$ir8*u3UkrpI@_0N*`7?);;5^qSlR4Pi}z*f_@(;dZhtB&?k`*CNA|x@Vj*th_yIhkp*_MS^zfXb|L2NWL&myf zU_03p(O#h`^k*y6)Wabi9`XwRyZkm@*$gaZn9N^*8xM(qkNW?)7>o4$n;^8XPM$jc z0!^&{Pjlc@%D15aEI29ruVF|)<_dDs|I=1`>VS?50KhX1Q^6vH1J*bQmA-`h-!Buw zGYmTcXVRezgN_tIxss57H~sRZyjU1lA>{OIYTD8K2tWr*Xx(0}GR<3}Mf`}DPsf@f zcC!co!p1VkNC-gGO-c=Q(9834KlAE}#OV=pkpf}A%1{!9%cJ~7QJRS2bwMM7elhYl zwAgtZ$}T8jjwkAWcaJ5Du^neFsU~tY#n7D!4Z95?gZXLeP(1bems7nKbx;YEza!k{ zY;WUCLZ2jc{2oLVw4{W25al6q(!I+i{Y|dF5_*s&AI?kDP25vbNp|3lFCba_>N%#k zJVDA#qyyV{b!`=t*9!qAn?@YuLaUCA_qZgC`04^JhOay4DaV3@TWzS7gIM9n?Kjo^FQD%7tK3lyz&n zJXc*^UC{kv)MGu0AQ%9Sl-T4gfVgPbkoIEGdVHqxQpNnaCqdDH*ed{(e;L4`(m3@MZ4K(b9$4CgAMmOnf3DZU zCxsQQ`uQ*(apJNvH@kS*Rf`ma>lR4bo1=! zL3@KPI$${@)dIe&wA-$BqFDsAom=QDjB0K(zatlh0RPz_JOMU6Xog&gwjxA@V8*I+6?0tL!yH0LcF;Zu0;$`_8%zg=3o3pa*bc~zWfRD}XWrko4~xvRKwkl#1+ zdH&wBTuyH|ut~uWY2+RR$jp{jSDvRu#<%U9TG}_A#>-L8i9n;P9m5~IIpgX8K({mE zZU50Ousx^#+e+5&t45p2(^U2+3{3d|z)v1-;nhN5j&WgiarL;A)WI4!_fg5=%~4?c z3?T4)Ntk*^|Y131{lo8Kh`xKF5ndk}bUqi4p&n6OVZSaJL?ZCMG|(Sn*@y$gLf*C$^@qw2jr zKSJ?&-sh~x9yq>N?ek86`AE3s)oG+`-8_HktrYku|42J$dW75TBP0CaA@1H?5`1E1aN6iO2NpwG-l+m2h0xkX_EP zy4f;ZPUzh&IDg)OYp-U6FW7Lt%vSoM1$|RSLSiSAobe}^(996|ZrZs`!u}mYt4pC> z8&ti9_`^LgGQR-7h#5j4=Up8`@bkXo_trxu1MOzpRY&lF;Fog7(=u}Um=)^&`@K+A z6vI$5WEs1O*EK9@P6M%8@%X&RHm&%^tM-PzsDROze(QXSW`1PGviux$kIYS{>o*h9 zuqW4E;BPm*V;>5F@9+dVdKp<19$uN)w?gXlRY4uHZo3_ZB!2}^+%6Gj19jWM!=7{( z9^$(7y^XfF&*4@L(M6|grKNwJ8)mxgak09$&W?wOO^gK&-CI%y{APA-XOh^C3Q;Rl znu=N?O37)$V5QlVL_(`2>tgv@2`-1R-x;k` zIqdd>_Fq^2Yx1ML{ls&8VrF4CLUQ{Uyl}UR_*6_3t&dTG+e7Um;lcUh{(ef@4?aQ7 ze*1o;tMAVPk-5*LMDK^PqLaVF!BS=h@5PG!Y^fT7z;d}A%tm$WRK&h# zB|3#VI5wMlWuW0txG)TnnQ-7AqmxTT`l%efZ(^qtC6O~0H!Umixc)%j=XxBDh(#i+C!*S*Bzik)s%2OgNRz{vTkr3 z-UDk=f4`^6*O2?p*;n;j*C$>knXsb;Y*u~w4Y5yC5}%ozI3T$T>sEVw58S{LEmPwA zdRm)2<xr;D!vy^a@o*37)T({xn&+0Y_fLkF$MB%m=@X zboFiI@XEs?ek`2TzyyyvW6t_``NU(>fK*({9ih26Pe&y-%Y~El7S5vyQEqUmv$ixM zNEiYPEDrVYB9CJ?x70N)kKun4uVA1LtbyN!9T$Ps*q_6TfvGp1{Sbb#cZT}NxBNly zDa-JHy{8$~Q}L^e?zw9=ooBrw^%!4@Zv0mI^8PqmwF~MOF?6Ax^Uk=q+_jHvNKI3m zwHj2-Y3x{twBZ5ymKFXyda?}4LWb(q1xc-FNUQA=wTI{^mtlgP|Ab2g(e6chZ%9myCX|n#gX?$lFrw$TX zL8j|F{xCAx?sorw(R7tjQFUE-1jJE6Mx{Fiq`SMjq)Vi`yF-u;kuFK;?h-*jx;q4< zyBoeU?^@pvekf~k@11kb-cRj2$ol<5f83UT?VV7dmd{orn>tus03gAE@9LPy|D-ue zuI%O;Ep_R$>$>K)I<7Yf+%77NIkC`JAvxC1_U$NS`qo>^zB)L-YEo`uI|_BfbMw9| z&=FGUMC&XE1&k{y0+gBiegCOICp&3DMok9VzW(f-2ELBjR(8L= z9c;J8`%lwo`2{8%+2E$E#prS5G*#!R-!xYMIXfSfR{qG)U$DTZwFq*kA*h3B#p9e4y` z!mJcBtwB1Se^uHsMVIR8s+f?W`x3~CXtU4Bm+YlWKm4tX4PC$YX`fO(AL$#rX}h@4 z)O*opUiodmS(49(V8=8ekD$s%VKyfp6w;veB<4~oqc_4+g?o*S*i~njuZ4xb5B6T~ z+8-!Ug?vGd8A{)y}7^hr!%WwQmXpde7?*@EjyrjM+D@fBSaNt6r6B^+vc(BZ@Ab!d)lf z8)0+5gX`wEjQa9(-S?Z9l$*7rhhgIXI%4qEoRhzTnHpj3m1(3{TO>b6i5fi>D%zN& zHEIL5kpqo*kn*O!12xOo$6$FAJttLv#MXJji%o#F7f zgH348aOf4_#>R?SfMAADQ$k7NJe0>Jq3en` zU{e~wn9Hn^&AKMG-FL`2BGBCOFpNnU*8F(hTrI9%jvi^|v@ZS1U1<+!WjJD*mPFLjZ&HNb#$fX_`P zV)znNgWs)8%~hcIW?*M(%@;4XbQ;!@Aqm%)N57|~hWB1Zl&`7!F$FT0T%F7t5wexZ zAFE<%vHT1*-|Z8kf)bNpkhIV#KlmM=F!sxtN7#uz;P^|9t`3nu+5S{jIkY~qB23pz zUt6Y6szSeiI`AwlwESa>v~>W$bm$;l0T`@>{IJC>6A!6MgNwXVD`)jK>unucT#92D8q1GK!r1+ z{>r@D&>uk1^#3ObC1HId+~{1Rzww=0-~sKBl711GHnvb?8OEhyDJjp;T$zvtCE|If|0XFWq-cbKb1F6tRfcRCK%p~qj*PnHDL=cr@fcdMcHoCX{@S9A$jjZrX;`XS^KTtP24C?G zHwzz+?fP+*YP{_zIaJg=n1GjS605qFh=wmwDUt;_gyZbtB|q`o zEOiOz0+9BjPo)wP1b_KBwaaseMNsg0NRE1$D^qh0R=&)lz$NRA-78-z?BMQQ!vA&#Zl*8Wq7P;>b??*PjnQH`al^|? zo}o)8_it_O@7Msv(9`(j@uOlQH?q7?wAL3L5h*(r@B67YpGeI^m;<_UMEE?xy!e-v zOu1mHcoFop`TG?yB_lRm)M|ADZsW(RIfTO$8fnkd@W|*5ES%2Wj#A%cx!K~v()WK@ zw+;}HR>$ttemIe?!N?TxT8 zd_%pd*3Pr%`Z4rJ)gi4y1HhaYl{-@T10=Hl~sh~!dHg2!?JSPdK&Y?Wv zz0_AoFTE|Bv|(EAwFQfF3Z7yaz)1Zf3&l6cy{ijnCu^sUFSXBX;9}`MT7Q*J+~N}m zv5dn4)SwVxC$NLpVxM6Tn*HLl?C#+;|@2xU$07Rfqf`w}27=SPEXX6>7 zI##Q4nZcKmQY4}x`ww?yomth?;`lv`Tk${M%BMH=Hw!~?$djCC!p7+O-ALX<4MDZq zzN{tjCK#uG5t0v5WD}05?jL>~@#oqBX5Jf|*ofLyX{r=pxB!pg8VTf*dAY&bi5bRIG?a6>yMP1FYL2I3*B(NDua8InU~uE2`)PFC05!swmY#Zm zioXAmELaSUI4Er8V=X(7ks~oqrp~(VmK78RZAN1AelV%WZ!pq!M!kw;7#p2Q1zx~C zF6z7>#E7^elqn-TC`VW3WpVq=q5Rn`MLV%VVrrr;t(m)}VfZcKWXjz9Jlma2QwY|& zxFE_H1o8k}9JhIBC`~vs95*_{9gV(TbRr6fftcFOJ8|$TOq!OAuW!eNlKhAvR-RUF zLLV(GXwuj&P6}Qlmo(;iJ*{QO;8No7l}04>scsCE~Vfv$WPKQ{Rl|-5Ju>yC1&A|B1-Z8$%VgNZ7)_O zxb$SfLxZ0O49ML#xI1kK;CF znO=SVk+7hvApSV3AV@EiMC+|E7wlF2Wd8WeXsVP69x$#dz&U7w{*AmRdw6+_Icd&4{cn%4i}! zeqBJ>g1#3BV;6TJlL{u21 zuc3^HA`2!g3?-q12wKVgmg$&`^zTZU14<_%goptev8d^+4u6n*Dz_h?u}5!5WZ?_? zu0aGF`=BI{7t-U>vBFXzRAD7KWjEnSU#}lBD%+(n;xRC*|0G$u2@wB-(V{igeB>z_31n+_mkgCyGDvT|z+ z?zQVN;0%ROa!pSHEata1<00Goi4(nbWNr6xsPtwZej2eq%Rua;T8UFmss-ZplT^Mi zC8J%1w26pZfN~#F|L58u$}lY{=J$xnzkO}Z5G>ox1>DEP7{0vxyFIi`tPS*!viVKi z&wT7y#=UJRz%jq6ItdU^L|@pnJiH|;^p%jaR+Y*ZawQ`ESP@`KYG7_;&4S-BYh4C_ z$jk84Nbc5{0xgx!QPcpL&qT?asMc_AZ9#FSE%FlnywaIpj@-TdK$ce21!av$U6eEyUe_uKMu?WHf5b1WPVSM_CU zWo-7XEmdl~@-4C6k9-}@{rXF-hHhw3PGFA6S2Ez;;A|0qVOm>62q&*vGg!uGzn@dz z)E-Zr>VScr2@oC`ZU2NQ=}BW$|KcOr`KiuVCG8J!rjti$*D=P!4&?X*__)|aq2i=& zAeHq7qW1)1=TY*?we>vuIf*6QB1+3Wt_AAOdGacyTEbL&Ebi}(r~dX+le{m2r~+Hp zmU;H#OBAVcBTypgAU_cxXAnqyvP{)Ucm&bl;BdxP%h>6BS0&uuxC`Lb*EC+)Y>^v! z;33&hcE}Nj9zj?M!X45-%)bw>icEg&UziwMmWxm*&3hq}SikYdOk-znXU|jQzAdj? z=P5L)u(C0BF^CH6?B5n;m^EIg2!Ao24l^*6Tm$DT&=W^AyEm16N~HREv?6cfJrBLD zwKp(fzUrnUE=y7E0kStrQ~I!pE8oaJIGbr9zohRLLk@`lSO4i&*NSAr~S9rnBf}Sz&9049V)5CW83+ zEdr4YYRvYb*@oGR{=Pv+$m%CrkG6Rgo~4OcQUr>z&Tm@0q_nJL%y@(wv3Kg@(>lVSX95ip`)|@i&Gzfh!j4# zH*utcL7dxB#oWwTKh~z611(07Zh~x7Hnm>u?c|nBT4#`)eEgmT{N54 zQ6g+yb(-EAlw*b02xO2LE%m&h=QxT+d1P;5Juoz9$HIiU3JmaYg6+wWkcB@I`t{jd#&GJ`@M{3!YzmYQ#%)fs4X2g1-HkWtgHkMDaQIDmsHK!Flf7PaJ( zn&UCKU(3ICxaBKEz-0z6+yFqaEWO(d;h}eZTy2PIoY$TwHe*8@kfYOO+sLM>a;aZ` z9&v1?-t$wYo)i_JFKR%0Lwm=$z|pOo=_4$&b$P#^*rYFmk9CB07M^{zOpviN%$nvf z2|(A)t8}4yqHKA_o=2I;nE40|YXsNJy??9A1>6BB$btEDHa^0!$1|nzeD;Bcn8cXg zOzIfEUGx7IKJ*`f<&5t5i2b87Q9#AF&)B+s=6uJVeO0XWXcS~h%X4vw;mr1z^2xy1 z>KxjHJO$7@Ylu(u1tFxwA6G3c+DU2BN54#jJdb@Uq%vf$L-r{Kk!0kJ@CHOs7(Z2A zONkgL0wL&6>m^8)1;hF*v*j!7aOj1ZNehNMo$l+be(lqL-8WOI z7KmNIyJ2DOVxY#>PsUI6)JrhR>(WsyUuk?N-^rJ?(x@O*vNraP#7HvkpL!zJ)DY!R z<`zgsoS14vHA-X_-Z${8^h5j^-x*JS2L{9VVbFZr(k%Rr0)Bqbkj~Ic)4$K)uKIU2qoWo3_*PTN zhiif3m>|J0`HiDcVDM&&%G3l~fRryQskftv!-{aWig9-TH<-4{a?Z4wFV?5@9(E{6 zXBGJ)`D>}miFpM}u?I9fEgc8I3Bp4yw?M9%i&qUU9aX~Xnv(wI*2u)mZ<7?hItEOx z<5T_dx+7itkx5E%SHt1=3N7UQS1sHF;@_LB{q4@x{G3BQeK4ngzOa# zBn#LlH$W&5BcS6#Nf~l$3j$dwK=aTp99!Tpc)RxTdX*dGU~ zy2~8}dN?vmJu^P?+Fb`cKJpFhRyA9ec(h)`9t?Gq@0s|?Mh&m+m60KScKDVin%&{pMkGkW_Om&}K`&qdI>NoOIu~cuVO9B~c9;o< zx+uczU#zq1{b5ElFZefY4$u zjw~)R?q!x0%VcKP0y>&{kJTR}bm5^Wl)wn^)EAB0zmvgSgW27^Cl~6x-Fm>I?G|l; z&iO*717ElOz-&S3vil2S=S)}@V7X@j(m4irQ-R<2D_mM$t<;dNjeg5JU;e@O>G|h) zgBVM1>)l}>c^6%7Y6S_C7&9D7tD9z)Z$}hJ6kzcqK%~UKw6|Wy{np}&jisLJqx*fi zjjboo|tS5g>}zH1+0UZOO*i&x(zg@f^8hFiK*UN+r*pfw#8s*T%g*Y;(Zs zWY*IgsUa?X7YJjHX2J;*&E0(0vq?_}G>5 z+^GKKIIF5IyHT)yCBwC!4Pq7w|HZk2udaY(=2(aCRdLk};{Q6gvYC))um^x~b2<%VJ3 z=1(d;P)^qM4J~HV)u+HuZ>jsC95;0C+I6Cew}$zd)O!n~3;rA<$<|rNanwAZKvJ9dY_An-yF}CaZam8q zjl_ss_p+o@G_23|G+=`TIPQgnm7@Gi4A4!Tr4$7bFP3)^$LPb3s96^GZnG0Os`WrE)@=(n?D)RVybJ5P zylp;4FSZBY7VJ_2fT`W|{G-&wv9C$3cH9oyEoh-2)N}{Gx>%0GM{9R)w@+RcbfB4l zc@}vW`R=!nqi<`BLmPeB&zMM9cAPX(hvz2D6$+uGz8u}T0+TDQGrd(OuL@T9V-BjX zaM=tQv6o8A*aTi3%Nt{VbuXn_@QyL{bLi0^!OtyzP6A;@NST*u#7!`K&qyLA%>bKW z3G1kkMI~W8JkubkKhb*rP8;gqR@7ATsXmGi1eXw>P#gRxp|`EUJw-`4>0@3qaCVtx z0NN9Gu#j=Jip*o0TRE_l(K?yA05j!W;aWsxF~#I*y~z zPA_uH2=P+APX>{?(uUlMWwX8_=5Ae0{mx zraHZCi&n#)c^m=!aiRe9!{9bkwwSO4vyres|k5d2)U)DYy;>d9EOeah& zo}Zp}o-iC_lqKwTlc&3U{tnO6=h=5@+1?2{eU;~$63~;r0Se9L$?LAnaO+J4a`f|1 zkChH^nmk7$p7rh91n#vdd_e*6usC55(h>7>(@dy86>`o_Kt%eLfrcC46{Pr`U*(MO zxARM_HvEgNnLyYW#e)Etwu||?tHqpxV%j7A_dEyx5a{HANijIixq*`v7@oCnHfmE? zl49DlTP-VSsW;hpFOQuvf6tTOx(RJLxLalfrT-YmXD~~7;)hE@iPBu$O}Y~#{v~h! z&6oYLmT&4wIpO65P{_X#wSRr3QGUuc0f@Q1SH#^$;so0tx$=z|W^+~=$CF|*TD95; z!}emoxw@VX!M!3%%Ab^BpXwK_-4P&qQGW=T3ox#$Vap0TKYmms$w7XK{u*=Xv$OGW zp>7N|M1%Di;(RC^MnB{a+Z|#y`5+r1vPo!Zv2nqNok~zvml~M25wHPZlcST1(udsW zAVFG!a9omj@-XR>lAxHu!N{XJ;b5DpW&d4= z2p(dFU8z)+oJFH5wAUq?vP>IIB&57d!P8#26wgsMwWxm4cl?wjK8MPU^|)z3Cr*q} zvoRRu2QhZOZS9^AbQ>1X0x)Bz4IAq5)`E+)4LSb)Yv*5x68q`HeM5F{iNF7;oHh7{ zvbmbtuwR+);&b69Ajo5B!H6C2_w!wUr3rU674`5RdU5EJ=Vk`n6i)$2c_QfK>~76= zoS}x!YIl-jB1r=+DY8K#I)4hcz#)F&L3#dNp5iKMBs#_2Po9KBlG$1|5?*=Q#-4R7JNe|pa9Ev;Yb<@laK zHhIr4#=-d-9vr59w5w-*)pwi)f-Oi8Ni&*-=2F^CqxiSNWqBnmUxYAG%Pa9e@BJB= z!uo}@r=<~@M9?$#Z)@*k?V{JskJeM#eso0t3hr9D1ba!CE9rAe^mp425Gv>edkK{* zxz56pB$KdTFI*=sQzK@93X1M?Y3ZT{_bYxs2-03_VzowzuF0B>DRs^B=!FSGVRMdp zdfbP%YAiO(`HH%T1Dcrqn#Q8@Ujyv9gfLW)s2q#SzM-`iRrK2@ zN1dq;eUWIas#McdTfKuz{&9>oNzfVP!fC90Sxo0GSKqlZpko|H+X7>2 zcz0S&?r?Q*>PUwU0_h>#Bf!VjtfXO)!m@$8WINzYA}sl%-tww;ZNa$= zb>QxA$1B30z{M2qS1`p z!78F~M2#~7QUjddl7moR-Eg?l~ullySbIXu|8^<{E+v({# ze}KBi^6nk>Rlp_s?9X$;gY_!7B6wkiRPrq3Y3&UGtwxX$Sg7eIZb)umH-k$;I6t z&@!8wYKJptNQHF}oVGNyPMMNRy#l!MHW71LuXbi&82*%L+?3IAKxKF%k^qtnKWEy3 z41$62Z9|hYs&+`0zNN~MXkfCcL>5GoB8SMOU*Ia{85UXyL%|%BIUFsM1;vF8!4W(% zf+0h1TveL&Kts=m7)KK)vz^bNj#5U+9MmtW8Zxb$J|4i?vlxZ@rIGROuykC@1UND` zM?be*wr0$j7vQ-@ClvZ*sw!q}b80#n53DESz+bAa3)d~D9VokNDak%!@myaaIz~{n zV8tOMK#B0J-~TjCV_A&nBivipK^{i>GH4`nKZ+!qDs3O&=DM5K7vZzHEtZ?1M054g3N! zFD-4gtTs%+Fi@27T-~4n^)SepQUSFj5B_Vs-S6=0i_r4$gg+C`U9&5N$A?fl{}nI4 z1j;#lj3GYzq=jkP&R5MP*bwLt-;^CY3RE^nl~zDJ8>DA1FRzf>Z3@|ZWecXce|_&g z0xGxT&JB|iddpifmUJgAC1oK9yc4hs`$6`j#H2#vLF`Bcoj2V=2c+r>dzP1{0r`;# z%cf1G2`4-QoLo2YyY&e>mw;P5*1olaj|K=Jg28}t@N0fQCOu0q74g;2H%mX=;@3-r zKv*9yz55PLcn7^wfpgKaw*LH$I{cKJ4-SPm<7C^z&v*7%OF@+O>zqYZmGtC1PhYQr zeemn(^^_{YbdaTBv6nS=)~uzaSrY^UwiuX}#^1C5{+YORl+z?4fJU_bU}lynGYGQr zg-cs;-_nomc9^P4B1TBh*LpncifP7)nRQgu%2w1f2)x|)OF#~{JWQ~kv-ukCZ|4YjpCHJjfV>AQ+a*^LwVcPa*)a1i) z@I1YXH%OkhQ(cx3F8`fI)x5dg0Z^AJyC-ABRUB?;q;y;NYTs#j*8~#MiI~M#DQYT4Z zEW&2)cfWO`Kn;d@B*QC-QtX`2<3hGzsRK!P;K&(_S=Fxp{_CzpITI#*y2Jwrs7D#~ z?(2|w587Xg8OXP~TIq^JaKZ3oiuX^2Z1=CdzVh;#n@shBD08tT9(GnaKBFEKk%WW2 zu{#T8p+=w^C6G5Vynb>F_6IN$1y;c>982%quH;6Uy^#Rp0z^;0h>2z^6?W?C&*$>n zfE^n^FETGGaj)SY{7igPr4=57F@#HW+PZqSliRfiqFp@Y#G6b2Ej!@Tw}3!dIkA~V zGdHrH3qaJLU}Qsb4EH;LP~+`PowQ`xqh3Z|;-8;?dOG|;OS=E2DR{Z}&)|ad*PbC7 zK3l_xY0Jfg=vp8{v#T9x0k8QKZdhs8=5M4#Xo0-qy-oRfb?WYSnVi6{?e?CfnJ=xy zm$rBIPV=12fU>QnspU&!6EPzHCH@0h8lq&i0+d8Fn#8F|3@(L60 zU3x(Mp^#97t_#Lc*C^8C)30`%b4#~iSV>bv}YQs(3 z-m4!k+e4|sXuI9`bxCe!db>_$pe-u^FjRrNZUb|0;vmEndt+j14JHswB}OM{l>U|X z_PLe&Zb^W~XA10}_U&C9e5rb{F`t9UC?>`$svYMiBuuplG9wl(x&(;jkSMo4?36a5D3#1Jif0XM`QWRBNBjPA@O zvSkApBC{IH9yF6IXpk6Co5&zwx>Gqy>w;XwhHSr<@c!)e}e3x zt?RS~00`|IER9F|0B*CxHBT)SDJv<8@2TWaY$RgA0UZpdm=QdV$lf;UlyplZWxN-ICRK@X{IW@jdzr=fY@s7}3l*fFDd* zx!TtfpEOBQHGM1M49)KK03&M5w0(F4DK`moZxf1mK`KgM3iLBfh@aZO)MuVO?XK~L zrBrU&*-aB;YeYA-z)~QG+-L5=)_zGfKZhXWn?GG?)f}B=FR0eW-@ZIt2n)vfmT=Otw=i%?jMS8O zT|14T84I+jWo=D8Usc`R#F~wGEM8uL>N{~Cp^PXPlxST8ZnmvstQ%2uSA%N(12jzq zQ-FVv?hx+*n;aL*bC2G{!s+q66KRhUCza~+2GdU&(`Gg^q4=Sqc@v&VAOiw4*l5xq zR=&25^8G3H27r3AhS8Vj0epS~ffN`NgE2ST(OEGm|EDvWkE*e-m?tnWXHiCqAExKj zKz9iS#oUWQW|0AuwCJWCtCYoGmGHn7_+gmSWy5UlIU$EB8foI7T8oKuOxI7n15PUh z*3!|hg$SVn`I!;ZhsXVNbvvW!|1}|tW)N2{TofMADtqsb26@3CX7aU^*tRmlWg}#7_vEIV46ryv+c4I zzrcd0zjzMQPsP9|CT>0qg3AZ$MiZi;2%95>#> zCu8adv_Nk%1&+E2RSHh2sY|-mts=Lz&YJ7g=xDOcq1hUk~Ife*NAgBwl*C-J=7!& z1xXSMUEEvq)e{>0S27{q!}dC+tt_DdO{P%Im#AWoc5I;WhjTb+GgfPf1oU3;|!hO zByTr%4V*2Y&2gus81~=|yIWdlvAnA_^0@bL&i$aO`lGNk?B)YS_RYG-`w?crifOgC z?Mrfh-4SwgTmH(__vB|@YN3#Ia<*4<@{k~qV)KZ8NnQO#Mv_K=a`p->gLnS8!IV{} zdE#;GSY=-UUtm&g%+dX?dUHC*3;-ISo zYE)Q83pWAI|E4!=1{7Zf&p4zK`>A{?u?4#3g$6^7VJ$t<* zeOXmPnqyPZ^rCs5RKxpL5${Gl0d7`)yjLNn&!@>`eT(;jyXpdR~f|^+ipj zW8UvBoJD1qws0OEY^ZU1c8XuBs&YA=e_D2gKmsIp%k^=50+%%AzY2{yu_HIRe!+BoW2wmChp0ik; z3{Kc7*J+(`C4^*cIy_ohr^}Ttni?)^>B~K+xV*A|2hJflTR9L$kECEVZHdl;=TEN1 zhmX+s0vlVa3nNL&h`zPTISsZ<;1)j~ozoz;?=~(x_P;Hd7a-zUqCGoDS*P8I>RH>E z4EG+M=9o;Fn)vppDd*kjhoUamnZhXNDKZ_2I$!f>CZeEBE~b0?c6 zwdUO5^QxAbI6XZruH_kJ^--|TFo*?lIx)s8-qDWBFO)Y*T>L4b4Hr^E|CLRSPZp09 zW8mQ7u(IB)D}p*$YrN9(lM-~rAw&pkJ=+8`-ey#v8zsAPd95qE*UDVpLm~uHrn}=y zF*Ug`>&<>K_$}{>!6sUcmSCNYje&u5nq7@Q^b1}xUXqJTJ->o^Bf6gE@|oRuhTO|fb%;y(o9IeV;M71k-FaV|dmtChJI zXr8}BgbX8c#)c^N>hG(pzn?6>dj8}*`d;TtjBvMd-Qd(F$Xz>gtgMXMx8!NZ{od$U zs@!aWs&c-$ax&?kMhuw7TOcwZH7Y^VvNtzCf@oNK%Z*;mq!S2N<=4G`0b#{{aYdYS z`y6sqQyk)l$H!3)FD-nkstgt>CbnWN^E96Hmxn1!+zzKxtdO+Jv{xN5TF&j8gxwke zvsQ*C7RR;sU#6qpmYPyX{QyAGeaMmXsmKoHGY^SO{`YHqtc)(3SA`c-1A{!bWoYNY zohuzT8%4t#SY5g6pKJ9M7BaY%@#u?+-m}(E`$Q;fwX`%mgb$FOcPBKxPsf>eXxp-;OF7SPfvYCKAsJ2H$c_BH zs0du{;;ieJrD~6KJ3q7A=4|&=%Hb8FoNw;}YAdKmn&&h`gm@`e2D*-u(^w{IdM9a+ z<`#~_C>JD6eVIE$ONo1|R`2&7^q1{ZxRzF1{CKxhV5`(8%ctoyte%aKrhijiUsCbrQU8GD zTU5b0Y>PehQGa+)q%_CUtc>oZ7((=02v=Li-R2%LdF?ry*ox%eY6+<=`zXw(pOuJ6 z{?^NSx`#lYf4*0L{rW|Cj&Z*X&6-yOXQN%`nF67}|a)CFt#3T~4I{Xk*j2LLTqhw%0$e{QVh?r)~N+<<^5`qRsq zqbnVC*IiLiN2B%HnU8oNe&78^?KPDSYMdv0TW)3d5JOS-FPm!#`Dqu#PQM1hjKRtN zCL3)m<0+C(JTg|SUMKnoku{&o)9;|$Jo)u2y1e%B1-(mfd-vsZ0}S~u!cQOJt!dJK zX|y19&SH5P^dodmvEGTg*#W`Bt?^QVbA6_<4YvAgq?+y>fjD_Q^(xfgrI?FpIbB;L zS61NG@`etkE-&>6yx#tt{iCfGuWe0$nz_UO_I5;^_q+-3o|8E~9^+Xb5ICL&eNl1U z&>x~zw%s+eco&c4Dr3%f#s->Q_NxE!Hzsu~O)N_)mxzwMy^M~ASR~}YBE>{1YAJ%`ci5Gu z1O3eKE8jKKU>knN`d?J9p8Z61?HBH!*uTa)oJy#y%qwGtec+*{5ONwfiZK{tE-j37 zv)IvdeXkDC2e+Euipu&6p)4@oCAzRXQ?*yvxSf~L?41D~xkpsW41bS+$9ICVf309n zU=TYT{vptKqNL1Q3P@Aa)mgLi@H3x>bVktEIJ4K@c%9fIF}9SkX-*4@alUaQt;XEU z;yl;b^d&`-rf;3REx$OunK|B|_x*WE#L(t`Pjk3_J8Ru|=MUeke|VQb_1$kQ%xk~w z@-mds6{A{xL}J!i`chC_Z9OZ)EU56t)amzMaMJ}tYqy>@#iJgtxSSpxH*SY(0%G8OLT8PsV|SXQ`W z7$1i)Z!*3{reaI5u`s?gi?8CP{ERdoYg5g4Ep%D7=L7M-+rN`9y@v_Ucfao%&4(cQ zt1aSYcpclEqsx_^Pd;Ro2fleTqoeX#CBa;dg1u(jQ!bRAD&i(g=H+`Mv7#&lI#L_l zcL*~H29eRP78`x)Yfs>%U0M3{wk-N?(ZEE&E{Y#sPu|mv)wfTc-F;nRV(KSgrwJ40 zgV??P)kwophN=f(B5onK+RX<|v6aEaIj*LaTWgZLzM>O5asiEGeHb?mofY_+k(yv} z(XTMl#<#=>*<#Sxv`E&)i_tIa)w7?tt>uAVq&I7OJYRXU^DE$2@21>1t`{~YIfU|q z@7;&nw>=8=zIB_*kHt&&a^qGEFD56n^mUh&@7-6OUdZIfdH9w^A{P zX-HPSdE|vI(e=E}OGU7kRW76`kv$}Q&-^f{2%o!SE#PG8P}3ezosE^Zz{#Aix~8s! zjkEFnqj`!+GvN`@BpV^kD~Y@G?-c?OU-0mbKMaF%V6x~}LRGV)vE6u`yq;&WL*bpPKWckfv{ZrJ97qxj{kerjO&6Q`eUN0}vaYV1x6826i`+>D>kB zRUMU^l%{=F7F9VngMiyzSF%PB1iH2NTkttV2y*6wkSzy&-FlAs8nypZb)k`m)y~jf z>aFt-8(=xXWd6hX-t#lewK!}pmYXUPE4kRX-e#r*J%M0zZVkJYv^6nm!F&)P1Apcn1>9k&=8L8z zCt7=Mj?;gt36|3{HGP=o#}gZg-B+_fAz?K^H)Tns!wcrBtxQPk=lA6>68k>c(K{@GS{UNa6q=~p2!9%~VWtH>S`{}5e&mg-ypZVJiCPjXNa<;p1(L@Q_(BlFR zyFhac%4fuKaJKJ$?@g?_Gmx$x;KWpWo5DYxs-}O1R~{#uv(wtz68AkSe^^}|_)r{& z^B&ZBPc<>)PvU^2@Q=r|3~zSW>HvG^?T*|jJXu%Jhox6{#RT}`66NZ!xN(QkeBKo@3H^{YlL6SdY-VIjraUU&oTP@?w-&f zU)dF>rRK%Rx0f6bH%f2(A$GI-7grAl)s+aYas(O4I$J!wY|hoAFDVQJD*$#JwT%C@ zvOojMpn)(kL+LhIb6AX>-d|?snv)m8a$n!tg`(kYE;4d4weo{E1itrs`|XEqkxh9a z&7&}&Rwxh%l-d;|+ULU&JmhE6 z;Kr2tSH5R#?BM^43TX~wj4Gc(C423>ttpN-Jg=MGCK_1y8-H0{d^JSH@XgSNxo_M2 z@?pp+2M0|{Bkgh>5J7<>%YU)#J1%Z<|T ztz7o@(L+E0bD>EAEv8lZZiyZhVZEu_gH5zCUj`P6e~1w+sRISU&p4T+#!Rk9)?=fI zaCQWT!F#*(eHCw#p4!*v7gStT>{$Lp*L(Fh{iEZnflF_m3Yx)#v8pOE4j!2m>K#n= zB2vG-q_|HQLe`)j2LAr2ip}!{}QQ} zA4^J@?e!)X0h}0+q2c#?WcWNcxcpD1Tg+!G12rM_TXuP`e>u6u43$B7-&fp@{7uN6 z-m8}4pAM; zEPl`V75=?gZIvqH`1h!6PC7Vd+@-VZTJnR+cbYd*OkpW#Xh-$#5g34ej(6_RXqLZp zCZ8*2IL~r+C@Qwy{djrpp0TEbEyG^5wh7o5%7AC*72A7Z+48uv0l6B7Z!9;Se~vyn z&WYtLS5D}pnJDAo6!=tDx6#D9yY9kD|Miw?5I&wy`ssy>CV~c5R3;R1S^BYJlLHJm zWj~i!U09vw=69TlTKQ#|GQ4;lvWq_QQ8Og1$xedg0^u?$0TcgzV?p!l^*aIsWq*?j zJY4RrX9)t=SKqZQH;VD{3Y@}FoPq2|N79Ntbs>kx)Xx69@tovrP~Z+moMo_si zY#Ihpn>tU?L#{Civ6=y1%*EDPpEG+$xw7e!y)R6HWl)}ES-$nZYnN%Fq0P}04=%RG z`xuV-F#v#7`TIpT$40Wjh;6l_XW4}n^+NL6e|HX529?=WT_m?o@2?mypVzen+E+7w zsW1QZFX?HX`u=R$lc6mh^QiQ4dg+RH7VTPg0WBIF5LM_Km4ETXPMM1MSk-pJr&0$V z^N*QMV$Z(L^|ya*`jxQp->oY{Yi~B#2>g3)Igo;D8JeO>5tE!CGihls> zE=c7;hcPJ76M3pDaXSp754R1|qRGWW$=KzPa8B?S4TXVK7dSY~shKD+ z1Yj=pYY7P3j#}m?Si9xh4FtDeTwQeV^*3W4k2wE3yumbBK(ut?WZP46K(UVGV&K%F$8|D1@;40|&Gaa5MMYFg7r23&7Q&%0xLNFkYx~-KEv& ze5bN}h>C*RT~Ida5>*>h&C_`qc=G;#Z?t1sYD@Q#o`SDG7mvylEx276c8ePvD;E(4 z?V+dufNunlg&z>ZC;pmzeQ`?xPX}-U+HN~e%JuClRH#zH^b(__rVNerTftp%Z{1#R z>>IVB8?%F+mo7Jw0eQB!=?rji8ZNvp z4TKNS2GCqU^FY9Dn4G~Qb^yafGzz46zM2A%ufupBjGL1)N{(C);k7E9iLy(w<36g2 zQ+D9gX*IhhG2izxlwM+SVV=s&^PM@jd^G0ZP}2PYVki+5HQ~}UHlgs3-gdW zI*GBIWO95kc2yM|c7+>{hq3d)4`=~dEi5MBR1RplWkq+=H>Zo|g8#Du5?DQl`7n5* z&!ONGa-vb3IWlJ*#xx8U?7BXdG7z8il$&y1^*z?`nZGA{ud@Wz#^#gF$qz$c7MfrE z3{`*y_(C|@V5b>Xy2f&NF7){CFgCkgJ_N)Yt;|Z)LkgiohypIV$YxpV${Naf!*8pD z%PfwnUn7Y9TegzvM+71;;L=)BV$}s_J~)URYW3hQe1e{e9OwZ$rKx0kJmV!G7*gN{ za1?brM;KK~+`N?;8DkE9T2mBxF21SY`WfP&pJMyNQBfc#fSi{vlL!LDOo8$o;`(+paEh=r@QIk zF2QJmsL<^`4bTsN{F%l`wQ+GzN*vrXe|b2cRrcY-@UZb1*LfZ_R#g)Yu%Q;J9nPt5 z_5E0!V@=mzdH3g_{C5-Is2$(%9o4tYakuZLn~1p|jt(!q0KsEa3|*+3@XSOh2a=fm zYxNl^fWRrEk)IMv6%<^)lKhFi@mb*$SX&D)v$TDhFO@fbfVYDR18oOeIjI9QQRTvx zwwv{gvJMT=TG)Z>+xPqTziTOmIhG5`y=A+_dy9(2dfeRGj?1rQ^b=q4*N%t}r;6HI zig6zTk$5sLKG$3!8BFVb$gD3E%^tl`MFGlv=#7CZ7eXS4gZzlZ*gl3DIb>8$qDMY;Cf<%7HG7zm6hnt;-I&#=*rqrp#;E~T-0f&97i_W> z61jiMp&{sz|2NNBi3M2!f4({^YENS zbuk?nJQWVB@4Eaw-lW||NnGEqG{~nE_|=jt>l29cXvu|vR+rHsv{#}pd8Q;YaVFdX zf^fI8ovyx7Qvyvb0v)yKr zN2~#4QJ&1NEP8hDkzo<5lq9S2nL}~cYJD)r*CsVLm0nQsLF)FoRW>KthjhXwH=ZYf zCJ|19#PgJX`jIPg5A<2M7Z|196m;iK7B|&b~Fmc+%t_U zHM+F%wc2vbV*S04nar@x@DFf;QpW265q_CR-fHm8?;z#6TEMn%Xc2XkUhlDdJpGH_ zKhuR(7-T!~@$IpB$`L%|GAcBIc$#pU57+=`fcSQuQQuNHbV6MqxjG^{e693IrlvVy zJ;hN3`pLX6uE?1jrtl@8*Zeh6zHwVl!x1GDYOCLx7ev(gcJ@lM$_>%RgG3y?PlS+p zhgUJu;ObksR-lOu5dHaZrOic_L&PYezNhTWPo|5T6r8Ujv~Po&XK5(Z7az+52ftUK zT0%GPcO4~#c_G9k0ew?tdf>L^IFR#gPusE%!cDfM;4-H&WG?z}R`el3bZm@QI!@J2 zazCP55eA_DlS6kdamZm>eEdrVeaomLJC#)~Q_|Mn?qQF~#rt5ol6c{WmZHc8s=awo z^s~h-d}5ZuwX=GM8Eg*HvLS+Di3w~k9NO2T&o(0?hdhD?oE4&p@$eZB^0QWh`^25S zw(!g*rm$LGCYA>|$zS>FS1iQJmnH-^KYe2vua+Q1=n=J<wR)B?IWuPIzt2%-83{+lQ$&}!|V1;CNXi`d5bEu)p=Q|gN`&AN zgHrOi6tQ%QSugw|OLpYbgVzd2hbk zm=M3|m|+0ZZR*6W4}k;hKPamG=(#brvoe>{zqD5Pk{K)tt?cjKwo`wVZe~Osqji8H zHw`$pcMFr!2De~I_C3(r233mWoa8NC8WrNL{p|PPa*JEr9 z;4{>(%w4(Jpfh_1!c7T0_WV+192r@ZF1c8ExM25MMD&!nnOY|xixV1wa1EJxAzhwz zwkS{hZq*kre)9Cf(9oL{Sol#YA(A6?Q|qM^94qT~_M=q9%3)Y|_n}vJ{-S}Ak=SYB zysXV5Pwu=O@44NOHL~E{8*v%lzBczKGBFlo2A|(;a|MBw1k3SGP&F zP$`orU(OkqSqjUcL29H6+u-~Rh<6Ac6$klI{DPLXZ#o}01q$)zwW`dFAO!15WCF_R zEDI0eoEvC{?m5<~^On0WAsYyj>zdM&zq82#{ycO(x*+tg8kD#41F_b&|>0;q-NKc4%qe6DYF zcv+NReFr7eB@yK<-a!q4mUV_EmAlw)#bviWpUnnpN=_eduIN+cS2k~wQ6fKn2* zcWA0-{$6?>u~X$Z#u$Aj>>#lPwuV`@4NC#bEh+^q?h|A=b;umQ$@=bOch|z|G^NDO z5?)z&epY&%w`9^8MJOTSM0Reh>%N?4^8NJ4VV7`7EooM(7nSJQpqeW2jCNS$!d*f5 zMq7|*rC>+vm@J$^;=Aw`obkoM+lM=U6Ay$^<^!GDp# z8u_r^zQ~@5&)??bQCUaF2QG()Wu>>f%v$~_A!RoQE#7?Q?sdiF^r(}~Rde^sg~vJs z#P(TKT>iES9kVJs!<%H@lsZauYxzfbujV58WF&ZCy15BFx;g$31^3{^$zgV!2DXojC&@@$-W2joUbAd6UKd-vs4yOz`oRVX^4$GqU%YIPrG{ z1Id{lFlY_ehlG(4Etjag0bP#8qyPozmp*dxncKF5-U4Yrx(4a}cSK>k5l|m{=PP&T zeMX+o)&!B@9_POqs7UF)E;Pz3U5?PSmD-I0&&Z$(eXnfVqj`moM@B*!1_wP4It;1B z1VHdu8sNbd{9HB>5?xX1v2QrIGp%Amc<7!n*buhdRQ76p)^sxZT3hs+8FwLD>}D7V zF=Kv(kS$mjl+Q{((yG|QfpW3Fd94p5fXXn$J;DY;l@5aj)8+sgIjGK4&;HCyj{USFLW}0-3uUf#jxHyB?Ot z5vEU$;D@67s@?!Vz6HqI7y+P>ejlW>2CnENPHoCl6roWYuRNGr$yoh3GuS$PxVQ0G zaf$=oO@$<2@Cd~xAPC~2(68+pA_G^73VYLv${}4I7 zCqu50CfLD=N=wy#!Jld>rZy(ouO1{p8Z%YT0H6~T4B{0hew)DH00xHOeeVyRPaCev z!W>wOxO;$IXIYIqHMxcL$Tf`~p*HF|UHG#TZYH=|>#oVhl8O22c;#H<*KHjZpQ+|= z;-7}=1Tv^ntJ9x3qvWOCm;r?3Yu&JsZbBIn^5|w6*l&;r(oEXY*Es6Gz&x+JD5HGGh;NV-#{2M3sOM1vJ z|E)m%h}8jVkTAKT9>lf;pR}BNu2gRi(n;Vh$Mcf9ZAWr=DubYWh$Jc{i|0V0yk;*+ zk3l`#UVLc#KmBImGb|Sz{pXl1d?W9R>f?MDDPbec{ClPw>wzyxGs0gUO3dv*tGO~V zNUzne@ado>TJC4v*q0FaHi&qnQCf9kY&a$s%T5dodvvT7sjyIO@Msxh*YxNNo=*{N zfqeKRL$6?E@I>Q7v`uSmD)EB6^Sle2!!6@QW7!N+C-uk^-EKEi!=Xugp)5kbxXT69 zYMe+aFuLaFR_+gwb=S#_@0;O#2epZRGmJorT^zpL^Gq zyvUqMnf6b66V$vbQfkA0sGonm5C5QEoH|fV^LKTZc;BffrAs)rqQtYKcx2W;3R=0K zjwD2F>=p@wttrx;k`C`2R&11Jgw)$l+b}MhCP*E!SZr(Vzl%MYA9!lm-MIGtT8C(m zOkW}CkbO(v+_&{hpA=ZMMYcguFQp$?~2dstpET8n=v%>8OOICZ+OVh8Vw7a?`fYQ-yxd%P(%uwUWHs#(2=efY|1f?;2?fJ9?>ImK6>Vove7VRPkZFpadPTtWWGW5kdUsrm&O!T-fJQq zM>b|VPZ!&E#QM5MDX&(IjXj#VxLP}J@)=|7qPlzPQ!-Yk)yBn}Uq7TiYh!DRxb@`j zYdTF@Qxp$(3ianJH-bI%YQ2sOT(rb^FbEeBlRuC03<)k@OUK};?K^VrJ*K!CEJ?Ha znYpBXzI@EWsy!jue(UnAWrda#!m~Z$8?p@Zm(^KaJSS>7g*gn3K-l#1_SW1$5J_FP z>rFI3CK({ldL}TFk5pDgX;SR@5rHnLnG7MnQs~1tb21tD5F9uk^pWi^>!!|b^d3(f zxSo#89QQgi`MJHKi=Nv#-S(PUu&ZI?YJU$O*;K^vjXNasGNPFyjBmMqV9Dxb3kOb@ zqe8pJ(4WYZJrSes*_0}z(G`S#*zIR(McnPx2FT-{^|dhc_)iaP2TH_CSH<4fq4vd? z4C9-J#NMUF>yBz_=9^A+f96BkohH=bSuuoHaNo+(xhdJgI{xVxV1VrAz~M<&xQggOsdD1@+4icGjF2Prkyo{fh!N>SWeQD_qg8QHoZmX9j7OB(GtEy)P$X)zuHNytIaEtA~}Cz%|2J-{VI6G z+3x;jn+k#JJ#1Cgfp9@o3od8$tn1|G|3MnzwU5Sq{lbBxGve4VX0cXVY_Br{YnfQQ zUN~gNSfu{MvTDMtZYrR79Yr-`!qeUSzO^~~tvCG9MrlM->a#&0XMl}BmA7sQ8>~3(=IJjCOj80IOKR5nzHxG zlJ79`WRqy82PlHoCg7>3+aQxh&$C2Av*SIikC63@^7f-3ur zDqD4`)2W)+49L%)T(aBg=`g?xlu(0TL@z_J7gG2ImlbqIo*>o`W?^VDZzk`M9@G=e zTua@w<&=1&(Y-%K>#ozNvfElk>W>G@qeX~i=~`q$@Pj{MrPv>Spgd(TK?dlJIHu+2 zi?(pMLn0cnGz%Wh>1swt+HaXxO)RABA-oZYv`mKSo|(Hw@&uH15TaT|anoiMVd@3` zsItzrgIYQ9i~*B`OX&k9-fu8##-p8V<9bTV>xCtFxpc*knX(Vk#{o@kj{Cs>#=H}*FOtIo{ zRWKP%Pt7_ADa_5=2*@@&Xe-65sre7C@?44NTKW!=25aUmLON{^&9?!!)w zFfMOG?@LC7`ekEJ!_b7@nN%q3ls(@}hI_DP`T21~QjDIP=6YS+?GbTF?_>|JGm6u7 zM8xa5c5;e}Qdm@Iz0>){9Abzf@V@CCX;1OP(c_IhMf-z+Sx6~MR+;&f^&<6x zDYJ@wRGDeH7Hig+MdpwhTC3=%8P8n{RppBmWgCoiNnNzbV8Et{x^_M0aB=bDmQ!6S zl#gaXuL-NFb9e3+yYIEBWA_cYyKD{0%GYin-m4PbdsZ-%4=Ye<%(W_;^%PRFdH4{w z^U;Ehz$ZreSsMW%PuY#pO(%g=MYv#FNELHpCSb|;_}b=dMhim~lb1|*TR8HQGw)$h zRWX`yA>_i)U$Wmaa<7yU9s(LbJQTglp6ZX!Sz(oyesh~yW-Q6yBbEmoo zt;idk?c%k?frvLqqo3RG9W!J*gEz-kENhLL+Cg6aUGGoU)^Ut?YK!;a>3Qzr{#bX+ zQZE=A->fu5UR^s7x*L9#0rOGf)!GOy{AeuLqws+Nm9U5iLo>5{AwIsJ#$lW~BP42S z9=Dp$nL>7_`5Sk_&F!-GJ}(YE*GpYY(VI;5_5XN~gzKeHccvu^XQn2Kg zjper@0=fCv@m*5BS+umYx>bpZrghqEQ>zYkIfI>iC9j<7rWmpBws2^r>=7=f;9!=9 zWLh9bm5J_k2=-xccopO)Eu<_9EZ4}>$9S%0#VF<-I*JijVOP}8am z&7I5dSnrUMwzRfNy4l%19pUL2v#Q!dT-1u?{QO2J4AUovRZTj=E1R)6aq)Vdn)X7e zBn~=WarS3ddXMe%^CNz&AB>NWC)HL~{*=ubG>Ijd5 zvruY4%bY$Gg^Do?z8$oKPKix#SAYQ#Um52eH8s`zd=zfWSLTrD2?yye`(FDnw1^SQ zj9G=6P9CRoR!u$o7X%XTG-!ODPDo?d~$|{npU7D}tCP#a{ zaV&PiOZgsDSss6~f^Nx(=7$00iwG?v$&?V$I2SeRNrXL)?C^uWW9DitO+ygN8Q@gs z(E<@pvi#RlN@e=bPyVJFhyDqsG4hgz!|_4`WFKS5ZjE}ufs~pWQ!p`e<01r>Hx&p}=Tk@!#u&yHd@rIU zalA#gViR8qF2i$|4Vm#WZw}mRcuTX0@sQ|N${vA~iZs&50AbL3{1wG#m|`!AO;yMs z_m=bLE&n&g>qXKZ2CR7Q)(@Dx4f+Jnhw6D4MC1D{nJyX&LrR51NJwrhdbqXqO|fax zlaT`!qmAcb=yOz9!@_~<%*meE`QD#L)+LJ+=YLAh*O=nFNCcMC7E-*T?9X1SsmYjC zXg!FM&4r+Sub6{wY-B4Vi^jUj#CVIFbDuWo4itkIu$!=zP~thEd#b7pS?tfGSgMW_ zG2Lk&tsdl^iAUk%OS(b))K$ z`vhugya1M5IQm}{sn-pdtRy!Oz%4jJd6M=Z7&5y(WHv-ZP@$#p-sN8O1DeCQRzs+F zqP;{?KE>-PoY@Q0^_TtZ*_w<`F4yrZOJJnm4al(St$moGJj=|?EPrSxOLr7GO0wWo zH|JERKv2eL<)AQ_OL-NZ!BHp`&*9J^4i^x_hJD5^y4&fLoxT3om+?mpsLn0e4e#G` zH@%RV*=8*qG>9)@=xfU&rN?eRIKl>cnk2%|-VF2(I@Y|&Jx(76IG}=9yT9qif=;o89V1a<{8p!6Q}l_2R4NJ`4Uj)g}>>Jn`65~67`@D;7`PO}vwJ)h~X zr4WU~Zn&o~n2s@-RO? z-|)H%>~p3vUuAK=Su|(d)lYa-Wn=wm1CAH*Z0&x!uGdH2|HLyripCh>zU?-%S2MMB zZQ1>q%DZb@v4T=I?4+FE1S$D(j3Cn5k)$eWLs;HstOpQg&={nP)FE(mSmV2Td!loS z#WM#?zQ$xp+J*gc5y_^yLrEz^M~GpBv%bEbE=ZX7413A$IGz8XAAY9i$QC;4hYufS zQ;dv^THGlCO>8W^m5m_CbU|Yy{}h=fH6FL{b8|Y`Q7)vA))vR}aWj)5zVjtp#&X7? z!YmPA5nqu3=+DR(CF%vFGpAe5FZ1_Bqi9;cTwwLf9N7BrIQgzVQno-bwBxiS@Ziv9 zGRV1bOBi4xdIhcdlEWeYN7fxH6H{$0Y6UaY3leF3*`6HH2TK}44olKR;Tg>DxG2M( z#kwW&?@+yZvf`0>#Bet}X*-5NfMWmXF-??1;N5**gy6BAA9T#~6E>2D# zS-MMVYEhlWZy_2Kb08*EScq@Bss;v(>fH*LCJ2|#$YJ zTe&1O+Y~m59QTARzU!B3gF>m<->5Fr5ubQpzs`AL^QwIiQg^I$U% z$)s!V=uq`KeC6d-_*^OC-q(F@} zpH!#HmLtB~tFKqb)(BJbe_CpVqA16!!$ z0(l*D`m7I&=m0x%d7G!~F$3xQX0Tx($V0Q36|YYtwvYsJld9ZCnR14DclO4$p4kG=IZQ@M_A3CWOIg;Cx2)$)ss zqKme~FJsvU8aeA!M-VJ&2AB$nj{)+0)kfef?cm_RS2Ft4{Rf6` zS)}|{$TZJCc}ep0F9qL0KHwnJ`bJc~NR1JG6Hspds70=gn%Q)6)*zIjA>i(!j#KZf zAtMZyZWU*w*-y2uE)U;bd{37zdOX*$CFYx zX`^K6PNYgK9_Kw<`zmK)VX+^}szP)nO7`Qzj=N}DH&kiDP7H2A!Qc}2C1(AwhTmUq zu-CixPuS1WEMkfM{w&}9Jl^h39Hd2OH$mvDV5fB!u0LEFCLkq%p~KX^K#* z(N;uN-GjgNKK{Eb7Rmjp7YX_I(_HUleC?4{sO7TP9kwvEo*L8bgDK~k2P+D2Uxe4a z<+6O?%F4QjIJ$eUqrF`|C;wHN2XRt%hHgpAk{uKd>O^@%N5|XSP3NMp*8Z8moGRJ|{76GUqIu~2~4FDj}*fex?+fTNeA|+{jfICcY z|LjSYgSa_4J)^|nHKo4Z^MfRe9foIx!1?nibTs0M}2)d7_!)tfjUD(dh6D$U&rn!_qy`(HxP%ksfrRK z2R;wjm&wA=9tF|keed!8Z;qaY*hj#9z-2yCjDeW6;+KYv4VUKR<@LXx=1!QOPZQHg zl_*b>stDyG{TUOko$9|C0J)|kfo5(ife%t9YAf77J}B{ONJFnThHsDd*|Aho64%2< zJ$dp3RVfL0TAl4~`25(bH2-WO{A#MR3_KS9>kq;}&&D=0@l>bmqDcgbrMye}73Jj@H&> zP2USSV)s2bBExCn(5a5@TqIsb{4a`)`QKu)RN%?W%Qst9(Wdnod3cahy8ps}SG{)= zyxNIo?cl=k<7~&1%FlS3r*B|@0U3fofN+sN(AoJ|=~4nW9PE5N#~3&Na6QO8g(8j`T0&k zScG^EfKm}#L&FDhdYtXuH={)RwTc47GxR-YPv?(L2twO90OZ_%?{cY6?7V)pO`g|1 zQT}JMs_Fms>a&sK%hZ&VHzVtSCnT6+zZAWw`czu_-C5)-l6yh>&(6sy`OcOTC)-r^ zx~ok6gb9z(n{F$z@`#s$#9K8+mNnn4suuQF2Y-?(Smzrc$*oNqbY%d6#2SiO=k}od zrmXnODEX3cfhhjf-*j@*BUPOEVO52$tqo~wlVS+*eMsdEHGD8fY2ka;6O#%plvwBZ z_}$@=5rrk@|4N~t5WEf)1A78jclXJS<*&wE)t;w90LuiHQT2D=8F_iHv~ct*i745! zoffMXd|k4GcY@1V(fTxI8?dmo+jxI9-O;*QI@^5;dB)xo!NG9_o0bw`RwtmWR+ zmZ5^@paa5A3cbN>$VkejM&f)y)m7Cb^O}=mcvdx$hF^suar_AAJyEDs`Gln^H6D{a zyk7pL2sgK1C<*%)jxanGE)%g=|HV?LemdjgGp*a<(w~vs9m4MW12T{>nA~iH+|)$p zLaB=OpC>`vTXon%Zio2hOj#x0ID|q*BtT~ZyAE;Kn3Z{z zdPYug?tg;>u=THQ?!Jd=YM{8lEkW!6vjgej8PjdJy*&kTzJ_njlD2g9^s24>iv1=$ z_>mpx^76|dzrc#e+*g|ad%UMibY;wfc*jLs$ma3CC4r18(|+j3k9Ukh(BnedXso8| zO?!WG;9zDbU%RMD7{hT0^G{8xnncTF;nGIwJFIGF%9Crb!h6TF2d;BRCvy%$8S6rF zS%hrb)!uq%yYcgfzl<~^+61>ZUH**wWHVMraEEENehe4{H6>w{U4-J|Gk5TUz#%cTKIk z<7t&wj#>N^uk2f%P!;2D%cL`It#%OpbDI|gv8E%prog;B#=^ovgg`rS!!QXiR7S7! zBQJh6>I3tj9zi<#KOSPOH$&x0T5lHX5lOACkPh(lOcKjQj%_-v)I!1wl~UIhgXFqW zYh}g1JXw#2ASNNPJ=)R%(e3gjjIhW^=O98tI$*{p(Wn0lT&o~jWNzy>4xB|hK_cuc ze?j-)?21ZJybnYa#DsC~09CaL+8dyfJyVk^8v_9XMJ9KLfD>;@A@Y+W!PLS|LT2`i zC+b_N26+`MsDqA7g;txA=k6_NO9MpI$w$JTG_6`j!=O}~Mgc)u!z&?ahQT$>r zZ@X?X{7C5)oT0f3gA9l_Y=7V5BhTt*W1EL~ftS!tZ{9?Y>eFqx8=A2}?@Co{S=gb% zzeWX3C`yLHCzAmbF%3=4&ueS>77p?MK(yUv@$ki%n3#m5q%WhRNSv03AO_TEPk(oL zz{eM`v$Ml`TJMlZ{66pRd&4KT7`4eC-W9Ls4w+$+nkn2C{4w)LP0;we znyBWrH6{Q~AMbto7cvqn1gaU(lWUhR!3A%OwRP`CM2-}@hXCNTj_={4l4U2clEmywz0Vx|SNn za0td3WyyZKH%5@R&)Hb0)XYc7&!DHSJ zKPoORmQ(o;8}~09om}814VC~67Sv$}8$0{LppqDQLQJkBI)RH4(57yQ^GIl$19_V! z9a(Ob1WO>{^2kA`<4)>4ifL>ufHxw$?Z~diqLNj+!S!}hc48If69RE|xj`N%(J2qy zhyf`SPK0(WJQ#fX#mIptP4y>)b%Jno%iPMfwYs4W%?GJ%-7*cjGhDO3((!d_8QkXW zYP#1~g#f#Rq@&7$hlbRklr?W3(c)j5-54u#`I-1ixnu-gSs4%;dz&uiv2ocLrkmw| zJ>Iiv#-SuBG12E=c?_)~DMG=2KYG130*C^XE{^s}V-CoZ23`J=iOyKL5yvujPYn%{ zT1M1uZrWDG9i}#ya_=b%KG@F6{UVF1QF+U2z>=XK?CtHLCJ@)7j5Z^9xwtNsjD*%X zZ$p9@85>^)T?(~_vxz_Tht0c>i)tUEKlwg(;Auc>lmJ=wL}Vtz#Nj&)ZnpXOP)}Jp zl?JLTLTB+op0Mz6YDkNVhdMi6Rw)?j_Pi)e_Ef+SE^1RJ2N3pzgoKAI#4Y>#Jno{D z(4y4U)qf4Yur{!?EGoHb9Z~=VmPm?ofxT*CYGCjY?&Q%ew_u5DjAt7;rN&i5f~WPU zfh%#k?AOUuerV_=YgkHdy#Sd2Vlp8$Rf>Tq^ZbD)%^O#7pj_EGIdeNM00C`I|2TpY ze>#qHYX|eAC?T4$A%4(1$Rta;SG#;~_(JgCXrryAOi|1k<9S&&md+4T6EhGW!!~#h zK{r|JcmpsYKn++l5;pB-lEzF^Fd;9|4JSRuO58r>;_oLpRnahJ0O zO(z>YCc-dHGx-tRR+(+;O!qQzq@ht5AQ^~5F{h?=)fk>-N-Zf3?=mybTTY>zg1n9< z{6xOCImLJR*VG862-rGZx6b*W7vK^!@UY{EEMej-=by{VJH5i&`i_o{N|A#-M;b&o z%Z)b5RfE1cv6nrr^m``As6MW)f{uya9O9@@^%MFv)+?(g|1AQ+(e%ziIQWC^+ZW=n z3t3O%q3!p?UT4~l_Pcd2dLgp<8fLS|^;^RW%m-Bme_jC3*68i$NLL-xwv) zG4!slD=)(|=2n|piaiXBBhGNYc_L16!?v7~HF~9P(-WyyOj!Of<9#QWbrRxJh%Nx~ z$jvt|QkQD@Tx*n=yi&G*gU<=rbhYimRjbKrA4peVI=jCW<)0Ht&86%CY=A5&W1L#v z`wYqTZA7jr`!4!(&VWg}dV%AQ&I3P_=hDImMw{`xynzlO0uN!^e#=1mEAk;aM0kN& zD)s+Q8NBs5OoUYWXIsO=aaG>}ITic>I+`Ry$R&kAP?OV5lU~<6Z!u&q)SO7|=5DoM z_Ks-I&~wn?FY5s6RH4FtAiw_N=6OQy?(1{*p%{N6ynAP67JA#}$a z-u0Y#dB_rr_1P7_N8NpW$L|V6%7K%; zUdtsceDT?^S?;@?_XD&09unPnH%}<_hL?fLX}sp~HI4hZH_eu}{1XT=EOQ92e@k~L zsH2loEWqD%BIQf&`TN4%W7BDZi2SoYzGoAq(u0F%GBLuZWO03(G=j27BY^YBJ9m6$ zwzsRpzt8hqO$rc>h5Ct)ID+W(eu*5k2mEUnDiQPw^0J(7OI&s}WT2!gU!o6QtbSP5 zVTeYeP$+!7Kv1CRJ3SX_(NFH)FJEWGp&BB)-N;B_CV2)?{qKG#zb8UO*ZKKZK?NpmKcKZ@`*MgyO zy9p}EsA|LAN&7y>!i2)&Vm!+>C;;;PA7_A+x`>qk8cum;`qt9^5$PKfW==qhf`~J9_K-~%jdl^S z(v`{j9QoidVfB(aTRb#!W6iup4T+e}yz+5W8R#=qfa}I9%z?S1s6+s$12nO}J)Ja= z?(LZ~x|D86idKqy6Ul&AxRrHUZN5q8lzS^ zf2`SLvzQ4=i_PxhW9?dpJR_6&@86?wM(JcOefzDVsRrc}u>Dk>b5^dXIP|nKi+AaL zhd=UE5uzs+OTNL23=(@nwYb;+wy}HqxQI*>EI2Ta5wqIgF+w5O*_5}kcie^Rv_oh? z9loQaywq-0hS;wS(79{Hx==M{0dVN&JYSp9X?xbZ?Ddc`C}J`ws=FTYB6#WxE$28)^ZoW z`nk#d^wj9fw+<}(Uyci|hMI12uO7Z6ZhB{Eh6V_Xb3mX&g@>&((sSz!)cQHQ8V+IM zP*B$FO)>@2T3waj$>L#yf~AE_Dp)c$XB89$BTGbItYl|*Hx7~1Bhj>u-Q8UuN~L?z zoA@NBt*^;DjR~KZ=(eQ_J6G!LPbd{=`?iJ)Y^Gc~c}S&?O-?8~Wk_Rw9^mreAVK+| zQhd?QqAm%kEC<_aP%1qr+{JS*d4_Ez>#%Oi=i)pek{<;`c8HW zLa;}A!Gs4J@pX9*GNRh!gzs*6z@2x!eSJqF?1M{FDeG-qSq+C-(Vr;eRtQMmNOe4g z0izWr$h45jf$9(8mb$@&~Y z(BMEj0MyIE#)j7;rfbK;7%O*y-@M&!2oDYpCL|_eER%J0bv=D6dx%>yVt(idNa@Rx z9d)Xr(d*ZDo)>FBVu}@d8-hPTKfKoect@k^ssq#goaka*nibES^q7aEJ@{>#_?Gso z6<`2zY0xdh37y8`oW5My{$c*hetK#}E=_=>0$Y5`{Cwu?lN$SFd~E+Sn?9vaPY$z= z!E2`LGUp$jcK&ynR);?`uqD=|hGahQzNgLbRkHEpKW+KMk7qRkFCWt49SZ3*ys%tU z37D2KCk}W+f+(9yEzUUsZHVtJppM_}qR`4g@L^$Ph4Od@+*=)1p1#IjHZ|G_$;o~o zwxTs!p(4DzlWsi1(GD^U$3Jp2#D>5pDj6D#tt)jG8U`p~8yhT_e7sFlle?Ax=7EaW zy@#rs+FF?*A|Y*CH?=)TCnm@0;2Y9L-w{Syd@ivF==U8C@N2ZXCgpFPSK0 zdp?}E-ezdqWf>R+at2IgE}9!T#d29$S+&C|Avjt<==lUg9hi)cNit#B^hFT|V|`R4pK1l0wuTHs?WYO) zc<JY}HVn!6P>*jvB*=SeIqm9RcENsu!3q;!!^3GNdE~ORa1{JW( zdrWNdJyYYwq#L*nzJ$iR<9X9RT)lKgz;M*l%tC|>;yF!n4-G|Rmrw9bhA7#~P)0!Z zuXbD?jv~wgG7XqDL-}hr-Qe{Li4w!DMq89HlvNlep7pvV$6#F&E@cUq#;noCtI@Wa z(RRCv@p1-mBWw>!+-&8Fz$oPivA3h&kUR5YZ*9Ku;@8F{< zzJgFJs&5}*C~SzX&PrLMx~U9K$qTUq`1?YnSOi#jfjtgh)!?h9)N5~V=MWQ%gbp?X zf_0$KN|~bOeKgP;AS@twPto3X*uD*}X$B(KLshWt0I$2CS$l5vUTA4g;@J!w9V?8agBL$P9OSv6z{H^jR#td0X#pAE)|SA!;b7P&_Eu=9 zfAcH!o9fXOyBdT8n`DT>%Bhg4<_TME8`bbJh2b{#^~-B{S))d8HAs6c`AD_d;u9UG zi>+&(vpg<&vY|(8^!3s6w2gLyu7#c1Bd_x#gR-$+90yw0Pwa_ro6gpobbog$dDaC@1l3f(?OO(pY{145^s@im>+~)|KK$m0h8P+0g2&;bBZjOh_f$m>-DU{@`%>a{x-M}~6g+$| zmz~|2B$a)FdGkrucMR*Xope|@SSyOi*q|fzo@} zLu_fc+H!x1fl2yljRWO+Ae(2W?AIXC0Xkz@H3~IJ{({X?&i%$My5bf7DO76zbWdBz zB!^@bGxp(4bHBQvYAvZ-sIDchxcGPl6}yz@sS!dKUA<%Ba|flDJHsJ==^z<-1HX4A zU|vg01(YBjK9k?|%a;(|pp?bN#!8@@INEJ~cHe=oo8uJ{_tNhP8X=Qwl3HLdb^p>^m+?=79?Wg1M-4`0vMviV=PgFJL3X716|cBq6nFL z2V%&p-jvVbr2NL}i})?b7C`@?WL&TyNaM0UkOfJ&OGIA>In&21l0J)gv-T_@DxWC? zd4=Bbu)QSspwdM%<%3hg!o85lLd|PtJS5h%EorIW3To9-HQZj;@g`IL{QWg#)P=p0 zA!uGY%<-Cv{?lzJXOi?WkD$R%PHHcJF~P%Pl&?X8z2m9cK`V@H2LUg~%FX>bSPyJO zm&Pj;=j!Gy=00CgsVa}xh?c@tJ8&h>dYaebVIZbQ+n?5@R?=Q(g?VR{Pv3e=-H=bt zU98oQ<2uXiG)CZBLs0>ppGZ1KJIpFWK)fn*5NA2p(9wDDotZ}_7R)hFz3NZ4>ad)4 zmDO%TkpkBOq_u{&_B#}o%p1^4%NDp*9)N^t?10P+K`uBqu`RC@#g3`l_?0cpIDelIx9CX$@I?eAZaY3TH{ z72<9wzfMm7ld+)c^;__PWCFTkSX)~gtzZWVxnEcPTC7+LB>!)1b+L}YhRs@cxUQL; zv=xSTEsZ}t{T_Mm7YAvta|?j)Um#qap6Hzp>790Rq`g|9Sp=h-%gIGA6s;OO*Ss&R z#p-b4<5aIZ{HkthPSTbt8WUBmm5kG5?D=ZzEvo8vdbELj|_BBihnmTfSzz}7wDy=mkA6W~w@|7lwlNFcU zFrcpFR;Gz!YHxMpR3;2hEfgcVbwrqxD1Q~|oPgKa-+36%ygrHnXljSoHD9?j0W7_<(zg^784rCBWu2QIDOj8{v?!>$X;yj~o^)!$<)N z3Lv6MkOcaBlizM!j9Mc_cCUd#2Og9f>*d>E2LYeW{O(d$huxgH7(p4iF&zxs!J}YU zOHC2zV$iSgB(E?uX1MJMlf)&b=hWhck5l~U)kA{Xg*)<|N^U%^Y;T`uxNiP;!crym zTT|~PucLuO`TP4zY;IA9Tp5_Q z5UzTYs*Nr@{IaM^HH?cV%stpM=vIQK;ecNuq;EMQd)4BBO$gQ_AsZ+AR+=2FQsMIH za}MmnhKHKbFhc9@?VSg|7`gr9`JLZrmsCG0GCXibdJs?ns=ZLALFi@EYZTdEjv-Tk z-%ooS>BuW6%&q36wF3kTq-X`Ba$!k{5j5fUz;O)~r`%SU~#=T=)96TIP}S-SJu=o81@Ov2v=4->HpjN%d;)2mJH z$FmR=kmmoUZ4WrXcq#5A0Tk;)r06$<2%f$Pjd3oJkkg5#)3!*jzYFYmUG}L-5hghq zS1AUv5GzyV5>=YZ5jan-I2Vw7#PqAM&DW!}SoN+r-{+pIe1Xf}|9ZA+IxXpT%iJfy z_&1yZFp0W=W1z+NSC;gN?BT$3PGxK-gRdQQrVCHoO?TZliz{$S@YiCDQj*8zmY)|( zfJNzU!y>1AHF#v5*Yd~x`}Z*r5E&33iSq5;G>8`@Wrc|d^T-SXq<)wqkAG-GaNuja zjz>nk2^nq5=4q?CDP@0BKcINeGJM9S{&;T3>ke@Y*H8!xzQjlir%Qjzgsu;{yAbG; zZTdS#>^SE9;#{4l8-tQJ^(*nGdGD%59=q3}5;sMW1VV^@tf&7>&V);Eo*EXlsH)wj zh|Kv=Y|AfUS6CIb9<9M7)q9=JwXh=MCXHcgoQhV}RUE@7`@oOAyw>`1< zofqCp{k+ty?)GS>K`hKlb4t&e=G~w z|HR23Vv384gN2G-=mYC7NZ!BBPPT6zB$QLmgtmZf4>E!Km9t4wz%wR)z}=G#ZY0O< zXX*U5Ci`|>gl=Sv3G_ZMALxZ<7QWz^>bleAnx?yKZu@9R$ZodUD0N?vUfl3?{Agj5 zP8Qx2o7VZ$dW+P1-}`)xtE9Yks$wUqtS@}1U2v9RF>%{{Sy%#{Nv1^)hTJxsmTPGu zuL;2(aNR*?n;|~)Co*U7Itb?Zf~BFfwKe*|_oU|o!9W9mq-Q-sHA$i5SHByf(aNc{$kQGY0tejOPZA;9*3+qD#MNEYaC zg^8(}M+Ak(tZ}BfVL^(HaP?TgVR}3w)wkBqVz%;7hRnD#cj&4{H`xIbHG_Oe8%ep$e zI9)W>`R5)HH|IQ_WXxodAMQ=e`L!GUcXC4|u%sgG%~exfyqG={KFMpfW7hxOtMROW zN!PjQenA5TM`#<(g{5?|8Uses7h(t0@h|>2fGooRq$9J&0}im{&dvsa-#z4k*OD)`sz2x1{RB$8TU2BjB76 zjM9455^OKn`hLz2KdrVHPA%bXJjgy(cj)}igA3Z+g(Bi2GMfT_0V5Rn=Nl5*Rc?VT z^jt5%VD?)qb6}}v=q2rf^HL3dhHO@6J8>$>BTN-FVr>5ijKCIg2mADQX)C@%MRTE6 z6TJtSlrlK8Wk1dI3m#BC2pGEa#36WPh=_rkP1qjHMu;Qz^#9l-yVr47zau$VOJR|! z-Hx`R%qtI1P9>P5urFT%1*6*0oT1}+C#E9ABXCffsIST_??DFPQ6T-jKtYt0Z2;ri z3keDAdH)K`KrxWA@mc&KdCTe=BC?-TMf0`@{q5_27>$)UyXnnnC;} z!Umr<7z_{yK0ZFMUc#wbPdcUf#eF^;ir0%#Sf$yzrCxw2F`+qzrEm{o0s94E8s;!? z0U7K74;d(PP^=&ayBEj?SWonE*9vc6nx7fgRjRGmk)HcRi(>Hp9CsBr#40o+(=9GP zA4aY(q_6kapp%=&6f{Q^6*c{cu%?J>c@-o$kUS-2s7cp@5ak(%D&4h5Y4<_Go_60; z_&Y#(Iv|1Rq3@HylihUoXMNgv`t|ZSoP7~v)wQnpahsceK~J&uMCr@KzHaTZrghk_;Rvso9d zSA85mxZ2v?9aiIOg1ib9`BQau5C}Z9j=LM}EjPu&z)c4Y%13kyLIqBv5EBz${ZmaC z91H$vWB_OC` zXY0jZB^eKNtLeh)+C2gn`VPn#`vcpaM|D{b8kZj2k)!`OW+B>8S;;2|R?LBcfe0=# zbK2KgPsd`jiXC@pv%X0h7?G37I+%Z_=4H%o|Ejq8$gXwGUm*Bh?}$_kk!D=RC>&dw}UQiQDRy(%l~J-^-m|N9>AeK_u;`+4;HeaCfu#`!tV^HTDr z3#dB*ev>8S9FW2t1m|ep1oQ|j^aoWh4!oh!>A$kxWtpTB*jc(l5+sz!^}>Uy-8sIa|S#g%k#f8M5}1@y${X zlGx5cK_>!T$L!J|2&Nb`Vz`bGJO02$x64ggj%i12g3o}ND$NcDrU;joyCsG%>9Uqn zrbKr7$VwM|&Gt&xJ$7)}szmfl=fRwBckihc?Y+6HYr;Z~%r3J=@l+8_rnnCNT_aE^ z{Bqji!PxtpSGp73qrb13m}~`#FBwlLpNNS!qyt5-)|hlH)Q4W&p{~mvav^9!;%M>y zT$>WdEbsLinp~tCqKXHv+-|1(G|*Rw`M?w9dr&)U?-+C4wWXO_H1njJl=b7YOTRx^ zHyeJpH<{lkSG`*M`!T~2U#*{6OMCeP@+23v7#w***jfnPc(WGW855`LoL;Pr0(wm^ zEpiNm8O6rxDm<=_F9Z~DRQ1~uTrIFv!CPKW^-pwXez$q*4QHqJnVt&o^J2 zn3^oJRW?h*uDoa(c)=`apan(|DGOz$gs%`sxMO1Ltx680Q{?{pJ-=$C?)+kh01jOl+Iqj}Q#Q||Qpp05+M%h#?cG0fO_-6X!&He~9CF)2 zN1bjyJh)-|J1oJDt=x3Gmgj1y=24bcW4;4KPZXa9&IK`?i*#U8;2E^Gx*lvZ9l%mmAhFNLFh`N$kJb;l-I;VJ+9nqg_+I;e)}uRB4C?7uj)~z;wT}*^yq{m^ ziKQ`ni$^LJncXX}a=>(|#p2I}NAqjj=vlMNel?CET4z(J-17}QZF1PxapK6RyNcHH zlXaXWyPq69m!o$m?Qp&xV+xo54X^7=#}&`7il2nx!`OlxXX+E{Mdw^^%gwQqgWhjm zKYnQclsVLeTUMmi+sHjvd^(x3>L6(WaSBhv^40;ipwSG6w4+UnjaZl)@6c z!%Gw^w9}@g>e!GTaty{ORSu6;meMo(L_K&wo- zC?M#yiRaGK*Yx-f8eQJUw3#LF{OR#dnc!upuQ|6iQ$TRQI{*ZPmkW@)-m;9 z^ijk1#WhTs#knUmFsoYU%Ernlun( z;$a@D{Ud%xzUU&;i_#i$^3$a~73R;_&&Z>dI-yejwe!!jlGo8GI*4kRNudK;MmuXe z`k9GaqQn*$V$A8=*Isz_72X~QQzUJ0l9_dC0?P=k=4FW=TQr`a=>TXDLx>5bHYHHu zqFMma5aP|!6j>Ds&o9G0ab!+n*?KA&7IONJ$zF}plvG4V%w1*FDWfI3_+y8AC*NuGA)17`j)BAD(v^J-5Mn{t@Bf#DaXRTHob>V+YQv} zlC0hAJJ>~r_0wj#(1|HHQc;X=iiVbsmgW*&W$(ME?#ZzP{~ zg$%r)wUc|G!&kd+SB_ekBxlaYOoMMxj%|ruHk0?`bTVBp^+AW0M?NLMoQx^tN6q_~ zr=YDuORC)8LI&I!2*9?3YdY!Lz*))k2RK3;z{xkeq9y_2eu$#%HEAa$Kv_-tN>5_Y z8Z}F<@e!8OP|1jFF&QS$%ZTU9V)Q&7<1SfR0Oq z1Fcjwg6kBb`0PONpjGy13doj&QsX@sAz3pZi}66@2fHScO;*T(==dSyUzKDQJ48vy zLS05sEkbaf&k#^*WQ^4k!-1`xSGf}s84|nHrTqoD+|K6g zT%UECi59P8O+3Qs$2fUb`dGZ!s|P;Us`mWKqjQT)_lFNwbii+u*+wiL`>YVf%%_5_>qVbm+`?HgEPJs^V6cH2GLT);?PYnCZEgcc;{&M~9n8zbe(j2_jgbX`5#LNQ1L zJS3EWVEHbc)c!K=K!^q*-)juvE& zhW2zyup^H`2%kd*3_sNHD6V1sswe84pOYvq9q z_KRWdIRoK`R0=s%Ch9cvI;8m!tm+oYcBL1^e^xFg?3~+5 z-(3E->2&kyQBT|DxvLmb5)}!uEVq{SvRSlP#LW{Cyw<`BNiF9u=4y5-4XjIa9eulc ze(Yhpl5I4%p^S9JY@Va7EaH&0)cn|kXOfOjlp?O02{5Q@Yi}>@q0G_=0Ldn=lcK&O zJI-yUSiyc}{dBN5-TwV?QJBbg*;JN~QrYjF|GB^PhJVkuwm{FXC*|n+cgzgjXQuRl zA}7*!q&wRo`_rx}O-GKtSJaQQb*C6JXIOY#hZ9|OBsQdVe>wcRXR>R*bABu9m5s}5 zdz_90s%5uxnz3bOWV}JinUKKx`0-;20sE4rZE_lz&Yp~syvvC43CM8ocUJ~eVo-z? z3KfR)p-ZegPaX{;-?wky*vw3Qx>jmoIdeeWgT+NB2WMv~^_Gp*^N{Kr8z27r_wSVg zeY>d+L17V*#FsBgfhYUzRH}&XPS?1g^O8n#Z~SjR!Qe+d`Lec~hq- zn&WL=`bH>m`S1@e-7Zk4^o(sL4NGL(Uv$6r+Jo*5m4_ujE2?t2Y}xmh2T*=Cx;J}s zL3W|FReRvHDFtB_aOciS=Veb%wIi%hcE{Ydv}{}rFkWNJd+S80)K(~|6+-!>B<%0H zq=hWM@zlA`7juPDG={Zkf)&&?4bS?zwOAIUrKO#{b&Jo^(h{_BLR3*zRTb09M?HS^ zaY9PU4wMU6v<4gQckY~~ldHm54WNe)3XPe}pvKx>`Rw*VAZ2fzrWp@Wk{zOaU+C%@ z9v=Q8H->xz}tjHD5T1ka2T+6I`R_pp?^+x>N<(k8hD$2^cU^=iVd_6DY zbRf|SuVrKUcS)S(a^Slw0_@tkwSPDY$QlE$&tKWsM*5a^@6PSiezM>u7P_~LOzwZr zA||%RuGy@bCX+L<>DT1qqRu-v@cDx1A$b7?)wOsV`kWJ*`)0N@q#F%T&;--@osdsF z=U-=1)nDVIfmM7dl6XY%>r>akA?eiJ`)(bhxUtDeh*|fEiHX@_^2Qg-gDWCXypfTS ze=7{B(#y+>u7J(yai>-N{NQ^#U=paLTfcuFz--w-pUjj3&XBMwG1%Y@F#zp=5cf~E zXD7XV%W(eudBVVC{$}OkO^l1{s;kejg&vdtRk!m@{Ehv4j09;|loel%#kHqB@`8fB_{{HI^l+{+WY?yaXi_XZvb~w*9T+``#KQaG% zX)cYdD7rW>>XVJ|sZ*R0;oTNeAgFK;_fmOXKx`ml+0v_2n?)evbc5r?(3XoaSryqCd91aoY(;J^NoNbV_So^Kd*7>lwcjpE|IV@4GmZUWlO}v8 zJ+0&ho(B6Um@N-gcK8bRFhFikOce(POe8RUwb`hH&t~?lnWx`SEBVTg_6iYVP3W4N zb3F3#nbnA-E?3`>ncwNFms}pDzrRmuB9X1YDk?2~{Y5put>qaj51~2pZs`uyM*gt; z!*kM>2k*Ikt$dr%eBHB^zM@=FT3R~s_iL~aQKI1kVLDcE-CoR(DlI+z{i8ylPN zmCfjSpuD3wFA*Iby`?O*R*rU0t&W9-#k~fzYOpooqWJOJiRaPLc|m51q241S*TCbT zprrgdUv%N;jp99f_J}%7F+i9TccJP0N!AaW{s#_Q-r3MzTFd&e$7EA@X3W;@e9TzS zEv5DHd(Rps2Qn-BzsW*l7&jTL>o>7axE`2^;Xz zjhFG_&Xi})oFO01eehr_7JE{5cJQ@Czw?4osunkI)&Ods=`G*=bKA*G$XH(mN%xB5 zntf$y76nPYwzRdirDbNy;LV{f!rm4*b0)TRw|}4K>Bl*4M+Y?z^qc(n?jdKz!;*2? z&P}mg)r#V+R=TnEs;^qJS9oXWF@_hPSq9Ei-$_0nX>MCu@#4jmiEOyrW!^p+cRAIR z&*xmi17Z$xY1UKRO5xh6F#D~W8f|iOA&O?rijyz38V1s}5{=%9x$|xqXBDzGQq5>< zsH`6-pe=~XXPuMwc&(NygD8FM*fDh-9b%jX)sKmbi>RQC+7$mQ9UewTMrsODL1E$W z`J+daXi(Y3YSUKV{&jyTk!^Lo{=yJ*puE@1mq*7O#QrQSa0Kmrea&&OKJff*h2TS{ z9~@B#LO1*8Y|kmbrJ!xSF@?#=+fn}l3ME*!)%~`bj1&rG!CRMa0-0NuZCt~GMU4q?(N-6%1l^Ur^^E-n}`cL*#8?TFuMxME;ip-pv4{B|Ww?|)UH&P5yHKcfK>FxQk9jZN!zXCn z_utF3u$v8!=e6WyIe4H)dzZe1Y^qN004ZYEUXDMt0ehafhjj95z(K-mV!~2b82Ek0 zF3^sU`w6u{V`HN=Rq%(sa&mHb$zYY&b#&k&F*z)wC1md2JLjM0n}x={XQw(AcPqaD(BptBRv)?MCv87c4FL-z^JF z?Cog?!e~rPH~o@|UGBx0WYv?W8<@B^4p`@zY0h?MOeZ=y)CSE+l*(w=HahC-9=l^K zSo%=vf?SD`rQ|$s^O&zX*I-?Vb4 ztI9mD1URxK{(h$w_VvIP_e&YoOdF;%tw)-N4*53K1|>v4+*3!Zp_)W<=9Xhn^0O`l zp_0xT1{ozKax4{f1B2ai8Z<%BDpnIu<_L!905pM`GcYr&MeDb>wr)p3x3RI2d=sXz zvUl&EAtIlcSP4G`8CwzJ$d4cTbaZqOmcN@^I2tKf|D~hjnXi9xNi!B0QXiJgm21~X z!7^UDyj++?1@o!;XZiq+4asej=Q(7Zi^SSGnvVG&wTqXF!PT}arSs5HlC|pl`Fp? zM0k$`77B81kF`&m<@x-u3oFAJvE2K)?8XIJLOy)oO*hH6EE6s?xMG{Qx2ncA@p!?H z(?3JsbuV9N&$;Yy$oJ#iZeM++-ODeY?((Eee)=)6&g8(pe0HUCH*RqI2LxOdU_d|! zBnr&n;BT{k?p+mT)G#)t@~XNAifQ;KO3?2RV!^haO(%yRTUvIu54#e>p+nw%vz5j& zoKED(a3v*TkaeI!?Y{l-*{5sy1qBe?Cab3Bc1;tjlD7#H%i%^F91PnJvsO{Yhu*gGw|YWn^4EuV0) zlyqjUC10?LCCe$;-n^5BbE$4-J}Tz9BKw0Y0z1(|f>w+A0>%K zQ+37r8?SVpsx>^uYiDnZSzT)?Diz=G!*B~v%MVYBil$%QRDRzzbzzW z-(0Sm*_N1|P7b%9^73+}%F3!M?{ZAvqeh2)5|^vI8GFyV6R8?@Wy=H)bt3{ldy)-H0r}%$;dcoXD5gTW?+B~w6CT7{<#-5 z(VsEPkq%{tx(R%i6k&aM{!C0vz=Vo+>wdgzg`h*Ip}cvU5Uf?B1{A0b9tu9n&CRV% zexAsMhVc=!M=aDGp?}#OWHj#nFBhPa)Q_~dYubvq9iN3%o+z2b(46+L@ir) z3{KE-&wTOCc^dBo$N=-(I^8LNkehF)hXQj={9YY2ZkS3hV6-2p+)f`tKw zBSefB|MqFOIyjfCN;H_?oGIVx+f!vFl9ZUZ^`A-o6>IC`gWeAt%+8%Zzen{bEo{0q=#|6L?6B_p`78YDdA4nBcE4PNGEZiA-;7L}r zxAp5glUw{n;)R(NQH_tN+fLO{9LRb3P+Wc@Xm;gX{+_mR&4HoYB87=AxAxwW(O6OD zJ=&M~O!cVy0B!u+)j%8fLEGcspVD#;&2G%hQdX{vM3=9xub(~;&X^4rvgNgMMkTi$53mb9*IztHBZ{+P}z>Bp0a?K(}P{+!o^8P8kZOaA<=I~eH;6@l#a zA1I?JsHjYF&D`5V78S6k3&MB#lvJ4*#ikT0HrtG zzI|7b7Hev1FdkoB?2UVEB&QKx>!|ZF@~7I~qAgmdrK8iI_=hkT?BZ@dr@<3G!j^aL z<8uvX>Cu8O>57~q$vXG;tws!a6&4mg1byx8G%V)IOTRe|*OIS%2N+hGUGaB<3UjWo z@9(LOw%k#te{tQOQM6l{T0AR2+>Ixla)63I$m=lOMEHwXr?DY2p~IYgkv&$jZx8qX zfJN)>P<9S8$I+1yCpU}QZT@H>&>O?Mi{_*)Mjc4!+><+7eIMl{ay>CWfC>>2I^|{! z<(J6?QHL>Ve}8|P_Fq||?%2Viu79|&@XangY91v_?f@>NT-xhKS#oOTP~6Gt>9cm# zda9!|lkB-6i|2=@d>4u)bZFeqNf<1P%B||>=e3>BZ%gaa_jT-uV!s=!mij9v`0kW* zYDFWff-@sS<%?f zwQ6c@?$mGFZw@_FwXEZfn=ER#6&hC8YDx+<7#i`Av3)kYBGTJQR$fcpFxiz!R zA9LKY^~J7L*FqmrQP8(RCOm3%kb*QkB7z7>=wrd*_M7>T9@Gw~IwT~d_9m*&h! zKSw|Bv)-PK-Eiwxpry)o22;YT;Qs+Lo7o*d*-0=P5EK6Ulyuacb}mHPrp z>cTCKt0qPM`J`YvQce>8r=iI5rCv?7R_SB;BT%1cPCWf#z0Wu^`k;U84}813q_Jk< zg+ix7y;`WE@Nz@{zOuyz2L@M0c*a|;|0p; z#{@6%`q(Dp-yeLqPVT4lDN2c5d%^0u)GbJTVQYcO!?A|zM_QgLZxc71(B<7PgDt_^ z1bIN^=!5tD6HvDAejmhC^Y^b9?l%4KwwzIzx)7iMbn*9=KKr1EC(umR1uCK2AsYr#qJ8nAbW#iZ=OT5k?Uj90@y%qFeV!~}I)1Zs^GyxcyyGL^D2TVb}E7?KAhO8P}gkR zwr%NyBHA7=_W|`7_K)o2(Z|@HD1AM3aobsID&Gtp34Plq{*^0ELyespOSOX{ML1GI z^yEYzPmkG|3zukb-9*g=<`X8tm^}c&0K`bBx@i1F?Q{1O>ow?B{EF~|%h6_D->eTX zBs3rde+;*NMc~;`2vfM%4bHTHSlQ9D;c6&kv*(8J-n{BP|DI?FXCqnJr zsZWILzWl8Ff~`kBoP`^{rJ@l1X@q^7VQ6ylO|O3rsXHH@BODV+z3>M&lcQQmE$_^P z5cX>Yb9%Tig$Mw8?&8T-BF-bb0QdRKTdVnOF@cv0%yq0 zX^0+eHlD_M7^}rR`R4;%lACM4h>@A7dY+vLt(-^V+`$yC8Xo1L6gGp-Q_O$q%9{3FC%Y&3@uPFB+r6r4e_xg@xRXWsbdvNQ zierRxP1k+%?{F@KhN0me_yYlRg8dVrQAV91c%QqmcU!}fjo_qg%vVTsj(&}*sqjiXQ=D(=5KMiwu z1kIA9XZZXNR$4B+a(Flw-H`70aHv~rB>hTaqR#80Xz?>g!?;7_Ih04!V@YP{ zZs{`eM`U>at!90xJ8!W|H?q^e?6@ff${iv|v?M8@4n_&+180cm5$w!d;I3dz(PSSm z^~>jZU0ut7edo%STNV)|CZ_@LR3u{da_uv&+n2R|Lti{3RL+(CIO%QQuP zj?nX<*TWA=w1k8$04@=kVz8@*f7*+EcQ%zGEPO&%D%ZjTro)vCAYAF*Cw8ch|>$~yXf$FT6 zS}BuPKL6%eQR4V4IkhMqwP!7{y}O$NO99*lIPtyG_TD)l{ZNn;(H#g8u{fy7D!CpQ?un55?#w8^|)U_g9$B)b3zI|e1a*{BOm5`u- z*Y|C&Gwr@XL87cp)BJ*Uck?KxJGqSPR#gm3*~BD@Gp=gT`)9V9uRN>08#3{i)1Tij zL$`C6j5#qLTJPK3Sn6Uh6)%~a=^$U}U8>MsflG1UA!g>|DBmG_L9`W!{-i{6HQI5P zu8LRs;m+PGUkfruDFemsDoczN4j%G7x!=9h!*yO$sp;>uJGcNoYhJMPgyCpx1Tr})qlUY~Kv`v?4dOAP9 z-Afu<1VnMDl9FlUjjfO>Ne!az>PihcS@ZPd+K=^Jg{LBn|u?^y)Q}3)e1= zCC!{`IJ`fABPXeLV%^Hs-#2jQ%6ThC$Az;aqtm46=d#wEzm7W~=Mde@F&>`1!S8{0 z&cTrj(8J8H599+si6HOnw6IAwK%kHOTL^b#%_9eyf^X5F-iS)?vuW&Oq^9M_b#% zrmrHFOXxT^w~~vq`;mQe4ayIQ`h;#*$oAR&KYLF#7t@)$v^9zR{&G5s-LS zz?^6qFmFL8V>dq_2f!ihn*w#|_IM2y&fR59g_`%&sB1S&Z{6Ah4-h$BU3xTtU%I;= zgH8kvfvJ;Nnxi-6S)|8H&_>YDwRClF4#49ZKZXOX#^U=j=M=+%=w|x%jsjyq@KP~{)lH}-4-y46} zTgldXb+|FTW!!-XJOI4`!GQL%K}E9Jr}n)#>G=~d&MXd?=1Ki+38rN7?zEoawVe%C zppoT#(Eip|L`#DD_FC%=lSKIi>nW)M%N+?KE}3qM5F6&_lWq;^5x?Pvd8ae%RwvBA;3m6Iqo6VE+4p@Eq_@S$ zKXN+OJ*JP_%AsbN$`)~%pWeEWy*K}03*)6oJ9tLD2N`lf^j>>WX&lpOR>}C;Q_utz zwXG;;w)GyVE2SkD+CT-^m$N;pB&hm|03LpC(&KkE4-6t)RrXP8r)u~G?p|@4slPws zAl3pnv9)1sx~T6Z+wBJ|J0G~*>jW5vbG`8M-#m!fb&OSFZI0-qFr%ya`t|GG!%w;5 zj)-unMtqOBCFWjYp12;F@d#>E)Zw=jPV!pzAMLGk7w6-x_2KF%jU``%ciK8S!PGYf zYKj63y!}Q8Z6>XA^k$SU(e#Te@QI_Y1y43^Y&ImTitnW|Oph?=MBZTMb=iHb+D2`2jQvw2pI?+71>*pvSJ&Tk#YGTYc-ZlVYSQm=zTiHhtxt(V5*R{H3pzm*1-#Jh-;Ivm}WTW}W@7crZZ$7o>X31KP z_7^(5R&0xgx{5>jh>MI3iC?7&Qvh!hVI&q8C$FNin}oqxh*+T@ZanL>lE-uyQ+~(1 zp6!A(wQUTwqv_R7-C@Ibbv19;{&uuU`3^TAz;#>TgiIVAg2edl9f`YS-|<-v;^D#B zDX}%X&O{mzCm>)AoU(>;1C~K9<-N&2_5{j@3C8+eu)f~a$P#N*{~%!z$`y^E&YKk*F=XQYf*VK{Q3OM0#9t->>vVxt*p|JbhC z)c4TLYv}6w{69DWO$vkwWPg+Ytv-|4cdL(!FCRZ7?nD7R4i}6)^SQ~}N#uO&9#WZ5 zUVdj6&2$~Vt^_9&$_(CY#(DmPR-2!{T50%@)zS9MnW5t&EyMb+>6d@9@7*1Hk1Bb3S(W5XaXypO9R^dhi(Gts za;TNz5Q6&fOJCoGJv+#Wr`2&0!$`)12U}2>0YriG*?-nGGLgfwk?(a3_RN{D%;d)@ zN9r0jg{VcI>KQuubYysVcVg(p*IM~b=McMoHo(8~4-Xs}K25uObdBpl`nUP5ySqDx ziF%_ZJ(hGsKQy`4?bL0?x4AmPj1T)}n>&M3oG7Q9R?igd8<2jMWtRQ+{J2>BHbn=? z(RA%j;T1t3tysTJ!w)`PBdpm|Fh>DVtrm{&>KYpNF-3!!2UaBp zLj-notG}pZTy zmy9I8#|GJ1TYt_iEL^-nveZsa{_tExH_7+Og*W=tjkW)q7!JFB~63TPKfn z<+JD5v2J=GKF_JHY_?7|eLqcouxE~o+?lfVlZ{gt+8ta~YildqZfkI1E-o$#E1t++ z_*s#Cg{&XwH}(Ow4h)nY-M_yD&zsk^K?mlH5?Niv@QMxqprpSHD)&CEM;ly`*~ zB>qH4hAtDjY`7eeE0~-xz5KCiP>QXcZzTJUQQVkl8q>iIeFw_7S~U?xwb~h8JF^!o zZrs2l+JaLM=JVpgx?uiy-BYkM5WtM>%eQY{n7Cu4J2-fFQxpalSX94s#B&cM-hRSg z8-84H7u({WC+yr=XFh7QANjo#!Ccif_I&H3uF3AsV|;uMTP$jU4dYf3{}#y7vB@?Uj5p=} zXHigY$4G*3D8gEyP1lc&jRlU32w4B;&mU_l!BkrXPF*#f3?n zzMZf4|JPn02DgC#B8;-Lf6R0gUVP>O;WGKz50eWMG6~dBSs-68owXDl-R0Qh$MBg} z#>2Io+1%V*)O}ficmHk-sEJLrOZVS%I^=?tj-%#~l&@^QLE$abMm`eDgdD>-QkvM*ZR8VFJ7v8{@*1khbu- zPUiX6o4#MmCVo8DE`09$tSZT4Zmdpv_QcjQ-6=^F9k56sc?ULM1RB%qt;?BNuWuTt zeOOytD}Md@c#V^!TjkG|?K#VjGHv`4(pAY0`H0h%4VI>@!=#-y=t0Nk5qg*xY3u4H zWo7N*;NT!EUkq%@|M%T6yROonWUP7WUqQpNb6G?SD zb6vi-*qqF>)6{5_G(A)NRe)#l`rCa6g<|uLTx<0W%q@E0N@IM>=l8so zIZb>~(oYeWV=ZZbrSVpq3*B*_Mm>!#MTf}!>P*aGtZgm8@a4-F5~M?hG6v;=^BRR; ze|stHdmHwyTsojGbV$}Lbn4;}CtU|i89>>-jMASNm4(KmVgSN~L6U1;rw+l1O=)Rdi3 z8vkPFZl4-N9~Dtyq#e{(?}HD+|1no7l)X#meQB)X2TMc4*j%84zek(B1YvweIM%|Y zxR&MiC1*QzAO=K1aq}jRgBTMUFuU=uDdBOV|MI~05a99k0BsOxul`fb&V4u%{1Ybx zRAF&qpDa4A-+IkCS?9XXtBM5TOZW%?DZ$hl=ZXNl#L$0#KwTl-jxB}#-dz5g*M*`w z4%(F2u_V$MNQaN^o4mYCbwu7n7Tqi5Vadk;!{H+fmdU~B5q6q?p^AEiFp@MhG$hU? zA>vhJ!jX1Zk&bIS)=-^S+v{y%QW?IyWm#xvQM zOPl-V&0L?y-*55CZkLWfZjbcsVU=s!!kpOH`ra#BL4u^%ry<}|T?xJ8Q|JE%@5HeE zTHaO22;iQzAHCbm@7{lJ=mCr7e}DoEs%*!;uo5}6y*&xt9s)jkK=LCoMQ+rbDS`i> zbd#uOzw$3Niv~SA!!AiL7qw_vvH|?W$YaHP9I0uUo@C8|C%y+4SW==Nb%D%#^R1&dnuQjlxW)U08$YOB1#gXgvvvHKHsW$;151ZVw+yp16*8fMb4XopRDFb|lkZqv335o5)>h zyb@}D01s86@NY4n(jSk_)xJ~4B@Q>{zGoRkOqfrM+%sW+FngKB?Ih1aP*)IVT9CVK z^Tlu-+Jj9Wa$}xc2xI5w={(82PE2)xxnQvfLSNR~YlL2L>QZyWf6wlNDr&qRU0p;u ziXjL_Ch$<;nEGJ#<8*Q!f3eJwLMLh_(hAIUhFmgy#FWD(@)Cb!iAM1UaU1@w#R*s9 zoEPG()(GYMpJIb!g>>W?1DH$3H`g=B7#cDm(cN2eazADW9`=*`Bd3mByg(KGDN>s{ zEUR(<>^bfYU#O&7dSW)m#QoF(S`z$R5W?V3fC1as>@4RU!+#IbcN@{L_qq)3!8rpb zul{C2WejEz(KSNFR@i<^fPp43tM1QneE6G(dq`_uF1{}DjAhsX+b6Ixdo*YFI@**w ze4;%-SbY%&G(Ubk|70N?xrL$0X|-s`TQO7{nQ0m1KAn?fgWGgllzfB zerL1xa{0wp+P~t{XV|`{0c-OCd!_@76=b1Pa9C80`W~61 zHr{Nl3!q;r-xiwD=d;`mN<>-NA*9boM%nM7!ZdOn=lI_XX9=Y?_dx02^5cg;acmQD zW(QnX1jWUp)4qxNuFIhmnTL{=I5=ce_+Dl6;%x)_bC`8!^YQX38ZaADc4RnYm)I(J zZ_W)!18QMWqRGh2#JM|OSZ%(pQ={Adi{TI6N&)%rhtpDZm(AAJPt*UG3lNA-fZ!Qo zK8*egFG~(}=drWx7QzQ^p8VRGSISx!?FWpZVRlLCk^5=Z`)6NRH6>NMeKN#g4!CT! z9j0nZJ@s-f8DYzwM$^sZ^?ZNVjz>BEKP7$B=hq6#;>e0&&-poP9*3_xp;WI+AJTkbCAimMl9s=a^A53 z&$8-@t;*N(vlG<}J~dmibfOE~v(x%|rV{ocz~}K44iS zHDN792ZZ_*k-~0mneauco?IZNv;*i4b#k5k=J$ z+k?UHY0I^GolT}N1;WcSyHuE8Sa?o@j9BP3;`oMx4$3dg*G5v~GrKzh4;TsQF&d3F}{?Jq9# zd)jFz(eSLem$LO`VrYaVH26L^35W}*%r3(bx_~|J_SK&yS~2`goO6oH7{-jIua64z z13UYeRFz?W?M``s;32ozzh~Nx`Zxy!zaK;w1$~?Jojb**Jbg_fo=tA%TD0AcDtM1U$KBqy_nuodVc z!V`rOwD5mR@&e$ZbU1%tX1{dRD+}ux@!+)tU{`$MRDkv)Y z?3?zh%R)FW1oY|CvD2%0P6!8{ZHte>nZSDZ_1WcO#q#s^__WO5eEWARtEgyPzD$AY z3VTb-21tPKA@FJ~Z{7q-mVo1H_wU?}6M$fvfirIcF*O`Une%aQ-pW8I7Rhn>9(2+K z*osmI(1NUi!NJclr@i3j!OP3b9zpNBXa{p>y6D^EhVzb+*)1NGm112>*DexNsvXk+ zKS%L#+)N?b=eO5gd(f#pmKyqNIJ-@=B9y(qBgYgk8w|mBpoP1-xuqA80izBAG7ebx zoPvT+V*6w#e0gwW&rTBJ#G5(7xE9&S1qZ7|V4tFf`_k1F(A(R4M%+LFFU**mherk# zBXlC5=m~;_7u0M;tt)H`^3vLquE{#pah}Cj47)UK3gwy^DfDqQ^r5m zeHFI~L3&J2FTP$Z`c{#BYh_>MIEx&+lJbvB?mqL9EMl?8=ZnB820>;k2?YhkPejuP z0A{Y8z~b@c%|Xp-W21l&!C=~mNqnjM3Z~lv_m+k}pGFZw_>fjpkZxo4SiTAs)j0?T zw@=Q_>f(DpDN=Z&%sxeUH(`E*2|v~hA`SZKq_@iEr=*!1+nL@uRq&9e2fsw;|$u5kSp zs2373=ubG(n-wy9sF%!pl8&B^?geBt1eE~=h6nVX7?P?>vlFj_``EE+XpO?LzY245 zSgH2xQL?FA7il``e%McTjz~-cbpca&pak~e<|dAf8G+OG1hd=S4j0}7i2QT#_loVp z#Kp^%9!wZJSlqf*hp7h$lLUH$x|;JeH3G)`<@|4Q*C7X!ZBZNL6TyP6wjLcfdMt>< zRD)S&p#0!S!hW-HZ~uP7^G1;hCT(5KSu) zxG!T;8P2%-vY(#F-D!xaq{* z89Cqtk91;FJl4Dp=+B<8clz>$8psXJ83iKmgC6znAAn}@UZhw)NonE$2JTmdqSUeN zkX|y|c40bAiC(aa&p&Z{-X$9ywGT+}n|`6A%YVY{52MDtP}e+RCr7QmjB^2` z%ZVn@o+5r~d~8e|X5&g%JsAcq9+;N(OsdvJMWJv}!Io9IDAftA)vM-Oa8xJq6`fn~IPuJTr4 z@2eQ<>~@3OXt-Xv`CIt_vdS+iO2Q*S9>Q@SAN-c&5&zkb?2n#w5F1%=?Ns3}hp%z}Md1&)8fzGN1z$7H!?g5^?O$ z+MiS@b0AB^xsJqQMOYOo>dL|?OaUQZc48S@BcWiQ02mSM-2C(H0!FqYycc=)C8%>{ zMqC^AMziqk=)c3<@H3eZ^IhhiczCr6O`VrF(Wf2uiE z=ifcJP5;E9TJruKCos=Id7cu^gBT)_cueFybeYgNXT>C67OW55u%`bnQz7FU)dt~k zv~MriobapNv=pSj<1$jX8q5EdbANDS_fEZx4Tc1@9h1{#^yl*21h968rLS%TEKX3p zL_O9-Nq&aKudyTEB9-{!e`Csu_V2*To}n7oEC5+cOXO_#KuO-OgSpSE|CaZyo>>x~ zE&G-qvBj5L7j3+CksF*q@v*Y5nsm{Fa4o=1Ha7ePbNupgdQ1)oMuC99J)D$+adKjL zITJXCDBlo?>L52ztH?t=0r~G6O(P? zRr0C#X$0-Bhy3nWUu9-a>Xi&jtj*dN6UaH7Q}AJ${}xG{`o3r$?8GUoh1281IGBat zNTP1S8H?3}^Dk0U$vPb*oJ9{oyCVbn7f@fMaWL#}3+?4lq7f4pZ~6L_4L$S?clXQ1 z@Xt>A_j1=*3cq|1xj2c#WKD5qHB$H@>3VloR zR)Fj4K})6f{gcc*ehnvmV*G{vQGtu@$FGt_fP|!H!(8NbLi0%69XFLrE^sVZ!|Y)4J1IQmlBsp$*q_?qpocSu!XV zXk)N%;|=(4&+vm~OqdAbDzWso-hbB(Pc7q$&QT#TR^mi$AB5NRTb~I-KHS82GXVg? z)Ti|eFAd)J%+<&Jpka=UjXh~({Dny}guPRd2GxccWfK z3_%=VZTb~NSJGP6=Vxdq7W;AZH#Y=vt$tWTY!^VN#!9`6S&gpQrHYgmi;Z6(53iFO zevF^cw=jcRPcm6*H0Kg3@x)fD~qzrnHpC!B7A?;`}5 z=&33yDq9^z?te4b?gvCK)r+(w<@M@J$it z*k|<3ZU%U+7I~fseJzF;ZOwiBcs-E|39vIzKBB+>YGi=P?N~J*K>f()&?sC%V+~>~ znSSvX>mr<{LrAI79b>&9ZiqV#x$JejeLK%efFaHI-;)PQ+_y2^M+uj^$}5m^cW2Ga z%nahql%6?`7rX7go|Tcl{;?fiRWZnsP1JoChQ4jNiCX^p^;D|@{S@#vj+t=oeDFaK zaGC7&>!YPpE2Htot2n*Nx>-(;ok;T({35ecQ`(3f_WD+F+2P6Ss*+kQ|6PC-$gKT1 zAXNWq-^yp_0jZ7o;1qYK2E;$n559FHI5V5?`0-;;`HioM$3`_@w_B8!;cZ-6T}KFP zR??_|{uEEmAFmIJY;_{~)lzbEb5{|tkEk0CpNt?*f_b5cdZG6F&$CkNXKn%H1 zRDAmMDYwBa6uTrG5lW!(C?etqf_Da-S@Rn41Wb_Try_KXLY&;xk&xY@aBB_@4j(Wc z(-dIPhS2!4lfKpGNksy%K!gMZYY;J$B}v4YsEmPS{a1O^fe3(l77{7v{9ddM1RZ53 z(L-NxXpa40{T`<$$st6Vu6i%ID7b>)vCFOhA-zeCp6cIJ&%d07EAMf4%)AhpA(kPZ z!L>Io&*U~55b%!)pd*wWI^D$VY^qi+5l?JiV06Ro@lPWn{?(m$)p{({>gd5cJZ{k_ zVSCtA%su4iaxItqcRtS^rO^D%U;LZrPDx>rE&c!PA^KxA|4#&b2Id$9{Qni>UfNG* z_*eWTFJ8F>$9H{)S~Pb_#O+-D8f$mrrM1U~y8*5Q{-0&D6Gp?HU8& zE}rNv)5pa<)+wo}KGXT4abSK_;yrm`*iZ8~hbra?fpKMK-u&+?c!rWXx-pkw+-;xo z5^d9cx`;()$hYwFmHf@14gtft%ZT$|$YsC1ICTjF0O`QB#p`r6Uq z3+t2yk!ZdazjerNh;qGlTOBsV4cONxUdvlK!-)wJT5`*|;LYV=ah=^rh#iy3$3!a8 z-j)IqDQr)V^!{YNWNqU7LE)(@vBw9b<-lo%qEQ0Y7#jqmP5uiT|WHuPy83zv{A!i*kAQsdy#lTV>RypK47 zPpJAAv-%;Wtih}f1r@5!H(4*k;cKwmPv!XmO(XN&KN?PWXheO1It-7K$RWPlnji+L zVyM9dK^gdB$2&Y396I3sXH3H{h8idkBl>UDD0psI9RC`549J1>6vk5d)ZB+j9ab>R zX4oxve(;rW0ST078woF20^|Jto#-ynEW7}c*`=ZSd&Ql=&TuM--NxD-T*@(=(_n&Y zQAU+TyjZ)RgvJCH0PLNEM74ow=?wJrp7g=1`Cm2O(M&Kmp2$_aNBWS z-YX!4qP^Q@IJMKnGvV7fi;`xeIhL`0mdLPBJ%fXo;SY0CFV<=2i3L}I$RDq9=EfHb z&46j8(C~Tj6MWw$7jC>a6=pQAXW%(@%midFEV3z1sTFe2w6tcQ@%}6z!KMSd3TBV! zReE&zNbCeI!OJ3oM;B%Y1+urkz;zp3>BktUT5)DsT3GA^+u(m2@Wqf|_w7(>8)fTi z(8=AAieTkvu@IhKcf;s+FxO#kwTndD_jFA<4%1yG>@=OhRHBwm?=yUYss+#V2 zV)tt0Y~*l0>4QWrb)k>izD=z*D&}KzOO=(qZi~&UrW)Suj0?YTj^#f~oXoW`1t}AZ zKyDP>I`J#PUsi%4?c!JamSmSel@b~2bA*wgFI(q#W50H#=Q;Rw^%eJN6FA zbF<3LGib127d5?PZh55;E*;}9tKU|=+OVGA3N}1v;KjT5N9i5qG&Fl1R{n}aALx-j zQK341zDw=y4{{ug$$)WW4ilO8k`K|8gD!}M%i~YdVX&`9t|r$?%W2RNzV8s?18jVN z{^H*>1X?WYYpgqi$ZBH)1L%?J0fpECs+p$zKUDn%R8;%-K8_EilynIQI0DisrL+U; zh{Q-sh=d9vC5nN|&HgDoFnJ@xDLb_5ZJR*IjqrHO!pz zIE@mKHDwpLbJqb1r{5Ka_CIu?}f2nt1N$yXRNa^_q43Cx!r; z3PoGTy7NC?=bcci6wjC_K4W|3++$+3z*qN6@jvSZQByLq<5_4Mo*HFWDNegBSu2#s*a#4T?)c62faEIwi5 z?~OquE;1H{!WSB!)<0gBoDM&o)_hZSlh8&l+`W+|>o~ja^`0!5EB+fDzSqG^;oQlI z^r9vJ|TFJ69&G;b6ed`IY->J7A% zwg^AUH6gs~J1+*v>`MSzz6n-ZciK_@P>?z9vl|S3E%)WC3dQk5x@0I5@CZEgB zOO<%?F7}t&z(bwiemuT*kg|M3}Z+HNv9eJUy`jJQE6u~B8^Xyern#fkkUCK96=0h zi%ab5a7s^ui&34T$jr+@s8;~f+uQC?JCbM3xJ#jBAoKaLp=kBiXpz|Ktw9Fp_i)!+ zxCllgH%dppAWYWnA2cxPpe`cg9;Ao9(6P<`jSFUML-doq%Lf^+A2gJhC9N+Pln5Rq z=f&PvbJG`ez0YC!RW`SJmi}Oh{=VB8at&q5I|{v`>Cimb#Tk{of)pN>Mf{ii>8Jc5 z_0>YXj&TCafLqK{!s22xU1`^X~H_PI+*^BgGCBIAT1$FK7Usq;mRu7ws7 zaiBwv!Y&bGdum|7Qj{Si4WGOv#^wa}1?6zW)v2gL>bHv(WIg_m2zN(-9k{W3$~-P{ z_DUkc5lj$ldpV;PP6LL0j^k1rteu(W0G#EJGpj*_Ft`+N1$M^0k)>g698aZ)I;e@_ z!b1Gd>K+NW_q&>L|9w;v4ixx3CfmZN(hhigB{Y2V5!9vljL1?~5aryBNq{7)QQhEw zUks4P^~hjWt#A^Qt(X`IB}qVrPzT9g|Gc{amQ90!o;)H$pC5321mo(Sj}VF2Py;N0 z4i%A6zZeAMC>+y1rUgTOIRHgFm73mvmhb)- zh>zekP?RU;&|H}(*~G-; z9S6;&$WlIATCmsxV~wW$3;w?@G~w<4R(9}si(wUR!SBob-|shbAminD67BykBEwev ziiO_0!09D>DZZIw^D>GQdJ+IDGe8UA?iPD8SnS_J z6NgVC18aChg@w%&IB5OXkUv2AyoXd2<`JTTD&qNrVVddQVfogAfxG4JhSja=Ev20N z+Pc~y$6m+Y^G;RbT-{TTxtd9=Ngdousi=Zh+NQji-qG;H+PNjxO{rw3J| z;qV}<3co~I&witsm^s%uELLg$HNJ58lZVj@o5KlSPu*{yJ|zq-Yc%zlo1d+8TJ^ne z^5Dnj^9SDEbsNfkmjn|Ye1S1O{^ic&Rb1e!w^IVW5viWww017JTX=Gdk(?xuFJSSZ z6tUUUQcBkSt;N7$+Tuw{QjD$7B=2I(c?R-V9JaK0T#B?UQS14j=V{}|?<^z~CN2x1 zA34CIp=4(6E_+!ivF9=_A4VCD$yoC5aC?albRO?FXD7md`ts}VNJrdKb&GzVLmbU! z&)xrCqma-w3YCi~sAXQ_-uR6eT`TDPYa+j zUgdo4RpkK!bSp3#L`i2)a9r)~k?XNI%BO+xM2Te?at7eAM&d=RYS48U?1UzjWv?{3CHfNIGCuJ~{sExBA6}gg zoq9OY$u3FRf)~V*qQL8s|l6rtrnJ1O6qoKlSd(FQ7@xfFo<0>_^#@QW|N&v zldl%3ug{%1lCaM+9>Q5V=(x4ktw8<9Q#GU{0eGC9SrRGgoc|LIX12}RfG!5cqZ<8} zF-O$tQS|DPvNywW)59KB4wLnKIoeFaN=`PVjB4%qimG4RPnC8E2$M;&x3?Vm@qoMI zg|w}9AN1C!iWI2I4uT}?FdfL?THoD2C-?r+21K^^n01%Y#%^&V^jP@#-MSxJRnFso znh=7)`zK7CYK)tZvRL{%Aa=jv&RAJHLCy)%{yF!zAsF&XJcmY_mxMq_Yi#vj|EWm`ap7<`|I!ok7kh5MU#!t%b45 zSo=(_(LDWG@$N|)6*Y2H+M)pixrhbVyt~r52}yJ@rB=zQU}5fS4#A?w2w|FQ=&)R| z9$Upt>Xs~GnV6V)1tnBMyeYCbbwwxxt(}S44|>R>&;_(^k{wJt38HYlTtd zjeU1gQ;MqZ&Nw`MH;yF?d-bIW})|TBVOUuDgdP;9}BG11v?SH~o>8Dv1vX6tMz=#=UvToN9Ow$0oNXe-EY~dV(MsCm zRdLzst}N=-%a?XpH#`*A|DNZZu_43e*^Nq?lL==zYVVQYr*<2;CJS5kUPXMaTzr^~ z6FP6fD0tE^9xe;W@K()Z?0#}IdYL1L`yzaX3b?L>|}b+Yilq~((5E=7Q~&;E*a`Z?d7 zUuw0}Azbp-$XqUZZbfzPKi?TwJNeqg``u>Peti5>v&Lm0qDU|2FJR;I<`3@GBaTg$ z!bO2iS9F|^_Y|IbYW@Crl_;myiH-pQ->$MkMykccFwOfnt`tjWGoYE+Cv1OB2hxUi zM({S$igll5=9+YF2`$Dsq8>ix>GVeJ-0*0#f7hsg9Hr^xub5maR`7E3Y2&q;_ncnDb=g zei|sN{eFWbkxg7c9=@f_zWdFMc52|=2pZ@(*O}t|wV0k`a;;XV*7B44QCP%5v~u55 zQT=}N5l-6(9kh*=!5FclrxGiiqv*BxR_IeVLLm}cy8BEUn`ums*HWXK2ar)aD41e)%OQRyFfclIbqw=C*J*8+G)7ZU)WP%6(ld2(hL45FTG#t zq_J|uHr_q%11=W}Tb*f=qDr0-EH73#ChYDPnC(N4y7RU6w+S&Nd)*>IT08lmfhkTx zy4k{!l2ubA?BeaBo2cz@+;R!rd}H$Lsu~y$Ev z!)8TEzs5(PgE&*n7!5cBSjjaqrL*OAGB1Xf8J~^ZbDNQgk`@H_=DWZmsNP$O1+MRv zOzThQ>aX(spFaJ%{TV_!@7AwhccAKSQhTj$XT}!a#SgaVcg7|7>oJEH4l{IiY6R1D z1j$gY+@YCvgnj{Sb0@jfV*s=wTWVS&6&LCcpU|tOlsWHi`A#0n z7X97OxRog$#*2OHg+qX^&4@*!v3qBF~!?WY<~FTRrM)@u&>)8oiXN!{LWJtLJYq z9j%Z3eMCdQOSYdiW&s6SAXBHWM$>6E-~cG7^EyaMDLnL$EI?XYIEyo&URoYYCL~>} zo2eZ9=CFV2xXQ?Kq_n*2$(>*VkWZYgRh$mRRO2h*ozzhh$EJ7b7zGk>wefNC(W|?v zvd@Knsfls0vOY$mIvvV6YZxvu8P)$*rY~MWi*V0Bw3Aehk+z-d>j zQFdb8oWr**8&@-dn>gjwFVsdJG|f=`9Yeoox}l2`rYQ1s{?%XU?0wfRFMQ_$mQMeB z{1w3j9!9q>FK(N$b?k~{3DqalEs8{(h%BtYkdJsa9h-_F;Y;prNDTAi`CabJ1z^AA z&RB|)$p(r+`m$5P4A8y#zWn4M!;~XiiW!x$>_hzoV%dzO`PZ)eP#=CHqs+C{j zr88uww;dg8hqm^234al_d<~+F0uaGKQ>lM9G0C%)28j*V@T4J5_5)W5$`4rK(KcR>$BPM~K0v3r;U!&lX-0 zHu_|I$>!-|lnSu+n-HBZGLX}6H>&-BV(HP=&#(8uB|4n_vH<1D9`L-S1EQ86*rzv+ zL;0RgBgJ2TKAbSAy8CtK3Z#c${15kwhKOq0Q%~~j49}l|q8UG2n_Gm-v+FJsNz{|* zZYZ#8FUDt@2&h#q`xKjK_P2pCC&*J!NqZe4HPFbi1wd2c-8ORAW>H?JP2_JjiGhR$svBh9GZGx6uQ4%SlFgO`Tkm-(4OZYUJty*NegXr;U1 z=^a`IyJw{~W3A*+kR%CUY0sfyoDAv2a)l(+#e_DYp*Uv?ST^rjadQ-LWZi6c{X8?kBH$$a$nr`J?~Nu7cH1;Q9XYXXw5`tYM;H;e zDNU|XgE4$`(Lsi}D*By33~$k#birJMNRgiZ?;(>F=tka9+aFZBl5&2X+@@l?F^23Y z-Bj~qvMxmL?E_rbKEN)lzw=n4Wm4tminea#v5`;5XW~C%^9or*F6B!7@vlc3S@c@(Ue05UdrDSCYv;b4f-n*&65JZLL_>&tZlvy!shGKOJqWK4f0y<ZGg3JkFk^#Zy+|Bq#v9aWO}wGa!5P!JJ(pKNM!oP-G? ztfI!(VQ0Q^<^mxH@O4_=-n+3*Wnwgl$D%n9o0oOJvHb^2YU|AX;>(DfSJbV-Y353) zDsT44{u_Sh@1!aVwg-5R(`~;kAie78i+bdzMm;vp*?f_K$UH-)ZSRI{*{Gaq0g1U6) zsMdYe3M@u?iCn?!^B{#qWaK1s%x;HsdIzs{9`d30U;wc6$8URP8Zcx>2&ROX$(z80 zJzy%1*Uz3<73yJB>pX&D6Eh7^+bvgX%{MA|Pqg;_QE6In%OEarS&@5xe zSIEx)P~f0Tm^rFTSvWJ+q4DI@*zi`+l*B;pM2C`cnNa?6f81GXwQ2Y3DiN?c5)>4^ zF6-b^l+^pGk_g(ICxGmcbb2d8Oo@O#5&HD)w$p2%wBa#GWF42>u_i0YqTDzQIAo79CP|eqqfB(N-8`Kr*JbvAw z9M;3aF5?e!iI5|1BfeaLQU{rL)|oitLR_yb(}k=SZl|HX5Y zd809eb=Y?7R@QFqtXiuVuo@O8rHCw83{mBD@k&OeoPWw{Y6bvv?Lf%rN4oC``T)}?Q4MyFNcJlsVquPQO3bip2du!s} z*{JPTiHXW5)jj9!at{)ThMd;7L3E9*pN%{7`yeIM8wkjLPgi%-=7Mx|BBhs>mqi@A z?PQ)r-v;9di@s-aG>`{!{@Lg55Kh%OA%KrD9LpVU`skfVq#x4zkJ3o-F-@Xy_<$e) zY&6X=B&mh>LV~0Y_CBocAumpCMimkVMxiO_&-bybZaQ;gs12i1&=XB7>S`RnD40O; zSS{{iTXz;~uPj>{162ni=7+ef?8bexha0sW*WQzcTlRrI$C-7j6#X7}JpozvL7|XA zKFWXR61Fqdc1{UptszXk^>zz8^etJ-OZ*gmh(wi7SM{Qn4~Fm&aU!SP1o(^j64A&y z2Q6Qua@1fDJO?AY0P!NG9A`u63Cn>)(JD#o_g_>k@Yr2pN!dhfkYgWYmCfLX=C;|Z zVEeh^_VyFCZ8D#gYm*{eiVb*C33cY-!7CY@8?;b86<86}64DamdNb>*87srh0g1oS1&_Egf{URr)uoGc(Ch zh#wzY{tf3ZHKj9DbAb5=%br6rUZ$Z?8b(%pEG}yX&eYMm2a=ElMtm+1765%fDD{W?tCB05h+6&Vpc?dGGZ0U($`8Y$pe0mMWEV96C8#4J=c zVw`Hv_}3k$O`$zm*y}u-xVho|63X=;N*5N!kN>v$4H@r0cTk;-1Da@eaob3z@hVpG zcbB`9#OoG72I_uqM-c|DufL=BV^BYsYC;U#je^$^P1lHp$1&)pD!n}@xCb%C+dv|0 z@!@Er?>PWwRFPD?%Z>^8`1+sfriK|GM79C3t+-`nz)Lef*!FK@3^JsuX}7M42DLrf zp&D{C-IonUz9OQ$JLB3Qse@uoeg;{*e@sxiz~v-zVv42t%1WfP63xKllS!2&Sy}e8 z<$bCJS}1N_$okj6c=W+Y#+m+C=bxnAQw23Xa-|Ai?=b@?aJPP4+XoII(d9v~b}I3i z7e(Ux<_gR8{=GaTdw+F8Wx}aJObKE<-HEejz8`=&;=Pk% z1)RkzGaxY&KA5*Ypg`g;JV#^)GB6?;4-D@CoBhnXy1H8yFq>U%uT`ztjT?-B?wGDT zg!3R)N08>yudJ2PT2Il5-^C9AAHA#Y>+9RD1S&#TXw9rCK3DkvR_r;Xg^$BNc&9x` zTzvROtQ$b)w@;4J-{^fNXTmg)10cz-EJ( zK;-~(1GoMymA+Oah$DOgLbm{pKr@j5uQoLDyecVi!ECYocjyR84Cd%{K$Gi=a8@G* zL(ik^#UN^2*lA8oxdUoAI8+lr7>ji*YVuzxsy;YCMgcCuG|}0HyEfD}BHzIrCs#NF z)~zD`J@r5-?H(j`fGO9O=$#8$hWnsJ@&J(hlEVix41Unuwl7Vk3uc2KJT?@ml%fp$ zumuuqn1Q|VdU9eS4OI2uu+X@Aijouvt-fwvQKsNtKoU?7ovNiBzWAB`7X&mIBzUmG zmnWT4&Av2e*-h(fNx%Jf8vVZynOI-R9=y$9 z@PRbe2y1hAuu2P0X3ySV%pgQRXSC(0roZ;OIKxT z3w5$abIR=D1pd|CqKogt~aE=ma`n z0R2NzR|N%Pa-FMK#(=XZdD+thr7V0|iqZ+)@y?#l9D~h0bOD?Wx{PthUM3L|hijt= zmxL41Xt~ZExW#Bf7vOvxWC*&rmW45f_no!FuPf`3}LR)av)bv{YmZ^hqLa8hB&#dc>>0WZ-dZi~`yl zvg8_5&!wWpf2xp5c*V9jaoAF#(0aISS(f@s%@p=jHB&|r#hI>eJ3UyUB{z7qtg=6@ zKZ#-t>I%Y9gIbdheFskb`efPLVQMdD3$Invfy6V}OD=&OtqIU79>>%orbC6MQPvkr zA#2~&W~qg-JN#`I_GdKxE2Z-c-$zAJW%!vpMei^&j#pVqnO{rF(#%xEnN=y~#l_rvYGE|R`Dn8B|Rf9S6vhpXzl&pt~*W{+nOBlzj^i&&D@B|61PW8r6My zmx(=IO4f9&@;~%KhCmL$FV1{LQ}Ma9pcbY}pIMheBbK&FQ5cPdu4?oz4gnIrU$m@5 zS&s-p0_r6m=uumMek*O#&C%F);-|KSi_#uw?sW1g6pB#*k2|%0+Lp{*lx12yy%o=jVifkxpOwHiDh0+>qla7a9))2xM_{+ z$s{qe8F8z64s)m0o}0rZ)`v4*CC)M+M}l}kP4DM$kOLam=*~45YT7dbKpLwo0HHaE z%ggYv@h+rNPdM*G8BrNtIImu+&f5@8zEQ)#%X@XF_SacXX7-=0Z^_21o~%6+@0KZD z$#`2i%+hGWFeBbwcH}8G4-h8X1utIl|?JM6_q!x-fT&iE5N@;K^s1#{YOx^|Iu*Kb2l5f z;b}Y_`t+&d89~i4a%>Mc`aH-ds@9GcRXSuD647WAVSCgqzQd>6LnVG$W=VZL6TqjRn_sR_U27&g9_0U><3h;**Q;k}`^Zc1z{yeFWf3g= z9d6Vm1;RKt0cwskw9%Dt>JE06JlCivL;!EE#6^f2K>j(o6;5E)FTD7+*y*T-`t)`L z)=<&mVwOlTMr+dum-d?hYy@pthCV?-|G}$^VP_d1RI@umBZf^qr)4+29o=$oU`z_ zB>OS9$B|*wfg{lULBb+XOKwxhh58j*dKV~FII{+G@b8)82F%mxI_Mw;X6)Fp$K%G< z_B)RmZ=)FvlBGi!i4DQdZ(Sw8oT@Ilyjf<9HSblufe|1GKr&y=$QVgv$#cZwrL~z2 zuCU}QaJ#UeZWW30dRhn9FtIik=Uz10)TYpY6aK~Mw)B=Z3H#{_BAn^EIi;Xm5;H5~ zm-Ro`3zA-_7~Tm*rNMNqFOu^bLOSFSOH#?!Xi!Z+@pmtP%)DUX!;9SsvvLRDUyzJi zkB*HI;2gM8Sye@!mP)y@7Ai~zFcf%n%ssSfM;j;EA9uKa8^$bJ zgR*}q=K%cnJil0c8^|{5dSq~WwxD7<@$P-|6~2gL{OGcVRKP5^#;{pL`&2a zMnCf1B!Y9`c8F%-(82^u6H|_`V##|fy8ogX z)bEr(72_$jKXbBTRN6y@(QMk2NxdS@e8B7a95st9ms&QVruf>n_iyFCATD^gfJxfc#b$mXC8O|Py18lY-km#$L0 zdqKFuF~l&yPAt2S^k>OzUNoyVL)Uy|aN2_rwUhZbtTU=`v&TY;BgEquaUq(E21IV> zszTB(61wKy2^e%7MF1r9hqCE^byhF>8Qa{D{<8FR>8u@QfE^3dmC5Ba7+BmxqNE{d z2p3|kI*rFce|r+{y~f1F+#4ep%!i9DBj;^j!7}$>%njt5>I_%}hO(TMlO}O>xAqKg zb-clwc(*t4C#CL^bH|`BRey26e0P1O-8u{WoO~J^8umTF=HgKK+0kWu(2XHRY>6$G zuK}si-dU?FC-3gVjAbLo5%Z(3ZeWt^3H=4m|PTsvIVuyZ*1P-^6tUW@TDe^tkeM((=d}-E(z{}Bn2jH>jv>r z>gsMLr^4qOtXZ!jTJ0-r!jd0Z*qw;n1QwqcUg~V<@_Fg=ak-lCH%<>G=#(Ty13&}vF3Z>flaKK8Boir-70$;3B=yjGY^5Y^(xN&c>) zvjD^!=UH^QCvUbkj2_uIlCR${!8(&5-Kz1ovrV z1*8xvhQGP$el#DsP9D*?x_g&j`2wpxiN4U+Cj_I$F%E}e8)@DnFVDYAi;|9(4w*61 znI-kET+UvfQ5&NE+ZODd7h>MCx<9dM&n{-V=05;&Th(KxE&LD$Zt6u6nFMtBa$i?i ziL<<=F7g4FjTB@(85&f~=v4ms2y zVr*O!m#7&y|L8_i759x`YQ^+SmLgg9>i(1I<17s(od(n$tYU6i^!Kw2T^Pvywq@B^ z@?9-}N48Qd)_+fj0#I$Y`p%e)`!^%6^GKdHDBiu(z(;wYFZ>&Voep>&sCxe?oT#|X zeDKHR@P2)=kcETK-Yjniv!3!}#HtJSt7)a9QSsZiWAeoBgXV|gjQg_y`9HW{Kk`tC zaZ8bmJ(>sgK1x6!(EFVbDXJ$mx^RZOpzS#BW@KrrTQD|ldO!QPZHBAm358BnuGZ2# zU1DfUO?;rtYkdAY$~EPZHJuG#wJ?^2nk^+O!l0)mYu&I0!>yO~QqWqn7J>6o+RTAUJD*{&C_J9 zUM7}2fA)-8Nl$1CJ0Dvz)Qc6K-SzXIBS38t+Rp`lFP(k#@6J~eMteYIy2~=&GzV_w zp3xoS7|g=M?g{oeJ*9bNZOy~|318Tv8mlIc&*TH~ZjpKggVsGnj!4ntb6Fy}?rT}$ zVSKN{S7gc{B%Jxt&}iyF1aPFoo6uqpf#!eEL@Gcv?ST7_K%w!oJI`?037QA@sTh5| z0a{RdacdIV;=Fazl{~WfD0dsJAweUXE8s>8@;endMM)3vn6Yqj(w~$g#^OXa9FthZ zg&E&xy6>K)B)#%C$UMrY#!^!_k+x_JgZU;Eofg&^9lV4$o4l;zKCt3dth2qjfF}7G zR4O;^w6PIidBXv;z*K?FQsoW~^R;)U&$8XOl`W6({yg*7L%np(a@kExyurFFpSOB0 z+59(Sw+2hl<;V7BJw0~~PdL?&oU&Lj^zg9Klz66T^z6%Vll&Pg0TliszvGS7AtJNP zY+4@n{nazYzf?Nh7=%SJm{*!?!p2yq-nfxmOzB6P?~2TfW=TdY3+yV9mlHngzBtP& zDaaV~o+Y$I_Ek=JcqdpMG1L6*mMZ5h9-=uVB zgF8`G!;dl-ADVF4%0q9r9l%wF9&??HsY)K&^$jgS*-cHn=N|lQE4Hj-f}Y2AfR`ug zKs36=qvp5Q1BsPC-PBm;IU4-@{dSLL2I?J=`uiU+;i(9qk zW6KN1o*#G_QfZ5}!1vQ|;PdRRW}XhC`DZ2C7iXY=C%>i8$ zDP~Q;tKNef2fignNDQ!V(w<1@7eKnZ*9(MCW<+uwZf(I7BOkF&HKLNVnOX2mb?01NkB;{$~EYsC@GOaiyG^4X1KIp@#n? z{2zo#87O5el(i9OYNMEh{~xCSw1oWLxfkC4P>&MTY4-nqCz7>vsvwm*uvz@}{}4f7DsnNp^hLiZ^umPxe?Qk* zkXk0z{r~^Dosh+c#qa0c|NXvwESjsuQ0t(ILL=onCe9>!wg#worSU2OZshhk*bHfM z&ydKY=%pHHfAX#xA@l+B3sc>TAM#5|9$1dB>V-klrGG?# z;hSC)Y&a7biMqbccw8H!nA^}x8WQ$FPKA~SRTHD(NuEz)=*t=v9MD$D`9VAC@!^kG zt93jK7JKvm?j&8GYW=Z3m5qa*(+kc?dsvxz=`hM3<%#Z;drO3%5VZ%_ONtA9$#ZDS z^p3hdIKCZ9tMlOR%|cGfKhzY9*r>KB>PPq8N}0<7K2KIp-|1i4xk0y3xR-`pq5>Yr zni#uoiFk;*c9pV;=r>LaZ(oo|1%0?)d;Bds*_;(^|1RZ}McxLs zgSEYn%{!{)*WtPFVzs_YUa%@H_S#ESZg8O|(R$cluz4-4mMDUVC4w(GBUodn@EU#R zdA=-OIIhqhP&e58m2iIMY}Bu>bicmSZ1u}h4K^jUjp^AlR6M-^Aw<0loae{iT&b2n%Z#g+#`zDL0??RQX5V``7Y~ca83>tWqnceN^(mi zJpE)Eo4KKXd$h$12kbRqz9$p0?^0&gXwgvrApT}xu&r36&ydYQeQWy;=_BJ(QmHjt z-Uj~_y5o=Ja5cP3e*gV{DPW%G?#f!GC! zN7+1JVG3o_Y=!2uyS6X|y7pxd%2nVrrUoF>PuBsVhnb<`6H)xqII<)(Fp~?3#!v!PnJL%miuN) zN)}q^A47{^)F$@yX`rpnizK!@m25O+GtiG%sa15Hf|T8~?!GvfBWv%eumue;EpsXH z8EWEjO2DK_u!70Vnlim))80lHQCb#?sVATxnE~nyIq-|g3uS>`oaB2 zQC_{zy6)D_bACfxtK4jI{VfBouhv~rcNklOZo=;(OAlF3G_;xTz(jpt&o?2G>>#=GdMxz3Lqsa@6e348U22avOp5%e=RbTJB4-_G zbCm+!0#}LH2_t$9kf)sgse-ucAqozVtrS`{>@XGI-zWp!JJM^PnQ8mU0|a4HKtY)T zN33N*;4>7Y?RZc6ib)eQL&Zo;1&Ix)jI3CyUFOPM933CEdR(!WzxyQ&q&(cpUalA$ zY)>SRS~JigI$Gm4%TcUfgMU47)rYgzU(ug(`l4B*&%<}It{_S>ppqOrlnn3}TJSSa zUuG-VLD}HkK*cl*^wX({Rl@Pzt+*+*a{F7h)e-v2(zl~w?JbDkmf z@87@KZR`W}U+7QPOhMG@LM{;&a|Y<36J^%0_dZuT0iX9vWB12o6K{92WRq$4bN52C z@_#nqKwe!?>45v`hjvBduDpOFI2Td2ja|Q~s2Zju=W!4t0k?$;0M{F!q7LPiy{><53zX5bd-*p<6b%W23tA2 zrYC?#ZcMrSf(h`BcN`uD@ydGXs>f`5VzIBJN=vU9o;*s1(vfWSy+3CaYgAx74Q!E? zGr&GviEHuRfQ^2yn0H=e<^VpE7tyHH48cXc?4vMI01>uCSL+CiIhB z-}&_oIPng+Tqyu>^7sGAEaLmFaa?Uljitd-%3jtDlgdV#f`Fzqnk<0|05%z7T?8z< zjdLLiRx=tfdFw)Z-Q$p@Sycw6*qcF_#tPKi69De7gN?!YkjfK^uGev1F9bb)zbqw= z>DPBG`f&wZFlDWVHvu>cd)6O;eCj|_!nJ9i;oS|`)m(q@^{u8~XaWInafDQ6odh4d z4tT^g-hH4ijn&OL`od*(qQSKEM!Tt)C$9X~0GeCn(Y;PT5M!l)6zdiLhCcic7C>x$ zo)j<#E#E47n#ho4s4XnuDIP4H31-aj%SMyw(zZvyqXfS20*ke(h5fuc8aF30A7Gjk z9L1%8n8~FrJ|?(?(t5^BjC{qD1~2$| ziR4!QgGK+DFK<0grCkf^qd@`~C^A?lH+^{W?)bg6xNCT+^eQWw^B1ZUqA&6;2d~ry$JYau&AU-fABbYAQhI10 z`;_(fRNGp$4;m4_ghXz})Z3rRtK#66vV4Eh-yB-Uc)~5AtNqJQ%VXTRo!{gw1O<-CNij4diIs#t~v!~?5 z-WiD5C9ou_F-Qff1YB^HKw47^h<}saA(k<=uX)I)b1`XLx)@y8ji^I((p67H&+;X6 z?Zg=TNsB9mRjw(1nt37S{ms)lLYg@j48pBO%EbPPvI+`x*}0q2mv)n&IStZuphqiG zIt7f<-q6)C(Twr8lQQg9mMZN1P>s775C#+7r3w!SI!Ca=uW@-clTW^mKBDCF9z7pS z6=-ip8ThK8=nDKYjDHl*)=Q6usEqW9j)soBpGXKL9Q}<|ke5d$CBhp*0q5Aiw-G9J zVAvmpQafM8hR>iQfvc02ty4c3Aa}Umiec2?U?y%%OLLD@=zjnm9HRM4RrTcrSth8j zINc*DNfKD-uaoI7+31H)AMzk_aBzll$Gqi%nr!rq4H-~;Z(p5bei_d`+ z5oX@sq#NlFD%+*Gjv}M|6wLedh@lGWivfcuXl0DV3LU@un94}6ecFUfd4`Ndl3lRO z^;YEZ;fX@Z~Ikynd5dcgp8`C*cON$8VwV08OM!p z74to(%7?E8>%1t=5h#U&g?IvrYFp?O zdh!Rvts^0x41*D@qTt&!{q${{Fk+Tj>a~93`*?N9%q~_KM1AO%XL3%|KdPKF;na5I z=tcBitkvQ=I`t#8IG4J$vu=sR=9q$H_agx?@JGS!vBSd2qWnKb0*lG@^7q`!rKE2| zOavQY(U4sR#=AAsA)0qdV-I%`tjoB>O63-A7x_xhv)l7TBy!&WVGenpcV{DHDxvmf zPm)}$AyW&Zy&5RRscDO$qlBXcUr@cOj&aEulD)fU zvZX9$QRCWnleW$5t^52-ETtSOJgR-z?Lo5P)AT|lodX*^^OZ6cWr9uyfJSMHufTgM z9778422#3!BG%kfcf1N_K1e)Loi;=qLLsog(bxutlt+G?`{YsipWGRgxo=0iS%T0N z!-h$avoHx@I6NRv4MC#)K!#RkRX(D;L|!;>IF{U4&ZYz5SkbcQ4$|{7^H=`PsQyqn zT8A!>E@aa2x_Fm2PbX=-f)nlD>T=S6j^Jhp%RZ=-X?Og3&pGpDKiLjFwl@pg$l=e= zuTMQ!XurBg{GS$Jm^Hrd6iBnIeAcxTqn|*ag$~DK!ir>n8z8|~v90`asSo<|-}vn# zHj6Q5lQZEKz+AR2jdv{GZYb2=P0)uhXNP9|{?vx-J+KsM5DU}gGtKsjj z29HG6j&{w}6r}24d@Y*PDXjiyu|28(^PvOT(E05S7A&dUs^ka8?!Bfbp`ldF(C%#o zD{i9lw8hgB(R`ckc7Y=;B0ugrdOQ$RB;Z?zTZ)Q$WNSz0%6BKt-Z!Y^={X|@l;n_lU#pU_4 z2PnzwW=U;SdWJ+w_i3tZ?6#%hCM1 zPb>-FrmTTxHYp+p1_<$uT^AFCpJ>Nu(BY$+-_#3`A_i%Y-ON67D%JpRYCwU_e-l7l z4r1v@qFLzRQkSb96fs-$)i1&@%)E+Cwowthi>$q{$3}yau(#d#wN+v z=o3RVR6ss#TSn&;tl4`sVl(E5-`wN&F?svZY8PIRQ3e$h*HVLeWH~li8_nJE4)p7; zGi_ADO{$u(l52aLePAT^YKic^CzzBOLq53$1|xq$HX5KyB4~#g+;-14QWP5|Wd&6> z%iF;4+?PI-E~y~KgFbgQa6o-B;lABcu2SXeV%j&HecCjlws|CYX z_Jxu?23iS|t^JMzf`GiU5E|dB+M+dK`vPRlFFksd;{#~}{o9l(0Ru%7t3CmpUD2b9 zYRP0VuO==DU;oT@^pUREPV(l8O`K8=KfL&o4ZoP6Ta``1A`IlYEfdUUOW~9tW*lwu zZxZ6Q4N%q#4%giFJ&hKT80hZlH>Wp0Zw?CDEAr1-+3N$oc#s_N`_3*9GF~9Z*_4VI zS@d|4^y7s1C)AmPKD)7#;rnVEvEEi6ju4jZWR7=D+5Ao1H)W--p<@%&wOh-TE9Sa#h`3l6+~`o2nHg*EQT>A{mZF zl0qlLmVZY8G}pp^L1h0}0&3|%lWrny=8LGxQ>p!ugo~52>RFSc7xF#^{c51g_Lrkl zDfg0Cm3#72aslNQ2;i#)TU)e!jjL{$z1iKa=Kwt=FgY9?j(eAn63ccEHobomUu5t{ z#0!PLuKH+>OMER-S2y^g=ES)-Zf$aw@<4F5Z=-1lhI1ilSIBI<6paa zuzq+u9`$a@g_dbF-16uBI<}%LkxN;X6$Tl`5;K0QDw}*0S^l19G%YUm9XdZ2(KcW52o64eJ?y=?MgBoy{n?%7DYH{@uWodftdy&bEw!=q z%EzV|Gz%Go`k1|1vbn~};8L67Nak7nPc6ijZ$wntP7QzF8y74ou#4 z?pn40aXlgpL2D1^OyuZaZW?@tC9#sn){<=DR(a#bYA7>had-`79Lz&u!pjg2k{C!f z=Lv%At_~SOh_O;UkK}?W3wBZXJ3%|K8>E9uCE5&bmY(0Me85!fg2LkQVcrMx2PD;} z+MG$*ON2Jfr_jeXDd)`FDAsXhHict)3bs@ibZK$AjMS}ciRyKnD!T=IdIFo_N zL$)-^WSS72LVGo?c|LWI#!bR;ZgNsB`OvEV=({TC&YgR)oO;WD%m97K$x|}*<8uA1 z(U0d#tWZl`qy*t8gP!E2;NXRjR!aFhw<1o8kcs?xE*%>`P6`}0lSYM?!lR`E)KYo#=iSLvz_VBI z3W6-wlfuG>#l`;J_SveM_36k}NUZQbB&GRPjji8n(JK>QEjspY|Hc&#=G;}DT|VM0 z6Wv}OQsbcN0Io(cwQg!Hw^qKk4h8~ROSst9jpSkAbgJZT3Jt+J}Jrvbem zSN>UYpV}R#a zwe6E)Vq$~_Ww_o~TB=ItBz!2Khm6IB+Cwtonf8f~uxLcigURS9RE-mb#32oi4}f*n zvvPyIxxVqAtr(1}wN75nhm?silULo{RK$Jh3`o4xU}kmWN9u z?Muzs76uAiZYB0JZ2RDP2k{^*ddZtc!6p&8xm(;%oVX1nur6>`36AJ_XYac?I}<9{ zFpzurP^vw)GK`+S6SNvE^pJioBHmvjc`h7(IYo6Z~|eV`3f_7JC0$ z5Jg!KS+M{XU^)^c`~eztvomM3d|wn5h1b^Z2RQl)MX^e_*+PJ|C_30vt6TloK0%Wt zW2O5-&}khmnG)Z)aia&+^UoIJvhZ5R$Hzs))yx>euqeeBb|=Yb{RX5|_3hi0m{H#6 z&OInB41*s7WV|8$XFc$#E*W~c2qN(P_=>}1jtx>3o?-w~#z&9xMON6IpFPpQT%REX z5D%4ab!~0#3?axLi_oCMxz2xt3p|tzc~L-nnglQbC)HE`iW3cBIS(=Dk&$lQl#~?FXh9m` zuf$-Cf}Z6&P~B+NuP14H{Sa;ng5eLIJh^-8c|k!)d;763C4Odk#(| z9+>}U_kb`4qY%uN{?yr7_3hhTaoWyPWGa3fb~zkcNEcxrbm6O}y80^-YyV5ACHx`v zb3Hk^9CG4CF~P=b_2U+$_9J&~t#B>)3Uvbw7#$jZ7DpsO3VHJ=3h^DHyVgfsSx$a< zOM>J@Ix-cFjd7{I&tATa!S;FDev&xh{`$ucxCBhfJIM7LUcnJs9%Sml|u_-rVg0D`C8?HQzoA4jw0X0uK)gIN;{`M8{Ru z0W%x$roaqcL=99j>Q?%6u2+&;v6U)T<#?TJn-Ws(P}YK@jgJ=e;z$du3UpLgH?Q-4 z-ad`9Kua^5c)C z@~RHj2HH|xQ-8g5_sLYiHc4FDKTF{SRy0U9n8OCavb&r;3&RA_HEVQ{e;9tJ(En(_ z4n|03_qu6AzZOE6uv*`1pqs|}el-)8Pf$fc9hJq2AbjMD)6>__&i3yl{28%~6}Fz} z;oP;iq~~8=vx3?ZgBJh^V`%ZckhaJ_Ef$8clkS0mEXgO%_Vx>dBnZu8%)Q!_3oKhU z0{Le#7|J1$WqqeVgeCR+_XiEQB*_a1b1M}U`)Pll602Dx@+WhxHBOH|b#zpI`$pt| z+tR!U{@qi5;b{sxI~XjcNk?=vLIw~93Ttm4B!jodxH_@O>idJ620yG}5n8DT0fD~| z-w^397}YvMI@NmqPYW74Cof-96rDkTi>CjOY|Kaqr&J~plWOOoj#Is$7v~T}cqjlU zo%8=XtFVsbmk~{)DZ*?EnB0Ow!+|3~#PzOH0#^)7wLG(2ynqW8aQDBd&X%@n8iDwlowv8h!y`W=tsWJ!QBYpe zAx#Z;D%|L$8^1=zPu0HQDoxv#v=5rwK^zX2#^$4P@)45AFIeoQ-HJWHaoRsMM>PKvOy z!6FHjJX<^IBG`KR$(}eVl;Uad_+e5m9Ed1Wm0B9zLm1scB)z;`_d@hl$5mMObWkKG z+n*6`Di`i?IA6g9A#FP~?=I${o<}5B)Yi6o6yN*ijs8^<8mq5}bH)1(92g3WZyBN! zQ)QV8bTq}QfaiX7zKlV5|2KDIt-zuMggFcjd1MwEbhNiuz&Q)zvRKgsgHH^U0&qY= z{g3D}0Rb)&8U=LvAiP4RN6H1f!l=Q<`X^t!zoHx9eUCqf$CibSyzt?Xca)BAK12%E zz9q0@#}00;1tcO<06&hvBw`@u_~H|!-$r767BkhK);G*M^^fEJJJ@ZS9ky<7i9~+a23hH=pS_QIsX`9`%;! zH^RjN-OS>9q@?TD6+iq%XzMNv7%Ggdbt)a#)H8nl>(~8XH#1q^JA7&^|OR--_(;V(hOW(r*i8-*q{64NH zQ~DGs3tIB?ub|g<0v=#%#7yxBppZ-Wztq(&gPgPw{SwY?L4W(ro6EKx&WfsUKQc-B zDuQLwi>Zs?chH`iV;PVMx{h@;RH;Y&tD4SGBeRqvMj z_~Oee+4DFn5rT143JvFe1z@Fz#{+}Nh3di%ZEbCE3`cZU-uDTa76Rbd%n(ul>Vxay zCoE>-WS{$~Q@X}N1gQgK7I|0~=LPe_tT|ESzG#<@y?r{> zb$G%T-z~T-3`@>TiXURsVBG&xb$7(nGJS~EsB$#t6lCR3oe}_&3T-*M!>O>1SSwH& z(+r#wgIn#;&=4V+5A*oa(o(l8VV?i02cy2~ldC+BuRQF`lBAH~y}HH%FYSd&lbeQy zh6jEP=6WPvyEXy`vV`AX`&yL0ytr_5-BES1-A9ieZN3}}$N~HqoY?xG+CRjx5$WnA zbjZ~65G5M@J$Oh<(@3TQy8|1_YWq^zm66@(F4N=BQ?a0?aVjZdCr)9%Dk}@Rt$X81 z{4fE3ctd~|@9nt{FtySuw31s9MuZQ2A#S_*Fp_;*hTJ=B+C=W&Tf`Kw1S zq~1Bg%;LP2q(;S|`Urj~#VpRBIEnBJ==|m66kVWRXJh=OR`<}RLAkcV6cb+aYrDt| zQ-atOSbM?>4}=$S!QcZJC1dV-=WtksT`B4fmG1}Qcp)NbqT1oginNT=E`CcC@2gqJ9(+N;Oi-9~ z1nSnZ>FM)VGfR-tmWB10xXB}y0#2d_5r&Pwa_tUvbppW6B`I}`2=m~JXi5f^Pqw$wQMkW6LX zIU>b0#&BD#l)Rr!eloNfcfT2t&AMp zsuz_L@-e~a?~lz9?BT|HT6a0JsL%6$JEaZF!rTB5Z>!wuWAZI~Pt=21taG376-0ou zKY#wIK9jV&Eq?fB%(Sm7BNs`W7EYBJ2E*_f4UI~ z{$GDjk39elL6l#(@J~6k>ZxS!+0Yk9szs=B%gdzMU@(*RRmPq!_e`-ewTcdeC(E;e z+atv}rAvk9*r1z(r`(8F%Xm;lG3pee+vgd-`@ zJ#qV(io8%I3zn;)^K}oc+?o>_0{hv;Ri2@m7SG$~8trtWdthshFL~d~bQEo$eom^4 zv&JiqNiA<^+X!&jzR~VO!Vjq0V2H9ZMVbm%N(w)Z5DM*my;;Tn$v)h1WFs z9DKSFlFJm6+YO4G1k3$ElDAoRaVJ7{%1IJ6V+AVLq+rtmRf9!*ZXAer2AuJGy0+9*Z!fs?%nZsAR!}@xe zY{b{3mVY%bXKU!ohH|T|7v*p`r=pJ<2%5OsrdB)LuSl`b&*(SZJ#jUXIY2!uKdckc zqdpmJTP$QK1D^H~pFv^`Lsif;xT48tg4TB9}Y(ESaA$Y~| z(a7M8+UCPY4L!s%*(|(5r$xJLB$>7sO(IYiAuh7Nw4s{2WWpO+!5;29cID@E{;>dO zCnuBuKv3LEmPFPy6+1LLOc(spHOhQ^&x7OSuWfB?wS7F6p@5>8{@iF`X3+%EgYW3j zetgsf5e?nkVBm*xZOn|KQ2CzRuEe?Ju9j2yGxys5Ijb<#sBDWnt`D?WCa~JUX*x;} zSfwBnUOah3B9?o#)l%>|{7aYGqNu?=ZH%ve&-3{6H{;zCuf~fF$ucGOzDBndMY&Nt zp|9^qp<4KT#GXbiw{QP`TR>CbX9k1m3V48%?fdragD5;=A(2mEJ-lZh2)5Jz0`L<> zwbvp35l(23Y?z(Zyx6o%52YF`?BN2aETn;-dQkfHWVjEX{24(g(M(+X3=uyQi+pq2 z0`PobnHK(Ml)9Am^al1rNXyXHPnED6gjkv#KnDm9lxsW)(Z53i3c9d#J3C{bL|A^Z zaOiJd?~YCRD`yf*GI`SfR4?A~n{F3S=71?_wP2M9>4fD%krlwr(GJStz{eOIAe^ue z(h&xPS7%>Eq9Y!yzrPs38|nqbNKDZvpFIOi%V;oUnMB0LuTZ~fRNlj+!1fqE_1t`X ze5kNO(+dfJ9I+ zKutCS-`|Y;H|q)GBy59o&-An?)cJuWc7e&mA|`ANuU@^%$$km^tp}tluI0;w`-Li| zPzDCb0_(I@Kl$XfL}K)oH=1Rfi;QxgGfvmnFjFkE89);N1xRE?1n*u3qXMu2U3(M| zp6~+G^!-gtp9#0!If$xf4dK!bt4m^(1kVDU6 zuiVw_?d%r72$W&=`UnaYc$#%#z==TOm^H(`0#$zJ7NksLJk%|Pj|)cSp&SUk@4gy4 z>3T}ahrqyAJL&o9-@jD>b0g}uYic^szcb#LKOr2Z(VD>hi>_Up`^;$->R`+s0hV7x zVnSOE-%kWq^?vXaU!QDhVS~qGyPT3`FgyYNvC(J@29_{!YxsA*QpL+r1}G|$KnMUV z1D>x~vSbPPecA6>cmG{z7E`h}jka8P55SfxRjx-)k41q@V0+A(LH|eEuLF1vbiARFgtd2qsx2E|NmJ4x6P^+>rv?dO%Sp7!e2GimGJ2X^!cG>0e}f-%ZqUAxa?`xii=6?8wOabPD5*hLKMf(VN1=MLWWy2q1v z&?+h_&-VDcxV*86Z5+%`?Ro3@#VurN{OBjcI8zqyqmq&|2LKiM#)sEO$A&Y z3P6H+LcMXvSzP^Rbe6OsBYz1ReV7rW!5nCAP8*N9Mxz>PQ6N-2;AIUy#vc3=k+jcz z_i2uD`D=1~>M%nXa@DYYy;R=)zJKy`(n6!m6)ckrx)z83R!B>=s6BtW;~IyvN=-?T zw_znelR|)EY&;AfVcleACFEsrJ7>SUMw_f}K^>hTPKZIP&vl0Fz1gC(gk?~19*9gS}nla!> z{C~Px!<*Klcqg&85@li74!>*f|wevJB9i~P)Zzxt)it!y|BN^ZI+9YObF z7xP50h5iYk34l{$K~kHpoL;5>=#CPXhC9aTaD1!G>Z)ear!MVyxI_XlZ?2ZMBsdJ&8+ zT(Nc6qOVv_SU#e&wK&7HQ>&ygG6TCGWgU?QN^M5oWi>$`=odBl=FN)fX>~Mc;E)J6 z7+bb_OubjPTfAWgdJLghheT23?R~4Y0=i_x=?PG5cfe{TDkrvo+JifdaG9)BV$_L*4DN=p~}M;HOZ-E z2wY+4Hi)C# zUyu02D*Fz}dLI?4VAF3(8HAqH1&<&qF0OX=#@>zbbb1Xya-7tvUzry|lgQc2#!AKk z!@x;7?=DVn_-_-SV}U1BQBkqCKnpiReA34F|2}CPI1g|eAcI6gaDqo(;?{SMKuY!e zYJUzui^dl*W{ehBijlK<)e4W*!VM8aFopvYBw!E+`l)`)a(4I){7985Hu0A)J7Zv% ztyPv=`;dP(mg5SV{@_`;=pIx~EQf#qal)GT$_#9>(19ZQUKo;9DUo8Cw4XoByJdf5 zzfZZ7I~q!V>gtUGyNwfKpFlXkU3<9pTHtc7LW9ya#&4(ZmU)cl&=ks8RiIt&KDDlw)2SpEt*t99t>=u>&h|4f$QvkWV$#20fG zyvHzGg>A7pqiO55Z5Y?uCD5=iQ~c2^Po(ipkOQfV6J`#EGWQPWQ2*SvRZHGQmWl9q zke`!N3ZfR$ypia*T(B?0$TN;?r6hH%j;xTcokZR&i90{xTS6RZKuhAJU;bowGfj0h zUE`*jd&er!vY-~g!Hj5H7o2fLtOnH#LT;&DHJHAhQN=a&(tC}Zh4x?=gaS(N$U_O~ALkJ-l zP0p1YH*F%I35pTj@^BdBq60=m94vBQ*XWO4;htOHe_xS5--*EW{rh)W~x+lX}$gZ%>`q>-X;^)LW z2U-EH;$DA8niquevabBim0evDWGa|%R8}Rdvzzc7zI}7L%+3-~xHk5w?dLfFMcfiw zcCk15GozyqQ?D&fnY?!E#tj-?4K^LnS&nQ0NnQ9H3Tw<3qpIeP$w0pn)SVo^e1z*! z7t6)@|BjEX7Xy%h7a)NM!E_Ue9Y7c{4x6jc^L9KKI0_ZQL=paJ12=;!Cx{5ciz65AVSYn90*JY$>3tybADZZFsLo8-sN zMC*pzISD)S)~zKT&koHv)@L&*XaWNYYt>HSu)&6=d*~=me5`#pr~DR;6)q%acA%)2 z;25N2ho|#E(%7TMTDFlU>P*ZZfNmRDdzbeL{M1rY_xw1kfo|Z^zdm=GjsrK~&9+S5 z5Tv09#jH>FS&fNy^Gi)3e;OMblZt?5a$yN9s0U=4w_W-^Frb5n z$!^H%P)su+uCBxiAO?1P?CJ)P&Iq>dZY|@XJ{{J#(3M3=(teecqIT^)JKW;7D~f7( ztYAcAVi_GV8$-YJzp7wS&_ZHYSZ7}mT-98TLbm$y)Y#ag(n*vZS|{>NFtTHEoQ*s4 zZ8*DCW!ttT2**Urmf*?K;DA~v8B=uetv5Z zrwE)vyM54Di4(d}ZS1NP5AY;9qX@_KTA0khv`Xl{zsHP)%C}owc#HE(oA)T^9~?!k zkWg)Q%)){O<2hrk%NuuJY~q3Ot$L7lyY%T63niyE}c`}mipis z(HG~hC5blgkxd9H@0R|~+PY&$Bs#l8d{OALppXMgPaNZNP^R8AS})4K`a3t7D!OWw z%;!@E_$wU5d?FEFF@{qprWuK`Q~Y|A z>s-GgvLXoOGXgxYyme9ZT2vn{?(VNYeY$=-_rY!q89dK%`TDAVeAOJm_g>Xs1b~p2 z!mUfbRO{5V-UxGjF_}$+Dj}KYtWZ!0(TkMX!^fOGJq5A1xi6vAC;E;co?zr_5jgL1 zHP+-Z`!b$o;*XS%4GqS^TTE6d5Z`WCi3{&DU(qWsEVGf(>Ot?Xn{ zAQpuqBBmD>-HFAR6gmK9LlfV(_y?DE?d|{IuI6|A45z%CXv0C26!q;p*ICiLsJ5SV zhH<|o=9O-Dr6eJ8eBT@AY>HR80}ZQPc+G$a=utv`Br>AFZUZw7y#|!3nCezIvHs{! zFb-nt*4bl71C4kTBO5kl?Av(AMAXF&xNTRb_2OyHIof#C@%Zp3={}gkl3Kn?TF5u| zGd_u%IDd&q;polfWV#Oj9H+ME1ynpaqIy911XKf!U~;+}Ngr4gJAY{qy&S;o?%hzI z{dp7=F5n3W1{&ZT;j;71B=$HtXyomaO;`0Xt|ckNTXL=EP0wf=dO?Vv3R~EDPH2(f z3*!bkc0@T0_6cYab5-EFsuRu(D9Hi<2m3ooF-tD?QOU% z|BoCKam~l5Ag~*dCx9!m80v9_A2agFSU6bzADWwqLKWpE;!Iv|NJLc+M&5kayooI9 z8O2)Z9vK;VSIf7mxduZs1YwCXId}x7Hn{zuroq=;U1_Oxw=?`*_^L$|tVA2VRn?=* z!C4>aPuUFgNMLwOClF~8q~kptP)zuF+})j7-(QXeU+_rlMsS{oQF~`+;EDeCL+q`- zO3AetF$Mp{IQpeND?rL1sM)o^L(KV2j1aF8h;5TrB-&B-74Dut?4N0TDZ4kICyAo$ zHw)FBU}VK_$!E}fGh~|y(P1f%$^~CqQ(#WdYg(}q1J*XEWpT2zOGic&Nj5lLXHqtj zK{RC-EdZ^AkqY~Qb!K8G#%r*g!N{)MzD!jiYj<}0N4{?LWgy)E@v`5ZJR4=!GcrO! zI3sFQ+${J{6w9H4c1pwy%Bh6MRsu9KZmq)Z z60&)D_eB8C7`mh&@qF5~H$>%xxBcYKQ1$ch7}1>f3?@UR`oN=|v)uyDSP@l#$SF%O z%jqoe>iRgk1UZqBw0euV1(@!;Aku-ThEx-`=5EPm1bfiD5Dg+Glu$aeOpv8eXIXx7 zD<9XybHf*gX(2q0XWBfgVC881PCc18Qk=Ak;7p)f=Y02K@sENhN92eFOmz2)_lTYX z5FpA-@ZN~70CnUbQcP8PW&-3wh&woI9cOs(q)|buJGvUkd1#b`UXdK%#^3CI2e#4- zVU&p=1;E@UHX7a3qOOgX}JBl^N73fN2ZQY#jR=o7o}L8<9$nGM&)mNwPruD z8aESUFkp*)yWbuYgSe$Kr^hgkpzo4fsf!sXv^_CbntlKys6zD1Z1OJ3S%IWx*XHN< zP{tFZlNeGAdhNCks21%5&+%{jk+p%~XA54hr7j{U>Q;Ao!=HAR0z!19PvT(tKnP=0 zl9c%bH60!tFi88a6h}WP1C07&YAw{I@Z3ufElz%hC?IjM6|TEQqY}{_i_@&1zcVt5 zR&JLw_>_5IxO*d)OP|`YmV2XJ1|aM7xD*#pOIQ4ZTG+w-V~C+_0!>jANcN zTWe5x;Emx)VJkRm2ml3x-2>RRt*2B@WSR~gN$m&1@Or+UT(-F_)m!Uxt&OD!nl)8D zN?g2A(R!JR8E^D(x;?IYaqNl(@dD7!0YQq;LeQJLe7mRg zB#lp(8&=MEG^>3z6`~*Lv{Muv-iUyAkTLOTXhK_F^RN^R1>dH?$yVq2+`_`C1L)E3 zOH|Rr1i6i=3Y2jj`Zrhhl}g6(bN6sC_nZ99XKvjbCOV!kmo0<5|QXAqQ^b~;l zK~|j^gI~a$dv?zT$c`bJS_2O@eE#g~`F}r``0f@$m=lDd4uv^y@hjz#WN*`fofpVm z9fVZ*kCBlFFBC}s_ha!}Z~D)Ef;%JBl+9^xFtRut7+Cyc#<~5+lAY6~^AoMkw@zSN z^apnP%yCnhD5?jsske$POGc);r7wk6(CrH?FOG1n4K97^e!bn+()rWhWIUJ!|IrO# z9Ps|SopYKwPc84~x1a1s6kP>t;J0iE^86HZZ2olCKO0VxT=bv(|E%b%nECE?bERUD z6@Ts>c6(*_aFM3?0Ubv3VFu%P0QX!TVAM zZlsT7ssfqnb~wkY`@mf90h2uCYl#t*D_@pop0?glJe*7=#91oRB!f!sQ0wJ{9 z|8QjNW?RtT1p1qt*fpQd{Tg!YKMk_yA^Mg_uq^o%(EdjO@TdNN1J{4}?w7ouQIH}9 zOUTR`W;Q+ZXbAZDLe)6F+96H)9#u4WRDKt^bkDjArh~SM9ZE-@ALH(6hXpT+p-AqZ z&c;F$UJoYE%-z@)_;a&CTzBdtIg#881qHv54-GN{a3BGPvR=$h9dKJYIY1Kfi+#xvD3s{VC!+O0E~VmG}fsrFmke6giVwMX=1y@HT3hx6TT z1I{^Ib1dI^*zcaAY`lU~{w+sy?YzWD?2rYYf3@csB3jSR&K7AE{x5kn4Kk%8kZ6Go zFqMmmp8he-s7OrVBXnU$;XVIHe_T2ucaA#$60I1i`06uIcqvs691Ee%{W1P~pJ&N_ zo8CQA`BnLy+v`3F7#=;~I#gvUn=zk)@y2jH{xbIa)>Na+&Zmbl2fd8LF)}l}ND>yJ zl61&E?{RRHTgP{>dP5pZGQp6V;G6N`@go$Xm;)fZjDzIu@?H4q$3qnl+g{)Myw2{S zkWZni;QAV6A$mhX)}-IY_y$HcTbi4m9B8GST(5 ztTADL(F9vC)C3!bBJ!w%m2v)j&VO^UI>dNLObp;39~xVz2NH$DRYVz4Pvo0Ep8fnx zK5&0#?hy1MQp}$I+Ppyw0sh_~Z;Kl$$j_?}I$W#vv1Q5XGu&Q3GN6^A%X@PyOFlBWnPT5u=9~>IUhI z$_`&Bh5?U3J1xZA6zB?v`7_)-Ti(A0y%W0CwA>{Pudyd*PhHFr%O#lJ!nNy@ld=ZXWoLRL*!xB_4}eI+)XnDYtTVcPhi)wiDGHuh zuyKCj^}MbVYHdmDzR-AgTHerUFfG}5IDdRBMkXQ%YhdU7_Fy0Ks)VoXu^%`|f~El~ zUbI)1Ar)hO4kv9vT-?mCvO0rvKcLl>cI@EWMS(KH0#ua51UrVnK{Mi3Kv(Eu9OQxL z1C8aoH&B^ExmvuB_4BI=ybR}7XRzK&3-P})lQ9fg);zn_P<8bd3qRI!kj8Wv zGFk2AJ<3^GWS+3{z1Za80Omtpg4F)-Nv<9BtZ3SLm?f$AIzP82>#OXC*Gx z+PVsZ@zFpcPCf*(9(>^g{rHlqKwcisq@GFt(Bc)TYPthmF;?U2?ru21R2dr!p2ktj30O1ueS%jdlu;kQ zt2o2sQWV~AkbSwv+=^l>gx)uQsA8us+lRs1aD&_B*gMtq44$OfXUVhvwXJjG&37I?yt?50k!tqYv@%Jlsz9}E+g=Wzd%l0hR`sLo)OQa-!8K`5AM6|N?OoGL z)4i$SF;)?C?#fDS?HYZNh(v!+1OQCF$|fia-4xy(Xv%QhzgYIw(7CDwMmv};Gjl*q zn3F``sTATh#5mxt^^TT%F#d^_vm)q<)cyvXJ3!MOINg7`J4{_u^EKYg2m-)l$Fl{! z^}9kM=O2Gd^S3oV-=0&qD`ebgt{(0tStHx$ZRH(^~31W;JSYe>$ZN|X(W>Y1-7JpyD@WysEPDm?yS5@{w3Yq*3UBcvb1%P%KeQq zmA{KuFX=tR*=&(rP5*m;zZlMzb$hTex+VBtX`6>1Hu*>EU~_KYX)WM-#W_?`+qs^S)ENvfV?#GCb*>K-ni!L^hI;2yE-C#wj-^3u7TMiE<0d3ycO>xcctq)) z=+%7A79LYukzQeEyP{`%e5YX{O54LZ!iWUutzvq&LGknJ8bvoY%MxDT(!+>T1dlZEbycIaT%+M?)Xyz))n39|K8cK(k)$mi&VY#>-Bbw zKa!4s{;sTniTP;SE?5#~cp4t(*IA^)qMUx`X(=`3C#s|Bt;s8~TjmOdRt8*Q%4nZQ zMHMaovqDC<0{D^eJ=wwSF{?H;o%8a~=H!hQs!G9!Zhu9NqDHWrTnjYF)MccVq;sUL zER!`EA9l&)ZeSiEQ=Mp+|2ftt);c*d7zyrbd(Tux#XBb5F_GDI&5^xoi(&TdPmnzv z=qz|rbfdJUzShC=guHUZ_+6O=I1}ykIN|1pf?Ioy)w2_qZ_hAkHr)Rsal=`}Ze%l5 zksuRnl#?D{Bsx5t2buT9#2k&kGC6MF#)lY_Oh^zePnE)8(eyxijJ(%@INGIyZ*5KL zQiVRpp6(YOlQmjVtA?uO+Ml=TB4d2R<2M6u1Rtn5`(Aq?Tl#ylorqrTZu zNT{MQ-dUW(sg%h$Zg@P-WOcW?{BE)Vg$D4YL^3cu9z|K+^m<{2YQ&*Sf*YB7k6YdM zUF#dLhD(bT-+{%OxfRM|0)CtDy&58smJ}N3?J`}znUuqpHX@y4Ft%_w8XmIla$;4j zri@%F^N38wN}B$OU(XXvEN-pXwvu)^*hF?YO-!sRob)blY}R7Yo@}5|?{x^QxtMx4{X)y4gL6JN^zA~Exn6ZSzO#-3L2!A%B{FiB6>3sh z{J|&VjY!{(>kZx!~o7Oj5@6g?!FEn$tY1T<1B^M0O^!M>y{_@uXp2bQ@`&2iHNmqG7f)Dcw*78U1E|Os|9&cAl zyKrDR?JF}@*YJ1{CGHMOy#K`}_2|ef&gvzxizt2S@|B*J%U|)-j~kQ14`|Owd3NM= zdtD5VG=oGgXh}SOif>{CN%aHSa6tp@-|2(_E!9mS?EWA6ZJeWMYxW z;qY8scrnDp^_zO#0v$=_buzVL>C<{0V<9?&!C0Z)>V7SYV~CTxiOJ^|nO_T6yH>6l!f^_gRhfueoY);h;KvQE=7J=oPE>KQ97aemfV2z_rm zFRz3GeMigV`!=os)WvBeqA5?)Z(Vk2#(2_%#(ps26Ck8*ZK-%);d9Wsi={HG`Rh+k z?FkUtyMpV+iI36!d||}{qQZ3Jy4K@pe@RBL<;m*NJ=3SDQ_2SoAF~=&FGitfL(}KY zJem9#4Jxc*?u!OJUX%B)86MLDBGagEy>C}u(%){|*WlN)%DZ^!*_@PyQa zg~z(p!FW+OvejJ;?fJ)Wx_{VvObghv9^11ZDorI|rhMl!h-Bd>&M;cjb0JmBTa?I=qo|mfZOf`5oxTqtVSUcuf%;0r_3`YC35*e(jF!yfx<5E z=UbS@jJ@ouF}Qns^r6%JHLS)JBy*a+C8L=?LzPQnKiPmcC>HgOL3}j}+7sC?rz2n5 zT*%E+!g#GbMnY!@cPbH*3yn;2Fu#ABby~BYuSj(pc2qjcu!trnLc*~Ey0?x@F8<#e zo{c04=0Hmp$KuwGlWdl&mzI&C%mK3C>8p3fDf%3_nuy6M$H(ScFD1+b?&Mx9GL@x! zxIU%UJi0!7{GG_w5Wj?81y$adKJRi_ubUh5^DPI>e6&&9X9-!Tu27W!T44W~rnQri zIik^(6XKt3-*0$xtXLOcMjtkhaT|=7aghlRiRs(cAmg1^c0;bVX>MZ+Pf%K0)E9eZ|IDnwn(8Z& z-+q<%{oA4^R1xVCr8~azld2ghW%0$?#ai$<7fENia_fFmmw$Qa-~t^D@3joZ))eoX z0dj>|Eirv2fu^L^6ls#7+;3sJ!Kmh~MHkUh)z8=#Wv?i^cm3N>)g9{>4$2q!hp3@y%iUQ*PF>Y9#m$T&}2eZ3T{@f#QG^{d0v-ylCSDUN2ha&=+Doc#EyzOcay{UqqK{%oEfW10)N=- zpgdURU~UBa=$$sn8MfVirjhkZLY);!uzS(M$S6ns&VIih}I+D2#Z zLb*{>yX{=26t0@U*@EH4X;0qus2OHw=sX>y(DHrdv=t%_f7jfRVX8hPhPae+?$?eX zZA%_53qARSUb%Yt#j%GO1wYEJQfT9+t7=ly`;rpM=Sj2NQ4^QjUGU-B@~IjM zt?s8)NRY%HmI;TCl-e(Y$@#Uaj^=gbAe*P>Fsl)OBIGb8I~DKq&+mN0iX0S3mVQ9O OF9W)f-hG-)(EkHUs_~}) diff --git a/templates/template_base.html b/templates/template_base.html index 36056a37..77f8c2c6 100644 --- a/templates/template_base.html +++ b/templates/template_base.html @@ -25,6 +25,10 @@ {%block title %}{% endblock %}{% if self.title() %} | {% endif %}xemu: Original Xbox Emulator {% block append_head %}{% endblock %} + + + + - - - {% block append_foot %}{% endblock %} diff --git a/templates/template_index.html b/templates/template_index.html index 9e690173..b420683b 100644 --- a/templates/template_index.html +++ b/templates/template_index.html @@ -67,7 +67,7 @@ margin-right: 0.75em; } -canvas { +#logo-canvas { display: block; visibility: hidden; width: 256px; @@ -78,22 +78,44 @@ canvas { padding: 0; border: none; } + +#bg-scene { + height: 100%; + width: 100%; + position: absolute; + left: 0; + top: 0; +} + +.jumbotron { + position: relative; +} + +@media only screen and (min-width: 768px) +{ + .navbar-transparent + { + background-color: transparent !important; + transition: background-color 200ms linear; + } +} {% endblock %} {% block jumbotron %} -
+
+
-
+

- xemu logo + xemu logo

-

Original Xbox Emulator

+

Original Xbox Emulator

A free and open-source application that emulates the original Microsoft Xbox game console, enabling people to play their original Xbox games on @@ -103,21 +125,21 @@ canvas {

- Latest Release: v{{xemu_build_version}} ({{xemu_build_date.strftime('%b %-d, %Y')}}) + Latest release: v{{xemu_build_version}} ({{xemu_build_date.strftime('%b %-d, %Y')}})
@@ -126,18 +148,12 @@ canvas {
+
-
{% endblock %} {% block content %} -
- -
- -
-

Features

@@ -166,6 +182,10 @@ canvas {
+
+
+ +

@@ -201,8 +221,6 @@ canvas { {% endblock %} {% block append_foot %} - - + + + + + + + + + - + {% endblock %} diff --git a/theme.scss b/theme.scss index a05e967e..4ca5605c 100644 --- a/theme.scss +++ b/theme.scss @@ -1,6 +1,5 @@ // Your variable overrides /*$body-bg: #303030;*/ -$body-color: #A7A7A7; //////////////////////////////////////////////////////////////////////////////// @@ -21,9 +20,10 @@ $gray-600: #888 !default; $gray-700: #444 !default; $gray-800: #303030 !default; $gray-900: #222 !default; +$gray-1000: #111 !default; $black: #000 !default; -$xemu-logo-green: #42e335ff !default; +$xemu-logo-green: #62ca13ff !default; $blue: #375a7f !default; $indigo: #6610f2 !default; @@ -36,25 +36,25 @@ $green: #00bc8c !default; $teal: #20c997 !default; $cyan: #3498DB !default; -$primary: darken($xemu-logo-green, 10%) !default; +$primary: darken($xemu-logo-green, 5%) !default; $secondary: $gray-500 !default; $success: $green !default; $info: $cyan !default; $warning: $yellow !default; $danger: $red !default; $light: $gray-500 !default; -$dark: $gray-800 !default; +$dark: $gray-1000 !default; $yiq-contrasted-threshold: 175 !default; // Body $body-bg: $gray-900 !default; -$body-color: $white !default; +$body-color: $gray-400; // Links -$link-color: $gray-300 !default; +$link-color: $white !default; $link-hover-color: $white !default; // Fonts @@ -67,7 +67,7 @@ $h1-font-size: 3rem !default; $h2-font-size: 2.5rem !default; $h3-font-size: 2rem !default; -$text-muted: $gray-600 !default; +$text-muted: $gray-500 !default; // Tables @@ -142,7 +142,7 @@ $pagination-disabled-border-color: transparent !default; // Jumbotron -$jumbotron-bg: $gray-800 !default; +$jumbotron-bg: $gray-1000 !default; // Cards @@ -422,13 +422,6 @@ $web-font-path: "https://fonts.googleapis.com/css?family=Roboto:400,400italic&di } } -body { - background-image: url(xbox_duke.png); - background-position: -200px 40em; - background-size: 400px 311px; - background-repeat: no-repeat; -} - .btn-icon { padding-right: 0.5em; } @@ -445,3 +438,7 @@ body { .btn-secondary.focus { color: $gray-900; } + +.btn-green { + @include button-outline-variant(#82b540, $gray-900, #8dc103, #8dc103); +}