dealposbooks 5.47.0 → 5.48.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/3rdpartylicenses.txt +75 -26
- package/assets/images/users/user1_160.jpg +0 -0
- package/assets/images/users/user1_40.jpg +0 -0
- package/assets/images/users/user1_80.jpg +0 -0
- package/assets/scss/layouts/_sidebar.scss +0 -1
- package/{chunk-2MKKFLNJ.js → chunk-2BI7WNJP.js} +1 -1
- package/{chunk-OVEQKHUV.js → chunk-2H7KQZEC.js} +2 -2
- package/{chunk-XT4YHL2M.js → chunk-2JNXKEYZ.js} +1 -1
- package/{chunk-53HJBLFX.js → chunk-2VZ7JZIO.js} +1 -1
- package/{chunk-YFNWEI3R.js → chunk-2XW2ZOT4.js} +1 -1
- package/{chunk-E4MHRZVH.js → chunk-3DBSHDAQ.js} +1 -1
- package/{chunk-MT3DTYJO.js → chunk-3NWFEFT2.js} +1 -1
- package/{chunk-JOHRJHEX.js → chunk-3UAQHNUY.js} +1 -1
- package/{chunk-3A4BFUGD.js → chunk-3VQUNDVT.js} +1 -1
- package/{chunk-CL4EKWSU.js → chunk-4LI7GDDM.js} +1 -1
- package/chunk-52U5NSQT.js +2 -0
- package/{chunk-VK3G2VIU.js → chunk-5B5AMMR3.js} +1 -1
- package/{chunk-5K3KAKU5.js → chunk-5FV7K5RQ.js} +1 -1
- package/{chunk-6NX36ZC2.js → chunk-6DTQWLB3.js} +1 -1
- package/chunk-6GQ4PTPT.js +7 -0
- package/chunk-6QJHEOXN.js +7 -0
- package/chunk-6WWXJJID.js +1 -0
- package/chunk-72H3DW5Z.js +1 -0
- package/{chunk-L2524E6T.js → chunk-7OP477BS.js} +1 -1
- package/{chunk-EIV4TELQ.js → chunk-7WCUKMRG.js} +1 -1
- package/{chunk-XDJSQLQN.js → chunk-ACDLAA4B.js} +1 -1
- package/{chunk-BUDZ3ONE.js → chunk-AD247LWQ.js} +1 -1
- package/{chunk-HQMTUZZQ.js → chunk-AMGBUOC4.js} +1 -1
- package/{chunk-CWFLUFKM.js → chunk-AN4SAUSA.js} +1 -1
- package/{chunk-KIBBRAL5.js → chunk-ARJ7OCQO.js} +1 -1
- package/{chunk-EEJGJ7WF.js → chunk-B3VZ2ZHJ.js} +1 -1
- package/{chunk-5BXMDXZD.js → chunk-B4C3ZPN6.js} +1 -1
- package/{chunk-WFIXL354.js → chunk-BG6BR7KI.js} +1 -1
- package/chunk-BKTBVFNX.js +1 -0
- package/chunk-BNPR5SPH.js +1 -0
- package/chunk-BT7Y4ADP.js +1 -0
- package/{chunk-5YO43YBO.js → chunk-CEK7MQW2.js} +1 -1
- package/chunk-CVDRHTES.js +1 -0
- package/{chunk-IYFNOI7S.js → chunk-CZSVRFCL.js} +1 -1
- package/chunk-D6IS6PE6.js +1 -0
- package/{chunk-GDQUB54I.js → chunk-DDM2KWNX.js} +1 -1
- package/{chunk-Q7SK53ST.js → chunk-DJXQKSLT.js} +1 -1
- package/chunk-DSZOROE6.js +1 -0
- package/{chunk-2D2YD753.js → chunk-DTYVTTET.js} +1 -1
- package/{chunk-PTQPB44D.js → chunk-E6SW7I4D.js} +1 -1
- package/{chunk-NDLX3ORI.js → chunk-E7QWESN4.js} +1 -1
- package/{chunk-CNXYBR45.js → chunk-ENH6HA3V.js} +1 -1
- package/{chunk-6XE7LGUS.js → chunk-EQTP2O7O.js} +1 -1
- package/{chunk-NHHXXJY6.js → chunk-F3RSX7TC.js} +1 -1
- package/{chunk-3IEOINKV.js → chunk-F6LZM7H5.js} +1 -1
- package/{chunk-AOOG6YOT.js → chunk-F7PVAVLQ.js} +1 -1
- package/{chunk-BXEGWIR3.js → chunk-F7XGJYCZ.js} +1 -1
- package/{chunk-53I5JFOQ.js → chunk-FSB3LHPU.js} +1 -1
- package/{chunk-S3FQPUAS.js → chunk-FUCKNGW4.js} +1 -1
- package/{chunk-AHX56FH2.js → chunk-FVYL3BQ7.js} +1 -1
- package/{chunk-5SYYPB6N.js → chunk-G42V3ZZU.js} +1 -1
- package/{chunk-C3IOIS5V.js → chunk-H7GQCGCR.js} +1 -1
- package/{chunk-F5CCLXIY.js → chunk-IDHDHBFV.js} +1 -1
- package/{chunk-JZVNZ3I3.js → chunk-JD3HX7VY.js} +1 -1
- package/{chunk-DEOAL7PG.js → chunk-JE4XET33.js} +1 -1
- package/{chunk-VSHPIUZM.js → chunk-KZHI6PGZ.js} +1 -1
- package/{chunk-PXN4RATH.js → chunk-LBREDZL5.js} +1 -1
- package/{chunk-35UWKNGE.js → chunk-LCKRY7CZ.js} +1 -1
- package/{chunk-SZAGTA5I.js → chunk-LXLOWSN6.js} +1 -1
- package/{chunk-YZTBV6HG.js → chunk-M4SSELXT.js} +1 -1
- package/{chunk-IMVMIXVJ.js → chunk-ME4ALIS7.js} +1 -1
- package/{chunk-LABWETHZ.js → chunk-MHRSQRHT.js} +1 -1
- package/{chunk-CWDU4F7J.js → chunk-NNNKDAA2.js} +1 -1
- package/{chunk-DRTMMJ4Q.js → chunk-NPXVSAMB.js} +1 -1
- package/chunk-O76TW6JA.js +1 -0
- package/{chunk-U5XXKH2H.js → chunk-OJTHBHGK.js} +1 -1
- package/{chunk-RZFXAB7W.js → chunk-OT3UFDBI.js} +1 -1
- package/chunk-OVDG3ZBT.js +1 -0
- package/{chunk-Q4LKKVQU.js → chunk-PGOSR3RI.js} +1 -1
- package/{chunk-XPRP6AB4.js → chunk-PPXXWO4E.js} +1 -1
- package/{chunk-ML5KV2U2.js → chunk-PQL4GCC5.js} +1 -1
- package/{chunk-QWTGY7FA.js → chunk-QPPFPDWZ.js} +1 -1
- package/{chunk-EQU7DDK6.js → chunk-RE5GBQH6.js} +1 -1
- package/{chunk-PKOERZXQ.js → chunk-RM5HLXNW.js} +1 -1
- package/{chunk-NM5M567G.js → chunk-RXR5DXWS.js} +1 -1
- package/{chunk-ZUDQOT7C.js → chunk-S27Z7D3D.js} +1 -1
- package/{chunk-GJYEM7DL.js → chunk-S2BFXF7C.js} +1 -1
- package/{chunk-DTFLX2XQ.js → chunk-SFMFIWMX.js} +1 -1
- package/{chunk-OLLF6BKH.js → chunk-SUXEBUIX.js} +1 -1
- package/chunk-SV6BE4HG.js +130 -0
- package/{chunk-SEXB43QC.js → chunk-T367AQJ2.js} +1 -1
- package/{chunk-SS4J7T3N.js → chunk-TOGXYKTE.js} +1 -1
- package/{chunk-IGWIRCAS.js → chunk-U2VDC52W.js} +1 -1
- package/{chunk-OW25MQS7.js → chunk-UEFTMQDF.js} +1 -1
- package/{chunk-4X3G6MGP.js → chunk-UI2UMYSE.js} +1 -1
- package/{chunk-RXOOTYEO.js → chunk-UPSNJEHO.js} +1 -1
- package/{chunk-LWYAFMN3.js → chunk-URH77XNK.js} +1 -1
- package/{chunk-HZ7BZ72K.js → chunk-UVSR4LPB.js} +1 -1
- package/{chunk-AXU3K2IY.js → chunk-V22QPBAO.js} +1 -1
- package/{chunk-T3EH4DR2.js → chunk-VDXZGF3M.js} +1 -1
- package/{chunk-ZBO62XAM.js → chunk-VKT27VPR.js} +2 -2
- package/{chunk-OIBDX2CA.js → chunk-VMI3QWC6.js} +1 -1
- package/{chunk-VTCV67A4.js → chunk-VVAI7ZGN.js} +1 -1
- package/{chunk-6PNHT5U7.js → chunk-VW2FJYIZ.js} +1 -1
- package/{chunk-VL2HEHI5.js → chunk-W5E37PZP.js} +1 -1
- package/chunk-W63NE6LU.js +229 -0
- package/{chunk-OJ2VC4ER.js → chunk-WKHQICFW.js} +1 -1
- package/{chunk-DHLFL3KH.js → chunk-WMZF4DQK.js} +1 -1
- package/{chunk-ETFYQ4GV.js → chunk-WOYTUHJD.js} +1 -1
- package/{chunk-WPMC3LJJ.js → chunk-WPJGKTVO.js} +5 -5
- package/{chunk-ZMIVD3SF.js → chunk-WXIG4CXY.js} +1 -1
- package/{chunk-Q47KHO2M.js → chunk-XCTUTMD3.js} +1 -1
- package/{chunk-MBJKUKHJ.js → chunk-XOSALV7T.js} +1 -1
- package/{chunk-RF27SIL3.js → chunk-Y7SF5NXD.js} +1 -1
- package/{chunk-DU72RNAU.js → chunk-YPOBALKC.js} +1 -1
- package/{chunk-V4SH72WU.js → chunk-ZFNIPERQ.js} +1 -1
- package/chunk-ZK43JB4A.js +2 -0
- package/{chunk-5JZTWUDG.js → chunk-ZQWFATZY.js} +1 -1
- package/index.html +2 -2
- package/main-XTOQBEFQ.js +1 -0
- package/package.json +1 -1
- package/{styles-4HAX3IDP.css → styles-4L5CAR46.css} +1 -1
- package/chunk-2RNKYO2Q.js +0 -1
- package/chunk-5CZNOXPC.js +0 -1
- package/chunk-5HZBSMCT.js +0 -7
- package/chunk-6ZZZTNIH.js +0 -130
- package/chunk-EPLZY6T4.js +0 -1
- package/chunk-M3TKVRYP.js +0 -1
- package/chunk-NMCKMUY4.js +0 -7
- package/chunk-QF4D5YPK.js +0 -1
- package/chunk-SN7DLFX2.js +0 -1
- package/chunk-TUFQ5JVG.js +0 -180
- package/chunk-V4B5LQYD.js +0 -2
- package/chunk-VZ5CMS5O.js +0 -2
- package/chunk-WGJFR6CK.js +0 -1
- package/main-Q2T6QX2N.js +0 -1
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{a as It,b as Ce}from"./chunk-YQFG5XE2.js";var Js,_i,si;(X=ao||(ao={})).SVG_NS="http://www.w3.org/2000/svg",X.product="Highcharts",X.version="12.4.0",X.win=typeof window<"u"?window:{},X.doc=X.win.document,X.svg=!!X.doc?.createElementNS?.(X.SVG_NS,"svg")?.createSVGRect,X.pageLang=X.doc?.documentElement?.closest("[lang]")?.lang,X.userAgent=X.win.navigator?.userAgent||"",X.isChrome=X.win.chrome,X.isFirefox=X.userAgent.indexOf("Firefox")!==-1,X.isMS=/(edge|msie|trident)/i.test(X.userAgent)&&!X.win.opera,X.isSafari=!X.isChrome&&X.userAgent.indexOf("Safari")!==-1,X.isTouchDevice=/(Mobile|Android|Windows Phone)/.test(X.userAgent),X.isWebKit=X.userAgent.indexOf("AppleWebKit")!==-1,X.deg2rad=2*Math.PI/360,X.marginNames=["plotTop","marginRight","marginBottom","plotLeft"],X.noop=function(){},X.supportsPassiveEvents=function(){let h=!1;if(!X.isMS){let t=Object.defineProperty({},"passive",{get:function(){h=!0}});X.win.addEventListener&&X.win.removeEventListener&&(X.win.addEventListener("testPassive",X.noop,t),X.win.removeEventListener("testPassive",X.noop,t))}return h}(),X.charts=[],X.composed=[],X.dateFormats={},X.seriesTypes={},X.symbolSizes={},X.chartCount=0;var P=ao,{charts:fn,doc:Xi,win:oe}=P;function qe(h,t,e,i){let s=t?"Highcharts error":"Highcharts warning";h===32&&(h=`${s}: Deprecated member`);let o=to(h),r=o?`${s} #${h}: www.highcharts.com/errors/${h}/`:h.toString();if(i!==void 0){let a="";o&&(r+="?"),re(i,function(n,l){a+=`
|
|
2
|
+
- ${l}: ${n}`,o&&(r+=encodeURI(l)+"="+encodeURI(n))}),r+=a}Ya(P,"displayError",{chart:e,code:h,message:r,params:i},function(){if(t)throw Error(r);oe.console&&qe.messages.indexOf(r)===-1&&console.warn(r)}),qe.messages.push(r)}function No(h,t){return parseInt(h,t||10)}function Ke(h){return typeof h=="string"}function Hi(h){let t=Object.prototype.toString.call(h);return t==="[object Array]"||t==="[object Array Iterator]"}function xe(h,t){return!!h&&typeof h=="object"&&(!t||!Hi(h))}function Qs(h){return xe(h)&&typeof h.nodeType=="number"}function zo(h){let t=h?.constructor;return!!(xe(h,!0)&&!Qs(h)&&t?.name&&t.name!=="Object")}function to(h){return typeof h=="number"&&!isNaN(h)&&h<1/0&&h>-1/0}function ye(h){return h!=null}function Fa(h,t,e){let i,s=Ke(t)&&!ye(e),o=(r,a)=>{ye(r)?h.setAttribute(a,r):s?(i=h.getAttribute(a))||a!=="class"||(i=h.getAttribute(a+"Name")):h.removeAttribute(a)};return Ke(t)?o(e,t):re(t,o),i}function Ro(h){return Hi(h)?h:[h]}function ke(h,t){let e;for(e in h||(h={}),t)h[e]=t[e];return h}function Ae(){let h=arguments,t=h.length;for(let e=0;e<t;e++){let i=h[e];if(i!=null)return i}}function Ji(h,t){ke(h.style,t)}function Wo(h){return Math.pow(10,Math.floor(Math.log(h)/Math.LN10))}function Xo(h,t){return h>1e14?h:parseFloat(h.toPrecision(t||14))}(qe||(qe={})).messages=[],Math.easeInOutSine=function(h){return-.5*(Math.cos(Math.PI*h)-1)};var mn=Array.prototype.find?function(h,t){return h.find(t)}:function(h,t){let e,i=h.length;for(e=0;e<i;e++)if(t(h[e],e))return h[e]};function re(h,t,e){for(let i in h)Object.hasOwnProperty.call(h,i)&&t.call(e||h[i],h[i],i,h)}function Ho(h,t,e){function i(r,a){let n=h.removeEventListener;n&&n.call(h,r,a,!1)}function s(r){let a,n;h.nodeName&&(t?(a={})[t]=!0:a=r,re(a,function(l,c){if(r[c])for(n=r[c].length;n--;)i(c,r[c][n].fn)}))}let o=typeof h=="function"&&h.prototype||h;if(Object.hasOwnProperty.call(o,"hcEvents")){let r=o.hcEvents;if(t){let a=r[t]||[];e?(r[t]=a.filter(function(n){return e!==n.fn}),i(t,e)):(s(r),r[t]=[])}else s(r),delete o.hcEvents}}function Ya(h,t,e,i){if(e=e||{},Xi?.createEvent&&(h.dispatchEvent||h.fireEvent&&h!==P)){let s=Xi.createEvent("Events");s.initEvent(t,!0,!0),e=ke(s,e),h.dispatchEvent?h.dispatchEvent(e):h.fireEvent(t,e)}else if(h.hcEvents){e.target||ke(e,{preventDefault:function(){e.defaultPrevented=!0},target:h,type:t});let s=[],o=h,r=!1;for(;o.hcEvents;)Object.hasOwnProperty.call(o,"hcEvents")&&o.hcEvents[t]&&(s.length&&(r=!0),s.unshift.apply(s,o.hcEvents[t])),o=Object.getPrototypeOf(o);r&&s.sort((a,n)=>a.order-n.order),s.forEach(a=>{a.fn.call(h,e)===!1&&e.preventDefault()})}i&&!e.defaultPrevented&&i.call(h,e)}var xn=function(){let h=Math.random().toString(36).substring(2,9)+"-",t=0;return function(){return"highcharts-"+(Js?"":h)+t++}}();oe.jQuery&&(oe.jQuery.fn.highcharts=function(){let h=[].slice.call(arguments);if(this[0])return h[0]?(new P[Ke(h[0])?h.shift():"Chart"](this[0],h[0],h[1]),this):fn[Fa(this[0],"data-highcharts-chart")]});var N={addEvent:function(h,t,e,i={}){let s=typeof h=="function"&&h.prototype||h;Object.hasOwnProperty.call(s,"hcEvents")||(s.hcEvents={});let o=s.hcEvents;P.Point&&h instanceof P.Point&&h.series&&h.series.chart&&(h.series.chart.runTrackerClick=!0);let r=h.addEventListener;r&&r.call(h,t,e,!!P.supportsPassiveEvents&&{passive:i.passive===void 0?t.indexOf("touch")!==-1:i.passive,capture:!1}),o[t]||(o[t]=[]);let a={fn:e,order:typeof i.order=="number"?i.order:1/0};return o[t].push(a),o[t].sort((n,l)=>n.order-l.order),function(){Ho(h,t,e)}},arrayMax:function(h){let t=h.length,e=h[0];for(;t--;)h[t]>e&&(e=h[t]);return e},arrayMin:function(h){let t=h.length,e=h[0];for(;t--;)h[t]<e&&(e=h[t]);return e},attr:Fa,clamp:function(h,t,e){return h>t?h<e?h:e:t},clearTimeout:function(h){ye(h)&&clearTimeout(h)},correctFloat:Xo,createElement:function(h,t,e,i,s){let o=Xi.createElement(h);return t&&ke(o,t),s&&Ji(o,{padding:"0",border:"none",margin:"0"}),e&&Ji(o,e),i&&i.appendChild(o),o},crisp:function(h,t=0,e){let i=t%2/2,s=e?-1:1;return(Math.round(h*s-i)+i)*s},css:Ji,defined:ye,destroyObjectProperties:function(h,t,e){re(h,function(i,s){i!==t&&i?.destroy&&i.destroy(),(i?.destroy||!e)&&delete h[s]})},diffObjects:function(h,t,e,i){let s={};return function o(r,a,n,l){let c=e?a:r;re(r,function(d,p){if(!l&&i&&i.indexOf(p)>-1&&a[p]){d=Ro(d),n[p]=[];for(let g=0;g<Math.max(d.length,a[p].length);g++)a[p][g]&&(d[g]===void 0?n[p][g]=a[p][g]:(n[p][g]={},o(d[g],a[p][g],n[p][g],l+1)))}else xe(d,!0)&&!d.nodeType?(n[p]=Hi(d)?[]:{},o(d,a[p]||{},n[p],l+1),Object.keys(n[p]).length===0&&(p!=="colorAxis"||l!==0)&&delete n[p]):(r[p]!==a[p]||p in r&&!(p in a))&&p!=="__proto__"&&p!=="constructor"&&(n[p]=c[p])})}(h,t,s,0),s},discardElement:function(h){h?.parentElement?.removeChild(h)},erase:function(h,t){let e=h.length;for(;e--;)if(h[e]===t){h.splice(e,1);break}},error:qe,extend:ke,extendClass:function(h,t){let e=function(){};return e.prototype=new h,ke(e.prototype,t),e},find:mn,fireEvent:Ya,getAlignFactor:(h="")=>({center:.5,right:1,middle:.5,bottom:1})[h]||0,getClosestDistance:function(h,t){let e,i,s,o,r=!t;return h.forEach(a=>{if(a.length>1)for(o=i=a.length-1;o>0;o--)(s=a[o]-a[o-1])<0&&!r?(t?.(),t=void 0):s&&(e===void 0||s<e)&&(e=s)}),e},getMagnitude:Wo,getNestedProperty:function(h,t){let e=h.split(".");for(;e.length&&ye(t);){let i=e.shift();if(i===void 0||i==="__proto__")return;if(i==="this"){let o;return xe(t)&&(o=t["@this"]),o??t}let s=t[i.replace(/[\\'"]/g,"")];if(!ye(s)||typeof s=="function"||typeof s.nodeType=="number"||s===oe)return;t=s}return t},getStyle:function h(t,e,i){let s;if(e==="width"){let r=Math.min(t.offsetWidth,t.scrollWidth),a=t.getBoundingClientRect?.().width;return a<r&&a>=r-1&&(r=Math.floor(a)),Math.max(0,r-(h(t,"padding-left",!0)||0)-(h(t,"padding-right",!0)||0))}if(e==="height")return Math.max(0,Math.min(t.offsetHeight,t.scrollHeight)-(h(t,"padding-top",!0)||0)-(h(t,"padding-bottom",!0)||0));let o=oe.getComputedStyle(t,void 0);return o&&(s=o.getPropertyValue(e),Ae(i,e!=="opacity")&&(s=No(s))),s},insertItem:function(h,t){let e,i=h.options.index,s=t.length;for(e=h.options.isInternal?s:0;e<s+1;e++)if(!t[e]||to(i)&&i<Ae(t[e].options.index,t[e]._i)||t[e].options.isInternal){t.splice(e,0,h);break}return e},isArray:Hi,isClass:zo,isDOMElement:Qs,isFunction:function(h){return typeof h=="function"},isNumber:to,isObject:xe,isString:Ke,merge:function(h,...t){let e,i=[h,...t],s={},o=function(a,n){return typeof a!="object"&&(a={}),re(n,function(l,c){c!=="__proto__"&&c!=="constructor"&&(!xe(l,!0)||zo(l)||Qs(l)?a[c]=n[c]:a[c]=o(a[c]||{},l))}),a};h===!0&&(s=i[1],i=Array.prototype.slice.call(i,2));let r=i.length;for(e=0;e<r;e++)s=o(s,i[e]);return s},normalizeTickInterval:function(h,t,e,i,s){let o,r=h;e=Ae(e,Wo(h));let a=h/e;for(!t&&(t=s?[1,1.2,1.5,2,2.5,3,4,5,6,8,10]:[1,2,2.5,5,10],i===!1&&(e===1?t=t.filter(function(n){return n%1==0}):e<=.1&&(t=[1/e]))),o=0;o<t.length&&(r=t[o],(!s||!(r*e>=h))&&(s||!(a<=(t[o]+(t[o+1]||t[o]))/2)));o++);return Xo(r*e,-Math.round(Math.log(.001)/Math.LN10))},objectEach:re,offset:function(h){let t=Xi.documentElement,e=h.parentElement||h.parentNode?h.getBoundingClientRect():{top:0,left:0,width:0,height:0};return{top:e.top+(oe.pageYOffset||t.scrollTop)-(t.clientTop||0),left:e.left+(oe.pageXOffset||t.scrollLeft)-(t.clientLeft||0),width:e.width,height:e.height}},pad:function(h,t,e){return Array((t||2)+1-String(h).replace("-","").length).join(e||"0")+h},pick:Ae,pInt:No,pushUnique:function(h,t){return 0>h.indexOf(t)&&!!h.push(t)},relativeLength:function(h,t,e){return/%$/.test(h)?t*parseFloat(h)/100+(e||0):parseFloat(h)},removeEvent:Ho,replaceNested:function(h,...t){let e,i;do for(i of(e=h,t))h=h.replace(i[0],i[1]);while(h!==e);return h},splat:Ro,stableSort:function(h,t){let e,i,s=h.length;for(i=0;i<s;i++)h[i].safeI=i;for(h.sort(function(o,r){return(e=t(o,r))===0?o.safeI-r.safeI:e}),i=0;i<s;i++)delete h[i].safeI},syncTimeout:function(h,t,e){return t>0?setTimeout(h,t,e):(h.call(0,e),-1)},timeUnits:{millisecond:1,second:1e3,minute:6e4,hour:36e5,day:864e5,week:6048e5,month:24192e5,year:314496e5},ucfirst:function(h){return Ke(h)?h.substring(0,1).toUpperCase()+h.substring(1):String(h)},uniqueKey:xn,useSerialIds:function(h){return Js=Ae(h,Js)},wrap:function(h,t,e){let i=h[t];h[t]=function(){let s=arguments,o=this;return e.apply(this,[function(){return i.apply(o,arguments.length?arguments:s)}].concat([].slice.call(arguments)))}}},{pageLang:yn,win:Fi}=P,{defined:Fo,error:Yo,extend:Qi,isNumber:Go,isObject:ts,isString:Pe,merge:bn,objectEach:vn,pad:Wt,splat:kn,timeUnits:es,ucfirst:wn}=N,Mn=P.isSafari&&Fi.Intl&&!Fi.Intl.DateTimeFormat.prototype.formatRange,Sn=h=>h.main===void 0,Tn=class{constructor(h,t){this.options={timezone:"UTC"},this.variableTimezone=!1,this.Date=Fi.Date,this.update(h),this.lang=t}update(h={}){this.dTLCache={},this.options=h=bn(!0,this.options,h);let{timezoneOffset:t,useUTC:e,locale:i}=h;this.Date=h.Date||Fi.Date||Date;let s=h.timezone;Fo(e)&&(s=e?"UTC":void 0),t&&t%60==0&&(s="Etc/GMT"+(t>0?"+":"")+t/60),this.variableTimezone=s!=="UTC"&&s?.indexOf("Etc/GMT")!==0,this.timezone=s,this.lang&&i&&(this.lang.locale=i),["months","shortMonths","weekdays","shortWeekdays"].forEach(o=>{let r=/months/i.test(o),a=/short/.test(o),n={timeZone:"UTC"};n[r?"month":"weekday"]=a?"short":"long",this[o]=(r?[0,1,2,3,4,5,6,7,8,9,10,11]:[3,4,5,6,7,8,9]).map(l=>this.dateFormat(n,(r?31:1)*24*36e5*l))})}toParts(h){let[t,e,i,s,o,r,a]=this.dateTimeFormat({weekday:"narrow",day:"numeric",month:"numeric",year:"numeric",hour:"numeric",minute:"numeric",second:"numeric"},h,"es").split(/(?:, | |\/|:)/g);return[s,i-1,e,o,r,a,Math.floor(Number(h)||0)%1e3,"DLMXJVS".indexOf(t)].map(Number)}dateTimeFormat(h,t,e=this.options.locale||yn){let i=JSON.stringify(h)+e;Pe(h)&&(h=this.str2dtf(h));let s=this.dTLCache[i];if(!s){h.timeZone??(h.timeZone=this.timezone);try{s=new Intl.DateTimeFormat(e,h)}catch(o){/Invalid time zone/i.test(o.message)?(Yo(34),h.timeZone="UTC",s=new Intl.DateTimeFormat(e,h)):Yo(o.message,!1)}}return this.dTLCache[i]=s,s?.format(t)||""}str2dtf(h,t={}){let e={L:{fractionalSecondDigits:3},S:{second:"2-digit"},M:{minute:"numeric"},H:{hour:"2-digit"},k:{hour:"numeric"},E:{weekday:"narrow"},a:{weekday:"short"},A:{weekday:"long"},d:{day:"2-digit"},e:{day:"numeric"},b:{month:"short"},B:{month:"long"},m:{month:"2-digit"},o:{month:"numeric"},y:{year:"2-digit"},Y:{year:"numeric"}};return Object.keys(e).forEach(i=>{h.indexOf(i)!==-1&&Qi(t,e[i])}),t}makeTime(h,t,e=1,i=0,s,o,r){let a=this.Date.UTC(h,t,e,i,s||0,o||0,r||0);if(this.timezone!=="UTC"){let n=this.getTimezoneOffset(a);if(a+=n,[2,3,8,9,10,11].indexOf(t)!==-1&&(i<5||i>20)){let l=this.getTimezoneOffset(a);n!==l?a+=l-n:n-36e5!==this.getTimezoneOffset(a-36e5)||Mn||(a-=36e5)}}return a}parse(h){if(!Pe(h))return h??void 0;let t=(h=h.replace(/\//g,"-").replace(/(GMT|UTC)/,"")).indexOf("Z")>-1||/([+-][0-9]{2}):?[0-9]{2}$/.test(h),e=/^[0-9]{4}-[0-9]{2}(-[0-9]{2}|)$/.test(h);t||e||(h+="Z");let i=Date.parse(h);if(Go(i))return i+(!t||e?this.getTimezoneOffset(i):0)}getTimezoneOffset(h){if(this.timezone!=="UTC"){let[t,e,i,s,o=0]=this.dateTimeFormat({timeZoneName:"shortOffset"},h,"en").split(/(GMT|:)/).map(Number),r=-(60*(i+o/60)*6e4);if(Go(r))return r}return 0}dateFormat(h,t,e){let i=this.lang;if(!Fo(t)||isNaN(t))return i?.invalidDate||"";if(Pe(h=h??"%Y-%m-%d %H:%M:%S")){let s,o=/%\[([a-zA-Z]+)\]/g;for(;s=o.exec(h);)h=h.replace(s[0],this.dateTimeFormat(s[1],t,i?.locale))}if(Pe(h)&&h.indexOf("%")!==-1){let s=this,[o,r,a,n,l,c,d,p]=this.toParts(t),g=i?.weekdays||this.weekdays,u=i?.shortWeekdays||this.shortWeekdays,x=i?.months||this.months,m=i?.shortMonths||this.shortMonths;vn(Qi({a:u?u[p]:g[p].substr(0,3),A:g[p],d:Wt(a),e:Wt(a,2," "),w:p,v:i?.weekFrom??"",b:m[r],B:x[r],m:Wt(r+1),o:r+1,y:o.toString().substr(2,2),Y:o,H:Wt(n),k:n,I:Wt(n%12||12),l:n%12||12,M:Wt(l),p:n<12?"AM":"PM",P:n<12?"am":"pm",S:Wt(c),L:Wt(d,3)},P.dateFormats),function(f,y){if(Pe(h))for(;h.indexOf("%"+y)!==-1;)h=h.replace("%"+y,typeof f=="function"?f.call(s,t):f)})}else if(ts(h)){let s=(this.getTimezoneOffset(t)||0)/36e5,o=this.timezone||"Etc/GMT"+(s>=0?"+":"")+s,{prefix:r="",suffix:a=""}=h;h=r+this.dateTimeFormat(Qi({timeZone:o},h),t)+a}return e?wn(h):h}resolveDTLFormat(h){return ts(h,!0)?ts(h,!0)&&Sn(h)?{main:h}:h:{main:(h=kn(h))[0],from:h[1],to:h[2]}}getDateFormat(h,t,e,i){let s=this.dateFormat("%m-%d %H:%M:%S.%L",t),o="01-01 00:00:00.000",r={millisecond:15,second:12,minute:9,hour:6,day:3},a="millisecond",n=a;for(a in es){if(h&&h===es.week&&+this.dateFormat("%w",t)===e&&s.substr(6)===o.substr(6)){a="week";break}if(h&&es[a]>h){a=n;break}if(r[a]&&s.substr(r[a])!==o.substr(r[a]))break;a!=="week"&&(n=a)}return this.resolveDTLFormat(i[a]).main}},{defined:jo,extend:Cn,timeUnits:et}=N,Eo=class extends Tn{getTimeTicks(h,t,e,i){let s=this,o=[],r={},{count:a=1,unitRange:n}=h,[l,c,d,p,g,u]=s.toParts(t),x=(t||0)%1e3,m;if(i??(i=1),jo(t)){if(x=n>=et.second?0:a*Math.floor(x/a),n>=et.second&&(u=n>=et.minute?0:a*Math.floor(u/a)),n>=et.minute&&(g=n>=et.hour?0:a*Math.floor(g/a)),n>=et.hour&&(p=n>=et.day?0:a*Math.floor(p/a)),n>=et.day&&(d=n>=et.month?1:Math.max(1,a*Math.floor(d/a))),n>=et.month&&(c=n>=et.year?0:a*Math.floor(c/a)),n>=et.year&&(l-=l%a),n===et.week){a&&(t=s.makeTime(l,c,d,p,g,u,x));let b=this.dateTimeFormat({timeZone:this.timezone,weekday:"narrow"},t,"es"),v="DLMXJVS".indexOf(b);d+=-v+i+(v<i?-7:0)}t=s.makeTime(l,c,d,p,g,u,x),s.variableTimezone&&jo(e)&&(m=e-t>4*et.month||s.getTimezoneOffset(t)!==s.getTimezoneOffset(e));let f=t,y=1;for(;f<e;)o.push(f),n===et.year?f=s.makeTime(l+y*a,0):n===et.month?f=s.makeTime(l,c+y*a):m&&(n===et.day||n===et.week)?f=s.makeTime(l,c,d+y*a*(n===et.day?1:7)):m&&n===et.hour&&a>1?f=s.makeTime(l,c,d,p+y*a):f+=n*a,y++;o.push(f),n<=et.hour&&o.length<1e4&&o.forEach(b=>{b%18e5==0&&s.dateFormat("%H%M%S%L",b)==="000000000"&&(r[b]="day")})}return o.info=Cn(h,{higherRanks:r,totalRange:n*a}),o}},{isTouchDevice:An}=P,{fireEvent:Pn,merge:Ln}=N,Nt={colors:["#2caffe","#544fc5","#00e272","#fe6a35","#6b8abc","#d568fb","#2ee0ca","#fa4b42","#feb56a","#91e8e1"],symbols:["circle","diamond","square","triangle","triangle-down"],lang:{weekFrom:"week from",chartTitle:"Chart title",locale:void 0,loading:"Loading...",months:void 0,seriesName:"Series {add index 1}",shortMonths:void 0,weekdays:void 0,numericSymbols:["k","M","G","T","P","E"],pieSliceName:"Slice",resetZoom:"Reset zoom",yAxisTitle:"Values",resetZoomTitle:"Reset zoom level 1:1"},global:{buttonTheme:{fill:"#f7f7f7",padding:8,r:2,stroke:"#cccccc","stroke-width":1,style:{color:"#333333",cursor:"pointer",fontSize:"0.8em",fontWeight:"normal"},states:{hover:{fill:"#e6e6e6"},select:{fill:"#e6e9ff",style:{color:"#000000",fontWeight:"bold"}},disabled:{style:{color:"#cccccc"}}}}},time:{Date:void 0,timezone:"UTC",timezoneOffset:0,useUTC:void 0},chart:{alignThresholds:!1,panning:{enabled:!1,type:"x"},styledMode:!1,borderRadius:0,colorCount:10,allowMutatingData:!0,ignoreHiddenSeries:!0,spacing:[10,10,15,10],resetZoomButton:{theme:{},position:{}},reflow:!0,type:"line",zooming:{singleTouch:!1,resetButton:{theme:{zIndex:6},position:{align:"right",x:-10,y:10}}},width:null,height:null,borderColor:"#334eff",backgroundColor:"#ffffff",plotBorderColor:"#cccccc"},title:{style:{color:"#333333",fontWeight:"bold"},text:"Chart title",margin:15,minScale:.67},subtitle:{style:{color:"#666666",fontSize:"0.8em"},text:""},caption:{margin:15,style:{color:"#666666",fontSize:"0.8em"},text:"",align:"left",verticalAlign:"bottom"},plotOptions:{},legend:{enabled:!0,align:"center",alignColumns:!0,className:"highcharts-no-tooltip",events:{},layout:"horizontal",itemMarginBottom:2,itemMarginTop:2,labelFormatter:function(){return this.name},borderColor:"#999999",borderRadius:0,navigation:{style:{fontSize:"0.8em"},activeColor:"#0022ff",inactiveColor:"#cccccc"},itemStyle:{color:"#333333",cursor:"pointer",fontSize:"0.8em",textDecoration:"none",textOverflow:"ellipsis"},itemHoverStyle:{color:"#000000"},itemHiddenStyle:{color:"#666666",textDecoration:"line-through"},shadow:!1,itemCheckboxStyle:{position:"absolute",width:"13px",height:"13px"},squareSymbol:!0,symbolPadding:5,verticalAlign:"bottom",x:0,y:0,title:{style:{color:"#333333",fontSize:"0.8em",fontWeight:"bold"}}},loading:{labelStyle:{fontWeight:"bold",position:"relative",top:"45%"},style:{position:"absolute",backgroundColor:"#ffffff",opacity:.5,textAlign:"center"}},tooltip:{enabled:!0,animation:{duration:300,easing:h=>Math.sqrt(1-Math.pow(h-1,2))},borderRadius:3,dateTimeLabelFormats:{millisecond:"%[AebHMSL]",second:"%[AebHMS]",minute:"%[AebHM]",hour:"%[AebHM]",day:"%[AebY]",week:"%v %[AebY]",month:"%[BY]",year:"%Y"},footerFormat:"",headerShape:"callout",hideDelay:500,padding:8,position:{x:0,y:3},shared:!1,snap:An?25:10,headerFormat:'<span style="font-size: 0.8em">{ucfirst point.key}</span><br/>',pointFormat:'<span style="color:{point.color}">\u25CF</span> {series.name}: <b>{point.y}</b><br/>',backgroundColor:"#ffffff",borderWidth:void 0,stickOnContact:!1,style:{color:"#333333",cursor:"default",fontSize:"0.8em"},useHTML:!1},credits:{enabled:!0,href:"https://www.highcharts.com?credits",position:{align:"right",x:-10,verticalAlign:"bottom",y:-5},style:{cursor:"pointer",color:"#999999",fontSize:"0.6em"},text:"Highcharts.com"}},is=new Eo(Nt.time,Nt.lang),xt={defaultOptions:Nt,defaultTime:is,getOptions:function(){return Nt},setOptions:function(h){return Pn(P,"setOptions",{options:h}),Ln(!0,Nt,h),h.time&&is.update(Nt.time),h.lang&&"locale"in h.lang&&is.update({locale:h.lang.locale}),h.lang?.chartTitle&&(Nt.title=Ce(It({},Nt.title),{text:h.lang.chartTitle})),Nt}},{win:On}=P,{isNumber:Le,isString:En,merge:In,pInt:pt,defined:Uo}=N,Vo=(h,t,e)=>`color-mix(in srgb,${h},${t} ${100*e}%)`,ss=h=>En(h)&&!!h&&h!=="none",nt=class h{static parse(t){return t?new h(t):h.None}constructor(t){let e,i,s,o;this.rgba=[NaN,NaN,NaN,NaN],this.input=t;let r=P.Color;if(r&&r!==h)return new r(t);if(typeof t=="object"&&t.stops!==void 0)this.stops=t.stops.map(a=>new h(a[1]));else if(typeof t=="string")for(this.input=t=h.names[t.toLowerCase()]||t,s=h.parsers.length;s--&&!i;)(e=(o=h.parsers[s]).regex.exec(t))&&(i=o.parse(e));i&&(this.rgba=i)}get(t){let e=this.input,i=this.rgba;if(this.output)return this.output;if(typeof e=="object"&&this.stops!==void 0){let s=In(e);return s.stops=[].slice.call(s.stops),this.stops.forEach((o,r)=>{s.stops[r]=[s.stops[r][0],o.get(t)]}),s}return i&&Le(i[0])?t!=="rgb"&&(t||i[3]!==1)?t==="a"?`${i[3]}`:"rgba("+i.join(",")+")":"rgb("+i[0]+","+i[1]+","+i[2]+")":e}brighten(t){let e=this.rgba;if(this.stops)this.stops.forEach(function(i){i.brighten(t)});else if(Le(t)&&t!==0)if(Le(e[0]))for(let i=0;i<3;i++)e[i]+=pt(255*t),e[i]<0&&(e[i]=0),e[i]>255&&(e[i]=255);else h.useColorMix&&ss(this.input)&&(this.output=Vo(this.input,t>0?"white":"black",Math.abs(t)));return this}setOpacity(t){return this.rgba[3]=t,this}tweenTo(t,e){let i=this.rgba,s=t.rgba;if(!Le(i[0])||!Le(s[0]))return h.useColorMix&&ss(this.input)&&ss(t.input)&&e<.99?Vo(this.input,t.input,e):t.input||"none";let o=s[3]!==1||i[3]!==1,r=(n,l)=>n+(i[l]-n)*(1-e),a=s.slice(0,3).map(r).map(Math.round);return o&&a.push(r(s[3],3)),(o?"rgba(":"rgb(")+a.join(",")+")"}};nt.names={white:"#ffffff",black:"#000000"},nt.parsers=[{regex:/rgba\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d?(?:\.\d+)?)\s*\)/,parse:function(h){return[pt(h[1]),pt(h[2]),pt(h[3]),parseFloat(h[4],10)]}},{regex:/rgb\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*\)/,parse:function(h){return[pt(h[1]),pt(h[2]),pt(h[3]),1]}},{regex:/^#([a-f0-9])([a-f0-9])([a-f0-9])([a-f0-9])?$/i,parse:function(h){return[pt(h[1]+h[1],16),pt(h[2]+h[2],16),pt(h[3]+h[3],16),Uo(h[4])?pt(h[4]+h[4],16)/255:1]}},{regex:/^#([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})?$/i,parse:function(h){return[pt(h[1],16),pt(h[2],16),pt(h[3],16),Uo(h[4])?pt(h[4],16)/255:1]}}],nt.useColorMix=On.CSS?.supports("color","color-mix(in srgb,red,blue 9%)"),nt.None=new nt("");var{parse:$o}=nt,{win:Dn}=P,{isNumber:os,objectEach:Bn}=N,ae=(()=>{class h{constructor(e,i,s){this.pos=NaN,this.options=i,this.elem=e,this.prop=s}dSetter(){let e=this.paths,i=e?.[0],s=e?.[1],o=this.now||0,r=[];if(o!==1&&i&&s)if(i.length===s.length&&o<1)for(let a=0;a<s.length;a++){let n=i[a],l=s[a],c=[];for(let d=0;d<l.length;d++){let p=n[d],g=l[d];os(p)&&os(g)&&(l[0]!=="A"||d!==4&&d!==5)?c[d]=p+o*(g-p):c[d]=g}r.push(c)}else r=s;else r=this.toD||[];this.elem.attr("d",r,void 0,!0)}update(){let e=this.elem,i=this.prop,s=this.now,o=this.options.step;this[i+"Setter"]?this[i+"Setter"]():e.attr?e.element&&e.attr(i,s,null,!0):e.style[i]=s+this.unit,o&&o.call(e,s,this)}run(e,i,s){let o=this,r=o.options,a=function(c){return!a.stopped&&o.step(c)},n=Dn.requestAnimationFrame||function(c){setTimeout(c,13)},l=function(){for(let c=0;c<h.timers.length;c++)h.timers[c]()||h.timers.splice(c--,1);h.timers.length&&n(l)};e!==i||this.elem["forceAnimate:"+this.prop]?(this.startTime=+new Date,this.start=e,this.end=i,this.unit=s,this.now=this.start,this.pos=0,a.elem=this.elem,a.prop=this.prop,a()&&h.timers.push(a)===1&&n(l)):(delete r.curAnim[this.prop],r.complete&&Object.keys(r.curAnim).length===0&&r.complete.call(this.elem))}step(e){let i,s,o=+new Date,r=this.options,a=this.elem,n=r.complete,l=r.duration,c=r.curAnim;return a.attr&&!a.element?i=!1:e||o>=l+this.startTime?(this.now=this.end,this.pos=1,this.update(),c[this.prop]=!0,s=!0,Bn(c,function(d){d!==!0&&(s=!1)}),s&&n&&n.call(a),i=!1):(this.pos=r.easing((o-this.startTime)/l),this.now=this.start+(this.end-this.start)*this.pos,this.update(),i=!0),i}initPath(e,i,s){let o=e.startX,r=e.endX,a=s.slice(),n=e.isArea,l=n?2:1,c=i&&s.length>i.length&&s.hasStackedCliffs,d,p,g,u,x=i?.slice();if(!x||c)return[a,a];function m(y,b){for(;y.length<p;){let v=y[0],S=b[p-y.length];if(S&&v[0]==="M"&&(S[0]==="C"?y[0]=["C",v[1],v[2],v[1],v[2],v[1],v[2]]:y[0]=["L",v[1],v[2]]),y.unshift(v),n){let w=y.pop();y.push(y[y.length-1],w)}}}function f(y){for(;y.length<p;){let b=y[Math.floor(y.length/l)-1].slice();if(b[0]==="C"&&(b[1]=b[5],b[2]=b[6]),n){let v=y[Math.floor(y.length/l)].slice();y.splice(y.length/2,0,b,v)}else y.push(b)}}if(o&&r&&r.length){for(g=0;g<o.length;g++)if(o[g]===r[0]){d=g;break}else if(o[0]===r[r.length-o.length+g]){d=g,u=!0;break}else if(o[o.length-1]===r[r.length-o.length+g]){d=o.length-g;break}d===void 0&&(x=[])}return x.length&&os(d)&&(p=a.length+d*l,u?(m(x,a),f(a)):(m(a,x),f(x))),[x,a]}fillSetter(){h.prototype.strokeSetter.apply(this,arguments)}strokeSetter(){this.elem.attr(this.prop,$o(this.start).tweenTo($o(this.end),this.pos),void 0,!0)}}return h.timers=[],h})(),{defined:Nn,getStyle:zn,isArray:Rn,isNumber:Wn,isObject:eo,merge:Ga,objectEach:Xn,pick:Hn}=N;function rs(h){return eo(h)?Ga({duration:500,defer:0},h):{duration:500*!!h,defer:0}}function Zo(h,t){let e=ae.timers.length;for(;e--;)ae.timers[e].elem!==h||t&&t!==ae.timers[e].prop||(ae.timers[e].stopped=!0)}var at={animate:function(h,t,e){let i,s="",o,r,a;eo(e)||(a=arguments,e={duration:a[2],easing:a[3],complete:a[4]}),Wn(e.duration)||(e.duration=400),e.easing=typeof e.easing=="function"?e.easing:Math[e.easing]||Math.easeInOutSine,e.curAnim=Ga(t),Xn(t,function(n,l){Zo(h,l),r=new ae(h,e,l),o=void 0,l==="d"&&Rn(t.d)?(r.paths=r.initPath(h,h.pathArray,t.d),r.toD=t.d,i=0,o=1):h.attr?i=h.attr(l):(i=parseFloat(zn(h,l))||0,l!=="opacity"&&(s="px")),o||(o=n),typeof o=="string"&&o.match("px")&&(o=o.replace(/px/g,"")),r.run(i,o,s)})},animObject:rs,getDeferredAnimation:function(h,t,e){let i=rs(t),s=e?[e]:h.series,o=0,r=0;return s.forEach(a=>{let n=rs(a.options.animation);o=eo(t)&&Nn(t.defer)?i.defer:Math.max(o,n.duration+n.defer),r=Math.min(i.duration,n.duration)}),h.renderer.forExport&&(o=0),{defer:Math.max(0,o-r),duration:Math.min(o,r)}},setAnimation:function(h,t){t.renderer.globalAnimation=Hn(h,t.options.chart.animation,!0)},stop:Zo},{SVG_NS:qo,win:Fn}=P,{attr:Yn,createElement:Gn,css:jn,error:Ko,isFunction:Un,isString:_o,objectEach:Jo,splat:Vn}=N,{trustedTypes:as}=Fn,Yi=as&&Un(as.createPolicy)&&as.createPolicy("highcharts",{createHTML:h=>h}),$n=Yi?Yi.createHTML(""):"",ot=class h{static filterUserAttributes(t){return Jo(t,(e,i)=>{let s=!0;h.allowedAttributes.indexOf(i)===-1&&(s=!1),["background","dynsrc","href","lowsrc","src"].indexOf(i)!==-1&&(s=_o(e)&&h.allowedReferences.some(o=>e.indexOf(o)===0)),s||(Ko(33,!1,void 0,{"Invalid attribute in config":`${i}`}),delete t[i]),_o(e)&&t[i]&&(t[i]=e.replace(/</g,"<"))}),t}static parseStyle(t){return t.split(";").reduce((e,i)=>{let s=i.split(":").map(r=>r.trim()),o=s.shift();return o&&s.length&&(e[o.replace(/-([a-z])/g,r=>r[1].toUpperCase())]=s.join(":")),e},{})}static setElementHTML(t,e){t.innerHTML=h.emptyHTML,e&&new h(e).addToDOM(t)}constructor(t){this.nodes=typeof t=="string"?this.parseMarkup(t):t}addToDOM(t){return function e(i,s){let o;return Vn(i).forEach(function(r){let a,n=r.tagName,l=r.textContent?P.doc.createTextNode(r.textContent):void 0,c=h.bypassHTMLFiltering;if(n)if(n==="#text")a=l;else if(h.allowedTags.indexOf(n)!==-1||c){let d=n==="svg"?qo:s.namespaceURI||qo,p=P.doc.createElementNS(d,n),g=r.attributes||{};Jo(r,function(u,x){x!=="tagName"&&x!=="attributes"&&x!=="children"&&x!=="style"&&x!=="textContent"&&(g[x]=u)}),Yn(p,c?g:h.filterUserAttributes(g)),r.style&&jn(p,r.style),l&&p.appendChild(l),e(r.children||[],p),a=p}else Ko(33,!1,void 0,{"Invalid tagName in config":n});a&&s.appendChild(a),o=a}),o}(this.nodes,t)}parseMarkup(t){let e,i=[];t=t.trim().replace(/ style=(["'])/g," data-style=$1");try{e=new DOMParser().parseFromString(Yi?Yi.createHTML(t):t,"text/html")}catch{}if(!e){let o=Gn("div");o.innerHTML=t,e={body:o}}let s=(o,r)=>{let a=o.nodeName.toLowerCase(),n={tagName:a};a==="#text"&&(n.textContent=o.textContent||"");let l=o.attributes;if(l){let c={};[].forEach.call(l,d=>{d.name==="data-style"?n.style=h.parseStyle(d.value):c[d.name]=d.value}),n.attributes=c}if(o.childNodes.length){let c=[];[].forEach.call(o.childNodes,d=>{s(d,c)}),c.length&&(n.children=c)}r.push(n)};return[].forEach.call(e.body.childNodes,o=>s(o,i)),i}};ot.allowedAttributes=["alt","aria-controls","aria-describedby","aria-expanded","aria-haspopup","aria-hidden","aria-label","aria-labelledby","aria-live","aria-pressed","aria-readonly","aria-roledescription","aria-selected","class","clip-path","color","colspan","cx","cy","d","disabled","dx","dy","fill","filterUnits","flood-color","flood-opacity","height","href","id","in","in2","markerHeight","markerWidth","offset","opacity","operator","orient","padding","paddingLeft","paddingRight","patternUnits","r","radius","refX","refY","result","role","rowspan","scope","slope","src","startOffset","stdDeviation","stroke-linecap","stroke-width","stroke","style","summary","tabindex","tableValues","target","text-align","text-anchor","textAnchor","textLength","title","type","valign","width","x","x1","x2","xlink:href","y","y1","y2","zIndex"],ot.allowedReferences=["https://","http://","mailto:","/","../","./","#"],ot.allowedTags=["#text","a","abbr","b","br","button","caption","circle","clipPath","code","dd","defs","div","dl","dt","em","feComponentTransfer","feComposite","feDropShadow","feFlood","feFuncA","feFuncB","feFuncG","feFuncR","feGaussianBlur","feMerge","feMergeNode","feMorphology","feOffset","filter","h1","h2","h3","h4","h5","h6","hr","i","img","li","linearGradient","marker","ol","p","path","pattern","pre","rect","small","span","stop","strong","style","sub","sup","svg","table","tbody","td","text","textPath","th","thead","title","tr","tspan","u","ul"],ot.emptyHTML=$n,ot.bypassHTMLFiltering=!1;var{defaultOptions:ja,defaultTime:Ua}=xt,{pageLang:Zn}=P,{extend:qn,getNestedProperty:Kn,isArray:_n,isNumber:Qo,isObject:Jn,isString:Qn,pick:th,ucfirst:eh}=N,Bi={add:(h,t)=>h+t,divide:(h,t)=>t!==0?h/t:"",eq:(h,t)=>h==t,each:function(h){let t=arguments[arguments.length-1];return!!_n(h)&&h.map((e,i)=>Gi(t.body,qn(Jn(e)?e:{"@this":e},{"@index":i,"@first":i===0,"@last":i===h.length-1}))).join("")},ge:(h,t)=>h>=t,gt:(h,t)=>h>t,if:h=>!!h,le:(h,t)=>h<=t,lt:(h,t)=>h<t,multiply:(h,t)=>h*t,ne:(h,t)=>h!=t,subtract:(h,t)=>h-t,ucfirst:eh,unless:h=>!h},tr={},er=h=>/^["'].+["']$/.test(h);function Gi(h="",t,e){let i=/\{([a-zA-Z\u00C0-\u017F\d:\.,;\-\/<>\[\]%_@+"'’= #\(\)]+)\}/g,s=/\(([a-zA-Z\u00C0-\u017F\d:\.,;\-\/<>\[\]%_@+"'= ]+)\)/g,o=[],r=/f$/,a=/\.(\d)/,n=e?.options?.lang||ja.lang,l=e?.time||Ua,c=e?.numberFormatter||Va.bind(e),d=(m="")=>{let f;return m==="true"||m!=="false"&&((f=Number(m)).toString()===m?f:er(m)?m.slice(1,-1):Kn(m,t))},p,g,u=0,x;for(;(p=i.exec(h))!==null;){let m=p,f=s.exec(p[1]);f&&(p=f,x=!0),g?.isBlock||(g={ctx:t,expression:p[1],find:p[0],isBlock:p[1].charAt(0)==="#",start:p.index,startInner:p.index+p[0].length,length:p[0].length});let y=(g.isBlock?m:p)[1].split(" ")[0].replace("#","");Bi[y]&&(g.isBlock&&y===g.fn&&u++,g.fn||(g.fn=y));let b=p[1]==="else";if(g.isBlock&&g.fn&&(p[1]===`/${g.fn}`||b))if(u)!b&&u--;else{let v=g.startInner,S=h.substr(v,p.index-v);g.body===void 0?(g.body=S,g.startInner=p.index+p[0].length):g.elseBody=S,g.find+=S+p[0],b||(o.push(g),g=void 0)}else g.isBlock||o.push(g);if(f&&!g?.isBlock)break}return o.forEach(m=>{let f,y,{body:b,elseBody:v,expression:S,fn:w}=m;if(w){let k=[m],M=[],T=S.length,A=0,C;for(y=0;y<=T;y++){let O=S.charAt(y);C||O!=='"'&&O!=="'"?C===O&&(C=""):C=O,C||O!==" "&&y!==T||(M.push(S.substr(A,y-A)),A=y+1)}for(y=Bi[w].length;y--;)k.unshift(d(M[y+1]));f=Bi[w].apply(t,k),m.isBlock&&typeof f=="boolean"&&(f=Gi(f?b:v,t,e))}else{let k=er(S)?[S]:S.split(":"),M=(f=d(k.shift()||""))%1!=0;if(typeof f=="number"&&(k.length||M)){let T=k.join(":");if(r.test(T)||M){let A=parseInt((T.match(a)||["","-1"])[1],10);f!==null&&(f=c(f,A,n.decimalPoint,T.indexOf(",")>-1?n.thousandsSep:""))}else f=l.dateFormat(T,f)}s.lastIndex=0,s.test(m.find)&&Qn(f)&&(f=`"${f}"`)}h=h.replace(m.find,th(f,""))}),x?Gi(h,t,e):h}function Va(h,t,e,i){t*=1;let s,o,[r,a]=(h=+h||0).toString().split("e").map(Number),n=this?.options?.lang||ja.lang,l=(h.toString().split(".")[1]||"").split("e")[0].length,c=t,d={};e??(e=n.decimalPoint),i??(i=n.thousandsSep),t===-1?t=Math.min(l,20):Qo(t)?t&&a<0&&((o=t+a)>=0?(r=+r.toExponential(o).split("e")[0],t=o):(r=Math.floor(r),h=t<20?+(r*Math.pow(10,a)).toFixed(t):0,a=0)):t=2,a&&(t??(t=2),h=r),Qo(t)&&t>=0&&(d.minimumFractionDigits=t,d.maximumFractionDigits=t),i===""&&(d.useGrouping=!1);let p=i||e,g=p?"en":this?.locale||n.locale||Zn,u=JSON.stringify(d)+g;return s=(tr[u]??(tr[u]=new Intl.NumberFormat(g,d))).format(h),p&&(s=s.replace(/([,\.])/g,"_$1").replace(/_\,/g,i??",").replace("_.",e??".")),(t||+s!=0)&&(!(a<0)||c)||(s="0"),a&&+s!=0&&(s+="e"+(a<0?"":"+")+a),s}var yt={dateFormat:function(h,t,e){return Ua.dateFormat(h,t,e)},format:Gi,helpers:Bi,numberFormat:Va};(ge=no||(no={})).rendererTypes={},ge.getRendererType=function(h=si){return ge.rendererTypes[h]||ge.rendererTypes[si]},ge.registerRendererType=function(h,t,e){ge.rendererTypes[h]=t,(!si||e)&&(si=h,P.Renderer=t)};var ii=no,{clamp:ih,pick:sh,pushUnique:oh,stableSort:ns}=N;(ho||(ho={})).distribute=function h(t,e,i){let s=t,o=s.reducedLen||e,r=(b,v)=>b.target-v.target,a=[],n=t.length,l=[],c=a.push,d,p,g,u=!0,x,m,f=0,y;for(d=n;d--;)f+=t[d].size;if(f>o){for(ns(t,(b,v)=>(v.rank||0)-(b.rank||0)),g=(y=t[0].rank===t[t.length-1].rank)?n/2:-1,p=y?g:n-1;g&&f>o;)x=t[d=Math.floor(p)],oh(l,d)&&(f-=x.size),p+=g,y&&p>=t.length&&(g/=2,p=g);l.sort((b,v)=>v-b).forEach(b=>c.apply(a,t.splice(b,1)))}for(ns(t,r),t=t.map(b=>({size:b.size,targets:[b.target],align:sh(b.align,.5)}));u;){for(d=t.length;d--;)x=t[d],m=(Math.min.apply(0,x.targets)+Math.max.apply(0,x.targets))/2,x.pos=ih(m-x.size*x.align,0,e-x.size);for(d=t.length,u=!1;d--;)d>0&&t[d-1].pos+t[d-1].size>t[d].pos&&(t[d-1].size+=t[d].size,t[d-1].targets=t[d-1].targets.concat(t[d].targets),t[d-1].align=.5,t[d-1].pos+t[d-1].size>e&&(t[d-1].pos=e-t[d-1].size),t.splice(d,1),u=!0)}return c.apply(s,a),d=0,t.some(b=>{let v=0;return(b.targets||[]).some(()=>(s[d].pos=b.pos+v,i!==void 0&&Math.abs(s[d].pos-s[d].target)>i?(s.slice(0,d+1).forEach(S=>delete S.pos),s.reducedLen=(s.reducedLen||e)-.1*e,s.reducedLen>.1*e&&h(s,e,i),!0):(v+=s[d].size,d++,!1)))}),ns(s,r),s};var qi=ho,{animate:rh,animObject:ah,stop:ir}=at,{deg2rad:sr,doc:he,svg:nh,SVG_NS:oi,win:hh,isFirefox:lh}=P,{addEvent:dh,attr:hs,createElement:ch,crisp:ri,css:or,defined:St,erase:ph,extend:Oe,fireEvent:ls,getAlignFactor:ds,isArray:rr,isFunction:ar,isNumber:gh,isObject:uh,isString:nr,merge:cs,objectEach:le,pick:Dt,pInt:ai,pushUnique:fh,replaceNested:mh,syncTimeout:xh,uniqueKey:hr}=N,rt=class h{_defaultGetter(t){let e=Dt(this[t+"Value"],this[t],this.element?this.element.getAttribute(t):null,0);return/^-?[\d\.]+$/.test(e)&&(e=parseFloat(e)),e}_defaultSetter(t,e,i){i.setAttribute(e,t)}add(t){let e,i=this.renderer,s=this.element;return t&&(this.parentGroup=t),this.textStr!==void 0&&this.element.nodeName==="text"&&i.buildText(this),this.added=!0,(!t||t.handleZ||this.zIndex)&&(e=this.zIndexSetter()),e||(t?t.element:i.box).appendChild(s),this.onAdd&&this.onAdd(),this}addClass(t,e){let i=e?"":this.attr("class")||"";return(t=(t||"").split(/ /g).reduce(function(s,o){return i.indexOf(o)===-1&&s.push(o),s},i?[i]:[]).join(" "))!==i&&this.attr("class",t),this}afterSetters(){this.doTransform&&(this.updateTransform(),this.doTransform=!1)}align(t,e,i,s=!0){let o=this.renderer,r=o.alignedObjects,a=!!t;t?(this.alignOptions=t,this.alignByTranslate=e,this.alignTo=i):(t=this.alignOptions||{},e=this.alignByTranslate,i=this.alignTo);let n=!i||nr(i)?i||"renderer":void 0;n&&(a&&fh(r,this),i=void 0);let l=Dt(i,o[n],o),c=(l.x||0)+(t.x||0)+((l.width||0)-(t.width||0))*ds(t.align),d=(l.y||0)+(t.y||0)+((l.height||0)-(t.height||0))*ds(t.verticalAlign),p={"text-align":t?.align};return p[e?"translateX":"x"]=Math.round(c),p[e?"translateY":"y"]=Math.round(d),s&&(this[this.placed?"animate":"attr"](p),this.placed=!0),this.alignAttr=p,this}alignSetter(t){let e={left:"start",center:"middle",right:"end"};e[t]&&(this.alignValue=t,this.element.setAttribute("text-anchor",e[t]))}animate(t,e,i){let s=ah(Dt(e,this.renderer.globalAnimation,!0)),o=s.defer;return he.hidden&&(s.duration=0),s.duration!==0?(i&&(s.complete=i),xh(()=>{this.element&&rh(this,t,s)},o)):(this.attr(t,void 0,i||s.complete),le(t,function(r,a){s.step&&s.step.call(this,r,{prop:a,pos:1,elem:this})},this)),this}applyTextOutline(t){let e=this.element;t.indexOf("contrast")!==-1&&(t=t.replace(/contrast/g,this.renderer.getContrast(e.style.fill)));let i=t.indexOf(" "),s=t.substring(i+1),o=t.substring(0,i);if(o&&o!=="none"&&P.svg){this.fakeTS=!0,o=o.replace(/(^[\d\.]+)(.*?)$/g,function(c,d,p){return 2*Number(d)+p}),this.removeTextOutline();let r=he.createElementNS(oi,"tspan");hs(r,{class:"highcharts-text-outline",fill:s,stroke:s,"stroke-width":o,"stroke-linejoin":"round"});let a=e.querySelector("textPath")||e;[].forEach.call(a.childNodes,c=>{let d=c.cloneNode(!0);d.removeAttribute&&["fill","stroke","stroke-width","stroke"].forEach(p=>d.removeAttribute(p)),r.appendChild(d)});let n=0;[].forEach.call(a.querySelectorAll("text tspan"),c=>{n+=Number(c.getAttribute("dy"))});let l=he.createElementNS(oi,"tspan");l.textContent="\u200B",hs(l,{x:Number(e.getAttribute("x")),dy:-n}),r.appendChild(l),a.insertBefore(r,a.firstChild)}}attr(t,e,i,s){let{element:o}=this,r=h.symbolCustomAttribs,a,n,l=this,c;return typeof t=="string"&&e!==void 0&&(a=t,(t={})[a]=e),typeof t=="string"?l=(this[t+"Getter"]||this._defaultGetter).call(this,t,o):(le(t,function(d,p){c=!1,s||ir(this,p),this.symbolName&&r.indexOf(p)!==-1&&(n||(this.symbolAttr(t),n=!0),c=!0),this.rotation&&(p==="x"||p==="y")&&(this.doTransform=!0),c||(this[p+"Setter"]||this._defaultSetter).call(this,d,p,o)},this),this.afterSetters()),i&&i.call(this),l}clip(t){if(t&&!t.clipPath){let e=hr()+"-",i=this.renderer.createElement("clipPath").attr({id:e}).add(this.renderer.defs);Oe(t,{clipPath:i,id:e,count:0}),t.add(i)}return this.attr("clip-path",t?`url(${this.renderer.url}#${t.id})`:"none")}crisp(t,e){e=Math.round(e||t.strokeWidth||0);let i=t.x||this.x||0,s=t.y||this.y||0,o=(t.width||this.width||0)+i,r=(t.height||this.height||0)+s,a=ri(i,e),n=ri(s,e);return Oe(t,{x:a,y:n,width:ri(o,e)-a,height:ri(r,e)-n}),St(t.strokeWidth)&&(t.strokeWidth=e),t}complexColor(t,e,i){let s=this.renderer,o,r,a,n,l,c,d,p,g,u,x=[],m;ls(this.renderer,"complexColor",{args:arguments},function(){if(t.radialGradient?r="radialGradient":t.linearGradient&&(r="linearGradient"),r){if(a=t[r],l=s.gradients,c=t.stops,g=i.radialReference,rr(a)&&(t[r]=a={x1:a[0],y1:a[1],x2:a[2],y2:a[3],gradientUnits:"userSpaceOnUse"}),r==="radialGradient"&&g&&!St(a.gradientUnits)&&(n=a,a=cs(a,s.getRadialAttr(g,n),{gradientUnits:"userSpaceOnUse"})),le(a,function(f,y){y!=="id"&&x.push(y,f)}),le(c,function(f){x.push(f)}),l[x=x.join(",")])u=l[x].attr("id");else{a.id=u=hr();let f=l[x]=s.createElement(r).attr(a).add(s.defs);f.radAttr=n,f.stops=[],c.forEach(function(y){y[1].indexOf("rgba")===0?(d=(o=nt.parse(y[1])).get("rgb"),p=o.get("a")):(d=y[1],p=1);let b=s.createElement("stop").attr({offset:y[0],"stop-color":d,"stop-opacity":p}).add(f);f.stops.push(b)})}m="url("+s.url+"#"+u+")",i.setAttribute(e,m),i.gradient=x,t.toString=function(){return m}}})}css(t){let e=this.styles,i={},s=this.element,o,r=!e;if(e&&le(t,function(a,n){e&&e[n]!==a&&(i[n]=a,r=!0)}),r){e&&(t=Oe(e,i)),t.width===null||t.width==="auto"?delete this.textWidth:s.nodeName.toLowerCase()==="text"&&t.width&&(o=this.textWidth=ai(t.width)),Oe(this.styles,t),o&&!nh&&this.renderer.forExport&&delete t.width;let a=lh&&t.fontSize||null;a&&(gh(a)||/^\d+$/.test(a))&&(t.fontSize+="px");let n=cs(t);s.namespaceURI===this.SVG_NS&&(["textOutline","textOverflow","whiteSpace","width"].forEach(l=>n&&delete n[l]),n.color&&(n.fill=n.color,delete n.color)),or(s,n)}return this.added&&(this.element.nodeName==="text"&&this.renderer.buildText(this),t.textOutline&&this.applyTextOutline(t.textOutline)),this}dashstyleSetter(t){let e,i=this["stroke-width"];if(i==="inherit"&&(i=1),t){let s=(t=t.toLowerCase()).replace("shortdashdotdot","3,1,1,1,1,1,").replace("shortdashdot","3,1,1,1").replace("shortdot","1,1,").replace("shortdash","3,1,").replace("longdash","8,3,").replace(/dot/g,"1,3,").replace("dash","4,3,").replace(/,$/,"").split(",");for(e=s.length;e--;)s[e]=""+ai(s[e])*Dt(i,NaN);t=s.join(",").replace(/NaN/g,"none"),this.element.setAttribute("stroke-dasharray",t)}}destroy(){let t=this,e=t.element||{},i=t.renderer,s=e.ownerSVGElement,o=e.nodeName==="SPAN"&&t.parentGroup||void 0,r,a;if(e.onclick=e.onmouseout=e.onmouseover=e.onmousemove=e.point=null,ir(t),t.clipPath&&s){let n=t.clipPath;[].forEach.call(s.querySelectorAll("[clip-path],[CLIP-PATH]"),function(l){l.getAttribute("clip-path").indexOf(n.element.id)>-1&&l.removeAttribute("clip-path")}),t.clipPath=n.destroy()}if(t.stops){for(a=0;a<t.stops.length;a++)t.stops[a].destroy();t.stops.length=0,t.stops=void 0}for(t.safeRemoveChild(e);o?.div&&o.div.childNodes.length===0;)r=o.parentGroup,t.safeRemoveChild(o.div),delete o.div,o=r;t.alignOptions&&ph(i.alignedObjects,t),le(t,(n,l)=>{(t[l]?.parentGroup===t||["connector","foreignObject"].indexOf(l)!==-1)&&t[l]?.destroy?.(),delete t[l]})}dSetter(t,e,i){rr(t)&&(typeof t[0]=="string"&&(t=this.renderer.pathToSegments(t)),this.pathArray=t,t=t.reduce((s,o,r)=>o?.join?(r?s+" ":"")+o.join(" "):(o||"").toString(),"")),/(NaN| {2}|^$)/.test(t)&&(t="M 0 0"),this[e]!==t&&(i.setAttribute(e,t),this[e]=t)}fillSetter(t,e,i){typeof t=="string"?i.setAttribute(e,t):t&&this.complexColor(t,e,i)}hrefSetter(t,e,i){i.setAttributeNS("http://www.w3.org/1999/xlink",e,t)}getBBox(t,e){let i,s,o,r,{alignValue:a,element:n,renderer:l,styles:c,textStr:d}=this,{cache:p,cacheKeys:g}=l,u=n.namespaceURI===this.SVG_NS,x=Dt(e,this.rotation,0),m=l.styledMode?n&&h.prototype.getStyle.call(n,"font-size"):c.fontSize;if(St(d)&&((r=d.toString()).indexOf("<")===-1&&(r=r.replace(/\d/g,"0")),r+=["",l.rootFontSize,m,x,this.textWidth,a,c.lineClamp,c.textOverflow,c.fontWeight].join(",")),r&&!t&&(i=p[r]),!i||i.polygon){if(u||l.forExport){try{o=this.fakeTS&&function(y){let b=n.querySelector(".highcharts-text-outline");b&&or(b,{display:y})},ar(o)&&o("none"),i=n.getBBox?Oe({},n.getBBox()):{width:n.offsetWidth,height:n.offsetHeight,x:0,y:0},ar(o)&&o("")}catch{}(!i||i.width<0)&&(i={x:0,y:0,width:0,height:0})}else i=this.htmlGetBBox();s=i.height,u&&(i.height=s={"11px,17":14,"13px,20":16}[`${m||""},${Math.round(s)}`]||s),x&&(i=this.getRotatedBox(i,x));let f={bBox:i};ls(this,"afterGetBBox",f),i=f.bBox}if(r&&(d===""||i.height>0)){for(;g.length>250;)delete p[g.shift()];p[r]||g.push(r),p[r]=i}return i}getRotatedBox(t,e){let{x:i,y:s,width:o,height:r}=t,{alignValue:a,translateY:n,rotationOriginX:l=0,rotationOriginY:c=0}=this,d=ds(a),p=Number(this.element.getAttribute("y")||0)-(n?0:s),g=e*sr,u=(e-90)*sr,x=Math.cos(g),m=Math.sin(g),f=o*x,y=o*m,b=Math.cos(u),v=Math.sin(u),[[S,w],[k,M]]=[l,c].map(W=>[W-W*x,W*m]),T=i+d*(o-f)+S+M+p*b,A=T+f,C=A-r*b,O=C-f,D=s+p-d*y-w+k+p*v,B=D+y,E=B-r*v,L=E-y,I=Math.min(T,A,C,O),V=Math.min(D,B,E,L),Y=Math.max(T,A,C,O)-I,ht=Math.max(D,B,E,L)-V;return{x:I,y:V,width:Y,height:ht,polygon:[[T,D],[A,B],[C,E],[O,L]]}}getStyle(t){return hh.getComputedStyle(this.element||this,"").getPropertyValue(t)}hasClass(t){return(""+this.attr("class")).split(" ").indexOf(t)!==-1}hide(){return this.attr({visibility:"hidden"})}htmlGetBBox(){return{height:0,width:0,x:0,y:0}}constructor(t,e){this.onEvents={},this.opacity=1,this.SVG_NS=oi,this.element=e==="span"||e==="body"?ch(e):he.createElementNS(this.SVG_NS,e),this.renderer=t,this.styles={},ls(this,"afterInit")}on(t,e){let{onEvents:i}=this;return i[t]&&i[t](),i[t]=dh(this.element,t,e),this}opacitySetter(t,e,i){let s=Number(Number(t).toFixed(3));this.opacity=s,i.setAttribute(e,s)}reAlign(){this.alignOptions?.width&&this.alignOptions.align!=="left"&&(this.alignOptions.width=this.getBBox().width,this.placed=!1,this.align())}removeClass(t){return this.attr("class",(""+this.attr("class")).replace(nr(t)?RegExp(`(^| )${t}( |$)`):t," ").replace(/ +/g," ").trim())}removeTextOutline(){let t=this.element.querySelector("tspan.highcharts-text-outline");t&&this.safeRemoveChild(t)}safeRemoveChild(t){let e=t.parentNode;e&&e.removeChild(t)}setRadialReference(t){let e=this.element.gradient&&this.renderer.gradients[this.element.gradient]||void 0;return this.element.radialReference=t,e?.radAttr&&e.animate(this.renderer.getRadialAttr(t,e.radAttr)),this}shadow(t){let{renderer:e}=this,i=cs(this.parentGroup?.rotation===90?{offsetX:-1,offsetY:-1}:{},uh(t)?t:{}),s=e.shadowDefinition(i);return this.attr({filter:t?`url(${e.url}#${s})`:"none"})}show(t=!0){return this.attr({visibility:t?"inherit":"visible"})}"stroke-widthSetter"(t,e,i){this[e]=t,i.setAttribute(e,t)}strokeWidth(){if(!this.renderer.styledMode)return this["stroke-width"]||0;let t=this.getStyle("stroke-width"),e=0,i;return/px$/.test(t)?e=ai(t):t!==""&&(hs(i=he.createElementNS(oi,"rect"),{width:t,"stroke-width":0}),this.element.parentNode.appendChild(i),e=i.getBBox().width,i.parentNode.removeChild(i)),e}symbolAttr(t){let e=this;h.symbolCustomAttribs.forEach(function(i){e[i]=Dt(t[i],e[i])}),e.attr({d:e.renderer.symbols[e.symbolName](e.x,e.y,e.width,e.height,e)})}textSetter(t){t!==this.textStr&&(delete this.textPxLength,this.textStr=t,this.added&&this.renderer.buildText(this),this.reAlign())}titleSetter(t){let e=this.element,i=e.getElementsByTagName("title")[0]||he.createElementNS(this.SVG_NS,"title");e.insertBefore?e.insertBefore(i,e.firstChild):e.appendChild(i),i.textContent=mh(Dt(t,""),[/<[^>]*>/g,""]).replace(/</g,"<").replace(/>/g,">")}toFront(){let t=this.element;return t.parentNode.appendChild(t),this}translate(t,e){return this.attr({translateX:t,translateY:e})}updateTransform(t="transform"){let{element:e,foreignObject:i,matrix:s,padding:o,rotation:r=0,rotationOriginX:a,rotationOriginY:n,scaleX:l,scaleY:c,text:d,translateX:p=0,translateY:g=0}=this,u=["translate("+p+","+g+")"];St(s)&&u.push("matrix("+s.join(",")+")"),r&&(u.push("rotate("+r+" "+(a??e.getAttribute("x")??this.x??0)+" "+(n??e.getAttribute("y")??this.y??0)+")"),d?.element.tagName!=="SPAN"||d?.foreignObject||d.attr({rotation:r,rotationOriginX:(a||0)-o,rotationOriginY:(n||0)-o})),(St(l)||St(c))&&u.push("scale("+Dt(l,1)+" "+Dt(c,1)+")"),u.length&&!(d||this).textPath&&(i?.element||e).setAttribute(t,u.join(" "))}visibilitySetter(t,e,i){t==="inherit"?i.removeAttribute(e):this[e]!==t&&i.setAttribute(e,t),this[e]=t}xGetter(t){return this.element.nodeName==="circle"&&(t==="x"?t="cx":t==="y"&&(t="cy")),this._defaultGetter(t)}zIndexSetter(t,e){let i=this.renderer,s=this.parentGroup,o=(s||i).element||i.box,r=this.element,a=o===i.box,n,l,c,d=!1,p,g=this.added,u;if(St(t)?(r.setAttribute("data-z-index",t),t*=1,this[e]===t&&(g=!1)):St(this[e])&&r.removeAttribute("data-z-index"),this[e]=t,g){for((t=this.zIndex)&&s&&(s.handleZ=!0),u=(n=o.childNodes).length-1;u>=0&&!d;u--)p=!St(c=(l=n[u]).getAttribute("data-z-index")),l!==r&&(t<0&&p&&!a&&!u?(o.insertBefore(r,n[u]),d=!0):(ai(c)<=t||p&&(!St(t)||t>=0))&&(o.insertBefore(r,n[u+1]),d=!0));d||(o.insertBefore(r,n[3*!!a]),d=!0)}return d}};rt.symbolCustomAttribs=["anchorX","anchorY","clockwise","end","height","innerR","r","start","width","x","y"],rt.prototype.strokeSetter=rt.prototype.fillSetter,rt.prototype.yGetter=rt.prototype.xGetter,rt.prototype.matrixSetter=rt.prototype.rotationOriginXSetter=rt.prototype.rotationOriginYSetter=rt.prototype.rotationSetter=rt.prototype.scaleXSetter=rt.prototype.scaleYSetter=rt.prototype.translateXSetter=rt.prototype.translateYSetter=rt.prototype.verticalAlignSetter=function(h,t){this[t]=h,this.doTransform=!0};var Et=rt,{defined:lr,extend:yh,getAlignFactor:dr,isNumber:Ee,merge:bh,pick:ni,removeEvent:cr}=N,_e=class h extends Et{constructor(t,e,i,s,o,r,a,n,l,c){let d;super(t,"g"),this.paddingLeftSetter=this.paddingSetter,this.paddingRightSetter=this.paddingSetter,this.doUpdate=!1,this.textStr=e,this.x=i,this.y=s,this.anchorX=r,this.anchorY=a,this.baseline=l,this.className=c,this.addClass(c==="button"?"highcharts-no-tooltip":"highcharts-label"),c&&this.addClass("highcharts-"+c),this.text=t.text(void 0,0,0,n).attr({zIndex:1}),typeof o=="string"&&((d=/^url\((.*?)\)$/.test(o))||this.renderer.symbols[o])&&(this.symbolKey=o),this.bBox=h.emptyBBox,this.padding=3,this.baselineOffset=0,this.needsBox=t.styledMode||d,this.deferredAttr={},this.alignFactor=0}alignSetter(t){let e=dr(t);this.textAlign=t,e!==this.alignFactor&&(this.alignFactor=e,this.bBox&&Ee(this.xSetting)&&this.attr({x:this.xSetting}))}anchorXSetter(t,e){this.anchorX=t,this.boxAttr(e,Math.round(t)-this.getCrispAdjust()-this.xSetting)}anchorYSetter(t,e){this.anchorY=t,this.boxAttr(e,t-this.ySetting)}boxAttr(t,e){this.box?this.box.attr(t,e):this.deferredAttr[t]=e}css(t){if(t){let e={};t=bh(t),h.textProps.forEach(i=>{t[i]!==void 0&&(e[i]=t[i],delete t[i])}),this.text.css(e),"fontSize"in e||"fontWeight"in e?this.updateTextPadding():("width"in e||"textOverflow"in e)&&this.updateBoxSize()}return Et.prototype.css.call(this,t)}destroy(){cr(this.element,"mouseenter"),cr(this.element,"mouseleave"),this.text&&this.text.destroy(),this.box&&(this.box=this.box.destroy()),Et.prototype.destroy.call(this)}fillSetter(t,e){t&&(this.needsBox=!0),this.fill=t,this.boxAttr(e,t)}getBBox(t,e){this.textStr&&this.bBox.width===0&&this.bBox.height===0&&this.updateBoxSize();let{padding:i,height:s=0,translateX:o=0,translateY:r=0,width:a=0}=this,n=ni(this.paddingLeft,i),l=e??(this.rotation||0),c={width:a,height:s,x:o+this.bBox.x-n,y:r+this.bBox.y-i+this.baselineOffset};return l&&(c=this.getRotatedBox(c,l)),c}getCrispAdjust(){return(this.renderer.styledMode&&this.box?this.box.strokeWidth():this["stroke-width"]?parseInt(this["stroke-width"],10):0)%2/2}heightSetter(t){this.heightSetting=t,this.doUpdate=!0}afterSetters(){super.afterSetters(),this.doUpdate&&(this.updateBoxSize(),this.doUpdate=!1)}onAdd(){this.text.add(this),this.attr({text:ni(this.textStr,""),x:this.x||0,y:this.y||0}),this.box&&lr(this.anchorX)&&this.attr({anchorX:this.anchorX,anchorY:this.anchorY})}paddingSetter(t,e){Ee(t)?t!==this[e]&&(this[e]=t,this.updateTextPadding()):this[e]=void 0}rSetter(t,e){this.boxAttr(e,t)}strokeSetter(t,e){this.stroke=t,this.boxAttr(e,t)}"stroke-widthSetter"(t,e){t&&(this.needsBox=!0),this["stroke-width"]=t,this.boxAttr(e,t)}"text-alignSetter"(t){this.textAlign=this["text-align"]=t,this.updateTextPadding()}textSetter(t){t!==void 0&&this.text.attr({text:t}),this.updateTextPadding(),this.reAlign()}updateBoxSize(){let t,e=this.text,i={},s=this.padding,o=this.bBox=(!Ee(this.widthSetting)||!Ee(this.heightSetting)||this.textAlign)&&lr(e.textStr)?e.getBBox(void 0,0):h.emptyBBox;this.width=this.getPaddedWidth(),this.height=(this.heightSetting||o.height||0)+2*s;let r=this.renderer.fontMetrics(e);if(this.baselineOffset=s+Math.min((this.text.firstLineMetrics||r).b,o.height||1/0),this.heightSetting&&(this.baselineOffset+=(this.heightSetting-r.h)/2),this.needsBox&&!e.textPath){if(!this.box){let a=this.box=this.symbolKey?this.renderer.symbol(this.symbolKey):this.renderer.rect();a.addClass((this.className==="button"?"":"highcharts-label-box")+(this.className?" highcharts-"+this.className+"-box":"")),a.add(this)}i.x=t=this.getCrispAdjust(),i.y=(this.baseline?-this.baselineOffset:0)+t,i.width=Math.round(this.width),i.height=Math.round(this.height),this.box.attr(yh(i,this.deferredAttr)),this.deferredAttr={}}}updateTextPadding(){let t=this.text,e=t.styles.textAlign||this.textAlign;if(!t.textPath){this.updateBoxSize();let i=this.baseline?0:this.baselineOffset,s=(this.paddingLeft??this.padding)+dr(e)*(this.widthSetting??this.bBox.width);(s!==t.x||i!==t.y)&&(t.attr({align:e,x:s}),i!==void 0&&t.attr("y",i)),t.x=s,t.y=i}}widthSetter(t){this.widthSetting=Ee(t)?t:void 0,this.doUpdate=!0}getPaddedWidth(){let t=this.padding,e=ni(this.paddingLeft,t),i=ni(this.paddingRight,t);return(this.widthSetting||this.bBox.width||0)+e+i}xSetter(t){this.x=t,this.alignFactor&&(t-=this.alignFactor*this.getPaddedWidth(),this["forceAnimate:x"]=!0),this.anchorX&&(this["forceAnimate:anchorX"]=!0),this.xSetting=Math.round(t),this.attr("translateX",this.xSetting)}ySetter(t){this.anchorY&&(this["forceAnimate:anchorY"]=!0),this.ySetting=this.y=Math.round(t),this.attr("translateY",this.ySetting)}};_e.emptyBBox={width:0,height:0,x:0,y:0},_e.textProps=["color","direction","fontFamily","fontSize","fontStyle","fontWeight","lineClamp","lineHeight","textAlign","textDecoration","textOutline","textOverflow","whiteSpace","width"];var{defined:pr,isNumber:vh,pick:Ie}=N;function gr(h,t,e,i,s){let o=[];if(s){let r=s.start||0,a=s.end||0,n=Ie(s.r,e),l=Ie(s.r,i||e),c=2e-4/(s.borderRadius?1:Math.max(n,1)),d=Math.abs(a-r-2*Math.PI)<c;d&&(r=Math.PI/2,a=2.5*Math.PI-c);let p=s.innerR,g=Ie(s.open,d),u=Math.cos(r),x=Math.sin(r),m=Math.cos(a),f=Math.sin(a),y=Ie(s.longArc,a-r-Math.PI<c?0:1),b=["A",n,l,0,y,Ie(s.clockwise,1),h+n*m,t+l*f];b.params={start:r,end:a,cx:h,cy:t},o.push(["M",h+n*u,t+l*x],b),pr(p)&&((b=["A",p,p,0,y,pr(s.clockwise)?1-s.clockwise:0,h+p*u,t+p*x]).params={start:a,end:r,cx:h,cy:t},o.push(g?["M",h+p*m,t+p*f]:["L",h+p*m,t+p*f],b)),g||o.push(["Z"])}return o}function ur(h,t,e,i,s){return s?.r?io(h,t,e,i,s):[["M",h,t],["L",h+e,t],["L",h+e,t+i],["L",h,t+i],["Z"]]}function io(h,t,e,i,s){let o=s?.r||0;return[["M",h+o,t],["L",h+e-o,t],["A",o,o,0,0,1,h+e,t+o],["L",h+e,t+i-o],["A",o,o,0,0,1,h+e-o,t+i],["L",h+o,t+i],["A",o,o,0,0,1,h,t+i-o],["L",h,t+o],["A",o,o,0,0,1,h+o,t],["Z"]]}var $a={arc:gr,callout:function(h,t,e,i,s){let o=Math.min(s?.r||0,e,i),r=o+6,a=s?.anchorX,n=s?.anchorY||0,l=io(h,t,e,i,{r:o});if(!vh(a)||a<e&&a>0&&n<i&&n>0)return l;if(h+a>e-r)if(n>t+r&&n<t+i-r)l.splice(3,1,["L",h+e,n-6],["L",h+e+6,n],["L",h+e,n+6],["L",h+e,t+i-o]);else if(a<e){let c=n<t+r,d=c?t:t+i;l.splice(c?2:5,0,["L",a,n],["L",h+e-o,d])}else l.splice(3,1,["L",h+e,i/2],["L",a,n],["L",h+e,i/2],["L",h+e,t+i-o]);else if(h+a<r)if(n>t+r&&n<t+i-r)l.splice(7,1,["L",h,n+6],["L",h-6,n],["L",h,n-6],["L",h,t+o]);else if(a>0){let c=n<t+r,d=c?t:t+i;l.splice(c?1:6,0,["L",a,n],["L",h+o,d])}else l.splice(7,1,["L",h,i/2],["L",a,n],["L",h,i/2],["L",h,t+o]);else n>i&&a<e-r?l.splice(5,1,["L",a+6,t+i],["L",a,t+i+6],["L",a-6,t+i],["L",h+o,t+i]):n<0&&a>r&&l.splice(1,1,["L",a-6,t],["L",a,t-6],["L",a+6,t],["L",e-o,t]);return l},circle:function(h,t,e,i){return gr(h+e/2,t+i/2,e/2,i/2,{start:.5*Math.PI,end:2.5*Math.PI,open:!1})},diamond:function(h,t,e,i){return[["M",h+e/2,t],["L",h+e,t+i/2],["L",h+e/2,t+i],["L",h,t+i/2],["Z"]]},rect:ur,roundedRect:io,square:ur,triangle:function(h,t,e,i){return[["M",h+e/2,t],["L",h+e,t+i],["L",h,t+i],["Z"]]},"triangle-down":function(h,t,e,i){return[["M",h,t],["L",h+e,t],["L",h+e/2,t+i],["Z"]]}},{doc:ps,SVG_NS:kh,win:fr}=P,{attr:gs,extend:wh,fireEvent:Mh,isString:Sh,objectEach:Th,pick:Ch}=N,us=(h,t)=>h.substring(0,t)+"\u2026",Ah=class{constructor(h){let t=h.styles;this.renderer=h.renderer,this.svgElement=h,this.width=h.textWidth,this.textLineHeight=t?.lineHeight,this.textOutline=t?.textOutline,this.ellipsis=t?.textOverflow==="ellipsis",this.lineClamp=t?.lineClamp,this.noWrap=t?.whiteSpace==="nowrap"}buildSVG(){let h=this.svgElement,t=h.element,e=h.renderer,i=Ch(h.textStr,"").toString(),s=i.indexOf("<")!==-1,o=t.childNodes,r=!h.added&&e.box,a=[i,this.ellipsis,this.noWrap,this.textLineHeight,this.textOutline,h.getStyle("font-size"),h.styles.lineClamp,this.width].join(",");if(a!==h.textCache){h.textCache=a,delete h.actualWidth;for(let n=o.length;n--;)t.removeChild(o[n]);if(s||this.ellipsis||this.width||h.textPath||i.indexOf(" ")!==-1&&(!this.noWrap||/<br.*?>/g.test(i))){if(i!==""){r&&r.appendChild(t);let n=new ot(i);this.modifyTree(n.nodes),n.addToDOM(t),this.modifyDOM(),this.ellipsis&&(t.textContent||"").indexOf("\u2026")!==-1&&h.attr("title",this.unescapeEntities(h.textStr||"",["<",">"])),r&&r.removeChild(t)}}else t.appendChild(ps.createTextNode(this.unescapeEntities(i)));Sh(this.textOutline)&&h.applyTextOutline&&h.applyTextOutline(this.textOutline)}}modifyDOM(){let h,t=this.svgElement,e=gs(t.element,"x");for(t.firstLineMetrics=void 0;(h=t.element.firstChild)&&/^[\s\u200B]*$/.test(h.textContent||" ");)t.element.removeChild(h);[].forEach.call(t.element.querySelectorAll("tspan.highcharts-br"),(r,a)=>{r.nextSibling&&r.previousSibling&&(a===0&&r.previousSibling.nodeType===1&&(t.firstLineMetrics=t.renderer.fontMetrics(r.previousSibling)),gs(r,{dy:this.getLineHeight(r.nextSibling),x:e}))});let i=this.width||0;if(!i)return;let s=(r,a)=>{let n=r.textContent||"",l=n.replace(/([^\^])-/g,"$1- ").split(" "),c=!this.noWrap&&(l.length>1||t.element.childNodes.length>1),d=this.getLineHeight(a),p=Math.max(0,i-.8*d),g=0,u=t.actualWidth;if(c){let x=[],m=[];for(;a.firstChild&&a.firstChild!==r;)m.push(a.firstChild),a.removeChild(a.firstChild);for(;l.length;)if(l.length&&!this.noWrap&&g>0&&(x.push(r.textContent||""),r.textContent=l.join(" ").replace(/- /g,"-")),this.truncate(r,void 0,l,g===0&&u||0,i,p,(f,y)=>l.slice(0,y).join(" ").replace(/- /g,"-")),u=t.actualWidth,g++,this.lineClamp&&g>=this.lineClamp){l.length&&(this.truncate(r,r.textContent||"",void 0,0,i,p,us),r.textContent=r.textContent?.replace("\u2026","")+"\u2026");break}m.forEach(f=>{a.insertBefore(f,r)}),x.forEach(f=>{a.insertBefore(ps.createTextNode(f),r);let y=ps.createElementNS(kh,"tspan");y.textContent="\u200B",gs(y,{dy:d,x:e}),a.insertBefore(y,r)})}else this.ellipsis&&n&&this.truncate(r,n,void 0,0,i,p,us)},o=r=>{[].slice.call(r.childNodes).forEach(a=>{a.nodeType===fr.Node.TEXT_NODE?s(a,r):(a.className.baseVal.indexOf("highcharts-br")!==-1&&(t.actualWidth=0),o(a))})};o(t.element)}getLineHeight(h){let t=h.nodeType===fr.Node.TEXT_NODE?h.parentElement:h;return this.textLineHeight?parseInt(this.textLineHeight.toString(),10):this.renderer.fontMetrics(t||this.svgElement.element).h}modifyTree(h){let t=(e,i)=>{let{attributes:s={},children:o,style:r={},tagName:a}=e,n=this.renderer.styledMode;if(a==="b"||a==="strong"?n?s.class="highcharts-strong":r.fontWeight="bold":(a==="i"||a==="em")&&(n?s.class="highcharts-emphasized":r.fontStyle="italic"),r?.color&&(r.fill=r.color),a==="br"){s.class="highcharts-br",e.textContent="\u200B";let l=h[i+1];l?.textContent&&(l.textContent=l.textContent.replace(/^ +/gm,""))}else a==="a"&&o&&o.some(l=>l.tagName==="#text")&&(e.children=[{children:o,tagName:"tspan"}]);a!=="#text"&&a!=="a"&&(e.tagName="tspan"),wh(e,{attributes:s,style:r}),o&&o.filter(l=>l.tagName!=="#text").forEach(t)};h.forEach(t),Mh(this.svgElement,"afterModifyTree",{nodes:h})}truncate(h,t,e,i,s,o,r){let a,n,l=this.svgElement,{rotation:c}=l,d=[],p=e&&!i?1:0,g=(t||e||"").length,u=g;e||(s=o);let x=function(m,f){let y=f||m,b=h.parentNode;if(b&&d[y]===void 0&&b.getSubStringLength)try{d[y]=i+b.getSubStringLength(0,e?y+1:y)}catch{}return d[y]};if(l.rotation=0,i+(n=x(h.textContent.length))>s){for(;p<=g;)u=Math.ceil((p+g)/2),e&&(a=r(e,u)),n=x(u,a&&a.length-1),p===g?p=g+1:n>s?g=u-1:p=u;g===0?h.textContent="":t&&g===t.length-1||(h.textContent=a||r(t||e,u)),this.ellipsis&&n>s&&this.truncate(h,h.textContent||"",void 0,0,s,o,us)}e&&e.splice(0,u),l.actualWidth=n,l.rotation=c}unescapeEntities(h,t){return Th(this.renderer.escapes,function(e,i){t&&t.indexOf(e)!==-1||(h=h.toString().replace(RegExp(e,"g"),i))}),h}},{defaultOptions:Ph}=xt,{charts:Lh,deg2rad:mr,doc:de,isFirefox:xr,isMS:yr,isWebKit:Oh,noop:Eh,SVG_NS:Ih,symbolSizes:fs,win:ms}=P,{addEvent:hi,attr:li,createElement:Dh,crisp:br,css:di,defined:Kt,destroyObjectProperties:Bh,extend:ie,isArray:Nh,isNumber:_t,isObject:De,isString:zh,merge:xs,pick:ys,pInt:Rh,replaceNested:Wh,uniqueKey:Xh}=N,Se=class{constructor(t,e,i,s,o,r,a){let n,l;this.x=0,this.y=0;let c=this.createElement("svg").attr({version:"1.1",class:"highcharts-root"}),d=c.element;a||c.css(this.getStyle(s||{})),t.appendChild(d),li(t,"dir","ltr"),t.innerHTML.indexOf("xmlns")===-1&&li(d,"xmlns",this.SVG_NS),this.box=d,this.boxWrapper=c,this.alignedObjects=[],this.url=this.getReferenceURL(),this.createElement("desc").add().element.appendChild(de.createTextNode("Created with Highcharts 12.4.0")),this.defs=this.createElement("defs").add(),this.allowHTML=r,this.forExport=o,this.styledMode=a,this.gradients={},this.cache={},this.cacheKeys=[],this.imgCount=0,this.rootFontSize=c.getStyle("font-size"),this.setSize(e,i,!1),xr&&t.getBoundingClientRect&&((n=function(){di(t,{left:0,top:0}),l=t.getBoundingClientRect(),di(t,{left:Math.ceil(l.left)-l.left+"px",top:Math.ceil(l.top)-l.top+"px"})})(),this.unSubPixelFix=hi(ms,"resize",n))}definition(t){return new ot([t]).addToDOM(this.defs.element)}getReferenceURL(){if((xr||Oh)&&de.getElementsByTagName("base").length){if(!Kt(_i)){let t=Xh(),e=new ot([{tagName:"svg",attributes:{width:8,height:8},children:[{tagName:"defs",children:[{tagName:"clipPath",attributes:{id:t},children:[{tagName:"rect",attributes:{width:4,height:4}}]}]},{tagName:"rect",attributes:{id:"hitme",width:8,height:8,"clip-path":`url(#${t})`,fill:"rgba(0,0,0,0.001)"}}]}]).addToDOM(de.body);di(e,{position:"fixed",top:0,left:0,zIndex:9e5}),_i=de.elementFromPoint(6,6)?.id==="hitme",de.body.removeChild(e)}if(_i)return Wh(ms.location.href.split("#")[0],[/<[^>]*>/g,""],[/([\('\)])/g,"\\$1"],[/ /g,"%20"])}return""}getStyle(t){return this.style=ie({fontFamily:'-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif',fontSize:"1rem"},t),this.style}setStyle(t){this.boxWrapper.css(this.getStyle(t))}isHidden(){return!this.boxWrapper.getBBox().width}destroy(){let t=this.defs;return this.box=null,this.boxWrapper=this.boxWrapper.destroy(),Bh(this.gradients||{}),this.gradients=null,this.defs=t.destroy(),this.unSubPixelFix&&this.unSubPixelFix(),this.alignedObjects=null,null}createElement(t){return new this.Element(this,t)}getRadialAttr(t,e){return{cx:t[0]-t[2]/2+(e.cx||0)*t[2],cy:t[1]-t[2]/2+(e.cy||0)*t[2],r:(e.r||0)*t[2]}}shadowDefinition(t){let e=[`highcharts-drop-shadow-${this.chartIndex}`,...Object.keys(t).map(s=>`${s}-${t[s]}`)].join("-").toLowerCase().replace(/[^a-z\d\-]/g,""),i=xs({color:"#000000",offsetX:1,offsetY:1,opacity:.15,width:5},t);return this.defs.element.querySelector(`#${e}`)||this.definition({tagName:"filter",attributes:{id:e,filterUnits:i.filterUnits},children:this.getShadowFilterContent(i)}),e}getShadowFilterContent(t){return[{tagName:"feDropShadow",attributes:{dx:t.offsetX,dy:t.offsetY,"flood-color":t.color,"flood-opacity":Math.min(5*t.opacity,1),stdDeviation:t.width/2}}]}buildText(t){new Ah(t).buildSVG()}getContrast(t){if(t==="transparent")return"#000000";let e=nt.parse(t).rgba,i=" clamp(0,calc(9e9*(0.5 - (0.2126*r + 0.7152*g + 0.0722*b))),1)";if(_t(e[0])||!nt.useColorMix){let s=e.map(r=>{let a=r/255;return a<=.04?a/12.92:Math.pow((a+.055)/1.055,2.4)}),o=.2126*s[0]+.7152*s[1]+.0722*s[2];return 1.05/(o+.05)>(o+.05)/.05?"#FFFFFF":"#000000"}return"color(from "+t+" srgb"+i+i+i+")"}button(t,e,i,s,o={},r,a,n,l,c){let d=this.label(t,e,i,l,void 0,void 0,c,void 0,"button"),p=this.styledMode,g=arguments,u=0;o=xs(Ph.global.buttonTheme,o),p&&(delete o.fill,delete o.stroke,delete o["stroke-width"]);let x=o.states||{},m=o.style||{};delete o.states,delete o.style;let f=[ot.filterUserAttributes(o)],y=[m];return p||["hover","select","disabled"].forEach((b,v)=>{f.push(xs(f[0],ot.filterUserAttributes(g[v+5]||x[b]||{}))),y.push(f[v+1].style),delete f[v+1].style}),hi(d.element,yr?"mouseover":"mouseenter",function(){u!==3&&d.setState(1)}),hi(d.element,yr?"mouseout":"mouseleave",function(){u!==3&&d.setState(u)}),d.setState=(b=0)=>{if(b!==1&&(d.state=u=b),d.removeClass(/highcharts-button-(normal|hover|pressed|disabled)/).addClass("highcharts-button-"+["normal","hover","pressed","disabled"][b]),!p){d.attr(f[b]);let v=y[b];De(v)&&d.css(v)}},d.attr(f[0]),!p&&(d.css(ie({cursor:"default"},m)),c&&d.text.css({pointerEvents:"none"})),d.on("touchstart",b=>b.stopPropagation()).on("click",function(b){u!==3&&s?.call(d,b)})}crispLine(t,e){let[i,s]=t;return Kt(i[1])&&i[1]===s[1]&&(i[1]=s[1]=br(i[1],e)),Kt(i[2])&&i[2]===s[2]&&(i[2]=s[2]=br(i[2],e)),t}path(t){let e=this.styledMode?{}:{fill:"none"};return Nh(t)?e.d=t:De(t)&&ie(e,t),this.createElement("path").attr(e)}circle(t,e,i){let s=De(t)?t:t===void 0?{}:{x:t,y:e,r:i},o=this.createElement("circle");return o.xSetter=o.ySetter=function(r,a,n){n.setAttribute("c"+a,r)},o.attr(s)}arc(t,e,i,s,o,r){let a;De(t)?(e=(a=t).y,i=a.r,s=a.innerR,o=a.start,r=a.end,t=a.x):a={innerR:s,start:o,end:r};let n=this.symbol("arc",t,e,i,i,a);return n.r=i,n}rect(t,e,i,s,o,r){let a=De(t)?t:t===void 0?{}:{x:t,y:e,r:o,width:Math.max(i||0,0),height:Math.max(s||0,0)},n=this.createElement("rect");return this.styledMode||(r!==void 0&&(a["stroke-width"]=r,ie(a,n.crisp(a))),a.fill="none"),n.rSetter=function(l,c,d){n.r=l,li(d,{rx:l,ry:l})},n.rGetter=function(){return n.r||0},n.attr(a)}roundedRect(t){return this.symbol("roundedRect").attr(t)}setSize(t,e,i){this.width=t,this.height=e,this.boxWrapper.animate({width:t,height:e},{step:function(){this.attr({viewBox:"0 0 "+this.attr("width")+" "+this.attr("height")})},duration:ys(i,!0)?void 0:0}),this.alignElements()}g(t){let e=this.createElement("g");return t?e.attr({class:"highcharts-"+t}):e}image(t,e,i,s,o,r){let a={preserveAspectRatio:"none"};_t(e)&&(a.x=e),_t(i)&&(a.y=i),_t(s)&&(a.width=s),_t(o)&&(a.height=o);let n=this.createElement("image").attr(a),l=function(c){n.attr({href:t}),r.call(n,c)};if(r){n.attr({href:"data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=="});let c=new ms.Image;hi(c,"load",l),c.src=t,c.complete&&l({})}else n.attr({href:t});return n}symbol(t,e,i,s,o,r){let a,n,l,c,d=this,p=/^url\((.*?)\)$/,g=p.test(t),u=!g&&(this.symbols[t]?t:"circle"),x=u&&this.symbols[u];if(x)typeof e=="number"&&(n=x.call(this.symbols,e||0,i||0,s||0,o||0,r)),a=this.path(n),d.styledMode||a.attr("fill","none"),ie(a,{symbolName:u||void 0,x:e,y:i,width:s,height:o}),r&&ie(a,r);else if(g){l=t.match(p)[1];let m=a=this.image(l);m.imgwidth=ys(r?.width,fs[l]?.width),m.imgheight=ys(r?.height,fs[l]?.height),c=f=>f.attr({width:f.width,height:f.height}),["width","height"].forEach(f=>{m[`${f}Setter`]=function(y,b){this[b]=y;let{alignByTranslate:v,element:S,width:w,height:k,imgwidth:M,imgheight:T}=this,A=b==="width"?M:T,C=1;r&&r.backgroundSize==="within"&&w&&k&&M&&T?(C=Math.min(w/M,k/T),li(S,{width:Math.round(M*C),height:Math.round(T*C)})):S&&A&&S.setAttribute(b,A),!v&&M&&T&&this.translate(((w||0)-M*C)/2,((k||0)-T*C)/2)}}),Kt(e)&&m.attr({x:e,y:i}),m.isImg=!0,m.symbolUrl=t,Kt(m.imgwidth)&&Kt(m.imgheight)?c(m):(m.attr({width:0,height:0}),Dh("img",{onload:function(){let f=Lh[d.chartIndex];this.width===0&&(di(this,{position:"absolute",top:"-999em"}),de.body.appendChild(this)),fs[l]={width:this.width,height:this.height},m.imgwidth=this.width,m.imgheight=this.height,m.element&&c(m),this.parentNode&&this.parentNode.removeChild(this),d.imgCount--,d.imgCount||!f||f.hasLoaded||f.onload()},src:l}),this.imgCount++)}return a}clipRect(t,e,i,s){return this.rect(t,e,i,s,0)}text(t,e,i,s){let o={};if(s&&(this.allowHTML||!this.forExport))return this.html(t,e,i);o.x=Math.round(e||0),i&&(o.y=Math.round(i)),Kt(t)&&(o.text=t);let r=this.createElement("text").attr(o);return s&&(!this.forExport||this.allowHTML)||(r.xSetter=function(a,n,l){let c=l.getElementsByTagName("tspan"),d=l.getAttribute(n);for(let p=0,g;p<c.length;p++)(g=c[p]).getAttribute(n)===d&&g.setAttribute(n,a);l.setAttribute(n,a)}),r}fontMetrics(t){let e=_t(t)?t:Rh(Et.prototype.getStyle.call(t,"font-size")||0),i=e<24?e+3:Math.round(1.2*e),s=Math.round(.8*i);return{h:i,b:s,f:e}}rotCorr(t,e,i){let s=t;return e&&i&&(s=Math.max(s*Math.cos(e*mr),4)),{x:-t/3*Math.sin(e*mr),y:s}}pathToSegments(t){let e=[],i=[],s={A:8,C:7,H:2,L:3,M:3,Q:5,S:5,T:3,V:2};for(let o=0;o<t.length;o++)zh(i[0])&&_t(t[o])&&i.length===s[i[0].toUpperCase()]&&t.splice(o,0,i[0].replace("M","L").replace("m","l")),typeof t[o]=="string"&&(i.length&&e.push(i.slice(0)),i.length=0),i.push(t[o]);return e.push(i.slice(0)),e}label(t,e,i,s,o,r,a,n,l){return new _e(this,t,e,i,s,o,r,a,n,l)}alignElements(){this.alignedObjects.forEach(t=>t.align())}};ie(Se.prototype,{Element:Et,SVG_NS:Ih,escapes:{"&":"&","<":"<",">":">","'":"'",'"':"""},symbols:$a,draw:Eh}),ii.registerRendererType("svg",Se,!0);var{composed:Hh,isFirefox:Fh}=P,{attr:Yh,css:Xt,createElement:Gh,defined:vr,extend:jh,getAlignFactor:Uh,isNumber:ci,pInt:Vh,pushUnique:$h}=N;function Za(h,t,e){let i=this.div?.style;Et.prototype[`${t}Setter`].call(this,h,t,e),i&&(e.style[t]=i[t]=h)}var Zh=(h,t)=>{if(!h.div){let e=Yh(h.element,"class"),i=h.css,s=Gh("div",e?{className:e}:void 0,Ce(It({position:"absolute",left:`${h.translateX||0}px`,top:`${h.translateY||0}px`},h.styles),{display:h.display,opacity:h.opacity,visibility:h.visibility}),h.parentGroup?.div||t);h.classSetter=(o,r,a)=>{a.setAttribute("class",o),s.className=o},h.translateXSetter=h.translateYSetter=(o,r)=>{h[r]=o,s.style[r==="translateX"?"left":"top"]=`${o}px`,h.doTransform=!0},h.scaleXSetter=h.scaleYSetter=(o,r)=>{h[r]=o,h.doTransform=!0},h.opacitySetter=h.visibilitySetter=Za,h.css=o=>(i.call(h,o),o.cursor&&(s.style.cursor=o.cursor),o.pointerEvents&&(s.style.pointerEvents=o.pointerEvents),h),h.on=function(){return Et.prototype.on.apply({element:s,onEvents:h.onEvents},arguments),h},h.div=s}return h.div},Je=class h extends Et{static compose(t){$h(Hh,this.compose)&&(t.prototype.html=function(e,i,s){return new h(this,"span").attr({text:e,x:Math.round(i),y:Math.round(s)})})}constructor(t,e){super(t,e),h.useForeignObject?this.foreignObject=t.createElement("foreignObject").attr({zIndex:2}):this.css(It({position:"absolute"},t.styledMode?{}:{fontFamily:t.style.fontFamily,fontSize:t.style.fontSize})),this.element.style.whiteSpace="nowrap"}getSpanCorrection(t,e,i){this.xCorr=-t*i,this.yCorr=-e}css(t){let e,{element:i}=this,s=i.tagName==="SPAN"&&t&&"width"in t,o=s&&t.width;return s&&(delete t.width,this.textWidth=Vh(o)||void 0,e=!0),t?.textOverflow==="ellipsis"&&(t.overflow="hidden",t.whiteSpace="nowrap"),t?.lineClamp&&(t.display="-webkit-box",t.WebkitLineClamp=t.lineClamp,t.WebkitBoxOrient="vertical",t.overflow="hidden"),ci(Number(t?.fontSize))&&(t.fontSize+="px"),jh(this.styles,t),Xt(i,t),e&&this.updateTransform(),this}htmlGetBBox(){let{element:t}=this;return{x:t.offsetLeft,y:t.offsetTop,width:t.offsetWidth,height:t.offsetHeight}}updateTransform(){if(!this.added){this.alignOnAdd=!0;return}let{element:t,foreignObject:e,oldTextWidth:i,renderer:s,rotation:o,rotationOriginX:r,rotationOriginY:a,scaleX:n,scaleY:l,styles:{display:c="inline-block",whiteSpace:d},textAlign:p="left",textWidth:g,translateX:u=0,translateY:x=0,x:m=0,y:f=0}=this;if(e||Xt(t,{marginLeft:`${u}px`,marginTop:`${x}px`}),t.tagName==="SPAN"){let y,b=[o,p,t.innerHTML,g,this.textAlign].join(","),v=-(this.parentGroup?.padding*1)||0;if(g!==i){let M=this.textPxLength?this.textPxLength:(Xt(t,{width:"",whiteSpace:d||"nowrap"}),t.offsetWidth),T=g||0,A=!s.styledMode&&t.style.textOverflow===""&&t.style.webkitLineClamp;(T>i||M>T||A)&&(/[\-\s\u00AD]/.test(t.textContent||t.innerText)||t.style.textOverflow==="ellipsis")&&(Xt(t,{width:(o||n||M>T||A)&&ci(g)?g+"px":"auto",display:c,whiteSpace:d||"normal"}),this.oldTextWidth=g)}e&&(Xt(t,{display:"inline-block",verticalAlign:"top"}),e.attr({width:s.width,height:s.height})),b!==this.cTT&&(y=s.fontMetrics(t).b,vr(o)&&!e&&(o!==(this.oldRotation||0)||p!==this.oldAlign)&&Xt(t,{transform:`rotate(${o}deg)`,transformOrigin:`${v}% ${v}px`}),this.getSpanCorrection(!vr(o)&&!this.textWidth&&this.textPxLength||t.offsetWidth,y,Uh(p)));let{xCorr:S=0,yCorr:w=0}=this,k={left:`${m+S}px`,top:`${f+w}px`,textAlign:p,transformOrigin:`${(r??m)-S-m-v}px ${(a??f)-w-f-v}px`};(n||l)&&(k.transform=`scale(${n??1},${l??1})`),e?(super.updateTransform(),ci(m)&&ci(f)?(e.attr({x:m+S,y:f+w,width:t.offsetWidth+3,height:t.offsetHeight,"transform-origin":t.getAttribute("transform-origin")||"0 0"}),Xt(t,{display:c,textAlign:p})):Fh&&e.attr({width:0,height:0})):Xt(t,k),this.cTT=b,this.oldRotation=o,this.oldAlign=p}}add(t){let{foreignObject:e,renderer:i}=this,s=i.box.parentNode,o=[];if(e)e.add(t),super.add(i.createElement("body").attr({xmlns:"http://www.w3.org/1999/xhtml"}).css({background:"transparent",margin:"0 3px 0 0"}).add(e));else{let r;if(this.parentGroup=t,t&&!(r=t.div)){let a=t;for(;a;)o.push(a),a=a.parentGroup;for(let n of o.reverse())r=Zh(n,s)}(r||s).appendChild(this.element)}return this.added=!0,this.alignOnAdd&&this.updateTransform(),this}textSetter(t){t!==this.textStr&&(delete this.bBox,delete this.oldTextWidth,ot.setElementHTML(this.element,t??""),this.textStr=t,this.doTransform=!0)}alignSetter(t){this.alignValue=this.textAlign=t,this.doTransform=!0}xSetter(t,e){this[e]=t,this.doTransform=!0}},Jt=Je.prototype;Jt.visibilitySetter=Jt.opacitySetter=Za,Jt.ySetter=Jt.rotationSetter=Jt.rotationOriginXSetter=Jt.rotationOriginYSetter=Jt.xSetter,(Ur=lo||(lo={})).xAxis={alignTicks:!0,allowDecimals:void 0,panningEnabled:!0,zIndex:2,zoomEnabled:!0,dateTimeLabelFormats:{millisecond:{main:"%[HMSL]",range:!1},second:{main:"%[HMS]",range:!1},minute:{main:"%[HM]",range:!1},hour:{main:"%[HM]",range:!1},day:{main:"%[eb]"},week:{main:"%[eb]"},month:{main:"%[bY]"},year:{main:"%Y"}},endOnTick:!1,gridLineDashStyle:"Solid",gridZIndex:1,labels:{autoRotationLimit:80,distance:15,enabled:!0,indentation:10,overflow:"justify",reserveSpace:void 0,rotation:void 0,staggerLines:0,step:0,useHTML:!1,zIndex:7,style:{color:"#333333",cursor:"default",fontSize:"0.8em",textOverflow:"ellipsis"}},maxPadding:.01,minorGridLineDashStyle:"Solid",minorTickLength:2,minorTickPosition:"outside",minorTicksPerMajor:5,minPadding:.01,offset:void 0,reversed:void 0,reversedStacks:!1,showEmpty:!0,showFirstLabel:!0,showLastLabel:!0,startOfWeek:1,startOnTick:!1,tickLength:10,tickPixelInterval:100,tickmarkPlacement:"between",tickPosition:"outside",title:{align:"middle",useHTML:!1,x:0,y:0,style:{color:"#666666",fontSize:"0.8em"}},visible:!0,minorGridLineColor:"#f2f2f2",minorGridLineWidth:1,minorTickColor:"#999999",lineColor:"#333333",lineWidth:1,gridLineColor:"#e6e6e6",gridLineWidth:void 0,tickColor:"#333333"},Ur.yAxis={reversedStacks:!0,endOnTick:!0,maxPadding:.05,minPadding:.05,tickPixelInterval:72,showLastLabel:!0,labels:{x:void 0},startOnTick:!0,title:{},stackLabels:{animation:{},allowOverlap:!1,enabled:!1,crop:!0,overflow:"justify",formatter:function(){let{numberFormatter:h}=this.axis.chart;return h(this.total||0,-1)},style:{color:"#000000",fontSize:"0.7em",fontWeight:"bold",textOutline:"1px contrast"}},gridLineWidth:1,lineWidth:0};var qh=lo,{addEvent:Kh,isFunction:_h,objectEach:Jh,removeEvent:Qh}=N;(co||(co={})).registerEventOptions=function(h,t){h.eventOptions=h.eventOptions||{},Jh(t.events,function(e,i){h.eventOptions[i]!==e&&(h.eventOptions[i]&&(Qh(h,i,h.eventOptions[i]),delete h.eventOptions[i]),_h(e)&&(h.eventOptions[i]=e,Kh(h,i,e,{order:0})))})};var Ki=co,{deg2rad:bs}=P,{clamp:tl,correctFloat:pi,defined:vs,destroyObjectProperties:el,extend:kr,fireEvent:Be,getAlignFactor:il,isNumber:gi,merge:sl,objectEach:ol,pick:Tt}=N,be=class{constructor(h,t,e,i,s){this.isNew=!0,this.isNewLabel=!0,this.axis=h,this.pos=t,this.type=e||"",this.parameters=s||{},this.tickmarkOffset=this.parameters.tickmarkOffset,this.options=this.parameters.options,Be(this,"init"),e||i||this.addLabel()}addLabel(){let h=this,t=h.axis,e=t.options,i=t.chart,s=t.categories,o=t.logarithmic,r=t.names,a=h.pos,n=Tt(h.options?.labels,e.labels),l=t.tickPositions,c=a===l[0],d=a===l[l.length-1],p=(!n.step||n.step===1)&&t.tickInterval===1,g=l.info,u=h.label,x,m,f,y=this.parameters.category||(s?Tt(s[a],r[a],a):a);o&&gi(y)&&(y=pi(o.lin2log(y))),t.dateTime&&(g?x=(m=i.time.resolveDTLFormat(e.dateTimeLabelFormats[!e.grid?.enabled&&g.higherRanks[a]||g.unitName])).main:gi(y)&&(x=t.dateTime.getXDateFormat(y,e.dateTimeLabelFormats||{}))),h.isFirst=c,h.isLast=d;let b={axis:t,chart:i,dateTimeLabelFormat:x,isFirst:c,isLast:d,pos:a,tick:h,tickPositionInfo:g,value:y};Be(this,"labelFormat",b);let v=k=>n.formatter?n.formatter.call(k,k):n.format?(k.text=t.defaultLabelFormatter.call(k),yt.format(n.format,k,i)):t.defaultLabelFormatter.call(k),S=v.call(b,b),w=m?.list;w?h.shortenLabel=function(){for(f=0;f<w.length;f++)if(kr(b,{dateTimeLabelFormat:w[f]}),u.attr({text:v.call(b,b)}),u.getBBox().width<t.getSlotWidth(h)-2*(n.padding||0))return;u.attr({text:""})}:h.shortenLabel=void 0,p&&t._addedPlotLB&&h.moveLabel(S,n),vs(u)||h.movedLabel?u&&u.textStr!==S&&!p&&(!u.textWidth||n.style.width||u.styles.width||u.css({width:null}),u.attr({text:S}),u.textPxLength=u.getBBox().width):(h.label=u=h.createLabel(S,n),h.rotation=0)}createLabel(h,t,e){let i=this.axis,{renderer:s,styledMode:o}=i.chart,r=t.style.whiteSpace,a=vs(h)&&t.enabled?s.text(h,e?.x,e?.y,t.useHTML).add(i.labelGroup):void 0;return a&&(o||a.css(sl(t.style)),a.textPxLength=a.getBBox().width,!o&&r&&a.css({whiteSpace:r})),a}destroy(){el(this,this.axis)}getPosition(h,t,e,i){let s=this.axis,o=s.chart,r=i&&o.oldChartHeight||o.chartHeight,a={x:h?pi(s.translate(t+e,void 0,void 0,i)+s.transB):s.left+s.offset+(s.opposite?(i&&o.oldChartWidth||o.chartWidth)-s.right-s.left:0),y:h?r-s.bottom+s.offset-(s.opposite?s.height:0):pi(r-s.translate(t+e,void 0,void 0,i)-s.transB)};return a.y=tl(a.y,-1e9,1e9),Be(this,"afterGetPosition",{pos:a}),a}getLabelPosition(h,t,e,i,s,o,r,a){let n,l,c=this.axis,d=c.transA,p=c.isLinked&&c.linkedParent?c.linkedParent.reversed:c.reversed,g=c.staggerLines,u=c.tickRotCorr||{x:0,y:0},x=i||c.reserveSpaceDefault?0:-c.labelOffset*(c.labelAlign==="center"?.5:1),m=s.distance,f={};return n=c.side===0?e.rotation?-m:-e.getBBox().height:c.side===2?u.y+m:Math.cos(e.rotation*bs)*(u.y-e.getBBox(!1,0).height/2),vs(s.y)&&(n=c.side===0&&c.horiz?s.y+n:s.y),h=h+Tt(s.x,[0,1,0,-1][c.side]*m)+x+u.x-(o&&i?o*d*(p?-1:1):0),t=t+n-(o&&!i?o*d*(p?1:-1):0),g&&(l=r/(a||1)%g,c.opposite&&(l=g-l-1),t+=l*(c.labelOffset/g)),f.x=h,f.y=Math.round(t),Be(this,"afterGetLabelPosition",{pos:f,tickmarkOffset:o,index:r}),f}getLabelSize(){return this.label?this.label.getBBox()[this.axis.horiz?"height":"width"]:0}getMarkPath(h,t,e,i,s=!1,o){return o.crispLine([["M",h,t],["L",h+(s?0:-e),t+(s?e:0)]],i)}handleOverflow(h){let t=this.axis,e=t.options.labels,i=h.x,s=t.chart.chartWidth,o=t.chart.spacing,r=Tt(t.labelLeft,Math.min(t.pos,o[3])),a=Tt(t.labelRight,Math.max(t.isRadial?0:t.pos+t.len,s-o[1])),n=this.label,l=this.rotation,c=il(t.labelAlign||n.attr("align")),d=n.getBBox().width,p=t.getSlotWidth(this),g=p,u=1,x;l||e.overflow!=="justify"?l<0&&i-c*d<r?x=Math.round(i/Math.cos(l*bs)-r):l>0&&i+c*d>a&&(x=Math.round((s-i)/Math.cos(l*bs))):(i-c*d<r?g=h.x+g*(1-c)-r:i+(1-c)*d>a&&(g=a-h.x+g*c,u=-1),(g=Math.min(p,g))<p&&t.labelAlign==="center"&&(h.x+=u*(p-g-c*(p-Math.min(d,g)))),(d>g||t.autoRotation&&n?.styles?.width)&&(x=g)),x&&n&&(this.shortenLabel?this.shortenLabel():n.css(kr({},{width:Math.floor(x)+"px",lineClamp:+!t.isRadial})))}moveLabel(h,t){let e=this,i=e.label,s=e.axis,o=!1,r;i&&i.textStr===h?(e.movedLabel=i,o=!0,delete e.label):ol(s.ticks,function(a){o||a.isNew||a===e||!a.label||a.label.textStr!==h||(e.movedLabel=a.label,o=!0,a.labelPos=e.movedLabel.xy,delete a.label)}),!o&&(e.labelPos||i)&&(r=e.labelPos||i.xy,e.movedLabel=e.createLabel(h,t,r),e.movedLabel&&e.movedLabel.attr({opacity:0}))}render(h,t,e){let i=this.axis,s=i.horiz,o=this.pos,r=Tt(this.tickmarkOffset,i.tickmarkOffset),a=this.getPosition(s,o,r,t),n=a.x,l=a.y,c=i.pos,d=c+i.len,p=s?n:l,g=Tt(e,this.label?.newOpacity,1);!i.chart.polar&&(pi(p)<c||p>d)&&(e=0),e??(e=1),this.isActive=!0,this.renderGridLine(t,e),this.renderMark(a,e),this.renderLabel(a,t,g,h),this.isNew=!1,Be(this,"afterRender")}renderGridLine(h,t){let e=this.axis,i=e.options,s={},o=this.pos,r=this.type,a=Tt(this.tickmarkOffset,e.tickmarkOffset),n=e.chart.renderer,l=this.gridLine,c,d=i.gridLineWidth,p=i.gridLineColor,g=i.gridLineDashStyle;this.type==="minor"&&(d=i.minorGridLineWidth,p=i.minorGridLineColor,g=i.minorGridLineDashStyle),l||(e.chart.styledMode||(s.stroke=p,s["stroke-width"]=d||0,s.dashstyle=g),r||(s.zIndex=1),h&&(t=0),this.gridLine=l=n.path().attr(s).addClass("highcharts-"+(r?r+"-":"")+"grid-line").add(e.gridGroup)),l&&(c=e.getPlotLinePath({value:o+a,lineWidth:l.strokeWidth(),force:"pass",old:h,acrossPanes:!1}))&&l[h||this.isNew?"attr":"animate"]({d:c,opacity:t})}renderMark(h,t){let e=this.axis,i=e.options,s=e.chart.renderer,o=this.type,r=e.tickSize(o?o+"Tick":"tick"),a=h.x,n=h.y,l=Tt(i[o!=="minor"?"tickWidth":"minorTickWidth"],!o&&e.isXAxis?1:0),c=i[o!=="minor"?"tickColor":"minorTickColor"],d=this.mark,p=!d;r&&(e.opposite&&(r[0]=-r[0]),!d&&(this.mark=d=s.path().addClass("highcharts-"+(o?o+"-":"")+"tick").add(e.axisGroup),e.chart.styledMode||d.attr({stroke:c,"stroke-width":l})),d[p?"attr":"animate"]({d:this.getMarkPath(a,n,r[0],d.strokeWidth(),e.horiz,s),opacity:t}))}renderLabel(h,t,e,i){let s=this.axis,o=s.horiz,r=s.options,a=this.label,n=r.labels,l=n.step,c=Tt(this.tickmarkOffset,s.tickmarkOffset),d=h.x,p=h.y,g=!0;a&&gi(d)&&(a.xy=h=this.getLabelPosition(d,p,a,o,n,c,i,l),(!this.isFirst||this.isLast||r.showFirstLabel)&&(!this.isLast||this.isFirst||r.showLastLabel)?!o||n.step||n.rotation||t||e===0||this.handleOverflow(h):g=!1,l&&i%l&&(g=!1),g&&gi(h.y)?(h.opacity=e,a[this.isNewLabel?"attr":"animate"](h).show(!0),this.isNewLabel=!1):(a.hide(),this.isNewLabel=!0))}replaceMovedLabel(){let h=this.label,t=this.axis;h&&!this.isNew&&(h.animate({opacity:0},void 0,h.destroy),delete this.label),t.isDirty=!0,this.label=this.movedLabel,delete this.movedLabel}},{animObject:rl}=at,{xAxis:wr,yAxis:al}=qh,{defaultOptions:so}=xt,{registerEventOptions:nl}=Ki,{deg2rad:hl}=P,{arrayMax:Mr,arrayMin:ll,clamp:ks,correctFloat:ft,defined:q,destroyObjectProperties:dl,erase:Sr,error:ws,extend:Ni,fireEvent:_,getClosestDistance:Tr,insertItem:cl,isArray:Cr,isNumber:z,isString:Ar,merge:zi,normalizeTickInterval:pl,objectEach:ui,pick:H,relativeLength:fi,removeEvent:gl,splat:ul,syncTimeout:fl}=N,Pr=(h,t)=>pl(t,void 0,void 0,H(h.options.allowDecimals,t<.5||h.tickAmount!==void 0),!!h.tickAmount);Ni(so,{xAxis:wr,yAxis:zi(wr,al)});var oo=(()=>{class h{constructor(e,i,s){this.init(e,i,s)}init(e,i,s=this.coll){let o=s==="xAxis",r=this.isZAxis||(e.inverted?!o:o);this.chart=e,this.horiz=r,this.isXAxis=o,this.coll=s,_(this,"init",{userOptions:i}),this.opposite=H(i.opposite,this.opposite),this.side=H(i.side,this.side,r?2*!this.opposite:this.opposite?1:3),this.setOptions(i);let a=this.options,n=a.labels;this.type??(this.type=a.type||"linear"),this.uniqueNames??(this.uniqueNames=a.uniqueNames??!0),_(this,"afterSetType"),this.userOptions=i,this.minPixelPadding=0,this.reversed=H(a.reversed,this.reversed),this.visible=a.visible,this.zoomEnabled=a.zoomEnabled,this.hasNames=this.type==="category"||a.categories===!0,this.categories=Cr(a.categories)&&a.categories||(this.hasNames?[]:void 0),this.names||(this.names=[],this.names.keys={}),this.plotLinesAndBandsGroups={},this.positiveValuesOnly=!!this.logarithmic,this.isLinked=q(a.linkedTo),this.ticks={},this.labelEdge=[],this.minorTicks={},this.plotLinesAndBands=[],this.alternateBands={},this.len??(this.len=0),this.minRange=this.userMinRange=a.minRange||a.maxZoom,this.range=a.range,this.offset=a.offset||0,this.max=void 0,this.min=void 0;let l=H(a.crosshair,ul(e.options.tooltip.crosshairs)[+!o]);this.crosshair=l===!0?{}:l,e.axes.indexOf(this)===-1&&(o?e.axes.splice(e.xAxis.length,0,this):e.axes.push(this),cl(this,e[this.coll])),e.orderItems(this.coll),this.series=this.series||[],e.inverted&&!this.isZAxis&&o&&!q(this.reversed)&&(this.reversed=!0),this.labelRotation=z(n.rotation)?n.rotation:void 0,nl(this,a),_(this,"afterInit")}setOptions(e){let i=this.horiz?{labels:{autoRotation:[-45],padding:3},margin:15}:{labels:{padding:1},title:{rotation:90*this.side}};this.options=zi(i,this.coll==="yAxis"?{title:{text:this.chart.options.lang.yAxisTitle}}:{},so[this.coll],e),_(this,"afterSetOptions",{userOptions:e})}defaultLabelFormatter(){let e=this.axis,{numberFormatter:i}=this.chart,s=z(this.value)?this.value:NaN,o=e.chart.time,r=e.categories,a=this.dateTimeLabelFormat,n=so.lang,l=n.numericSymbols,c=n.numericSymbolMagnitude||1e3,d=e.logarithmic?Math.abs(s):e.tickInterval,p=l?.length,g,u;if(r)u=`${this.value}`;else if(a)u=o.dateFormat(a,s,!0);else if(p&&l&&d>=1e3)for(;p--&&u===void 0;)d>=(g=Math.pow(c,p+1))&&10*s%g==0&&l[p]!==null&&s!==0&&(u=i(s/g,-1)+l[p]);return u===void 0&&(u=Math.abs(s)>=1e4?i(s,-1):i(s,-1,void 0,"")),u}getSeriesExtremes(){let e,i=this;_(this,"getSeriesExtremes",null,function(){i.hasVisibleSeries=!1,i.dataMin=i.dataMax=i.threshold=void 0,i.softThreshold=!i.isXAxis,i.series.forEach(s=>{if(s.reserveSpace()){let o=s.options,r,a=o.threshold,n,l;if(i.hasVisibleSeries=!0,i.positiveValuesOnly&&0>=(a||0)&&(a=void 0),i.isXAxis)(r=s.getColumn("x")).length&&(r=i.logarithmic?r.filter(c=>c>0):r,n=(e=s.getXExtremes(r)).min,l=e.max,z(n)||n instanceof Date||(r=r.filter(z),n=(e=s.getXExtremes(r)).min,l=e.max),r.length&&(i.dataMin=Math.min(H(i.dataMin,n),n),i.dataMax=Math.max(H(i.dataMax,l),l)));else{let c=s.applyExtremes();z(c.dataMin)&&(n=c.dataMin,i.dataMin=Math.min(H(i.dataMin,n),n)),z(c.dataMax)&&(l=c.dataMax,i.dataMax=Math.max(H(i.dataMax,l),l)),q(a)&&(i.threshold=a),(!o.softThreshold||i.positiveValuesOnly)&&(i.softThreshold=!1)}}})}),_(this,"afterGetSeriesExtremes")}translate(e,i,s,o,r,a){let n=this.linkedParent||this,l=o&&n.old?n.old.min:n.min;if(!z(l))return NaN;let c=n.minPixelPadding,d=(n.isOrdinal||n.brokenAxis?.hasBreaks||n.logarithmic&&r)&&!!n.lin2val,p=1,g=0,u=o&&n.old?n.old.transA:n.transA,x=0;return u||(u=n.transA),s&&(p*=-1,g=n.len),n.reversed&&(p*=-1,g-=p*(n.sector||n.len)),i?(x=(e=e*p+g-c)/u+l,d&&(x=n.lin2val(x))):(d&&(e=n.val2lin(e)),x=p*(e-l)*u+g+p*c+(z(a)?u*a:0),n.isRadial||(x=ft(x))),x}toPixels(e,i){return this.translate(this.chart?.time.parse(e)??NaN,!1,!this.horiz,void 0,!0)+(i?0:this.pos)}toValue(e,i){return this.translate(e-(i?0:this.pos),!0,!this.horiz,void 0,!0)}getPlotLinePath(e){let i=this,s=i.chart,o=i.left,r=i.top,a=e.old,n=e.value,l=e.lineWidth,c=a&&s.oldChartHeight||s.chartHeight,d=a&&s.oldChartWidth||s.chartWidth,p=i.transB,g=e.translatedValue,u=e.force,x,m,f,y,b;function v(w,k,M){return u!=="pass"&&(w<k||w>M)&&(u?w=ks(w,k,M):b=!0),w}let S={value:n,lineWidth:l,old:a,force:u,acrossPanes:e.acrossPanes,translatedValue:g};return _(this,"getPlotLinePath",S,function(w){x=f=(g=ks(g=H(g,i.translate(n,void 0,void 0,a)),-1e9,1e9))+p,m=y=c-g-p,z(g)?i.horiz?(m=r,y=c-i.bottom+(i.options.isInternal?0:s.scrollablePixelsY||0),x=f=v(x,o,o+i.width)):(x=o,f=d-i.right+(s.scrollablePixelsX||0),m=y=v(m,r,r+i.height)):(b=!0,u=!1),w.path=b&&!u?void 0:s.renderer.crispLine([["M",x,m],["L",f,y]],l||1)}),S.path}getLinearTickPositions(e,i,s){let o,r,a,n=ft(Math.floor(i/e)*e),l=ft(Math.ceil(s/e)*e),c=[];if(ft(n+e)===n&&(a=20),this.single)return[i];for(o=n;o<=l&&(c.push(o),(o=ft(o+e,a))!==r);)r=o;return c}getMinorTickInterval(){let{minorTicks:e,minorTickInterval:i}=this.options;return e===!0?H(i,"auto"):e!==!1?i:void 0}getMinorTickPositions(){let e=this.options,i=this.tickPositions,s=this.minorTickInterval,o=this.pointRangePadding||0,r=(this.min||0)-o,a=(this.max||0)+o,n=this.brokenAxis?.hasBreaks?this.brokenAxis.unitLength:a-r,l=[],c;if(n&&n/s<this.len/3){let d=this.logarithmic;if(d)this.paddedTicks.forEach(function(p,g,u){g&&l.push.apply(l,d.getLogTickPositions(s,u[g-1],u[g],!0))});else if(this.dateTime&&this.getMinorTickInterval()==="auto")l=l.concat(this.getTimeTicks(this.dateTime.normalizeTimeTickInterval(s),r,a,e.startOfWeek));else for(c=r+(i[0]-r)%s;c<=a&&c!==l[0];c+=s)l.push(c)}return l.length!==0&&this.trimTicks(l),l}adjustForMinRange(){let e=this.options,i=this.logarithmic,s=this.chart.time,{max:o,min:r,minRange:a}=this,n,l,c,d;this.isXAxis&&a===void 0&&!i&&(a=q(e.min)||q(e.max)||q(e.floor)||q(e.ceiling)?null:Math.min(5*(Tr(this.series.map(p=>{let g=p.getColumn("x");return p.xIncrement?g.slice(0,2):g}))||0),this.dataMax-this.dataMin)),z(o)&&z(r)&&z(a)&&o-r<a&&(l=this.dataMax-this.dataMin>=a,n=(a-o+r)/2,c=[r-n,s.parse(e.min)??r-n],l&&(c[2]=i?i.log2lin(this.dataMin):this.dataMin),d=[(r=Mr(c))+a,s.parse(e.max)??r+a],l&&(d[2]=i?i.log2lin(this.dataMax):this.dataMax),(o=ll(d))-r<a&&(c[0]=o-a,c[1]=s.parse(e.min)??o-a,r=Mr(c))),this.minRange=a,this.min=r,this.max=o}getClosest(){let e,i;if(this.categories)i=1;else{let s=[];this.series.forEach(function(o){let r=o.closestPointRange,a=o.getColumn("x");a.length===1?s.push(a[0]):o.sorted&&q(r)&&o.reserveSpace()&&(i=q(i)?Math.min(i,r):r)}),s.length&&(s.sort((o,r)=>o-r),e=Tr([s]))}return e&&i?Math.min(e,i):e||i}nameToX(e){let i=Cr(this.options.categories),s=i?this.categories:this.names,o=e.options.x,r;return e.series.requireSorting=!1,q(o)||(o=this.uniqueNames&&s?i?s.indexOf(e.name):H(s.keys[e.name],-1):e.series.autoIncrement()),o===-1?!i&&s&&(r=s.length):z(o)&&(r=o),r!==void 0?(this.names[r]=e.name,this.names.keys[e.name]=r):e.x&&(r=e.x),r}updateNames(){let e=this,i=this.names;i.length>0&&(Object.keys(i.keys).forEach(function(s){delete i.keys[s]}),i.length=0,this.minRange=this.userMinRange,(this.series||[]).forEach(s=>{s.xIncrement=null,(!s.points||s.isDirtyData)&&(e.max=Math.max(e.max||0,s.dataTable.rowCount-1),s.processData(),s.generatePoints());let o=s.getColumn("x").slice();s.data.forEach((r,a)=>{let n=o[a];r?.options&&r.name!==void 0&&(n=e.nameToX(r))!==void 0&&n!==r.x&&(o[a]=r.x=n)}),s.dataTable.setColumn("x",o)}))}setAxisTranslation(){let e=this,i=e.max-e.min,s=e.linkedParent,o=!!e.categories,r=e.isXAxis,a=e.axisPointRange||0,n,l=0,c=0,d,p=e.transA;(r||o||a)&&(n=e.getClosest(),s?(l=s.minPointOffset,c=s.pointRangePadding):e.series.forEach(function(g){let u=o?1:r?H(g.options.pointRange,n,0):e.axisPointRange||0,x=g.options.pointPlacement;if(a=Math.max(a,u),!e.single||o){let m=g.is("xrange")?!r:r;l=Math.max(l,m&&Ar(x)?0:u/2),c=Math.max(c,m&&x==="on"?0:u)}}),d=e.ordinal?.slope&&n?e.ordinal.slope/n:1,e.minPointOffset=l*=d,e.pointRangePadding=c*=d,e.pointRange=Math.min(a,e.single&&o?1:i),r&&(e.closestPointRange=n)),e.translationSlope=e.transA=p=e.staticScale||e.len/(i+c||1),e.transB=e.horiz?e.left:e.bottom,e.minPixelPadding=p*l,_(this,"afterSetAxisTranslation")}minFromRange(){let{max:e,min:i}=this;return z(e)&&z(i)&&e-i||void 0}setTickInterval(e){let{categories:i,chart:s,dataMax:o,dataMin:r,dateTime:a,isXAxis:n,logarithmic:l,options:c,softThreshold:d}=this,p=s.time,g=z(this.threshold)?this.threshold:void 0,u=this.minRange||0,{ceiling:x,floor:m,linkedTo:f,softMax:y,softMin:b}=c,v=z(f)&&s[this.coll]?.[f],S=c.tickPixelInterval,w=c.maxPadding,k=c.minPadding,M=0,T,A=z(c.tickInterval)&&c.tickInterval>=0?c.tickInterval:void 0,C,O,D,B;if(a||i||v||this.getTickAmount(),D=H(this.userMin,p.parse(c.min)),B=H(this.userMax,p.parse(c.max)),v?(this.linkedParent=v,T=v.getExtremes(),this.min=H(T.min,T.dataMin),this.max=H(T.max,T.dataMax),this.type!==v.type&&ws(11,!0,s)):(d&&q(g)&&z(o)&&z(r)&&(r>=g?(C=g,k=0):o<=g&&(O=g,w=0)),this.min=H(D,C,r),this.max=H(B,O,o)),z(this.max)&&z(this.min)&&(l&&(this.positiveValuesOnly&&!e&&0>=Math.min(this.min,H(r,this.min))&&ws(10,!0,s),this.min=ft(l.log2lin(this.min),16),this.max=ft(l.log2lin(this.max),16)),this.range&&z(r)&&(this.userMin=this.min=D=Math.max(r,this.minFromRange()||0),this.userMax=B=this.max,this.range=void 0)),_(this,"foundExtremes"),this.adjustForMinRange(),z(this.min)&&z(this.max)){if(!z(this.userMin)&&z(b)&&b<this.min&&(this.min=D=b),!z(this.userMax)&&z(y)&&y>this.max&&(this.max=B=y),i||this.axisPointRange||this.stacking?.usePercentage||v||(M=this.max-this.min)&&(!q(D)&&k&&(this.min-=M*k),!q(B)&&w&&(this.max+=M*w)),!z(this.userMin)&&z(m)&&(this.min=Math.max(this.min,m)),!z(this.userMax)&&z(x)&&(this.max=Math.min(this.max,x)),d&&z(r)&&z(o)){let L=g||0;!q(D)&&this.min<L&&r>=L?this.min=c.minRange?Math.min(L,this.max-u):L:!q(B)&&this.max>L&&o<=L&&(this.max=c.minRange?Math.max(L,this.min+u):L)}!s.polar&&this.min>this.max&&(q(c.min)?this.max=this.min:q(c.max)&&(this.min=this.max)),M=this.max-this.min}if(this.min!==this.max&&z(this.min)&&z(this.max)?v&&!A&&S===v.options.tickPixelInterval?this.tickInterval=A=v.tickInterval:this.tickInterval=H(A,this.tickAmount?M/Math.max(this.tickAmount-1,1):void 0,i?1:M*S/Math.max(this.len,S)):this.tickInterval=1,n&&!e){let L=this.min!==this.old?.min||this.max!==this.old?.max;this.series.forEach(function(I){I.forceCrop=I.forceCropping?.(),I.processData(L)}),_(this,"postProcessData",{hasExtremesChanged:L})}this.setAxisTranslation(),_(this,"initialAxisTranslation"),this.pointRange&&!A&&(this.tickInterval=Math.max(this.pointRange,this.tickInterval));let E=H(c.minTickInterval,a&&!this.series.some(L=>!L.sorted)?this.closestPointRange:0);!A&&E&&this.tickInterval<E&&(this.tickInterval=E),a||l||A||(this.tickInterval=Pr(this,this.tickInterval)),this.tickAmount||(this.tickInterval=this.unsquish()),this.setTickPositions()}setTickPositions(){let e=this.options,i=e.tickPositions,s=e.tickPositioner,o=this.getMinorTickInterval(),r=!this.isPanning,a=r&&e.startOnTick,n=r&&e.endOnTick,l=[],c;if(this.tickmarkOffset=this.categories&&e.tickmarkPlacement==="between"&&this.tickInterval===1?.5:0,this.single=this.min===this.max&&q(this.min)&&!this.tickAmount&&(this.min%1==0||e.allowDecimals!==!1),i)l=i.slice();else if(z(this.min)&&z(this.max)){if(!this.ordinal?.positions&&(this.max-this.min)/this.tickInterval>Math.max(2*this.len,200))l=[this.min,this.max],ws(19,!1,this.chart);else if(this.dateTime)l=this.getTimeTicks(this.dateTime.normalizeTimeTickInterval(this.tickInterval,e.units),this.min,this.max,e.startOfWeek,this.ordinal?.positions,this.closestPointRange,!0);else if(this.logarithmic)l=this.logarithmic.getLogTickPositions(this.tickInterval,this.min,this.max);else{let d=this.tickInterval,p=d;for(;p<=2*d&&(l=this.getLinearTickPositions(this.tickInterval,this.min,this.max),this.tickAmount&&l.length>this.tickAmount);)this.tickInterval=Pr(this,p*=1.1)}l.length>this.len&&(l=[l[0],l[l.length-1]])[0]===l[1]&&(l.length=1),s&&(this.tickPositions=l,(c=s.apply(this,[this.min,this.max]))&&(l=c))}this.tickPositions=l,this.minorTickInterval=o==="auto"&&this.tickInterval?this.tickInterval/e.minorTicksPerMajor:o,this.paddedTicks=l.slice(0),this.trimTicks(l,a,n),!this.isLinked&&z(this.min)&&z(this.max)&&(this.single&&l.length<2&&!this.categories&&!this.series.some(d=>d.is("heatmap")&&d.options.pointPlacement==="between")&&(this.min-=.5,this.max+=.5),i||c||this.adjustTickAmount()),_(this,"afterSetTickPositions")}trimTicks(e,i,s){let o=e[0],r=e[e.length-1],a=!this.isOrdinal&&this.minPointOffset||0;if(_(this,"trimTicks"),!this.isLinked||!this.grid){if(i&&o!==-1/0)this.min=o;else for(;this.min-a>e[0];)e.shift();if(s)this.max=r;else for(;this.max+a<e[e.length-1];)e.pop();e.length===0&&q(o)&&!this.options.tickPositions&&e.push((r+o)/2)}}alignToOthers(){let e,i=this,s=i.chart,o=[this],r=i.options,a=s.options.chart,n=this.coll==="yAxis"&&a.alignThresholds,l=[];if(i.thresholdAlignment=void 0,(a.alignTicks!==!1&&r.alignTicks||n)&&r.startOnTick!==!1&&r.endOnTick!==!1&&!i.logarithmic){let c=p=>{let{horiz:g,options:u}=p;return[g?u.left:u.top,u.width,u.height,u.pane].join(",")},d=c(this);s[this.coll].forEach(function(p){let{series:g}=p;g.length&&g.some(u=>u.visible)&&p!==i&&c(p)===d&&(e=!0,o.push(p))})}if(e&&n){o.forEach(d=>{let p=d.getThresholdAlignment(i);z(p)&&l.push(p)});let c=l.length>1?l.reduce((d,p)=>d+=p,0)/l.length:void 0;o.forEach(d=>{d.thresholdAlignment=c})}return e}getThresholdAlignment(e){if((!z(this.dataMin)||this!==e&&this.series.some(i=>i.isDirty||i.isDirtyData))&&this.getSeriesExtremes(),z(this.threshold)){let i=ks((this.threshold-(this.dataMin||0))/((this.dataMax||0)-(this.dataMin||0)),0,1);return this.options.reversed&&(i=1-i),i}}getTickAmount(){let e=this.options,i=e.tickPixelInterval,s=e.tickAmount;q(e.tickInterval)||s||!(this.len<i)||this.isRadial||this.logarithmic||!e.startOnTick||!e.endOnTick||(s=2),!s&&this.alignToOthers()&&(s=Math.ceil(this.len/i)+1),s<4&&(this.finalTickAmt=s,s=5),this.tickAmount=s}adjustTickAmount(){let e=this,{finalTickAmt:i,max:s,min:o,options:r,tickPositions:a,tickAmount:n,thresholdAlignment:l}=e,c=a?.length,d=H(e.threshold,e.softThreshold?0:null),p,g,u=e.tickInterval,x,m=()=>a.push(ft(a[a.length-1]+u)),f=()=>a.unshift(ft(a[0]-u));if(z(l)&&(x=l<.5?Math.ceil(l*(n-1)):Math.floor(l*(n-1)),r.reversed&&(x=n-1-x)),e.hasData()&&z(o)&&z(s)){let y=()=>{e.transA*=(c-1)/(n-1),e.min=r.startOnTick?a[0]:Math.min(o,a[0]),e.max=r.endOnTick?a[a.length-1]:Math.max(s,a[a.length-1])};if(z(x)&&z(e.threshold)){for(;a[x]!==d||a.length!==n||a[0]>o||a[a.length-1]<s;){for(a.length=0,a.push(e.threshold);a.length<n;)a[x]===void 0||a[x]>e.threshold?f():m();if(u>8*e.tickInterval)break;u*=2}y()}else if(c<n){for(;a.length<n;)a.length%2||o===d?m():f();y()}if(q(i)){for(g=p=a.length;g--;)(i===3&&g%2==1||i<=2&&g>0&&g<p-1)&&a.splice(g,1);e.finalTickAmt=void 0}}}setScale(){let{coll:e,stacking:i}=this,s=!1,o=!1;this.series.forEach(a=>{s=s||a.isDirtyData||a.isDirty,o=o||a.xAxis?.isDirty||!1}),this.setAxisSize();let r=this.len!==this.old?.len;r||s||o||this.isLinked||this.forceRedraw||this.userMin!==this.old?.userMin||this.userMax!==this.old?.userMax||this.alignToOthers()?(i&&e==="yAxis"&&i.buildStacks(),this.forceRedraw=!1,this.userMinRange||(this.minRange=void 0),this.getSeriesExtremes(),this.setTickInterval(),i&&e==="xAxis"&&i.buildStacks(),this.isDirty||(this.isDirty=r||this.min!==this.old?.min||this.max!==this.old?.max)):i&&i.cleanStacks(),s&&delete this.allExtremes,_(this,"afterSetScale")}setExtremes(e,i,s=!0,o,r){let a=this.chart;this.series.forEach(n=>{delete n.kdTree}),e=a.time.parse(e),i=a.time.parse(i),_(this,"setExtremes",r=Ni(r,{min:e,max:i}),n=>{this.userMin=n.min,this.userMax=n.max,this.eventArgs=n,s&&a.redraw(o)})}setAxisSize(){let e=this.chart,i=this.options,s=i.offsets||[0,0,0,0],o=this.horiz,r=this.width=Math.round(fi(H(i.width,e.plotWidth-s[3]+s[1]),e.plotWidth)),a=this.height=Math.round(fi(H(i.height,e.plotHeight-s[0]+s[2]),e.plotHeight)),n=this.top=Math.round(fi(H(i.top,e.plotTop+s[0]),e.plotHeight,e.plotTop)),l=this.left=Math.round(fi(H(i.left,e.plotLeft+s[3]),e.plotWidth,e.plotLeft));this.bottom=e.chartHeight-a-n,this.right=e.chartWidth-r-l,this.len=Math.max(o?r:a,0),this.pos=o?l:n}getExtremes(){let e=this.logarithmic;return{min:e?ft(e.lin2log(this.min)):this.min,max:e?ft(e.lin2log(this.max)):this.max,dataMin:this.dataMin,dataMax:this.dataMax,userMin:this.userMin,userMax:this.userMax}}getThreshold(e){let i=this.logarithmic,s=i?i.lin2log(this.min):this.min,o=i?i.lin2log(this.max):this.max;return e===null||e===-1/0?e=s:e===1/0?e=o:s>e?e=s:o<e&&(e=o),this.translate(e,0,1,0,1)}autoLabelAlign(e){let i=(H(e,0)-90*this.side+720)%360,s={align:"center"};return _(this,"autoLabelAlign",s,function(o){i>15&&i<165?o.align="right":i>195&&i<345&&(o.align="left")}),s.align}tickSize(e){let i=this.options,s=H(i[e==="tick"?"tickWidth":"minorTickWidth"],e==="tick"&&this.isXAxis&&!this.categories?1:0),o=i[e==="tick"?"tickLength":"minorTickLength"],r;s&&o&&(i[e+"Position"]==="inside"&&(o=-o),r=[o,s]);let a={tickSize:r};return _(this,"afterTickSize",a),a.tickSize}labelMetrics(){let e=this.chart.renderer,i=this.ticks,s=i[Object.keys(i)[0]]||{};return this.chart.renderer.fontMetrics(s.label||s.movedLabel||e.box)}unsquish(){let e=this.options.labels,i=e.padding||0,s=this.horiz,o=this.tickInterval,r=this.len/((+!!this.categories+this.max-this.min)/o),a=e.rotation,n=ft(.8*this.labelMetrics().h),l=Math.max(this.max-this.min,0),c=function(x){let m=(x+2*i)/(r||1);return(m=m>1?Math.ceil(m):1)*o>l&&x!==1/0&&r!==1/0&&l&&(m=Math.ceil(l/o)),ft(m*o)},d=o,p,g=Number.MAX_VALUE,u;if(s){if(!e.staggerLines&&(z(a)?u=[a]:r<e.autoRotationLimit&&(u=e.autoRotation)),u){let x,m;for(let f of u)(f===a||f&&f>=-90&&f<=90)&&(m=(x=c(Math.abs(n/Math.sin(hl*f))))+Math.abs(f/360))<g&&(g=m,p=f,d=x)}}else d=c(.75*n);return this.autoRotation=u,this.labelRotation=H(p,z(a)?a:0),e.step?o:d}getSlotWidth(e){let i=this.chart,s=this.horiz,o=this.options.labels,r=Math.max(this.tickPositions.length-!this.categories,1),a=i.margin[3];if(e&&z(e.slotWidth))return e.slotWidth;if(s&&o.step<2&&!this.isRadial)return o.rotation?0:(this.staggerLines||1)*this.len/r;if(!s){let n=o.style.width;if(n!==void 0)return parseInt(String(n),10);if(!this.opposite&&a)return a-i.spacing[3]}return .33*i.chartWidth}renderUnsquish(){let e=this.chart,i=e.renderer,s=this.tickPositions,o=this.ticks,r=this.options.labels,a=r.style,n=this.horiz,l=this.getSlotWidth(),c=Math.max(1,Math.round(l-(n?2*(r.padding||0):r.distance||0))),d={},p=this.labelMetrics(),g=a.lineClamp,u,x=g??(Math.floor(this.len/(s.length*p.h))||1),m=0;Ar(r.rotation)||(d.rotation=r.rotation||0),s.forEach(function(f){let y=o[f];y.movedLabel&&y.replaceMovedLabel();let b=y.label?.textPxLength||0;b>m&&(m=b)}),this.maxLabelLength=m,this.autoRotation?m>c&&m>p.h?d.rotation=this.labelRotation:this.labelRotation=0:l&&(u=c),d.rotation&&(u=m>.5*e.chartHeight?.33*e.chartHeight:m,g||(x=1)),this.labelAlign=r.align||this.autoLabelAlign(this.labelRotation),this.labelAlign&&(d.align=this.labelAlign),s.forEach(function(f){let y=o[f],b=y?.label,v=a.width,S={};b&&(b.attr(d),y.shortenLabel?y.shortenLabel():u&&!v&&a.whiteSpace!=="nowrap"&&(u<(b.textPxLength||0)||b.element.tagName==="SPAN")?b.css(Ni(S,{width:`${u}px`,lineClamp:x})):!b.styles.width||S.width||v||b.css({width:"auto"}),y.rotation=d.rotation)},this),this.tickRotCorr=i.rotCorr(p.b,this.labelRotation||0,this.side!==0)}hasData(){return this.series.some(function(e){return e.hasData()})||this.options.showEmpty&&q(this.min)&&q(this.max)}addTitle(e){let i,s=this.chart.renderer,o=this.horiz,r=this.opposite,a=this.options.title,n=this.chart.styledMode;this.axisTitle||((i=a.textAlign)||(i=(o?{low:"left",middle:"center",high:"right"}:{low:r?"right":"left",middle:"center",high:r?"left":"right"})[a.align]),this.axisTitle=s.text(a.text||"",0,0,a.useHTML).attr({zIndex:7,rotation:a.rotation||0,align:i}).addClass("highcharts-axis-title"),n||this.axisTitle.css(zi(a.style)),this.axisTitle.add(this.axisGroup),this.axisTitle.isNew=!0),n||a.style.width||this.isRadial||this.axisTitle.css({width:this.len+"px"}),this.axisTitle[e?"show":"hide"](e)}generateTick(e){let i=this.ticks;i[e]?i[e].addLabel():i[e]=new be(this,e)}createGroups(){let{axisParent:e,chart:i,coll:s,options:o}=this,r=i.renderer,a=(n,l,c)=>r.g(n).attr({zIndex:c}).addClass(`highcharts-${s.toLowerCase()}${l} `+(this.isRadial?`highcharts-radial-axis${l} `:"")+(o.className||"")).add(e);this.axisGroup||(this.gridGroup=a("grid","-grid",o.gridZIndex),this.axisGroup=a("axis","",o.zIndex),this.labelGroup=a("axis-labels","-labels",o.labels.zIndex))}getOffset(){let e=this,{chart:i,horiz:s,options:o,side:r,ticks:a,tickPositions:n,coll:l}=e,c=i.inverted&&!e.isZAxis?[1,0,3,2][r]:r,d=e.hasData(),p=o.title,g=o.labels,u=z(o.crossing),x=i.axisOffset,m=i.clipOffset,f=[-1,1,1,-1][r],y,b=0,v,S=0,w=0,k,M;if(e.showAxis=y=d||o.showEmpty,e.staggerLines=e.horiz&&g.staggerLines||void 0,e.createGroups(),d||e.isLinked?(n.forEach(function(T){e.generateTick(T)}),e.renderUnsquish(),e.reserveSpaceDefault=r===0||r===2||{1:"left",3:"right"}[r]===e.labelAlign,H(g.reserveSpace,!u&&null,e.labelAlign==="center"||null,e.reserveSpaceDefault)&&n.forEach(function(T){w=Math.max(a[T].getLabelSize(),w)}),e.staggerLines&&(w*=e.staggerLines),e.labelOffset=w*(e.opposite?-1:1)):ui(a,function(T,A){T.destroy(),delete a[A]}),p?.text&&p.enabled!==!1&&(e.addTitle(y),y&&!u&&p.reserveSpace!==!1&&(e.titleOffset=b=e.axisTitle.getBBox()[s?"height":"width"],S=q(v=p.offset)?0:H(p.margin,s?5:10))),e.renderLine(),e.offset=f*H(o.offset,x[r]?x[r]+(o.margin||0):0),e.tickRotCorr=e.tickRotCorr||{x:0,y:0},M=r===0?-e.labelMetrics().h:r===2?e.tickRotCorr.y:0,k=Math.abs(w)+S,w&&(k-=M,k+=f*(s?H(g.y,e.tickRotCorr.y+f*g.distance):H(g.x,f*g.distance))),e.axisTitleMargin=H(v,k),e.getMaxLabelDimensions&&(e.maxLabelDimensions=e.getMaxLabelDimensions(a,n)),l!=="colorAxis"&&m){let T=this.tickSize("tick");x[r]=Math.max(x[r],(e.axisTitleMargin||0)+b+f*e.offset,k,n?.length&&T?T[0]+f*e.offset:0);let A=!e.axisLine||o.offset?0:e.axisLine.strokeWidth()/2;m[c]=Math.max(m[c],A)}_(this,"afterGetOffset")}getLinePath(e){let i=this.chart,s=this.opposite,o=this.offset,r=this.horiz,a=this.left+(s?this.width:0)+o,n=i.chartHeight-this.bottom-(s?this.height:0)+o;return s&&(e*=-1),i.renderer.crispLine([["M",r?this.left:a,r?n:this.top],["L",r?i.chartWidth-this.right:a,r?n:i.chartHeight-this.bottom]],e)}renderLine(){!this.axisLine&&(this.axisLine=this.chart.renderer.path().addClass("highcharts-axis-line").add(this.axisGroup),this.chart.styledMode||this.axisLine.attr({stroke:this.options.lineColor,"stroke-width":this.options.lineWidth,zIndex:7}))}getTitlePosition(e){let i=this.horiz,s=this.left,o=this.top,r=this.len,a=this.options.title,n=i?s:o,l=this.opposite,c=this.offset,d=a.x,p=a.y,g=this.chart.renderer.fontMetrics(e),u=e?Math.max(e.getBBox(!1,0).height-g.h-1,0):0,x={low:n+(i?0:r),middle:n+r/2,high:n+(i?r:0)}[a.align],m=(i?o+this.height:s)+(i?1:-1)*(l?-1:1)*(this.axisTitleMargin||0)+[-u,u,g.f,-u][this.side],f={x:i?x+d:m+(l?this.width:0)+c+d,y:i?m+p-(l?this.height:0)+c:x+p};return _(this,"afterGetTitlePosition",{titlePosition:f}),f}renderMinorTick(e,i){let s=this.minorTicks;s[e]||(s[e]=new be(this,e,"minor")),i&&s[e].isNew&&s[e].render(null,!0),s[e].render(null,!1,1)}renderTick(e,i,s){let o=this.isLinked,r=this.ticks;(!o||e>=this.min&&e<=this.max||this.grid?.isColumn)&&(r[e]||(r[e]=new be(this,e)),s&&r[e].isNew&&r[e].render(i,!0,-1),r[e].render(i))}render(){let e,i,s=this,o=s.chart,r=s.logarithmic,a=o.renderer,n=s.options,l=s.isLinked,c=s.tickPositions,d=s.axisTitle,p=s.ticks,g=s.minorTicks,u=s.alternateBands,x=n.stackLabels,m=n.alternateGridColor,f=n.crossing,y=s.tickmarkOffset,b=s.axisLine,v=s.showAxis,S=rl(a.globalAnimation);if(s.labelEdge.length=0,s.overlap=!1,[p,g,u].forEach(function(w){ui(w,function(k){k.isActive=!1})}),z(f)){let w=this.isXAxis?o.yAxis[0]:o.xAxis[0],k=[1,-1,-1,1][this.side];if(w){let M=w.toPixels(f,!0);s.horiz&&(M=w.len-M),s.offset=k*M}}if(s.hasData()||l){let w=s.chart.hasRendered&&s.old&&z(s.old.min);s.minorTickInterval&&!s.categories&&s.getMinorTickPositions().forEach(function(k){s.renderMinorTick(k,w)}),c.length&&(c.forEach(function(k,M){s.renderTick(k,M,w)}),y&&(s.min===0||s.single)&&(p[-1]||(p[-1]=new be(s,-1,null,!0)),p[-1].render(-1))),m&&c.forEach(function(k,M){i=c[M+1]!==void 0?c[M+1]+y:s.max-y,M%2==0&&k<s.max&&i<=s.max+(o.polar?-y:y)&&(u[k]||(u[k]=new P.PlotLineOrBand(s,{})),e=k+y,u[k].options={from:r?r.lin2log(e):e,to:r?r.lin2log(i):i,color:m,className:"highcharts-alternate-grid"},u[k].render(),u[k].isActive=!0)}),s._addedPlotLB||(s._addedPlotLB=!0,(n.plotLines||[]).concat(n.plotBands||[]).forEach(function(k){s.addPlotBandOrLine(k)}))}[p,g,u].forEach(function(w){let k=[],M=S.duration;ui(w,function(T,A){T.isActive||(T.render(A,!1,0),T.isActive=!1,k.push(A))}),fl(function(){let T=k.length;for(;T--;)w[k[T]]&&!w[k[T]].isActive&&(w[k[T]].destroy(),delete w[k[T]])},w!==u&&o.hasRendered&&M?M:0)}),b&&(b[b.isPlaced?"animate":"attr"]({d:this.getLinePath(b.strokeWidth())}),b.isPlaced=!0,b[v?"show":"hide"](v)),d&&v&&(d[d.isNew?"attr":"animate"](s.getTitlePosition(d)),d.isNew=!1),x?.enabled&&s.stacking&&s.stacking.renderStackTotals(),s.old={len:s.len,max:s.max,min:s.min,transA:s.transA,userMax:s.userMax,userMin:s.userMin},s.isDirty=!1,_(this,"afterRender")}redraw(){this.visible&&(this.render(),this.plotLinesAndBands.forEach(function(e){e.render()})),this.series.forEach(function(e){e.isDirty=!0})}getKeepProps(){return this.keepProps||h.keepProps}destroy(e){let i=this,s=i.plotLinesAndBands,o=this.eventOptions;if(_(this,"destroy",{keepEvents:e}),e||gl(i),[i.ticks,i.minorTicks,i.alternateBands].forEach(function(r){dl(r)}),s){let r=s.length;for(;r--;)s[r].destroy()}for(let r in["axisLine","axisTitle","axisGroup","gridGroup","labelGroup","cross","scrollbar"].forEach(function(a){i[a]&&(i[a]=i[a].destroy())}),i.plotLinesAndBandsGroups)i.plotLinesAndBandsGroups[r]=i.plotLinesAndBandsGroups[r].destroy();ui(i,function(r,a){i.getKeepProps().indexOf(a)===-1&&delete i[a]}),this.eventOptions=o}drawCrosshair(e,i){let s=this.crosshair,o=s?.snap??!0,r=this.chart,a,n,l,c=this.cross,d;if(_(this,"drawCrosshair",{e,point:i}),e||(e=this.cross?.e),s&&(q(i)||!o)!==!1){if(o?q(i)&&(n=H(this.coll!=="colorAxis"?i.crosshairPos:null,this.isXAxis?i.plotX:this.len-i.plotY)):n=e&&(this.horiz?e.chartX-this.pos:this.len-e.chartY+this.pos),q(n)&&(d={value:i&&(this.isXAxis?i.x:H(i.stackY,i.y)),translatedValue:n},r.polar&&Ni(d,{isCrosshair:!0,chartX:e?.chartX,chartY:e?.chartY,point:i}),a=this.getPlotLinePath(d)||null),!q(a))return void this.hideCrosshair();l=this.categories&&!this.isRadial,c||(this.cross=c=r.renderer.path().addClass("highcharts-crosshair highcharts-crosshair-"+(l?"category ":"thin ")+(s.className||"")).attr({zIndex:H(s.zIndex,2)}).add(),!r.styledMode&&(c.attr({stroke:s.color||(l?nt.parse("#ccd3ff").setOpacity(.25).get():"#cccccc"),"stroke-width":H(s.width,1)}).css({"pointer-events":"none"}),s.dashStyle&&c.attr({dashstyle:s.dashStyle}))),c.show().attr({d:a}),l&&!s.width&&c.attr({"stroke-width":this.transA}),this.cross.e=e}else this.hideCrosshair();_(this,"afterDrawCrosshair",{e,point:i})}hideCrosshair(){this.cross&&this.cross.hide(),_(this,"afterHideCrosshair")}update(e,i){let s=this.chart;e=zi(this.userOptions,e),this.destroy(!0),this.init(s,e),s.isDirtyBox=!0,H(i,!0)&&s.redraw()}remove(e){let i=this.chart,s=this.coll,o=this.series,r=o.length;for(;r--;)o[r]&&o[r].remove(!1);Sr(i.axes,this),Sr(i[s]||[],this),i.orderItems(s),this.destroy(),i.isDirtyBox=!0,H(e,!0)&&i.redraw()}setTitle(e,i){this.update({title:e},i)}setCategories(e,i){this.update({categories:e},i)}}return h.keepProps=["coll","extKey","hcEvents","len","names","series","userMax","userMin"],h})(),{addEvent:ml,getMagnitude:xl,normalizeTickInterval:yl,timeUnits:mi}=N;(function(h){function t(){return this.chart.time.getTimeTicks.apply(this.chart.time,arguments)}function e(){if(this.type!=="datetime"){this.dateTime=void 0;return}this.dateTime||(this.dateTime=new i(this))}h.compose=function(s){return s.keepProps.includes("dateTime")||(s.keepProps.push("dateTime"),s.prototype.getTimeTicks=t,ml(s,"afterSetType",e)),s};class i{constructor(o){this.axis=o}normalizeTimeTickInterval(o,r){let a=r||[["millisecond",[1,2,5,10,20,25,50,100,200,500]],["second",[1,2,5,10,15,30]],["minute",[1,2,5,10,15,30]],["hour",[1,2,3,4,6,8,12]],["day",[1,2]],["week",[1,2]],["month",[1,2,3,4,6]],["year",null]],n=a[a.length-1],l=mi[n[0]],c=n[1],d;for(d=0;d<a.length&&(l=mi[(n=a[d])[0]],c=n[1],!a[d+1]||!(o<=(l*c[c.length-1]+mi[a[d+1][0]])/2));d++);l===mi.year&&o<5*l&&(c=[1,2,5]);let p=yl(o/l,c,n[0]==="year"?Math.max(xl(o/l),1):1);return{unitRange:l,count:p,unitName:n[0]}}getXDateFormat(o,r){let{axis:a}=this,n=a.chart.time;return a.closestPointRange?n.getDateFormat(a.closestPointRange,o,a.options.startOfWeek,r)||n.resolveDTLFormat(r.year).main:n.resolveDTLFormat(r.day).main}}h.Additions=i})(po||(po={}));var bl=po,{addEvent:Lr,normalizeTickInterval:vl,pick:kl}=N;(function(h){function t(){this.type!=="logarithmic"?this.logarithmic=void 0:this.logarithmic??(this.logarithmic=new i(this))}function e(){let s=this.logarithmic;s&&(this.lin2val=function(o){return s.lin2log(o)},this.val2lin=function(o){return s.log2lin(o)})}h.compose=function(s){return s.keepProps.includes("logarithmic")||(s.keepProps.push("logarithmic"),Lr(s,"afterSetType",t),Lr(s,"afterInit",e)),s};class i{constructor(o){this.axis=o}getLogTickPositions(o,r,a,n){let l=this.axis,c=l.len,d=l.options,p=[];if(n||(this.minorAutoInterval=void 0),o>=.5)o=Math.round(o),p=l.getLinearTickPositions(o,r,a);else if(o>=.08){let g,u,x,m,f,y,b,v=Math.floor(r);for(g=o>.3?[1,2,4]:o>.15?[1,2,4,6,8]:[1,2,3,4,5,6,7,8,9],u=v;u<a+1&&!b;u++)for(x=0,m=g.length;x<m&&!b;x++)(f=this.log2lin(this.lin2log(u)*g[x]))>r&&(!n||y<=a)&&y!==void 0&&p.push(y),y>a&&(b=!0),y=f}else{let g=this.lin2log(r),u=this.lin2log(a),x=n?l.getMinorTickInterval():d.tickInterval,m=d.tickPixelInterval/(n?5:1),f=n?c/l.tickPositions.length:c;o=vl(o=kl(x==="auto"?null:x,this.minorAutoInterval,(u-g)*m/(f||1))),p=l.getLinearTickPositions(o,g,u).map(this.log2lin),n||(this.minorAutoInterval=o/5)}return n||(l.tickInterval=o),p}lin2log(o){return Math.pow(10,o)}log2lin(o){return Math.log(o)/Math.LN10}}h.Additions=i})(go||(go={}));var wl=go,{erase:Ml,extend:Sl,isNumber:Or}=N;(function(h){let t;function e(l){return this.addPlotBandOrLine(l,"plotBands")}function i(l,c){let d=this.userOptions,p=new t(this,l);if(this.visible&&(p=p.render()),p){if(this._addedPlotLB||(this._addedPlotLB=!0,(d.plotLines||[]).concat(d.plotBands||[]).forEach(g=>{this.addPlotBandOrLine(g)})),c){let g=d[c]||[];g.push(l),d[c]=g}this.plotLinesAndBands.push(p)}return p}function s(l){return this.addPlotBandOrLine(l,"plotLines")}function o(l,c,d){d=d||this.options;let p=this.getPlotLinePath({value:c,force:!0,acrossPanes:d.acrossPanes}),g=[],u=this.horiz,x=!Or(this.min)||!Or(this.max)||l<this.min&&c<this.min||l>this.max&&c>this.max,m=this.getPlotLinePath({value:l,force:!0,acrossPanes:d.acrossPanes}),f,y=1,b;if(m&&p)for(x&&(b=m.toString()===p.toString(),y=0),f=0;f<m.length;f+=2){let v=m[f],S=m[f+1],w=p[f],k=p[f+1];(v[0]==="M"||v[0]==="L")&&(S[0]==="M"||S[0]==="L")&&(w[0]==="M"||w[0]==="L")&&(k[0]==="M"||k[0]==="L")&&(u&&w[1]===v[1]?(w[1]+=y,k[1]+=y):u||w[2]!==v[2]||(w[2]+=y,k[2]+=y),g.push(["M",v[1],v[2]],["L",S[1],S[2]],["L",k[1],k[2]],["L",w[1],w[2]],["Z"])),g.isFlat=b}return g}function r(l){this.removePlotBandOrLine(l)}function a(l){let c=this.plotLinesAndBands,d=this.options,p=this.userOptions;if(c){let g=c.length;for(;g--;)c[g].id===l&&c[g].destroy();[d.plotLines||[],p.plotLines||[],d.plotBands||[],p.plotBands||[]].forEach(function(u){for(g=u.length;g--;)u[g]?.id===l&&Ml(u,u[g])})}}function n(l){this.removePlotBandOrLine(l)}h.compose=function(l,c){let d=c.prototype;return d.addPlotBand||(t=l,Sl(d,{addPlotBand:e,addPlotLine:s,addPlotBandOrLine:i,getPlotBandPath:o,removePlotBand:r,removePlotLine:n,removePlotBandOrLine:a})),c}})(uo||(uo={}));var Tl=uo,{addEvent:Cl,arrayMax:Er,arrayMin:Ir,defined:Ct,destroyObjectProperties:Al,erase:Pl,fireEvent:Ll,merge:Dr,objectEach:Ol,pick:El}=N,ji=class h{static compose(t,e){return Cl(t,"afterInit",function(){this.labelCollectors.push(()=>{let i=[];for(let s of this.axes)for(let{label:o,options:r}of s.plotLinesAndBands)o&&!r?.label?.allowOverlap&&i.push(o);return i})}),Tl.compose(h,e)}constructor(t,e){this.axis=t,this.options=e,this.id=e.id}render(){Ll(this,"render");let{axis:t,options:e}=this,{horiz:i,logarithmic:s}=t,{color:o,events:r,zIndex:a=0}=e,{renderer:n,time:l}=t.chart,c={},d=l.parse(e.to),p=l.parse(e.from),g=l.parse(e.value),u=e.borderWidth,x=e.label,{label:m,svgElem:f}=this,y=[],b,v=Ct(p)&&Ct(d),S=Ct(g),w=!f,k={class:"highcharts-plot-"+(v?"band ":"line ")+(e.className||"")},M=v?"bands":"lines";if(!t.chart.styledMode&&(S?(k.stroke=o||"#999999",k["stroke-width"]=El(e.width,1),e.dashStyle&&(k.dashstyle=e.dashStyle)):v&&(k.fill=o||"#e6e9ff",u&&(k.stroke=e.borderColor,k["stroke-width"]=u))),c.zIndex=a,M+="-"+a,(b=t.plotLinesAndBandsGroups[M])||(t.plotLinesAndBandsGroups[M]=b=n.g("plot-"+M).attr(c).add()),f||(this.svgElem=f=n.path().attr(k).add(b)),Ct(g))y=t.getPlotLinePath({value:s?.log2lin(g)??g,lineWidth:f.strokeWidth(),acrossPanes:e.acrossPanes});else{if(!(Ct(p)&&Ct(d)))return;y=t.getPlotBandPath(s?.log2lin(p)??p,s?.log2lin(d)??d,e)}return!this.eventsAdded&&r&&(Ol(r,(T,A)=>{f?.on(A,C=>{r[A].apply(this,[C])})}),this.eventsAdded=!0),(w||!f.d)&&y?.length?f.attr({d:y}):f&&(y?(f.show(),f.animate({d:y})):f.d&&(f.hide(),m&&(this.label=m=m.destroy()))),x&&(Ct(x.text)||Ct(x.formatter))&&y?.length&&t.width>0&&t.height>0&&!y.isFlat?(x=Dr(It({align:i&&v?"center":void 0,x:i?!v&&4:10,verticalAlign:!i&&v?"middle":void 0,y:i?v?16:10:v?6:-4,rotation:i&&!v?90:0},v?{inside:!0}:{}),x),this.renderLabel(x,y,v,a)):m&&m.hide(),this}renderLabel(t,e,i,s){let o=this.axis,r=o.chart.renderer,a=t.inside,n=this.label;n||(this.label=n=r.text(this.getLabelText(t),0,0,t.useHTML).attr({align:t.textAlign||t.align,rotation:t.rotation,class:"highcharts-plot-"+(i?"band":"line")+"-label "+(t.className||""),zIndex:s}),o.chart.styledMode||n.css(Dr({color:o.chart.options.title?.style?.color,fontSize:"0.8em",textOverflow:i&&!a?"":"ellipsis"},t.style)),n.add());let l=e.xBounds||[e[0][1],e[1][1],i?e[2][1]:e[0][1]],c=e.yBounds||[e[0][2],e[1][2],i?e[2][2]:e[0][2]],d=Ir(l),p=Ir(c),g=Er(l)-d;n.align(t,!1,{x:d,y:p,width:g,height:Er(c)-p}),n.alignAttr.y-=r.fontMetrics(n).b,(!n.alignValue||n.alignValue==="left"||Ct(a))&&n.css({width:(t.style?.width||(i&&a?g:n.rotation===90?o.height-(n.alignAttr.y-o.top):(t.clip?o.width:o.chart.chartWidth)-(n.alignAttr.x-o.left)))+"px"}),n.show(!0)}getLabelText(t){return Ct(t.formatter)?t.formatter.call(this):t.text}destroy(){Pl(this.axis.plotLinesAndBands,this),delete this.axis,Al(this)}},{animObject:Il}=at,{format:Br}=yt,{composed:Dl,dateFormats:Bl,doc:Nr,isSafari:Nl}=P,{distribute:zl}=qi,{addEvent:Rl,clamp:ce,css:zr,discardElement:Wl,extend:Xl,fireEvent:Ms,getAlignFactor:Rr,isArray:Hl,isNumber:Fl,isObject:Yl,isString:Ss,merge:Gl,pick:pe,pushUnique:jl,splat:Ts,syncTimeout:Ul}=N,Qe=class{constructor(t,e,i){this.allowShared=!0,this.crosshairs=[],this.distance=0,this.isHidden=!0,this.isSticky=!1,this.options={},this.outside=!1,this.chart=t,this.init(t,e),this.pointer=i}bodyFormatter(t){return t.map(e=>{let i=e.series.tooltipOptions,s=e.formatPrefix||"point";return(i[s+"Formatter"]||e.tooltipFormatter).call(e,i[s+"Format"]||"")})}cleanSplit(t){this.chart.series.forEach(function(e){let i=e?.tt;i&&(!i.isActive||t?e.tt=i.destroy():i.isActive=!1)})}defaultFormatter(t){let e,i=this.points||Ts(this);return(e=(e=[t.headerFooterFormatter(i[0])]).concat(t.bodyFormatter(i))).push(t.headerFooterFormatter(i[0],!0)),e}destroy(){this.label&&(this.label=this.label.destroy()),this.split&&(this.cleanSplit(!0),this.tt&&(this.tt=this.tt.destroy())),this.renderer&&(this.renderer=this.renderer.destroy(),Wl(this.container)),N.clearTimeout(this.hideTimer)}getAnchor(t,e){let i,{chart:s,pointer:o}=this,r=s.inverted,a=s.plotTop,n=s.plotLeft;if(t=Ts(t),t[0].series?.yAxis&&!t[0].series.yAxis.options.reversedStacks&&(t=t.slice().reverse()),this.followPointer&&e)e.chartX===void 0&&(e=o.normalize(e)),i=[e.chartX-n,e.chartY-a];else if(t[0].tooltipPos)i=t[0].tooltipPos;else{let c=0,d=0;t.forEach(function(p){let g=p.pos(!0);g&&(c+=g[0],d+=g[1])}),c/=t.length,d/=t.length,this.shared&&t.length>1&&e&&(r?c=e.chartX:d=e.chartY),i=[c-n,d-a]}let l={point:t[0],ret:i};return Ms(this,"getAnchor",l),l.ret.map(Math.round)}getClassName(t,e,i){let s=this.options,o=t.series,r=o.options;return[s.className,"highcharts-label",i&&"highcharts-tooltip-header",e?"highcharts-tooltip-box":"highcharts-tooltip",!i&&"highcharts-color-"+pe(t.colorIndex,o.colorIndex),r?.className].filter(Ss).join(" ")}getLabel({anchorX:t,anchorY:e}={anchorX:0,anchorY:0}){let i=this,s=this.chart.styledMode,o=this.options,r=this.split&&this.allowShared,a=this.container,n=this.chart.renderer;if(this.label){let l=!this.label.hasClass("highcharts-label");(!r&&l||r&&!l)&&this.destroy()}if(!this.label){if(this.outside){let l=this.chart,c=l.options.chart.style,d=ii.getRendererType();this.container=a=P.doc.createElement("div"),a.className="highcharts-tooltip-container "+(l.renderTo.className.match(/(highcharts[a-zA-Z0-9-]+)\s?/gm)||""),zr(a,{position:"absolute",top:"1px",pointerEvents:"none",zIndex:Math.max(this.options.style.zIndex||0,(c?.zIndex||0)+3)}),this.renderer=n=new d(a,0,0,c,void 0,void 0,n.styledMode)}if(r?this.label=n.g("tooltip"):(this.label=n.label("",t,e,o.shape||"callout",void 0,void 0,o.useHTML,void 0,"tooltip").attr({padding:o.padding,r:o.borderRadius}),s||this.label.attr({fill:o.backgroundColor,"stroke-width":o.borderWidth||0}).css(o.style).css({pointerEvents:o.style.pointerEvents||(this.shouldStickOnContact()?"auto":"none")})),i.outside){let l=this.label;[l.xSetter,l.ySetter].forEach((c,d)=>{l[d?"ySetter":"xSetter"]=p=>{c.call(l,i.distance),l[d?"y":"x"]=p,a&&(a.style[d?"top":"left"]=`${p}px`)}})}this.label.attr({zIndex:8}).shadow(o.shadow??!o.fixed).add()}return a&&!a.parentElement&&P.doc.body.appendChild(a),this.label}getPlayingField(){let{body:t,documentElement:e}=Nr,{chart:i,distance:s,outside:o}=this;return{width:o?Math.max(t.scrollWidth,e.scrollWidth,t.offsetWidth,e.offsetWidth,e.clientWidth)-2*s-2:i.chartWidth,height:o?Math.max(t.scrollHeight,e.scrollHeight,t.offsetHeight,e.offsetHeight,e.clientHeight):i.chartHeight}}getPosition(t,e,i){let{distance:s,chart:o,outside:r,pointer:a}=this,{inverted:n,plotLeft:l,plotTop:c,polar:d}=o,{plotX:p=0,plotY:g=0}=i,u={},x=n&&i.h||0,{height:m,width:f}=this.getPlayingField(),y=a.getChartPosition(),b=E=>E*y.scaleX,v=E=>E*y.scaleY,S=E=>{let L=E==="x";return[E,L?f:m,L?t:e].concat(r?[L?b(t):v(e),L?y.left-s+b(p+l):y.top-s+v(g+c),0,L?f:m]:[L?t:e,L?p+l:g+c,L?l:c,L?l+o.plotWidth:c+o.plotHeight])},w=S("y"),k=S("x"),M,T=!!i.negative;!d&&o.hoverSeries?.yAxis?.reversed&&(T=!T);let A=!this.followPointer&&pe(i.ttBelow,!d&&!n===T),C=function(E,L,I,V,Y,ht,W){let R=r?E==="y"?v(s):b(s):s,j=(I-V)/2,F=V<Y-s,$=Y+s+V<L,Z=Y-R-I+j,U=Y+R-j;if(A&&$)u[E]=U;else if(!A&&F)u[E]=Z;else if(F)u[E]=Math.min(W-V,Z-x<0?Z:Z-x);else{if(!$)return u[E]=0,!1;u[E]=Math.max(ht,U+x+I>L?U:U+x)}},O=function(E,L,I,V,Y){if(Y<s||Y>L-s)return!1;Y<I/2?u[E]=1:Y>L-V/2?u[E]=L-V-2:u[E]=Y-I/2},D=function(E){[w,k]=[k,w],M=E},B=()=>{C.apply(0,w)!==!1?O.apply(0,k)!==!1||M||(D(!0),B()):M?u.x=u.y=0:(D(!0),B())};return(n&&!d||this.len>1)&&D(),B(),u}getFixedPosition(t,e,i){let s=i.series,{chart:o,options:r,split:a}=this,n=r.position,l=n.relativeTo,c=r.shared||s?.yAxis?.isRadial&&(l==="pane"||!l)?"plotBox":l,d=c==="chart"?o.renderer:o[c]||o.getClipBox(s,!0);return{x:d.x+(d.width-t)*Rr(n.align)+n.x,y:d.y+(d.height-e)*Rr(n.verticalAlign)+(!a&&n.y||0)}}hide(t){let e=this;N.clearTimeout(this.hideTimer),t=pe(t,this.options.hideDelay),this.isHidden||(this.hideTimer=Ul(function(){let i=e.getLabel();e.getLabel().animate({opacity:0},{duration:t&&150,complete:()=>{i.hide(),e.container&&e.container.remove()}}),e.isHidden=!0},t))}init(t,e){this.chart=t,this.options=e,this.crosshairs=[],this.isHidden=!0,this.split=e.split&&!t.inverted&&!t.polar,this.shared=e.shared||this.split,this.outside=pe(e.outside,!!(t.scrollablePixelsX||t.scrollablePixelsY))}shouldStickOnContact(t){return!!(!this.followPointer&&this.options.stickOnContact&&(!t||this.pointer.inClass(t.target,"highcharts-tooltip")))}move(t,e,i,s){let{followPointer:o,options:r}=this,a=Il(!o&&!this.isHidden&&!r.fixed&&r.animation),n=o||(this.len||0)>1,l={x:t,y:e};n?l.anchorX=l.anchorY=NaN:(l.anchorX=i,l.anchorY=s),a.step=()=>this.drawTracker(),this.getLabel().animate(l,a)}refresh(t,e){let{chart:i,options:s,pointer:o,shared:r}=this,a=Ts(t),n=a[0],l=s.format,c=s.formatter||this.defaultFormatter,d=i.styledMode,p=this.allowShared;if(!s.enabled||!n.series)return;N.clearTimeout(this.hideTimer),this.allowShared=!(!Hl(t)&&t.series&&t.series.noSharedTooltip),p=p&&!this.allowShared,this.followPointer=!this.split&&n.series.tooltipOptions.followPointer;let g=this.getAnchor(t,e),u=g[0],x=g[1];r&&this.allowShared&&(o.applyInactiveState(a),a.forEach(y=>y.setState("hover")),n.points=a),this.len=a.length;let m=Ss(l)?Br(l,n,i):c.call(n,this);n.points=void 0;let f=n.series;if(this.distance=pe(f.tooltipOptions.distance,16),m===!1)this.hide();else{if(this.split&&this.allowShared)this.renderSplit(m,a);else{let y=u,b=x;if(e&&o.isDirectTouch&&(y=e.chartX-i.plotLeft,b=e.chartY-i.plotTop),!(i.polar||f.options.clip===!1||a.some(v=>o.isDirectTouch||v.series.shouldShowTooltip(y,b))))return void this.hide();{let v=this.getLabel(p&&this.tt||{});(!s.style.width||d)&&v.css({width:(this.outside?this.getPlayingField():i.spacingBox).width+"px"}),v.attr({class:this.getClassName(n),text:m&&m.join?m.join(""):m}),this.outside&&v.attr({x:ce(v.x||0,0,this.getPlayingField().width-(v.width||0)-1)}),d||v.attr({stroke:s.borderColor||n.color||f.color||"#666666"}),this.updatePosition({plotX:u,plotY:x,negative:n.negative,ttBelow:n.ttBelow,series:f,h:g[2]||0})}}this.isHidden&&this.label&&this.label.attr({opacity:1}).show(),this.isHidden=!1}Ms(this,"refresh")}renderSplit(t,e){let i=this,{chart:s,chart:{chartWidth:o,chartHeight:r,plotHeight:a,plotLeft:n,plotTop:l,scrollablePixelsY:c=0,scrollablePixelsX:d,styledMode:p},distance:g,options:u,options:{fixed:x,position:m,positioner:f},pointer:y}=i,{scrollLeft:b=0,scrollTop:v=0}=s.scrollablePlotArea?.scrollingContainer||{},S=i.outside&&typeof d!="number"?Nr.documentElement.getBoundingClientRect():{left:b,right:b+o,top:v,bottom:v+r},w=i.getLabel(),k=this.renderer||s.renderer,M=!!s.xAxis[0]?.opposite,{left:T,top:A}=y.getChartPosition(),C=f||x,O=l+v,D=0,B=a-c,E=function(W,R,j,F=[0,0],$=!0){let Z,U;if(j.isHeader)U=M?0:B,Z=ce(F[0]-W/2,S.left,S.right-W-(i.outside?T:0));else if(x&&j){let K=i.getFixedPosition(W,R,j);Z=K.x,U=K.y-O}else U=F[1]-O,Z=ce(Z=$?F[0]-W-g:F[0]+g,$?Z:S.left,S.right);return{x:Z,y:U}};Ss(t)&&(t=[!1,t]);let L=t.slice(0,e.length+1).reduce(function(W,R,j){if(R!==!1&&R!==""){let F=e[j-1]||{isHeader:!0,plotX:e[0].plotX,plotY:a,series:{}},$=F.isHeader,Z=$?i:F.series,U=Z.tt=function(bt,dt,Mt){let Rt=bt,{isHeader:qt,series:Te}=dt,vt=Te.tooltipOptions||u;if(!Rt){let ne={padding:vt.padding,r:vt.borderRadius};p||(ne.fill=vt.backgroundColor,ne["stroke-width"]=vt.borderWidth??(x&&!qt?0:1)),Rt=k.label("",0,0,vt[qt?"headerShape":"shape"]||(x&&!qt?"rect":"callout"),void 0,void 0,vt.useHTML).addClass(i.getClassName(dt,!0,qt)).attr(ne).add(w)}return Rt.isActive=!0,Rt.attr({text:Mt}),p||Rt.css(vt.style).attr({stroke:vt.borderColor||dt.color||Te.color||"#333333"}),Rt}(Z.tt,F,R.toString()),K=U.getBBox(),lt=K.width+U.strokeWidth();$&&(D=K.height,B+=D,M&&(O-=D));let{anchorX:gt,anchorY:zt}=function(bt){let dt,Mt,{isHeader:Rt,plotX:qt=0,plotY:Te=0,series:vt}=bt;if(Rt)dt=Math.max(n+qt,n),Mt=l+a/2;else{let{xAxis:ne,yAxis:Bo}=vt;dt=ne.pos+ce(qt,-g,ne.len+g),vt.shouldShowTooltip(0,Bo.pos-l+Te,{ignoreX:!0})&&(Mt=Bo.pos+Te)}return{anchorX:dt=ce(dt,S.left-g,S.right+g),anchorY:Mt}}(F);if(typeof zt=="number"){let bt=K.height+1,dt=(f||E).call(i,lt,bt,F,[gt,zt]);W.push({align:C?0:void 0,anchorX:gt,anchorY:zt,boxWidth:lt,point:F,rank:pe(dt.rank,+!!$),size:bt,target:dt.y,tt:U,x:dt.x})}else U.isActive=!1}return W},[]);!C&&L.some(W=>{let{outside:R}=i,j=(R?T:0)+W.anchorX;return j<S.left&&j+W.boxWidth<S.right||j<T-S.left+W.boxWidth&&S.right-j>j})&&(L=L.map(W=>{let{x:R,y:j}=E.call(this,W.boxWidth,W.size,W.point,[W.anchorX,W.anchorY],!1);return Xl(W,{target:j,x:R})})),i.cleanSplit(),zl(L,B);let I={left:T,right:T};L.forEach(function(W){let{x:R,boxWidth:j,isHeader:F}=W;!F&&(i.outside&&T+R<I.left&&(I.left=T+R),!F&&i.outside&&I.left+j>I.right&&(I.right=T+R))}),L.forEach(function(W){let{x:R,anchorX:j,anchorY:F,pos:$,point:{isHeader:Z}}=W,U={visibility:$===void 0?"hidden":"inherit",x:R,y:($||0)+O+(x&&m.y||0),anchorX:j,anchorY:F};if(i.outside&&R<j){let K=T-I.left;K>0&&(Z||(U.x=R+K,U.anchorX=j+K),Z&&(U.x=(I.right-I.left)/2,U.anchorX=j+K))}W.tt.attr(U)});let{container:V,outside:Y,renderer:ht}=i;if(Y&&V&&ht){let{width:W,height:R,x:j,y:F}=w.getBBox();ht.setSize(W+j,R+F,!1),V.style.left=I.left+"px",V.style.top=A+"px"}Nl&&w.attr({opacity:w.opacity===1?.999:1})}drawTracker(){if(!this.shouldStickOnContact()){this.tracker&&(this.tracker=this.tracker.destroy());return}let t=this.chart,e=this.label,i=this.shared?t.hoverPoints:t.hoverPoint;if(!e||!i)return;let s={x:0,y:0,width:0,height:0},o=this.getAnchor(i),r=e.getBBox();o[0]+=t.plotLeft-(e.translateX||0),o[1]+=t.plotTop-(e.translateY||0),s.x=Math.min(0,o[0]),s.y=Math.min(0,o[1]),s.width=o[0]<0?Math.max(Math.abs(o[0]),r.width-o[0]):Math.max(Math.abs(o[0]),r.width),s.height=o[1]<0?Math.max(Math.abs(o[1]),r.height-Math.abs(o[1])):Math.max(Math.abs(o[1]),r.height),this.tracker?this.tracker.attr(s):(this.tracker=e.renderer.rect(s).addClass("highcharts-tracker").add(e),t.styledMode||this.tracker.attr({fill:"rgba(0,0,0,0)"}))}styledModeFormat(t){return t.replace('style="font-size: 0.8em"','class="highcharts-header"').replace(/style="color:{(point|series)\.color}"/g,'class="highcharts-color-{$1.colorIndex} {series.options.className} {point.options.className}"')}headerFooterFormatter(t,e){let i=t.series,s=i.tooltipOptions,o=i.xAxis,r=o?.dateTime,a={isFooter:e,point:t},n=s.xDateFormat||"",l=s[e?"footerFormat":"headerFormat"];return Ms(this,"headerFormatter",a,function(c){if(r&&!n&&Fl(t.key)&&(n=r.getXDateFormat(t.key,s.dateTimeLabelFormats)),r&&n){if(Yl(n)){let d=n;Bl[0]=p=>i.chart.time.dateFormat(d,p),n="%0"}(t.tooltipDateKeys||["key"]).forEach(d=>{l=l.replace(RegExp("point\\."+d+"([ \\)}])"),`(point.${d}:${n})$1`)})}i.chart.styledMode&&(l=this.styledModeFormat(l)),c.text=Br(l,t,this.chart)}),a.text||""}update(t){this.destroy(),this.init(this.chart,Gl(!0,this.options,t))}updatePosition(t){let{chart:e,container:i,distance:s,options:o,pointer:r,renderer:a}=this,{height:n=0,width:l=0}=this.getLabel(),{fixed:c,positioner:d}=o,{left:p,top:g,scaleX:u,scaleY:x}=r.getChartPosition(),m=(d||c&&this.getFixedPosition||this.getPosition).call(this,l,n,t),f=P.doc,y=(t.plotX||0)+e.plotLeft,b=(t.plotY||0)+e.plotTop,v;if(a&&i){if(d||c){let{scrollLeft:S=0,scrollTop:w=0}=e.scrollablePlotArea?.scrollingContainer||{};m.x+=S+p-s,m.y+=w+g-s}v=(o.borderWidth||0)+2*s+2,a.setSize(ce(l+v,0,f.documentElement.clientWidth)-1,n+v,!1),(u!==1||x!==1)&&(zr(i,{transform:`scale(${u}, ${x})`}),y*=u,b*=x),y+=p-m.x,b+=g-m.y}this.move(Math.round(m.x),Math.round(m.y||0),y,b)}};(Vr=Qe||(Qe={})).compose=function(h){jl(Dl,"Core.Tooltip")&&Rl(h,"afterInit",function(){let t=this.chart;t.options.tooltip&&(t.tooltip=new Vr(t,t.options.tooltip,this))})};var Wr=Qe,{animObject:Vl}=at,{defaultOptions:$l}=xt,{format:Zl}=yt,{addEvent:ql,crisp:Kl,erase:_l,extend:xi,fireEvent:Cs,getNestedProperty:Jl,isArray:Ql,isFunction:td,isNumber:Ht,isObject:yi,merge:Xr,pick:Ft,syncTimeout:ed,removeEvent:Hr,uniqueKey:id}=N,ro=class h{animateBeforeDestroy(){let t=this,e={x:t.startXPos,opacity:0},i=t.getGraphicalProps();i.singular.forEach(function(s){t[s]=t[s].animate(s==="dataLabel"?{x:t[s].startXPos,y:t[s].startYPos,opacity:0}:e)}),i.plural.forEach(function(s){t[s].forEach(function(o){o.element&&o.animate(xi({x:t.startXPos},o.startYPos?{x:o.startXPos,y:o.startYPos}:{}))})})}applyOptions(t,e){let i=this.series,s=i.options.pointValKey||i.pointValKey;return xi(this,t=h.prototype.optionsToObject.call(this,t)),this.options=this.options?xi(this.options,t):t,t.group&&delete this.group,t.dataLabels&&delete this.dataLabels,s&&(this.y=h.prototype.getNestedProperty.call(this,s)),this.selected&&(this.state="select"),"name"in this&&e===void 0&&i.xAxis&&i.xAxis.hasNames&&(this.x=i.xAxis.nameToX(this)),this.x===void 0&&i?this.x=e??i.autoIncrement():Ht(t.x)&&i.options.relativeXValue?this.x=i.autoIncrement(t.x):typeof this.x=="string"&&(e??(e=i.chart.time.parse(this.x)),Ht(e)&&(this.x=e)),this.isNull=this.isValid&&!this.isValid(),this.formatPrefix=this.isNull?"null":"point",this}destroy(){if(!this.destroyed){let t=this,e=t.series,i=e.chart,s=e.options.dataSorting,o=i.hoverPoints,r=Vl(t.series.chart.renderer.globalAnimation),a=()=>{for(let n in(t.graphic||t.graphics||t.dataLabel||t.dataLabels)&&(Hr(t),t.destroyElements()),t)delete t[n]};t.legendItem&&i.legend.destroyItem(t),o&&(t.setState(),_l(o,t),o.length||(i.hoverPoints=null)),t===i.hoverPoint&&t.onMouseOut(),s?.enabled?(this.animateBeforeDestroy(),ed(a,r.duration)):a(),i.pointCount--}this.destroyed=!0}destroyElements(t){let e=this,i=e.getGraphicalProps(t);i.singular.forEach(function(s){e[s]=e[s].destroy()}),i.plural.forEach(function(s){e[s].forEach(function(o){o?.element&&o.destroy()}),delete e[s]})}firePointEvent(t,e,i){let s=this,o=this.series.options;s.manageEvent(t),t==="click"&&o.allowPointSelect&&(i=function(r){!s.destroyed&&s.select&&s.select(null,r.ctrlKey||r.metaKey||r.shiftKey)}),Cs(s,t,e,i)}getClassName(){return"highcharts-point"+(this.selected?" highcharts-point-select":"")+(this.negative?" highcharts-negative":"")+(this.isNull?" highcharts-null-point":"")+(this.colorIndex!==void 0?" highcharts-color-"+this.colorIndex:"")+(this.options.className?" "+this.options.className:"")+(this.zone?.className?" "+this.zone.className.replace("highcharts-negative",""):"")}getGraphicalProps(t){let e,i,s=this,o=[],r={singular:[],plural:[]};for((t=t||{graphic:1,dataLabel:1}).graphic&&o.push("graphic","connector"),t.dataLabel&&o.push("dataLabel","dataLabelPath","dataLabelUpper"),i=o.length;i--;)s[e=o[i]]&&r.singular.push(e);return["graphic","dataLabel"].forEach(function(a){let n=a+"s";t[a]&&s[n]&&r.plural.push(n)}),r}getNestedProperty(t){if(t)return t.indexOf("custom.")===0?Jl(t,this.options):this[t]}getZone(){let t=this.series,e=t.zones,i=t.zoneAxis||"y",s,o=0;for(s=e[0];this[i]>=s.value;)s=e[++o];return this.nonZonedColor||(this.nonZonedColor=this.color),s?.color&&!this.options.color?this.color=s.color:this.color=this.nonZonedColor,s}hasNewShapeType(){return(this.graphic&&(this.graphic.symbolName||this.graphic.element.nodeName))!==this.shapeType}constructor(t,e,i){this.formatPrefix="point",this.visible=!0,this.point=this,this.series=t,this.applyOptions(e,i),this.id??(this.id=id()),this.resolveColor(),this.dataLabelOnNull??(this.dataLabelOnNull=t.options.nullInteraction),t.chart.pointCount++,Cs(this,"afterInit")}isValid(){return(Ht(this.x)||this.x instanceof Date)&&Ht(this.y)}optionsToObject(t){let e=this.series,i=e.options.keys,s=i||e.pointArrayMap||["y"],o=s.length,r={},a,n=0,l=0;if(Ht(t)||t===null)r[s[0]]=t;else if(Ql(t))for(!i&&t.length>o&&((a=typeof t[0])=="string"?e.xAxis?.dateTime?r.x=e.chart.time.parse(t[0]):r.name=t[0]:a==="number"&&(r.x=t[0]),n++);l<o;)i&&t[n]===void 0||(s[l].indexOf(".")>0?h.prototype.setNestedProperty(r,t[n],s[l]):r[s[l]]=t[n]),n++,l++;else typeof t=="object"&&(r=t,t.dataLabels&&(e.hasDataLabels=()=>!0),t.marker&&(e._hasPointMarkers=!0));return r}pos(t,e=this.plotY){if(!this.destroyed){let{plotX:i,series:s}=this,{chart:o,xAxis:r,yAxis:a}=s,n=0,l=0;if(Ht(i)&&Ht(e))return t&&(n=r?r.pos:o.plotLeft,l=a?a.pos:o.plotTop),o.inverted&&r&&a?[a.len-e+l,r.len-i+n]:[i+n,e+l]}}resolveColor(){let t=this.series,e=t.chart.options.chart,i=t.chart.styledMode,s,o,r=e.colorCount,a;delete this.nonZonedColor,t.options.colorByPoint?(i||(s=(o=t.options.colors||t.chart.options.colors)[t.colorCounter],r=o.length),a=t.colorCounter,t.colorCounter++,t.colorCounter===r&&(t.colorCounter=0)):(i||(s=t.color),a=t.colorIndex),this.colorIndex=Ft(this.options.colorIndex,a),this.color=Ft(this.options.color,s)}setNestedProperty(t,e,i){return i.split(".").reduce(function(s,o,r,a){let n=a.length-1===r;return s[o]=n?e:yi(s[o],!0)?s[o]:{},s[o]},t),t}shouldDraw(){return!this.isNull}tooltipFormatter(t){let{chart:e,pointArrayMap:i=["y"],tooltipOptions:s}=this.series,{valueDecimals:o="",valuePrefix:r="",valueSuffix:a=""}=s;return e.styledMode&&(t=e.tooltip?.styledModeFormat(t)||t),i.forEach(n=>{n="{point."+n,(r||a)&&(t=t.replace(RegExp(n+"}","g"),r+n+"}"+a)),t=t.replace(RegExp(n+"}","g"),n+":,."+o+"f}")}),Zl(t,this,e)}update(t,e,i,s){let o,r=this,a=r.series,n=r.graphic,l=a.chart,c=a.options;function d(){r.applyOptions(t);let p=n&&r.hasMockGraphic,g=r.y===null?!p:p;n&&g&&(r.graphic=n.destroy(),delete r.hasMockGraphic),yi(t,!0)&&(n?.element&&t&&t.marker&&t.marker.symbol!==void 0&&(r.graphic=n.destroy()),t?.dataLabels&&r.dataLabel&&(r.dataLabel=r.dataLabel.destroy())),o=r.index;let u={};for(let x of a.dataColumnKeys())u[x]=r[x];a.dataTable.setRow(u,o),c.data[o]=yi(c.data[o],!0)||yi(t,!0)?r.options:Ft(t,c.data[o]),a.isDirty=a.isDirtyData=!0,!a.fixedBox&&a.hasCartesianSeries&&(l.isDirtyBox=!0),c.legendType==="point"&&(l.isDirtyLegend=!0),e&&l.redraw(i)}e=Ft(e,!0),s===!1?d():r.firePointEvent("update",{options:t},d)}remove(t,e){this.series.removePoint(this.series.data.indexOf(this),t,e)}select(t,e){let i=this,s=i.series,o=s.chart;t=Ft(t,!i.selected),this.selectedStaging=t,i.firePointEvent(t?"select":"unselect",{accumulate:e},function(){i.selected=i.options.selected=t,s.options.data[s.data.indexOf(i)]=i.options,i.setState(t&&"select"),e||o.getSelectedPoints().forEach(function(r){let a=r.series;r.selected&&r!==i&&(r.selected=r.options.selected=!1,a.options.data[a.data.indexOf(r)]=r.options,r.setState(o.hoverPoints&&a.options.inactiveOtherPoints?"inactive":""),r.firePointEvent("unselect"))})}),delete this.selectedStaging}onMouseOver(t){let{inverted:e,pointer:i}=this.series.chart;i&&(t=t?i.normalize(t):i.getChartCoordinatesFromPoint(this,e),i.runPointActions(t,this))}onMouseOut(){let t=this.series.chart;this.firePointEvent("mouseOut"),this.series.options.inactiveOtherPoints||(t.hoverPoints||[]).forEach(function(e){e.setState()}),t.hoverPoints=t.hoverPoint=null}manageEvent(t){let e=Xr(this.series.options.point,this.options),i=e.events?.[t];td(i)&&(!this.hcEvents?.[t]||this.hcEvents?.[t]?.map(s=>s.fn).indexOf(i)===-1)?(this.importedUserEvent?.(),this.importedUserEvent=ql(this,t,i),this.hcEvents&&(this.hcEvents[t].userEvent=!0)):this.importedUserEvent&&!i&&this.hcEvents?.[t]&&this.hcEvents?.[t].userEvent&&(Hr(this,t),delete this.hcEvents[t],Object.keys(this.hcEvents)||delete this.importedUserEvent)}setState(t,e){let i=this.series,s=this.state,o=i.options.states[t||"normal"]||{},r=$l.plotOptions[i.type].marker&&i.options.marker,a=r&&r.enabled===!1,n=r?.states?.[t||"normal"]||{},l=n.enabled===!1,c=this.marker||{},d=i.chart,p=r&&i.markerAttribs,g=i.halo,u,x,m,f=i.stateMarkerGraphic,y;if((t=t||"")===this.state&&!e||this.selected&&t!=="select"||o.enabled===!1||t&&(l||a&&n.enabled===!1)||t&&c.states&&c.states[t]&&c.states[t].enabled===!1)return;if(this.state=t,p&&(u=i.markerAttribs(this,t)),this.graphic&&!this.hasMockGraphic){if(s&&this.graphic.removeClass("highcharts-point-"+s),t&&this.graphic.addClass("highcharts-point-"+t),!d.styledMode){x=i.pointAttribs(this,t),m=Ft(d.options.chart.animation,o.animation);let w=x.opacity;i.options.inactiveOtherPoints&&Ht(w)&&(this.dataLabels||[]).forEach(function(k){k&&!k.hasClass("highcharts-data-label-hidden")&&(k.animate({opacity:w},m),k.connector&&k.connector.animate({opacity:w},m))}),this.graphic.animate(x,m)}u&&this.graphic.animate(u,Ft(d.options.chart.animation,n.animation,r.animation)),f&&f.hide()}else t&&n&&(y=c.symbol||i.symbol,f&&f.currentSymbol!==y&&(f=f.destroy()),u&&(f?f[e?"animate":"attr"]({x:u.x,y:u.y}):y&&(i.stateMarkerGraphic=f=d.renderer.symbol(y,u.x,u.y,u.width,u.height,Xr(r,n)).add(i.markerGroup),f.currentSymbol=y)),!d.styledMode&&f&&this.state!=="inactive"&&f.attr(i.pointAttribs(this,t))),f&&(f[t&&this.isInside?"show":"hide"](),f.element.point=this,f.addClass(this.getClassName(),!0));let b=o.halo,v=this.graphic||f,S=v?.visibility||"inherit";b?.size&&v&&S!=="hidden"&&!this.isCluster?(g||(i.halo=g=d.renderer.path().add(v.parentGroup)),g.show()[e?"animate":"attr"]({d:this.haloPath(b.size)}),g.attr({class:"highcharts-halo highcharts-color-"+Ft(this.colorIndex,i.colorIndex)+(this.className?" "+this.className:""),visibility:S,zIndex:-1}),g.point=this,d.styledMode||g.attr(xi({fill:this.color||i.color,"fill-opacity":b.opacity},ot.filterUserAttributes(b.attributes||{})))):g?.point?.haloPath&&!g.point.destroyed&&g.animate({d:g.point.haloPath(0)},null,g.hide),Cs(this,"afterSetState",{state:t})}haloPath(t){let e=this.pos();return e?this.series.chart.renderer.symbols.circle(Kl(e[0],1)-t,e[1]-t,2*t,2*t):[]}},Zt=ro,{parse:sd}=nt,{charts:As,composed:od,isTouchDevice:rd}=P,{addEvent:mt,attr:ad,css:Ps,extend:Ls,find:Fr,fireEvent:Yt,isNumber:bi,isObject:vi,objectEach:nd,offset:hd,pick:At,pushUnique:ld,splat:Yr}=N,we=class h{applyInactiveState(t=[]){let e=[];for(let i of(t.forEach(s=>{let o=s.series;e.push(o),o.linkedParent&&e.push(o.linkedParent),o.linkedSeries&&e.push.apply(e,o.linkedSeries),o.navigatorSeries&&e.push(o.navigatorSeries),o.boosted&&o.markerGroup&&e.push.apply(e,this.chart.series.filter(r=>r.markerGroup===o.markerGroup))}),this.chart.series)){let s=i.options;s.states?.inactive?.enabled!==!1&&(e.indexOf(i)===-1?i.setState("inactive",!0):s.inactiveOtherPoints&&i.setAllPointsToState("inactive"))}}destroy(){let t=this;this.eventsToUnbind.forEach(e=>e()),this.eventsToUnbind=[],!P.chartCount&&(h.unbindDocumentMouseUp.forEach(e=>e.unbind()),h.unbindDocumentMouseUp.length=0,h.unbindDocumentTouchEnd&&(h.unbindDocumentTouchEnd=h.unbindDocumentTouchEnd())),clearInterval(t.tooltipTimeout),nd(t,function(e,i){t[i]=void 0})}getSelectionMarkerAttrs(t,e){let i={args:{chartX:t,chartY:e},attrs:{},shapeType:"rect"};return Yt(this,"getSelectionMarkerAttrs",i,s=>{let o,{chart:r,zoomHor:a,zoomVert:n}=this,{mouseDownX:l=0,mouseDownY:c=0}=r,d=s.attrs;d.x=r.plotLeft,d.y=r.plotTop,d.width=a?1:r.plotWidth,d.height=n?1:r.plotHeight,a&&(d.width=Math.max(1,Math.abs(o=t-l)),d.x=(o>0?0:o)+l),n&&(d.height=Math.max(1,Math.abs(o=e-c)),d.y=(o>0?0:o)+c)}),i}drag(t){let{chart:e}=this,{mouseDownX:i=0,mouseDownY:s=0}=e,{panning:o,panKey:r,selectionMarkerFill:a}=e.options.chart,n=e.plotLeft,l=e.plotTop,c=e.plotWidth,d=e.plotHeight,p=vi(o)?o.enabled:o,g=r&&t[`${r}Key`],u=t.chartX,x=t.chartY,m,f=this.selectionMarker;if((!f||!f.touch)&&(u<n?u=n:u>n+c&&(u=n+c),x<l?x=l:x>l+d&&(x=l+d),this.hasDragged=Math.sqrt(Math.pow(i-u,2)+Math.pow(s-x,2)),this.hasDragged>10)){m=e.isInsidePlot(i-n,s-l,{visiblePlotOnly:!0});let{shapeType:y,attrs:b}=this.getSelectionMarkerAttrs(u,x);this.hasZoom&&m&&!g&&!f&&(this.selectionMarker=f=e.renderer[y](),f.attr({class:"highcharts-selection-marker",zIndex:7}).add(),e.styledMode||f.attr({fill:a||sd("#334eff").setOpacity(.25).get()})),f&&f.attr(b),m&&!f&&p&&e.pan(t,o)}}dragStart(t){let e=this.chart;e.mouseIsDown=t.type,e.cancelClick=!1,e.mouseDownX=t.chartX,e.mouseDownY=t.chartY}getSelectionBox(t){let e={args:{marker:t},result:t.getBBox()};return Yt(this,"getSelectionBox",e),e.result}drop(t){let e,{chart:i,selectionMarker:s}=this;for(let o of i.axes)o.isPanning&&(o.isPanning=!1,(o.options.startOnTick||o.options.endOnTick||o.series.some(r=>r.boosted))&&(o.forceRedraw=!0,o.setExtremes(o.userMin,o.userMax,!1),e=!0));if(e&&i.redraw(),s&&t){if(this.hasDragged){let o=this.getSelectionBox(s);i.transform({axes:i.axes.filter(r=>r.zoomEnabled&&(r.coll==="xAxis"&&this.zoomX||r.coll==="yAxis"&&this.zoomY)),selection:It({originalEvent:t,xAxis:[],yAxis:[]},o),from:o})}bi(i.index)&&(this.selectionMarker=s.destroy())}i&&bi(i.index)&&(Ps(i.container,{cursor:i._cursor}),i.cancelClick=this.hasDragged>10,i.mouseIsDown=!1,this.hasDragged=0,this.pinchDown=[],this.hasPinchMoved=!1)}findNearestKDPoint(t,e,i){let s;return t.forEach(function(o){let r=!(o.noSharedTooltip&&e)&&0>o.options.findNearestPointBy.indexOf("y"),a=o.searchPoint(i,r);vi(a,!0)&&a.series&&(!vi(s,!0)||function(n,l){let c,d=n.distX-l.distX,p=n.dist-l.dist,g=l.series.group?.zIndex-n.series.group?.zIndex;return d!==0&&e?d:p!==0?p:g!==0?g:n.series.index>l.series.index?-1:1}(s,a)>0)&&(s=a)}),s}getChartCoordinatesFromPoint(t,e){let{xAxis:i,yAxis:s}=t.series,o=t.shapeArgs;if(i&&s){let r=t.clientX??t.plotX??0,a=t.plotY||0;return t.isNode&&o&&bi(o.x)&&bi(o.y)&&(r=o.x,a=o.y),e?{chartX:s.len+s.pos-a,chartY:i.len+i.pos-r}:{chartX:r+i.pos,chartY:a+s.pos}}if(o?.x&&o.y)return{chartX:o.x,chartY:o.y}}getChartPosition(){if(this.chartPosition)return this.chartPosition;let{container:t}=this.chart,e=hd(t);this.chartPosition={left:e.left,top:e.top,scaleX:1,scaleY:1};let{offsetHeight:i,offsetWidth:s}=t;return s>2&&i>2&&(this.chartPosition.scaleX=e.width/s,this.chartPosition.scaleY=e.height/i),this.chartPosition}getCoordinates(t){let e={xAxis:[],yAxis:[]};for(let i of this.chart.axes)e[i.isXAxis?"xAxis":"yAxis"].push({axis:i,value:i.toValue(t[i.horiz?"chartX":"chartY"])});return e}getHoverData(t,e,i,s,o,r){let a=[],n=function(g){return g.visible&&!(!o&&g.directTouch)&&At(g.options.enableMouseTracking,!0)},l=e,c,d={chartX:r?r.chartX:void 0,chartY:r?r.chartY:void 0,shared:o};Yt(this,"beforeGetHoverData",d),c=l&&!l.stickyTracking?[l]:i.filter(g=>g.stickyTracking&&(d.filter||n)(g));let p=s&&t||!r?t:this.findNearestKDPoint(c,o,r);return l=p?.series,p&&(o&&!l.noSharedTooltip?(c=i.filter(function(g){return d.filter?d.filter(g):n(g)&&!g.noSharedTooltip})).forEach(function(g){let u=g.options?.nullInteraction,x=Fr(g.points,function(m){return m.x===p.x&&(!m.isNull||!!u)});vi(x)&&(g.boosted&&g.boost&&(x=g.boost.getPoint(x)),a.push(x))}):a.push(p)),Yt(this,"afterGetHoverData",d={hoverPoint:p}),{hoverPoint:d.hoverPoint,hoverSeries:l,hoverPoints:a}}getPointFromEvent(t){let e=t.target,i;for(;e&&!i;)i=e.point,e=e.parentNode;return i}onTrackerMouseOut(t){let e=this.chart,i=t.relatedTarget,s=e.hoverSeries;this.isDirectTouch=!1,!s||!i||s.stickyTracking||this.inClass(i,"highcharts-tooltip")||this.inClass(i,"highcharts-series-"+s.index)&&this.inClass(i,"highcharts-tracker")||s.onMouseOut()}inClass(t,e){let i=t,s;for(;i;){if(s=ad(i,"class")){if(s.indexOf(e)!==-1)return!0;if(s.indexOf("highcharts-container")!==-1)return!1}i=i.parentElement}}constructor(t,e){this.hasDragged=0,this.pointerCaptureEventsToUnbind=[],this.eventsToUnbind=[],this.options=e,this.chart=t,this.runChartClick=!!e.chart.events?.click,this.pinchDown=[],this.setDOMEvents(),Yt(this,"afterInit")}normalize(t,e){let i=t.touches,s=i?i.length?i.item(0):At(i.changedTouches,t.changedTouches)[0]:t;e||(e=this.getChartPosition());let o=s.pageX-e.left,r=s.pageY-e.top;return Ls(t,{chartX:Math.round(o/=e.scaleX),chartY:Math.round(r/=e.scaleY)})}onContainerClick(t){let e=this.chart,i=e.hoverPoint,s=this.normalize(t),o=e.plotLeft,r=e.plotTop;!e.cancelClick&&(i&&this.inClass(s.target,"highcharts-tracker")?(Yt(i.series,"click",Ls(s,{point:i})),e.hoverPoint&&i.firePointEvent("click",s)):(Ls(s,this.getCoordinates(s)),e.isInsidePlot(s.chartX-o,s.chartY-r,{visiblePlotOnly:!0})&&Yt(e,"click",s)))}onContainerMouseDown(t){let e=(1&(t.buttons||t.button))==1;t=this.normalize(t),P.isFirefox&&t.button!==0&&this.onContainerMouseMove(t),(t.button===void 0||e)&&(this.zoomOption(t),e&&t.preventDefault?.(),this.dragStart(t))}onContainerMouseLeave(t){let{pointer:e}=As[At(h.hoverChartIndex,-1)]||{};t=this.normalize(t),this.onContainerMouseMove(t),e&&!this.inClass(t.relatedTarget,"highcharts-tooltip")&&(e.reset(),e.chartPosition=void 0)}onContainerMouseEnter(){delete this.chartPosition}onContainerMouseMove(t){let e=this.chart,i=e.tooltip,s=this.normalize(t);this.setHoverChartIndex(t),(e.mouseIsDown==="mousedown"||this.touchSelect(s))&&this.drag(s),!e.exporting?.openMenu&&(this.inClass(s.target,"highcharts-tracker")||e.isInsidePlot(s.chartX-e.plotLeft,s.chartY-e.plotTop,{visiblePlotOnly:!0}))&&!i?.shouldStickOnContact(s)&&(this.inClass(s.target,"highcharts-no-tooltip")?this.reset(!1,0):this.runPointActions(s))}onDocumentTouchEnd(t){this.onDocumentMouseUp(t)}onContainerTouchMove(t){this.touchSelect(t)?this.onContainerMouseMove(t):this.touch(t)}onContainerTouchStart(t){this.touchSelect(t)?this.onContainerMouseDown(t):(this.zoomOption(t),this.touch(t,!0))}onDocumentMouseMove(t){let e=this.chart,i=e.tooltip,s=this.chartPosition,o=this.normalize(t,s);!s||e.isInsidePlot(o.chartX-e.plotLeft,o.chartY-e.plotTop,{visiblePlotOnly:!0})||i?.shouldStickOnContact(o)||o.target!==e.container.ownerDocument&&this.inClass(o.target,"highcharts-tracker")||this.reset()}onDocumentMouseUp(t){t?.touches&&this.hasPinchMoved&&t?.preventDefault?.(),As[At(h.hoverChartIndex,-1)]?.pointer?.drop(t)}pinch(t){let e=this,{chart:i,hasZoom:s,lastTouches:o}=e,r=[].map.call(t.touches||[],d=>e.normalize(d)),a=r.length,n=a===1&&(e.inClass(t.target,"highcharts-tracker")&&i.runTrackerClick||e.runChartClick),l=i.tooltip,c=a===1&&At(l?.options.followTouchMove,!0);a>1?e.initiated=!0:c&&(e.initiated=!1),s&&e.initiated&&!n&&t.cancelable!==!1&&t.preventDefault(),t.type==="touchstart"?(e.pinchDown=r,e.res=!0,i.mouseDownX=t.chartX):c?this.runPointActions(e.normalize(t)):o&&(Yt(i,"touchpan",{originalEvent:t,touches:r},()=>{let d=p=>{let g=p[0],u=p[1]||g;return{x:g.chartX,y:g.chartY,width:u.chartX-g.chartX,height:u.chartY-g.chartY}};i.transform({axes:i.axes.filter(p=>p.zoomEnabled&&(this.zoomHor&&p.horiz||this.zoomVert&&!p.horiz)),to:d(r),from:d(o),trigger:t.type})}),e.res&&(e.res=!1,this.reset(!1,0))),e.lastTouches=r}reset(t,e){let i=this.chart,s=i.hoverSeries,o=i.hoverPoint,r=i.hoverPoints,a=i.tooltip,n=a?.shared?r:o;t&&n&&Yr(n).forEach(function(l){l.series.isCartesian&&l.plotX===void 0&&(t=!1)}),t?a&&n&&Yr(n).length&&(a.refresh(n),a.shared&&r?r.forEach(function(l){l.setState(l.state,!0),l.series.isCartesian&&(l.series.xAxis.crosshair&&l.series.xAxis.drawCrosshair(null,l),l.series.yAxis.crosshair&&l.series.yAxis.drawCrosshair(null,l))}):o&&(o.setState(o.state,!0),i.axes.forEach(function(l){l.crosshair&&o.series[l.coll]===l&&l.drawCrosshair(null,o)}))):(o&&o.onMouseOut(),r&&r.forEach(function(l){l.setState()}),s&&s.onMouseOut(),a&&a.hide(e),this.unDocMouseMove&&(this.unDocMouseMove=this.unDocMouseMove()),i.axes.forEach(function(l){l.hideCrosshair()}),i.hoverPoints=i.hoverPoint=void 0)}runPointActions(t,e,i){let s=this.chart,o=s.series,r=s.tooltip?.options.enabled?s.tooltip:void 0,a=!!r&&r.shared,n=e||s.hoverPoint,l=n?.series||s.hoverSeries,c=(!t||t.type!=="touchmove")&&(!!e||l?.directTouch&&this.isDirectTouch),d=this.getHoverData(n,l,o,c,a,t);n=d.hoverPoint,l=d.hoverSeries;let p=d.hoverPoints,g=l?.tooltipOptions.followPointer&&!l.tooltipOptions.split,u=a&&l&&!l.noSharedTooltip;if(n&&(i||n!==s.hoverPoint||r?.isHidden)){if((s.hoverPoints||[]).forEach(function(x){p.indexOf(x)===-1&&x.setState()}),s.hoverSeries!==l&&l.onMouseOver(),this.applyInactiveState(p),(p||[]).forEach(function(x){x.setState("hover")}),s.hoverPoint&&s.hoverPoint.firePointEvent("mouseOut"),!n.series)return;s.hoverPoints=p,s.hoverPoint=n,n.firePointEvent("mouseOver",void 0,()=>{r&&n&&r.refresh(u?p:n,t)})}else if(g&&r&&!r.isHidden){let x=r.getAnchor([{}],t);s.isInsidePlot(x[0],x[1],{visiblePlotOnly:!0})&&r.updatePosition({plotX:x[0],plotY:x[1]})}this.unDocMouseMove||(this.unDocMouseMove=mt(s.container.ownerDocument,"mousemove",x=>As[h.hoverChartIndex??-1]?.pointer?.onDocumentMouseMove(x)),this.eventsToUnbind.push(this.unDocMouseMove)),s.axes.forEach(function(x){let m,f=x.crosshair?.snap??!0;f&&((m=s.hoverPoint)&&m.series[x.coll]===x||(m=Fr(p,y=>y.series?.[x.coll]===x))),m||!f?x.drawCrosshair(t,m):x.hideCrosshair()})}setDOMEvents(){let t=this.chart.container,e=t.ownerDocument;t.onmousedown=this.onContainerMouseDown.bind(this),t.onmousemove=this.onContainerMouseMove.bind(this),t.onclick=this.onContainerClick.bind(this),this.eventsToUnbind.push(mt(t,"mouseenter",this.onContainerMouseEnter.bind(this)),mt(t,"mouseleave",this.onContainerMouseLeave.bind(this))),h.unbindDocumentMouseUp.some(s=>s.doc===e)||h.unbindDocumentMouseUp.push({doc:e,unbind:mt(e,"mouseup",this.onDocumentMouseUp.bind(this))});let i=this.chart.renderTo.parentElement;for(;i&&i.tagName!=="BODY";)this.eventsToUnbind.push(mt(i,"scroll",()=>{delete this.chartPosition})),i=i.parentElement;this.eventsToUnbind.push(mt(t,"touchstart",this.onContainerTouchStart.bind(this),{passive:!1}),mt(t,"touchmove",this.onContainerTouchMove.bind(this),{passive:!1})),h.unbindDocumentTouchEnd||(h.unbindDocumentTouchEnd=mt(e,"touchend",this.onDocumentTouchEnd.bind(this),{passive:!1})),this.setPointerCapture(),mt(this.chart,"redraw",this.setPointerCapture.bind(this))}setPointerCapture(){if(!rd)return;let t=this.pointerCaptureEventsToUnbind,e=this.chart,i=e.container,s=At(e.options.tooltip?.followTouchMove,!0)&&e.series.some(o=>o.options.findNearestPointBy.indexOf("y")>-1);!this.hasPointerCapture&&s?(t.push(mt(i,"pointerdown",o=>{o.target?.hasPointerCapture(o.pointerId)&&o.target?.releasePointerCapture(o.pointerId)}),mt(i,"pointermove",o=>{e.pointer?.getPointFromEvent(o)?.onMouseOver(o)})),e.styledMode||Ps(i,{"touch-action":"none"}),i.className+=" highcharts-no-touch-action",this.hasPointerCapture=!0):this.hasPointerCapture&&!s&&(t.forEach(o=>o()),t.length=0,e.styledMode||Ps(i,{"touch-action":At(e.options.chart.style?.["touch-action"],"manipulation")}),i.className=i.className.replace(" highcharts-no-touch-action",""),this.hasPointerCapture=!1)}setHoverChartIndex(t){let e=this.chart,i=P.charts[At(h.hoverChartIndex,-1)];if(i&&i!==e){let s={relatedTarget:e.container};t&&!t?.relatedTarget&&Object.assign({},t,s),i.pointer?.onContainerMouseLeave(t||s)}i?.mouseIsDown||(h.hoverChartIndex=e.index)}touch(t,e){let i,{chart:s,pinchDown:o=[]}=this;this.setHoverChartIndex(),(t=this.normalize(t)).touches.length===1?s.isInsidePlot(t.chartX-s.plotLeft,t.chartY-s.plotTop,{visiblePlotOnly:!0})&&!s.exporting?.openMenu?(e&&this.runPointActions(t),t.type==="touchmove"&&(this.hasPinchMoved=i=!!o[0]&&Math.pow(o[0].chartX-t.chartX,2)+Math.pow(o[0].chartY-t.chartY,2)>=16),At(i,!0)&&this.pinch(t)):e&&this.reset():t.touches.length===2&&this.pinch(t)}touchSelect(t){return!!(this.chart.zooming.singleTouch&&t.touches&&t.touches.length===1)}zoomOption(t){let e=this.chart,i=e.inverted,s=e.zooming.type||"",o,r;/touch/.test(t.type)&&(s=At(e.zooming.pinchType,s)),this.zoomX=o=/x/.test(s),this.zoomY=r=/y/.test(s),this.zoomHor=o&&!i||r&&i,this.zoomVert=r&&!i||o&&i,this.hasZoom=o||r}};we.unbindDocumentMouseUp=[],($r=we||(we={})).compose=function(h){ld(od,"Core.Pointer")&&mt(h,"beforeRender",function(){this.pointer=new $r(this,this.options)})};var Gr=we;(Zr=fo||(fo={})).setLength=function(h,t,e){return Array.isArray(h)?(h.length=t,h):h[e?"subarray":"slice"](0,t)},Zr.splice=function(h,t,e,i,s=[]){if(Array.isArray(h))return Array.isArray(s)||(s=Array.from(s)),{removed:h.splice(t,e,...s),array:h};let o=Object.getPrototypeOf(h).constructor,r=h[i?"subarray":"slice"](t,t+e),a=new o(h.length-e+s.length);return a.set(h.subarray(0,t),0),a.set(s,t),a.set(h.subarray(t+e),t+s.length),{removed:r,array:a}};var{setLength:dd,splice:jr}=fo,{fireEvent:Os,objectEach:Ne,uniqueKey:ze}=N,Ri=class{constructor(h={}){this.autoId=!h.id,this.columns={},this.id=h.id||ze(),this.modified=this,this.rowCount=0,this.versionTag=ze();let t=0;Ne(h.columns||{},(e,i)=>{this.columns[i]=e.slice(),t=Math.max(t,e.length)}),this.applyRowCount(t)}applyRowCount(h){this.rowCount=h,Ne(this.columns,(t,e)=>{t.length!==h&&(this.columns[e]=dd(t,h))})}deleteRows(h,t=1){if(t>0&&h<this.rowCount){let e=0;Ne(this.columns,(i,s)=>{this.columns[s]=jr(i,h,t).array,e=i.length}),this.rowCount=e}Os(this,"afterDeleteRows",{rowIndex:h,rowCount:t}),this.versionTag=ze()}getColumn(h,t){return this.columns[h]}getColumns(h,t){return(h||Object.keys(this.columns)).reduce((e,i)=>(e[i]=this.columns[i],e),{})}getRow(h,t){return(t||Object.keys(this.columns)).map(e=>this.columns[e]?.[h])}setColumn(h,t=[],e=0,i){this.setColumns({[h]:t},e,i)}setColumns(h,t,e){let i=this.rowCount;Ne(h,(s,o)=>{this.columns[o]=s.slice(),i=s.length}),this.applyRowCount(i),e?.silent||(Os(this,"afterSetColumns"),this.versionTag=ze())}setRow(h,t=this.rowCount,e,i){let{columns:s}=this,o=e?this.rowCount+1:t+1;Ne(h,(r,a)=>{let n=s[a]||i?.addColumns!==!1&&Array(o);n&&(e?n=jr(n,t,0,!0,[r]).array:n[t]=r,s[a]=n)}),o>this.rowCount&&this.applyRowCount(o),i?.silent||(Os(this,"afterSetRows"),this.versionTag=ze())}},{extend:cd,merge:pd,pick:qa}=N,ao,no,ho,lo,co,po,go,uo,fo,mo,xo,yo,bo,vo,ko,wo,Mo,So,X,ge,Ur,Vr,$r,Zr,qr,Kr,ki,Es=mo||(mo={});function _r(h,t,e){let i=this.legendItem=this.legendItem||{},{chart:s,options:o}=this,{baseline:r=0,symbolWidth:a,symbolHeight:n}=h,l=this.symbol||"circle",c=n/2,d=s.renderer,p=i.group,g=r-Math.round((h.fontMetrics?.b||n)*(e?.4:.3)),u={},x,m=o.marker,f=0;if(s.styledMode||(u["stroke-width"]=Math.min(o.lineWidth||0,24),o.dashStyle?u.dashstyle=o.dashStyle:o.linecap!=="square"&&(u["stroke-linecap"]="round")),i.line=d.path().addClass("highcharts-graph").attr(u).add(p),e&&(i.area=d.path().addClass("highcharts-area").add(p)),u["stroke-linecap"]&&(f=Math.min(i.line.strokeWidth(),a)/2),a){let y=[["M",f,g],["L",a-f,g]];i.line.attr({d:y}),i.area?.attr({d:[...y,["L",a-f,r],["L",f,r]]})}if(m&&m.enabled!==!1&&a){let y=Math.min(qa(m.radius,c),c);l.indexOf("url")===0&&(m=pd(m,{width:n,height:n}),y=0),i.symbol=x=d.symbol(l,a/2-y,g-y,2*y,2*y,cd({context:"legend"},m)).addClass("highcharts-point").add(p),x.isMarker=!0}}Es.areaMarker=function(h,t){_r.call(this,h,t,!0)},Es.lineMarker=_r,Es.rectangle=function(h,t){let e=t.legendItem||{},i=h.options,s=h.symbolHeight,o=i.squareSymbol,r=o?s:h.symbolWidth;e.symbol=this.chart.renderer.rect(o?(h.symbolWidth-s)/2:0,h.baseline-s+1,r,s,qa(h.options.symbolRadius,s/2)).addClass("highcharts-point").attr({zIndex:3}).add(e.group)};var Ka=mo,{defaultOptions:_a}=xt,{extend:gd,extendClass:ud,merge:fd}=N,Lt=xo||(xo={});function Jr(h,t){let e=_a.plotOptions||{},i=t.defaultOptions,s=t.prototype;return s.type=h,s.pointClass||(s.pointClass=Zt),!Lt.seriesTypes[h]&&(i&&(e[h]=i),Lt.seriesTypes[h]=t,!0)}Lt.seriesTypes=P.seriesTypes,Lt.registerSeriesType=Jr,Lt.seriesType=function(h,t,e,i,s){let o=_a.plotOptions||{};if(t=t||"",o[h]=fd(o[t],e),delete Lt.seriesTypes[h],Jr(h,ud(Lt.seriesTypes[t]||ut,i)),Lt.seriesTypes[h].prototype.type=h,s){class r extends Zt{}gd(r.prototype,s),Lt.seriesTypes[h].prototype.pointClass=r}return Lt.seriesTypes[h]};var tt=xo,{animObject:Qr,setAnimation:md}=at,{defaultOptions:wi}=xt,{registerEventOptions:xd}=Ki,{svg:yd,win:bd}=P,{seriesTypes:ue}=tt,{format:vd}=yt,{arrayMax:Is,arrayMin:ta,clamp:ea,correctFloat:ia,crisp:kd,defined:it,destroyObjectProperties:wd,diffObjects:Md,erase:sa,error:Mi,extend:me,find:Sd,fireEvent:J,getClosestDistance:Td,getNestedProperty:oa,insertItem:ra,isArray:aa,isNumber:st,isString:Cd,merge:Re,objectEach:Ds,pick:Q,removeEvent:Ad,syncTimeout:na}=N,Ot=class h{constructor(){this.zoneAxis="y"}init(t,e){let i;J(this,"init",{options:e}),this.dataTable??(this.dataTable=new Ri);let s=t.series;this.eventsToUnbind=[],this.chart=t,this.options=this.setOptions(e);let o=this.options,r=o.visible!==!1;this.linkedSeries=[],this.bindAxes(),me(this,{name:o.name,state:"",visible:r,selected:o.selected===!0}),xd(this,o),(o.events?.click||o.point?.events?.click||o.allowPointSelect)&&(t.runTrackerClick=!0),this.getColor(),this.getSymbol(),this.isCartesian&&(t.hasCartesianSeries=!0),s.length&&(i=s[s.length-1]),this._i=Q(i?._i,-1)+1,this.opacity=this.options.opacity,t.orderItems("series",ra(this,s)),o.dataSorting?.enabled?this.setDataSortingOptions():this.points||this.data||this.setData(o.data,!1),J(this,"afterInit")}is(t){return ue[t]&&this instanceof ue[t]}bindAxes(){let t,e=this,i=e.options,s=e.chart;J(this,"bindAxes",null,function(){(e.axisTypes||[]).forEach(function(o){(s[o]||[]).forEach(function(r){t=r.options,(Q(i[o],0)===r.index||i[o]!==void 0&&i[o]===t.id)&&(ra(e,r.series),e[o]=r,r.isDirty=!0)}),e[o]||e.optionalAxis===o||Mi(18,!0,s)})}),J(this,"afterBindAxes")}hasData(){return this.visible&&this.dataMax!==void 0&&this.dataMin!==void 0||this.visible&&this.dataTable.rowCount>0}hasMarkerChanged(t,e){let i=t.marker,s=e.marker||{};return i&&(s.enabled&&!i.enabled||s.symbol!==i.symbol||s.height!==i.height||s.width!==i.width)}autoIncrement(t){let e,i=this.options,{pointIntervalUnit:s,relativeXValue:o}=this.options,r=this.chart.time,a=this.xIncrement??r.parse(i.pointStart)??0;if(this.pointInterval=e=Q(this.pointInterval,i.pointInterval,1),o&&st(t)&&(e*=t),s){let n=r.toParts(a);s==="day"?n[2]+=e:s==="month"?n[1]+=e:s==="year"&&(n[0]+=e),e=r.makeTime.apply(r,n)-a}return o&&st(t)?a+e:(this.xIncrement=a+e,a)}setDataSortingOptions(){let t=this.options;me(this,{requireSorting:!1,sorted:!1,enabledDataSorting:!0,allowDG:!1}),it(t.pointRange)||(t.pointRange=1)}setOptions(t){let e,i=this.chart,s=i.options.plotOptions,o=i.userOptions||{},r=Re(t),a=i.styledMode,n={plotOptions:s,userOptions:r};J(this,"setOptions",n);let l=n.plotOptions[this.type],c=o.plotOptions||{},d=c.series||{},p=wi.plotOptions[this.type]||{},g=c[this.type]||{};l.dataLabels=this.mergeArrays(p.dataLabels,l.dataLabels),this.userOptions=n.userOptions;let u=Re(l,s.series,g,r);this.tooltipOptions=Re(wi.tooltip,wi.plotOptions.series?.tooltip,p?.tooltip,i.userOptions.tooltip,c.series?.tooltip,g.tooltip,r.tooltip),this.stickyTracking=Q(r.stickyTracking,g.stickyTracking,d.stickyTracking,!!this.tooltipOptions.shared&&!this.noSharedTooltip||u.stickyTracking),l.marker===null&&delete u.marker,this.zoneAxis=u.zoneAxis||"y";let x=this.zones=(u.zones||[]).map(m=>It({},m));return(u.negativeColor||u.negativeFillColor)&&!u.zones&&(e={value:u[this.zoneAxis+"Threshold"]||u.threshold||0,className:"highcharts-negative"},a||(e.color=u.negativeColor,e.fillColor=u.negativeFillColor),x.push(e)),x.length&&it(x[x.length-1].value)&&x.push(a?{}:{color:this.color,fillColor:this.fillColor}),J(this,"afterSetOptions",{options:u}),u}getName(){return this.options.name??vd(this.chart.options.lang.seriesName,this,this.chart)}getCyclic(t,e,i){let s,o,r=this.chart,a=`${t}Index`,n=`${t}Counter`,l=i?.length||r.options.chart.colorCount;!e&&(it(o=Q(t==="color"?this.options.colorIndex:void 0,this[a]))?s=o:(r.series.length||(r[n]=0),s=r[n]%l,r[n]+=1),i&&(e=i[s])),s!==void 0&&(this[a]=s),this[t]=e}getColor(){this.chart.styledMode?this.getCyclic("color"):this.options.colorByPoint?this.color="#cccccc":this.getCyclic("color",this.options.color||wi.plotOptions[this.type].color,this.chart.options.colors)}getPointsCollection(){return(this.hasGroupedData?this.points:this.data)||[]}getSymbol(){let t=this.options.marker;this.getCyclic("symbol",t.symbol,this.chart.options.symbols)}getColumn(t,e){return(e?this.dataTable.modified:this.dataTable).getColumn(t,!0)||[]}findPointIndex(t,e){let i,s,o,{id:r,x:a}=t,n=this.points,l=this.options.dataSorting,c=this.cropStart||0;if(r){let d=this.chart.get(r);d instanceof Zt&&(i=d)}else if(this.linkedParent||this.enabledDataSorting||this.options.relativeXValue){let d=p=>!p.touched&&p.index===t.index;if(l?.matchByName?d=p=>!p.touched&&p.name===t.name:this.options.relativeXValue&&(d=p=>!p.touched&&p.options.x===t.x),!(i=Sd(n,d)))return}return i&&(o=i?.index)!==void 0&&(s=!0),o===void 0&&st(a)&&(o=this.getColumn("x").indexOf(a,e)),o!==-1&&o!==void 0&&this.cropped&&(o=o>=c?o-c:o),!s&&st(o)&&n[o]?.touched&&(o=void 0),o}updateData(t,e){let{options:i,requireSorting:s}=this,o=i.dataSorting,r=this.points,a=[],n=t.length===r.length,l,c,d,p,g=!0;if(this.xIncrement=null,t.forEach((x,m)=>{let f,y=it(x)&&this.pointClass.prototype.optionsToObject.call({series:this},x)||{},{id:b,x:v}=y;b||st(v)?((f=this.findPointIndex(y,p))===-1||f===void 0?a.push(x):r[f]&&x!==i.data?.[f]?(r[f].update(x,!1,void 0,!1),r[f].touched=!0,s&&(p=f+1)):r[f]&&(r[f].touched=!0),(!n||m!==f||o?.enabled||this.hasDerivedData)&&(l=!0)):a.push(x)},this),l)for(c=r.length;c--;)(d=r[c])&&!d.touched&&d.remove?.(!1,e);else n&&!o?.enabled?(t.forEach((x,m)=>{x===r[m].y||r[m].destroyed||r[m].update(x,!1,void 0,!1)}),a.length=0):g=!1;if(r.forEach(x=>{x&&(x.touched=!1)}),!g)return!1;a.forEach(x=>{this.addPoint(x,!1,void 0,void 0,!1)},this);let u=this.getColumn("x");return this.xIncrement===null&&u.length&&(this.xIncrement=Is(u),this.autoIncrement()),!0}dataColumnKeys(){return["x",...this.pointArrayMap||["y"]]}setData(t,e=!0,i,s){let o=this.points,r=o?.length||0,a=this.options,n=this.chart,l=a.dataSorting,c=this.xAxis,d=a.turboThreshold,p=this.dataTable,g=this.dataColumnKeys(),u=this.pointValKey||"y",x=(this.pointArrayMap||[]).length,m=a.keys,f,y,b=0,v=1,S;n.options.chart.allowMutatingData||(a.data&&delete this.options.data,this.userOptions.data&&delete this.userOptions.data,S=Re(!0,t));let w=(t=S||t||[]).length;if(l?.enabled&&(t=this.sortData(t)),n.options.chart.allowMutatingData&&s!==!1&&w&&r&&!this.cropped&&!this.hasGroupedData&&this.visible&&!this.boosted&&(y=this.updateData(t,i)),!y){this.xIncrement=null,this.colorCounter=0;let k=d&&!a.relativeXValue&&w>d;if(k){let M=this.getFirstValidPoint(t),T=this.getFirstValidPoint(t,w-1,-1),A=C=>!!(aa(C)&&(m||st(C[0])));if(st(M)&&st(T)){let C=[],O=[];for(let D of t)C.push(this.autoIncrement()),O.push(D);p.setColumns({x:C,[u]:O})}else if(A(M)&&A(T))if(x){let C=+(M.length===x),O=Array(g.length).fill(0).map(()=>[]);for(let D of t){C&&O[0].push(this.autoIncrement());for(let B=C;B<=x;B++)O[B]?.push(D[B-C])}p.setColumns(g.reduce((D,B,E)=>(D[B]=O[E],D),{}))}else{m&&(b=m.indexOf("x"),v=m.indexOf("y"),b=b>=0?b:0,v=v>=0?v:1),M.length===1&&(v=0);let C=[],O=[];if(b===v)for(let D of t)C.push(this.autoIncrement()),O.push(D[v]);else for(let D of t)C.push(D[b]),O.push(D[v]);p.setColumns({x:C,[u]:O})}else k=!1}if(!k){let M=g.reduce((T,A)=>(T[A]=[],T),{});for(f=0;f<w;f++){let T=this.pointClass.prototype.applyOptions.apply({series:this},[t[f]]);for(let A of g)M[A][f]=T[A]}p.setColumns(M)}for(Cd(this.getColumn("y")[0])&&Mi(14,!0,n),this.data=[],this.options.data=this.userOptions.data=t,f=r;f--;)o[f]?.destroy();c&&(c.minRange=c.userMinRange),this.isDirty=n.isDirtyBox=!0,this.isDirtyData=!!o,i=!1}a.legendType==="point"&&(this.processData(),this.generatePoints()),e&&n.redraw(i)}sortData(t){let e=this,i=e.options.dataSorting.sortKey||"y",s=function(o,r){return it(r)&&o.pointClass.prototype.optionsToObject.call({series:o},r)||{}};return t.forEach(function(o,r){t[r]=s(e,o),t[r].index=r},this),t.concat().sort((o,r)=>{let a=oa(i,o),n=oa(i,r);return n<a?-1:+(n>a)}).forEach(function(o,r){o.x=r},this),e.linkedSeries&&e.linkedSeries.forEach(function(o){let r=o.options,a=r.data;!r.dataSorting?.enabled&&a&&(a.forEach(function(n,l){a[l]=s(o,n),t[l]&&(a[l].x=t[l].x,a[l].index=l)}),o.setData(a,!1))}),t}getProcessedData(t){let e=this,{dataTable:i,isCartesian:s,options:o,xAxis:r}=e,a=o.cropThreshold,n=t||e.getExtremesFromAll,l=r?.logarithmic,c=i.rowCount,d,p,g=0,u,x,m,f=e.getColumn("x"),y=i,b=!1;return r&&(x=(u=r.getExtremes()).min,m=u.max,b=!!(r.categories&&!r.names.length),s&&e.sorted&&!n&&(!a||c>a||e.forceCrop)&&(f[c-1]<x||f[0]>m?y=new Ri:e.getColumn(e.pointValKey||"y").length&&(f[0]<x||f[c-1]>m)&&(y=(d=this.cropData(i,x,m)).modified,g=d.start,p=!0))),f=y.getColumn("x")||[],{modified:y,cropped:p,cropStart:g,closestPointRange:Td([l?f.map(l.log2lin):f],()=>e.requireSorting&&!b&&Mi(15,!1,e.chart))}}processData(t){let e=this.xAxis,i=this.dataTable;if(this.isCartesian&&!this.isDirty&&!e.isDirty&&!this.yAxis.isDirty&&!t)return!1;let s=this.getProcessedData();i.modified=s.modified,this.cropped=s.cropped,this.cropStart=s.cropStart,this.closestPointRange=this.basePointRange=s.closestPointRange,J(this,"afterProcessData")}cropData(t,e,i){let s=t.getColumn("x",!0)||[],o=s.length,r={},a,n,l=0,c=o;for(a=0;a<o;a++)if(s[a]>=e){l=Math.max(0,a-1);break}for(n=a;n<o;n++)if(s[n]>i){c=n+1;break}for(let d of this.dataColumnKeys()){let p=t.getColumn(d,!0);p&&(r[d]=p.slice(l,c))}return{modified:new Ri({columns:r}),start:l,end:c}}generatePoints(){let t=this.options,e=this.processedData||t.data,i=this.dataTable.modified,s=this.getColumn("x",!0),o=this.pointClass,r=i.rowCount,a=this.cropStart||0,n=this.hasGroupedData,l=t.keys,c=[],d=t.dataGrouping?.groupAll?a:0,p=this.xAxis?.categories,g=this.pointArrayMap||["y"],u=this.dataColumnKeys(),x,m,f,y,b=this.data,v;if(!b&&!n){let S=[];S.length=e?.length||0,b=this.data=S}for(l&&n&&(this.options.keys=!1),y=0;y<r;y++)m=a+y,n?((f=new o(this,i.getRow(y,u)||[])).dataGroup=this.groupMap[d+y],f.dataGroup?.options&&(f.options=f.dataGroup.options,me(f,f.dataGroup.options),delete f.dataLabels)):(f=b[m],v=e?e[m]:i.getRow(y,g),f||v===void 0||(b[m]=f=new o(this,v,s[y]))),f&&(f.index=n?d+y:m,c[y]=f,f.category=p?.[f.x]??f.x,f.key=f.name??f.category);if(this.options.keys=l,b&&(r!==(x=b.length)||n))for(y=0;y<x;y++)y!==a||n||(y+=r),b[y]&&(b[y].destroyElements(),b[y].plotX=void 0);this.data=b,this.points=c,J(this,"afterGeneratePoints")}getXExtremes(t){return{min:ta(t),max:Is(t)}}getExtremes(t,e){let{xAxis:i,yAxis:s}=this,o=e||this.getExtremesFromAll||this.options.getExtremesFromAll,r=o&&this.cropped?this.dataTable:this.dataTable.modified,a=r.rowCount,n=t||this.stackedYData,l=n?[n]:(this.keysAffectYAxis||this.pointArrayMap||["y"])?.map(S=>r.getColumn(S,!0)||[])||[],c=this.getColumn("x",!0),d=[],p=this.requireSorting&&!this.is("column")?1:0,g=!!s&&s.positiveValuesOnly,u=o||this.cropped||!i,x,m,f,y=0,b=0;for(i&&(y=(x=i.getExtremes()).min,b=x.max),f=0;f<a;f++)if(m=c[f],u||(c[f+p]||m)>=y&&(c[f-p]||m)<=b)for(let S of l){let w=S[f];st(w)&&(w>0||!g)&&d.push(w)}let v={activeYData:d,dataMin:ta(d),dataMax:Is(d)};return J(this,"afterGetExtremes",{dataExtremes:v}),v}applyExtremes(){let t=this.getExtremes();return this.dataMin=t.dataMin,this.dataMax=t.dataMax,t}getFirstValidPoint(t,e=0,i=1){let s=t.length,o=e;for(;o>=0&&o<s;){if(it(t[o]))return t[o];o+=i}}translate(){this.generatePoints();let t=this.options,e=t.stacking,i=this.xAxis,s=this.enabledDataSorting,o=this.yAxis,r=this.points,a=r.length,n=this.pointPlacementToXValue(),l=!!n,c=t.threshold,d=t.startFromThreshold?c:0,p=t?.nullInteraction&&o.len,g,u,x,m,f=Number.MAX_VALUE;function y(b){return ea(b,-1e9,1e9)}for(g=0;g<a;g++){let b,v=r[g],S=v.x,w,k,M=v.y,T=v.low,A=e&&o.stacking?.stacks[(this.negStacks&&M<(d?0:c)?"-":"")+this.stackKey];v.plotX=st(u=i.translate(S,!1,!1,!1,!0,n))?ia(y(u)):void 0,e&&this.visible&&A&&A[S]&&(m=this.getStackIndicator(m,S,this.index),!v.isNull&&m.key&&(k=(w=A[S]).points[m.key]),w&&aa(k)&&(T=k[0],M=k[1],T===d&&m.key===A[S].base&&(T=Q(st(c)?c:o.min)),o.positiveValuesOnly&&it(T)&&T<=0&&(T=void 0),v.total=v.stackTotal=Q(w.total),v.percentage=it(v.y)&&w.total?v.y/w.total*100:void 0,v.stackY=M,this.irregularWidths||w.setOffset(this.pointXOffset||0,this.barW||0,void 0,void 0,void 0,this.xAxis))),v.yBottom=it(T)?y(o.translate(T,!1,!0,!1,!0)):void 0,this.dataModify&&(M=this.dataModify.modifyValue(M,g)),st(M)&&v.plotX!==void 0?b=st(b=o.translate(M,!1,!0,!1,!0))?y(b):void 0:!st(M)&&p&&(b=p),v.plotY=b,v.isInside=this.isPointInside(v),v.clientX=l?ia(i.translate(S,!1,!1,!1,!0,n)):u,v.negative=(v.y||0)<(c||0),v.isNull||v.visible===!1||(x!==void 0&&(f=Math.min(f,Math.abs(u-x))),x=u),v.zone=this.zones.length?v.getZone():void 0,!v.graphic&&this.group&&s&&(v.isNew=!0)}this.closestPointRangePx=f,J(this,"afterTranslate")}getValidPoints(t,e,i){let s=this.chart;return(t||this.points||[]).filter(function(o){let{plotX:r,plotY:a}=o;return(!!i||!o.isNull&&!!st(a))&&(!e||!!s.isInsidePlot(r,a,{inverted:s.inverted}))&&o.visible!==!1})}getSharedClipKey(){return this.sharedClipKey=(this.options.xAxis||0)+","+(this.options.yAxis||0),this.sharedClipKey}setClip(){let{chart:t,group:e,markerGroup:i}=this,s=t.sharedClips,o=t.renderer,r=t.getClipBox(this),a=this.getSharedClipKey(),n=s[a];n?n.animate(r):s[a]=n=o.clipRect(r),e&&e.clip(this.options.clip===!1?void 0:n),i&&i.clip()}animate(t){let{chart:e,group:i,markerGroup:s}=this,o=e.inverted,r=Qr(this.options.animation),a=[this.getSharedClipKey(),r.duration,r.easing,r.defer].join(","),n=e.sharedClips[a],l=e.sharedClips[a+"m"];if(t&&i){let c=e.getClipBox(this);if(n)n.attr("height",c.height);else{c.width=0,o&&(c.x=e.plotHeight),n=e.renderer.clipRect(c),e.sharedClips[a]=n;let d={x:-99,y:-99,width:o?e.plotWidth+199:99,height:o?99:e.plotHeight+199};l=e.renderer.clipRect(d),e.sharedClips[a+"m"]=l}i.clip(n),s?.clip(l)}else if(n&&!n.hasClass("highcharts-animating")){let c=e.getClipBox(this),d=r.step;(s?.element.childNodes.length||e.series.length>1)&&(r.step=function(p,g){d&&d.apply(g,arguments),g.prop==="width"&&l?.element&&l.attr(o?"height":"width",p+99)}),n.addClass("highcharts-animating").animate(c,r)}}afterAnimate(){this.setClip(),Ds(this.chart.sharedClips,(t,e,i)=>{t&&!this.chart.container.querySelector(`[clip-path="url(#${t.id})"]`)&&(t.destroy(),delete i[e])}),this.finishedAnimating=!0,J(this,"afterAnimate")}drawPoints(t=this.points){let e,i,s,o,r,a,n,l=this.chart,c=l.styledMode,{colorAxis:d,options:p}=this,g=p.marker,u=p.nullInteraction,x=this[this.specialGroup||"markerGroup"],m=this.xAxis,f=Q(g.enabled,!m||!!m.isRadial||null,this.closestPointRangePx>=g.enabledThreshold*g.radius);if(g.enabled!==!1||this._hasPointMarkers)for(e=0;e<t.length;e++){o=(s=(i=t[e]).graphic)?"animate":"attr",r=i.marker||{},a=!!i.marker;let y=i.isNull;if((f&&!it(r.enabled)||r.enabled)&&(!y||u)&&i.visible!==!1){let b=Q(r.symbol,this.symbol,"rect");n=this.markerAttribs(i,i.selected&&"select"),this.enabledDataSorting&&(i.startXPos=m.reversed?-(n.width||0):m.width);let v=i.isInside!==!1;if(!s&&v&&((n.width||0)>0||i.hasImage)&&(i.graphic=s=l.renderer.symbol(b,n.x,n.y,n.width,n.height,a?r:g).add(x),this.enabledDataSorting&&l.hasRendered&&(s.attr({x:i.startXPos}),o="animate")),s&&o==="animate"&&s[v?"show":"hide"](v).animate(n),s){let S=this.pointAttribs(i,c||!i.selected?void 0:"select");c?d&&s.css({fill:S.fill}):s[o](S)}s&&s.addClass(i.getClassName(),!0)}else s&&(i.graphic=s.destroy())}}markerAttribs(t,e){let i=this.options,s=i.marker,o=t.marker||{},r=o.symbol||s.symbol,a={},n,l,c=Q(o.radius,s?.radius);e&&(n=s.states[e],l=o.states&&o.states[e],c=Q(l?.radius,n?.radius,c&&c+(n?.radiusPlus||0))),t.hasImage=r&&r.indexOf("url")===0,t.hasImage&&(c=0);let d=t.pos();return st(c)&&d&&(i.crisp&&(d[0]=kd(d[0],t.hasImage?0:r==="rect"?s?.lineWidth||0:1)),a.x=d[0]-c,a.y=d[1]-c),c&&(a.width=a.height=2*c),a}pointAttribs(t,e){let i=this.options,s=i.marker,o=t?.options,r=o?.marker||{},a=o?.color,n=t?.color,l=t?.zone?.color,c,d,p=this.color,g,u,x=Q(r.lineWidth,s.lineWidth),m=t?.isNull&&i.nullInteraction?0:1;return p=a||l||n||p,g=r.fillColor||s.fillColor||p,u=r.lineColor||s.lineColor||p,e=e||"normal",c=s.states[e]||{},x=Q((d=r.states&&r.states[e]||{}).lineWidth,c.lineWidth,x+Q(d.lineWidthPlus,c.lineWidthPlus,0)),g=d.fillColor||c.fillColor||g,u=d.lineColor||c.lineColor||u,{stroke:u,"stroke-width":x,fill:g,opacity:m=Q(d.opacity,c.opacity,m)}}destroy(t){let e,i,s=this,o=s.chart,r=/AppleWebKit\/533/.test(bd.navigator.userAgent),a=s.data||[];for(J(s,"destroy",{keepEventsForUpdate:t}),this.removeEvents(t),(s.axisTypes||[]).forEach(function(n){i=s[n],i?.series&&(sa(i.series,s),i.isDirty=i.forceRedraw=!0)}),s.legendItem&&s.chart.legend.destroyItem(s),e=a.length;e--;)a[e]?.destroy?.();for(let n of s.zones)wd(n,void 0,!0);N.clearTimeout(s.animationTimeout),Ds(s,function(n,l){n instanceof Et&&!n.survive&&n[r&&l==="group"?"hide":"destroy"]()}),o.hoverSeries===s&&(o.hoverSeries=void 0),sa(o.series,s),o.orderItems("series"),Ds(s,function(n,l){t&&l==="hcEvents"||delete s[l]})}applyZones(){let{area:t,chart:e,graph:i,zones:s,points:o,xAxis:r,yAxis:a,zoneAxis:n}=this,{inverted:l,renderer:c}=e,d=this[`${n}Axis`],{isXAxis:p,len:g=0,minPointOffset:u=0}=d||{},x=(i?.strokeWidth()||0)/2+1,m=(f,y=0,b=0)=>{l&&(b=g-b);let{translated:v=0,lineClip:S}=f,w=b-v;S?.push(["L",y,Math.abs(w)<x?b-x*(w<=0?-1:1):v])};if(s.length&&(i||t)&&d&&st(d.min)){let f=d.getExtremes().max+u,y=S=>{S.forEach((w,k)=>{(w[0]==="M"||w[0]==="L")&&(S[k]=[w[0],p?g-w[1]:w[1],p?w[2]:g-w[2]])})};if(s.forEach(S=>{S.lineClip=[],S.translated=ea(d.toPixels(Q(S.value,f),!0)||0,0,g)}),i&&!this.showLine&&i.hide(),t&&t.hide(),n==="y"&&o.length<r.len)for(let S of o){let{plotX:w,plotY:k,zone:M}=S,T=M&&s[s.indexOf(M)-1];M&&m(M,w,k),T&&m(T,w,k)}let b=[],v=d.toPixels(d.getExtremes().min-u,!0);s.forEach(S=>{let w=S.lineClip||[],k=Math.round(S.translated||0);r.reversed&&w.reverse();let{clip:M,simpleClip:T}=S,A=0,C=0,O=r.len,D=a.len;p?(A=k,O=v):(C=k,D=v);let B=[["M",A,C],["L",O,C],["L",O,D],["L",A,D],["Z"]],E=[B[0],...w,B[1],B[2],...b,B[3],B[4]];b=w.reverse(),v=k,l&&(y(E),t&&y(B)),M?(M.animate({d:E}),T?.animate({d:B})):(M=S.clip=c.path(E),t&&(T=S.simpleClip=c.path(B))),i&&S.graph?.clip(M),t&&S.area?.clip(T)})}else this.visible&&(i&&i.show(),t&&t.show())}plotGroup(t,e,i,s,o){let r=this[t],a=!r,n={visibility:i,zIndex:s||.1};return it(this.opacity)&&!this.chart.styledMode&&this.state!=="inactive"&&(n.opacity=this.opacity),r||(this[t]=r=this.chart.renderer.g().add(o)),r.addClass("highcharts-"+e+" highcharts-series-"+this.index+" highcharts-"+this.type+"-series "+(it(this.colorIndex)?"highcharts-color-"+this.colorIndex+" ":"")+(this.options.className||"")+(r.hasClass("highcharts-tracker")?" highcharts-tracker":""),!0),r.attr(n)[a?"attr":"animate"](this.getPlotBox(e)),r}getPlotBox(t){let e=this.xAxis,i=this.yAxis,s=this.chart,o=s.inverted&&!s.polar&&e&&this.invertible&&t==="series";s.inverted&&(e=i,i=this.xAxis);let r={scale:1,translateX:e?e.left:s.plotLeft,translateY:i?i.top:s.plotTop,name:t};J(this,"getPlotBox",r);let{scale:a,translateX:n,translateY:l}=r;return{translateX:n,translateY:l,rotation:90*!!o,rotationOriginX:o?a*(e.len-i.len)/2:0,rotationOriginY:o?a*(e.len+i.len)/2:0,scaleX:o?-a:a,scaleY:a}}removeEvents(t){let{eventsToUnbind:e}=this;t||Ad(this),e.length&&(e.forEach(i=>{i()}),e.length=0)}render(){let t=this,{chart:e,options:i,hasRendered:s}=t,o=Qr(i.animation),r=t.visible?"inherit":"hidden",a=i.zIndex,n=e.seriesGroup,l=t.finishedAnimating?0:o.duration;J(this,"render"),t.plotGroup("group","series",r,a,n),t.markerGroup=t.plotGroup("markerGroup","markers",r,a,n),i.clip!==!1&&t.setClip(),l&&t.animate?.(!0),t.drawGraph&&(t.drawGraph(),t.applyZones()),t.visible&&t.drawPoints(),t.drawDataLabels?.(),t.redrawPoints?.(),i.enableMouseTracking&&t.drawTracker?.(),l&&t.animate?.(),s||(l&&o.defer&&(l+=o.defer),t.animationTimeout=na(()=>{t.afterAnimate()},l||0)),t.isDirty=!1,t.hasRendered=!0,J(t,"afterRender")}redraw(){let t=this.isDirty||this.isDirtyData;this.translate(),this.render(),t&&delete this.kdTree}reserveSpace(){return this.visible||!this.chart.options.chart.ignoreHiddenSeries}searchPoint(t,e){let{xAxis:i,yAxis:s}=this,o=this.chart.inverted;return this.searchKDTree({clientX:o?i.len-t.chartY+i.pos:t.chartX-i.pos,plotY:o?s.len-t.chartX+s.pos:t.chartY-s.pos},e,t)}buildKDTree(t){this.buildingKdTree=!0;let e=this,i=e.options,s=i.findNearestPointBy.indexOf("y")>-1?2:1;delete e.kdTree,na(function(){e.kdTree=function o(r,a,n){let l,c,d=r?.length;if(d)return l=e.kdAxisArray[a%n],r.sort((p,g)=>(p[l]||0)-(g[l]||0)),{point:r[c=Math.floor(d/2)],left:o(r.slice(0,c),a+1,n),right:o(r.slice(c+1),a+1,n)}}(e.getValidPoints(void 0,!e.directTouch,i?.nullInteraction),s,s),e.buildingKdTree=!1},i.kdNow||t?.type==="touchstart"?0:1)}searchKDTree(t,e,i,s,o){let r=this,[a,n]=this.kdAxisArray,l=e?"distX":"dist",c=(r.options.findNearestPointBy||"").indexOf("y")>-1?2:1,d=!!r.isBubble,p=s||((u,x,m)=>{let f=u[m]||0,y=x[m]||0;return[f===y&&u.index>x.index||f<y?u:x,!1]}),g=o||((u,x)=>u<x);if(this.kdTree||this.buildingKdTree||this.buildKDTree(i),this.kdTree)return function u(x,m,f,y){let b=m.point,v=r.kdAxisArray[f%y],S=b,w=!1;(function(A,C){let O=A[a],D=C[a],B=it(O)&&it(D)?O-D:null,E=A[n],L=C[n],I=it(E)&&it(L)?E-L:0,V=d&&C.marker?.radius||0;C.dist=Math.sqrt((B&&B*B||0)+I*I)-V,C.distX=it(B)?Math.abs(B)-V:Number.MAX_VALUE})(x,b);let k=(x[v]||0)-(b[v]||0)+(d&&b.marker?.radius||0),M=k<0?"left":"right",T=k<0?"right":"left";return m[M]&&([S,w]=p(b,u(x,m[M],f+1,y),l)),m[T]&&g(Math.sqrt(k*k),S[l],w)&&(S=p(S,u(x,m[T],f+1,y),l)[0]),S}(t,this.kdTree,c,c)}pointPlacementToXValue(){let{options:t,xAxis:e}=this,i=t.pointPlacement;return i==="between"&&(i=e.reversed?-.5:.5),st(i)?i*(t.pointRange||e.pointRange):0}isPointInside(t){let{chart:e,xAxis:i,yAxis:s}=this,{plotX:o=-1,plotY:r=-1}=t;return r>=0&&r<=(s?s.len:e.plotHeight)&&o>=0&&o<=(i?i.len:e.plotWidth)}drawTracker(){let t=this,e=t.options,i=e.trackByArea,s=[].concat((i?t.areaPath:t.graphPath)||[]),o=t.chart,r=o.pointer,a=o.renderer,n=o.options.tooltip?.snap||0,l=()=>{e.enableMouseTracking&&o.hoverSeries!==t&&t.onMouseOver()},c="rgba(192,192,192,"+(yd?1e-4:.002)+")",d=t.tracker;d?d.attr({d:s}):t.graph&&(t.tracker=d=a.path(s).attr({visibility:t.visible?"inherit":"hidden",zIndex:2}).addClass(i?"highcharts-tracker-area":"highcharts-tracker-line").add(t.group),o.styledMode||d.attr({"stroke-linecap":"round","stroke-linejoin":"round",stroke:c,fill:i?c:"none","stroke-width":t.graph.strokeWidth()+(i?0:2*n)}),[t.tracker,t.markerGroup,t.dataLabelsGroup].forEach(p=>{p&&(p.addClass("highcharts-tracker").on("mouseover",l).on("mouseout",g=>{r?.onTrackerMouseOut(g)}),e.cursor&&!o.styledMode&&p.css({cursor:e.cursor}),p.on("touchstart",l))})),J(this,"afterDrawTracker")}addPoint(t,e,i,s,o){let r,a,n=this.options,{chart:l,data:c,dataTable:d,xAxis:p}=this,g=p?.hasNames&&p.names,u=n.data,x=this.getColumn("x");e=Q(e,!0);let m={series:this};this.pointClass.prototype.applyOptions.apply(m,[t]);let f=m.x;if(a=x.length,this.requireSorting&&f<x[a-1])for(r=!0;a&&x[a-1]>f;)a--;d.setRow(m,a,!0,{addColumns:!1}),g&&m.name&&(g[f]=m.name),u?.splice(a,0,t),(r||this.processedData)&&(this.data.splice(a,0,null),this.processData()),n.legendType==="point"&&this.generatePoints(),i&&(c[0]&&c[0].remove?c[0].remove(!1):([c,u].filter(it).forEach(y=>{y.shift()}),d.deleteRows(0))),o!==!1&&J(this,"addPoint",{point:m}),this.isDirty=!0,this.isDirtyData=!0,e&&l.redraw(s)}removePoint(t,e,i){let s=this,{chart:o,data:r,points:a,dataTable:n}=s,l=r[t],c=function(){[a?.length===r.length?a:void 0,r,s.options.data].filter(it).forEach(d=>{d.splice(t,1)}),n.deleteRows(t),l?.destroy(),s.isDirty=!0,s.isDirtyData=!0,e&&o.redraw()};md(i,o),e=Q(e,!0),l?l.firePointEvent("remove",null,c):c()}remove(t,e,i,s){let o=this,r=o.chart;function a(){o.destroy(s),r.isDirtyLegend=r.isDirtyBox=!0,r.linkSeries(s),Q(t,!0)&&r.redraw(e)}i!==!1?J(o,"remove",null,a):a()}update(t,e){J(this,"update",{options:t=Md(t,this.userOptions)});let i=this,s=i.chart,o=i.userOptions,r=i.initialType||i.type,a=s.options.plotOptions,n=ue[r].prototype,l=i.finishedAnimating&&{animation:!1},c={},d,p,g=h.keepProps.slice(),u=t.type||o.type||s.options.chart.type,x=!(this.hasDerivedData||u&&u!==this.type||t.keys!==void 0||t.pointStart!==void 0||t.pointInterval!==void 0||t.relativeXValue!==void 0||t.joinBy||t.mapData||["dataGrouping","pointStart","pointInterval","pointIntervalUnit","keys"].some(f=>i.hasOptionChanged(f)));u=u||r,x?(g.push.apply(g,h.keepPropsForPoints),t.visible!==!1&&g.push("area","graph"),i.parallelArrays.forEach(function(f){g.push(f+"Data")}),t.data&&(t.dataSorting&&me(i.options.dataSorting,t.dataSorting),this.setData(t.data,!1))):this.dataTable.modified=this.dataTable,t=Re(o,{index:o.index===void 0?i.index:o.index,pointStart:a?.series?.pointStart??o.pointStart??i.getColumn("x")[0]},!x&&{data:i.options.data},t,l),x&&t.data&&(t.data=i.options.data),(g=["group","markerGroup","dataLabelsGroup","transformGroup"].concat(g)).forEach(function(f){g[f]=i[f],delete i[f]});let m=!1;if(ue[u]){if(m=u!==i.type,i.remove(!1,!1,!1,!0),m)if(s.propFromSeries(),Object.setPrototypeOf)Object.setPrototypeOf(i,ue[u].prototype);else{let f=Object.hasOwnProperty.call(i,"hcEvents")&&i.hcEvents;for(p in n)i[p]=void 0;me(i,ue[u].prototype),f?i.hcEvents=f:delete i.hcEvents}}else Mi(17,!0,s,{missingModuleFor:u});if(g.forEach(function(f){i[f]=g[f]}),i.init(s,t),x&&this.points)for(let f of((d=i.options).visible===!1?(c.graphic=1,c.dataLabel=1):(this.hasMarkerChanged(d,o)&&(c.graphic=1),i.hasDataLabels?.()||(c.dataLabel=1)),this.points))f?.series&&(f.resolveColor(),Object.keys(c).length&&f.destroyElements(c),d.showInLegend===!1&&f.legendItem&&s.legend.destroyItem(f));i.initialType=r,s.linkSeries(),s.setSortedData(),m&&i.linkedSeries.length&&(i.isDirtyData=!0),J(this,"afterUpdate"),Q(e,!0)&&s.redraw(!!x&&void 0)}setName(t){this.name=this.options.name=this.userOptions.name=t,this.chart.isDirtyLegend=!0}hasOptionChanged(t){let e=this.chart,i=this.options[t],s=e.options.plotOptions,o=this.userOptions[t],r=Q(s?.[this.type]?.[t],s?.series?.[t]);return o&&!it(r)?i!==o:i!==Q(r,i)}onMouseOver(){let t=this.chart,e=t.hoverSeries;t.pointer?.setHoverChartIndex(),e&&e!==this&&e.onMouseOut(),this.options.events.mouseOver&&J(this,"mouseOver"),this.setState("hover"),t.hoverSeries=this}onMouseOut(){let t=this.options,e=this.chart,i=e.tooltip,s=e.hoverPoint;e.hoverSeries=null,s&&s.onMouseOut(),this&&t.events.mouseOut&&J(this,"mouseOut"),i&&!this.stickyTracking&&(!i.shared||this.noSharedTooltip)&&i.hide(),e.series.forEach(function(o){o.setState("",!0)})}setState(t,e){let i=this,s=i.options,o=i.graph,r=s.inactiveOtherPoints,a=s.states,n=Q(a[t||"normal"]&&a[t||"normal"].animation,i.chart.options.chart.animation),l=s.lineWidth,c=s.opacity;if(t=t||"",i.state!==t&&([i.group,i.markerGroup,i.dataLabelsGroup].forEach(function(d){d&&(i.state&&d.removeClass("highcharts-series-"+i.state),t&&d.addClass("highcharts-series-"+t))}),i.state=t,!i.chart.styledMode)){if(a[t]&&a[t].enabled===!1)return;if(t&&(l=a[t].lineWidth||l+(a[t].lineWidthPlus||0),c=Q(a[t].opacity,c)),o&&!o.dashstyle&&st(l))for(let d of[o,...this.zones.map(p=>p.graph)])d?.animate({"stroke-width":l},n);r||[i.group,i.markerGroup,i.dataLabelsGroup,i.labelBySeries].forEach(function(d){d&&d.animate({opacity:c},n)})}e&&r&&i.points&&i.setAllPointsToState(t||void 0)}setAllPointsToState(t){this.points.forEach(function(e){e.setState&&e.setState(t)})}setVisible(t,e){let i=this,s=i.chart,o=s.options.chart.ignoreHiddenSeries,r=i.visible;i.visible=t=i.options.visible=i.userOptions.visible=t===void 0?!r:t;let a=t?"show":"hide";["group","dataLabelsGroup","markerGroup","tracker","tt"].forEach(n=>{i[n]?.[a]()}),(s.hoverSeries===i||s.hoverPoint?.series===i)&&i.onMouseOut(),i.legendItem&&s.legend.colorizeItem(i,t),i.isDirty=!0,i.options.stacking&&s.series.forEach(n=>{n.options.stacking&&n.visible&&(n.isDirty=!0)}),i.linkedSeries.forEach(n=>{n.setVisible(t,!1)}),o&&(s.isDirtyBox=!0),J(i,a),e!==!1&&s.redraw()}show(){this.setVisible(!0)}hide(){this.setVisible(!1)}select(t){this.selected=t=this.options.selected=t===void 0?!this.selected:t,this.checkbox&&(this.checkbox.checked=t),J(this,t?"select":"unselect")}shouldShowTooltip(t,e,i={}){return i.series=this,i.visiblePlotOnly=!0,this.chart.isInsidePlot(t,e,i)}drawLegendSymbol(t,e){Ka[this.options.legendSymbol||"rectangle"]?.call(this,t,e)}};Ot.defaultOptions={lineWidth:2,allowPointSelect:!1,crisp:!0,showCheckbox:!1,animation:{duration:1e3},enableMouseTracking:!0,events:{},marker:{enabledThreshold:2,lineColor:"#ffffff",lineWidth:0,radius:4,states:{normal:{animation:!0},hover:{animation:{duration:150},enabled:!0,radiusPlus:2,lineWidthPlus:1},select:{fillColor:"#cccccc",lineColor:"#000000",lineWidth:2}}},point:{events:{}},dataLabels:{animation:{},align:"center",borderWidth:0,defer:!0,formatter:function(){let{numberFormatter:h}=this.series.chart;return typeof this.y!="number"?"":h(this.y,-1)},padding:5,style:{fontSize:"0.7em",fontWeight:"bold",color:"contrast",textOutline:"1px contrast"},verticalAlign:"bottom",x:0,y:0},cropThreshold:300,opacity:1,pointRange:0,softThreshold:!0,states:{normal:{animation:!0},hover:{animation:{duration:150},lineWidthPlus:1,marker:{},halo:{size:10,opacity:.25}},select:{animation:{duration:0}},inactive:{animation:{duration:150},opacity:.2}},stickyTracking:!0,turboThreshold:1e3,findNearestPointBy:"x"},Ot.types=tt.seriesTypes,Ot.registerType=tt.registerSeriesType,Ot.keepProps=["colorIndex","eventOptions","navigatorSeries","symbolIndex","baseSeries"],Ot.keepPropsForPoints=["data","isDirtyData","isDirtyCanvas","points","dataTable","processedData","xIncrement","cropped","_hasPointMarkers","hasDataLabels","nodes","layout","level","mapMap","mapData","minY","maxY","minX","maxX","transformGroups"],me(Ot.prototype,{axisTypes:["xAxis","yAxis"],coll:"series",colorCounter:0,directTouch:!1,invertible:!0,isCartesian:!0,kdAxisArray:["clientX","plotY"],parallelArrays:["x","y"],pointClass:Zt,requireSorting:!0,sorted:!0}),tt.series=Ot;var ut=Ot,{animObject:Pd,setAnimation:Ld}=at,{registerEventOptions:ha}=Ki,{composed:Od,marginNames:la}=P,{distribute:Ed}=qi,{format:Id}=yt,{addEvent:Wi,createElement:Dd,css:Bd,defined:Bs,discardElement:Nd,find:zd,fireEvent:Bt,isNumber:da,merge:Qt,pick:kt,pushUnique:Rd,relativeLength:Wd,stableSort:Xd,syncTimeout:Hd}=N,ti=class{constructor(t,e){this.allItems=[],this.initialItemY=0,this.itemHeight=0,this.itemMarginBottom=0,this.itemMarginTop=0,this.itemX=0,this.itemY=0,this.lastItemY=0,this.lastLineHeight=0,this.legendHeight=0,this.legendWidth=0,this.maxItemWidth=0,this.maxLegendWidth=0,this.offsetWidth=0,this.padding=0,this.pages=[],this.symbolHeight=0,this.symbolWidth=0,this.titleHeight=0,this.totalItemWidth=0,this.widthOption=0,this.chart=t,this.setOptions(e),e.enabled&&(this.render(),ha(this,e),Wi(this.chart,"endResize",function(){this.legend.positionCheckboxes()})),Wi(this.chart,"render",()=>{this.options.enabled&&this.proximate&&(this.proximatePositions(),this.positionItems())})}setOptions(t){let e=kt(t.padding,8);this.options=t,this.chart.styledMode||(this.itemStyle=t.itemStyle,this.itemHiddenStyle=Qt(this.itemStyle,t.itemHiddenStyle)),this.itemMarginTop=t.itemMarginTop,this.itemMarginBottom=t.itemMarginBottom,this.padding=e,this.initialItemY=e-5,this.symbolWidth=kt(t.symbolWidth,16),this.pages=[],this.proximate=t.layout==="proximate"&&!this.chart.inverted,this.baseline=void 0}update(t,e){let i=this.chart;this.setOptions(Qt(!0,this.options,t)),"events"in this.options&&ha(this,this.options),this.destroy(),i.isDirtyLegend=i.isDirtyBox=!0,kt(e,!0)&&i.redraw(),Bt(this,"afterUpdate",{redraw:e})}colorizeItem(t,e){let i=t.color,{area:s,group:o,label:r,line:a,symbol:n}=t.legendItem||{};if((t instanceof ut||t instanceof Zt)&&(t.color=t.options?.legendSymbolColor||i),o?.[e?"removeClass":"addClass"]("highcharts-legend-item-hidden"),!this.chart.styledMode){let{itemHiddenStyle:l={}}=this,c=l.color,{fillColor:d,fillOpacity:p,lineColor:g,marker:u}=t.options,x=m=>(!e&&(m.fill&&(m.fill=c),m.stroke&&(m.stroke=c)),m);r?.css(Qt(e?this.itemStyle:l)),a?.attr(x({stroke:g||t.color})),n&&n.attr(x(u&&n.isMarker?t.pointAttribs():{fill:t.color})),s?.attr(x({fill:d||t.color,"fill-opacity":d?1:p??.75}))}t.color=i,Bt(this,"afterColorizeItem",{item:t,visible:e})}positionItems(){this.allItems.forEach(this.positionItem,this),this.chart.isResizing||this.positionCheckboxes()}positionItem(t){let{group:e,x:i=0,y:s=0}=t.legendItem||{},o=this.options,r=o.symbolPadding,a=!o.rtl,n=t.checkbox;if(e?.element){let l={translateX:a?i:this.legendWidth-i-2*r-4,translateY:s};e[Bs(e.translateY)?"animate":"attr"](l,void 0,()=>{Bt(this,"afterPositionItem",{item:t})})}n&&(n.x=i,n.y=s)}destroyItem(t){let e=t.legendItem||{};for(let i of["group","label","line","symbol"])e[i]&&(e[i]=e[i].destroy());t.checkbox=Nd(t.checkbox),t.legendItem=void 0}destroy(){for(let t of this.getAllItems())this.destroyItem(t);for(let t of["clipRect","up","down","pager","nav","box","title","group"])this[t]&&(this[t]=this[t].destroy());this.display=null}positionCheckboxes(){let t,e=this.group?.alignAttr,i=this.clipHeight||this.legendHeight,s=this.titleHeight;e&&(t=e.translateY,this.allItems.forEach(function(o){let r,a=o.checkbox;a&&(r=t+s+a.y+(this.scrollOffset||0)+3,Bd(a,{left:e.translateX+o.checkboxOffset+a.x-20+"px",top:r+"px",display:this.proximate||r>t-6&&r<t+i-6?"":"none"}))},this))}renderTitle(){let t=this.options,e=this.padding,i=t.title,s,o=0;i.text&&(this.title||(this.title=this.chart.renderer.label(i.text,e-3,e-4,void 0,void 0,void 0,t.useHTML,void 0,"legend-title").attr({zIndex:1}),this.chart.styledMode||this.title.css(i.style),this.title.add(this.group)),i.width||this.title.css({width:this.maxLegendWidth+"px"}),o=(s=this.title.getBBox()).height,this.offsetWidth=s.width,this.contentGroup.attr({translateY:o})),this.titleHeight=o}setText(t){let e=this.options;t.legendItem.label.attr({text:e.labelFormat?Id(e.labelFormat,t,this.chart):e.labelFormatter.call(t)})}renderItem(t){let e=t.legendItem=t.legendItem||{},i=this.chart,s=i.renderer,o=this.options,r=o.layout==="horizontal",a=this.symbolWidth,n=o.symbolPadding||0,l=this.itemStyle,c=this.itemHiddenStyle,d=r?kt(o.itemDistance,20):0,p=!o.rtl,g=!t.series,u=!g&&t.series.drawLegendSymbol?t.series:t,x=u.options,m=!!this.createCheckboxForItem&&x&&x.showCheckbox,f=o.useHTML,y=t.options.className,b=e.label,v=a+n+d+20*!!m;!b&&(e.group=s.g("legend-item").addClass("highcharts-"+u.type+"-series highcharts-color-"+t.colorIndex+(y?" "+y:"")+(g?" highcharts-series-"+t.index:"")).attr({zIndex:1}).add(this.scrollGroup),e.label=b=s.text("",p?a+n:-n,this.baseline||0,f),i.styledMode||b.css(Qt(t.visible?l:c)),b.attr({align:p?"left":"right",zIndex:2}).add(e.group),!this.baseline&&(this.fontMetrics=s.fontMetrics(b),this.baseline=this.fontMetrics.f+3+this.itemMarginTop,b.attr("y",this.baseline),this.symbolHeight=kt(o.symbolHeight,this.fontMetrics.f),o.squareSymbol&&(this.symbolWidth=kt(o.symbolWidth,Math.max(this.symbolHeight,16)),v=this.symbolWidth+n+d+20*!!m,p&&b.attr("x",this.symbolWidth+n))),u.drawLegendSymbol(this,t),this.setItemEvents&&this.setItemEvents(t,b,f)),m&&!t.checkbox&&this.createCheckboxForItem&&this.createCheckboxForItem(t),this.colorizeItem(t,t.visible),(i.styledMode||!l.width)&&b.css({width:(o.itemWidth||this.widthOption||i.spacingBox.width)-v+"px"}),this.setText(t);let S=b.getBBox(),w=this.fontMetrics?.h||0;t.itemWidth=t.checkboxOffset=o.itemWidth||e.labelWidth||S.width+v,this.maxItemWidth=Math.max(this.maxItemWidth,t.itemWidth),this.totalItemWidth+=t.itemWidth,this.itemHeight=t.itemHeight=Math.round(e.labelHeight||(S.height>1.5*w?S.height:w))}layoutItem(t){let e=this.options,i=this.padding,s=e.layout==="horizontal",o=t.itemHeight,r=this.itemMarginBottom,a=this.itemMarginTop,n=s?kt(e.itemDistance,20):0,l=this.maxLegendWidth,c=e.alignColumns&&this.totalItemWidth>l?this.maxItemWidth:t.itemWidth,d=t.legendItem||{};s&&this.itemX-i+c>l&&(this.itemX=i,this.lastLineHeight&&(this.itemY+=a+this.lastLineHeight+r),this.lastLineHeight=0),this.lastItemY=a+this.itemY+r,this.lastLineHeight=Math.max(o,this.lastLineHeight),d.x=this.itemX,d.y=this.itemY,s?this.itemX+=c:(this.itemY+=a+o+r,this.lastLineHeight=o),this.offsetWidth=this.widthOption||Math.max((s?this.itemX-i-(t.checkbox?0:n):c)+i,this.offsetWidth)}getAllItems(){let t=[];return this.chart.series.forEach(function(e){let i=e?.options;e&&kt(i.showInLegend,!Bs(i.linkedTo)&&void 0,!0)&&(t=t.concat(e.legendItem?.labels||(i.legendType==="point"?e.data:e)))}),Bt(this,"afterGetAllItems",{allItems:t}),t}getAlignment(){let t=this.options;return this.proximate?t.align.charAt(0)+"tv":t.floating?"":t.align.charAt(0)+t.verticalAlign.charAt(0)+t.layout.charAt(0)}adjustMargins(t,e){let i=this.chart,s=this.options,o=this.getAlignment();o&&[/(lth|ct|rth)/,/(rtv|rm|rbv)/,/(rbh|cb|lbh)/,/(lbv|lm|ltv)/].forEach((r,a)=>{r.test(o)&&!Bs(t[a])&&(i[la[a]]=Math.max(i[la[a]],i.legend[(a+1)%2?"legendHeight":"legendWidth"]+[1,-1,-1,1][a]*s[a%2?"x":"y"]+(s.margin??12)+e[a]+(i.titleOffset[a]||0)))})}proximatePositions(){let t,e=this.chart,i=[],s=this.options.align==="left";for(let o of(this.allItems.forEach(function(r){let a,n,l=s,c,d;r.yAxis&&(r.xAxis.options.reversed&&(l=!l),r.points&&(a=zd(l?r.points:r.points.slice(0).reverse(),function(p){return da(p.plotY)})),n=this.itemMarginTop+r.legendItem.label.getBBox().height+this.itemMarginBottom,d=r.yAxis.top-e.plotTop,c=r.visible?(a?a.plotY:r.yAxis.height)+(d-.3*n):d+r.yAxis.height,i.push({target:c,size:n,item:r}))},this),Ed(i,e.plotHeight)))t=o.item.legendItem||{},da(o.pos)&&(t.y=e.plotTop-e.spacing[0]+o.pos)}render(){let t=this.chart,e=t.renderer,i=this.options,s=this.padding,o=this.getAllItems(),r,a,n,l=this.group,c,d=this.box;this.itemX=s,this.itemY=this.initialItemY,this.offsetWidth=0,this.lastItemY=0,this.widthOption=Wd(i.width,t.spacingBox.width-s),c=t.spacingBox.width-2*s-i.x,["rm","lm"].indexOf(this.getAlignment().substring(0,2))>-1&&(c/=2),this.maxLegendWidth=this.widthOption||c,l||(this.group=l=e.g("legend").addClass(i.className||"").attr({zIndex:7}).add(),this.contentGroup=e.g().attr({zIndex:1}).add(l),this.scrollGroup=e.g().add(this.contentGroup)),this.renderTitle(),Xd(o,(p,g)=>(p.options?.legendIndex||0)-(g.options?.legendIndex||0)),i.reversed&&o.reverse(),this.allItems=o,this.display=r=!!o.length,this.lastLineHeight=0,this.maxItemWidth=0,this.totalItemWidth=0,this.itemHeight=0,o.forEach(this.renderItem,this),o.forEach(this.layoutItem,this),a=(this.widthOption||this.offsetWidth)+s,n=this.lastItemY+this.lastLineHeight+this.titleHeight,n=this.handleOverflow(n)+s,d||(this.box=d=e.rect().addClass("highcharts-legend-box").attr({r:i.borderRadius}).add(l)),t.styledMode||d.attr({stroke:i.borderColor,"stroke-width":i.borderWidth||0,fill:i.backgroundColor||"none"}).shadow(i.shadow),a>0&&n>0&&d[d.placed?"animate":"attr"](d.crisp.call({},{x:0,y:0,width:a,height:n},d.strokeWidth())),l[r?"show":"hide"](),t.styledMode&&l.getStyle("display")==="none"&&(a=n=0),this.legendWidth=a,this.legendHeight=n,r&&this.align(),this.proximate||this.positionItems(),Bt(this,"afterRender")}align(t=this.chart.spacingBox){let e=this.chart,i=this.options,s=t.y;/(lth|ct|rth)/.test(this.getAlignment())&&e.titleOffset[0]>0?s+=e.titleOffset[0]:/(lbh|cb|rbh)/.test(this.getAlignment())&&e.titleOffset[2]>0&&(s-=e.titleOffset[2]),s!==t.y&&(t=Qt(t,{y:s})),e.hasRendered||(this.group.placed=!1),this.group.align(Qt(i,{width:this.legendWidth,height:this.legendHeight,verticalAlign:this.proximate?"top":i.verticalAlign}),!0,t)}handleOverflow(t){let e=this,i=this.chart,s=i.renderer,o=this.options,r=o.y,a=o.verticalAlign==="top",n=this.padding,l=o.maxHeight,c=o.navigation,d=kt(c.animation,!0),p=c.arrowSize||12,g=this.pages,u=this.allItems,x=function(M){typeof M=="number"?k.attr({height:M}):k&&(e.clipRect=k.destroy(),e.contentGroup.clip()),e.contentGroup.div&&(e.contentGroup.div.style.clip=M?"rect("+n+"px,9999px,"+(n+M)+"px,0)":"auto")},m=function(M){return e[M]=s.circle(0,0,1.3*p).translate(p/2,p/2).add(w),i.styledMode||e[M].attr("fill","rgba(0,0,0,0.0001)"),e[M]},f,y,b,v,S=i.spacingBox.height+(a?-r:r)-n,w=this.nav,k=this.clipRect;return o.layout!=="horizontal"||o.verticalAlign==="middle"||o.floating||(S/=2),l&&(S=Math.min(S,l)),g.length=0,t&&S>0&&t>S&&c.enabled!==!1?(this.clipHeight=f=Math.max(S-20-this.titleHeight-n,0),this.currentPage=kt(this.currentPage,1),this.fullHeight=t,u.forEach((M,T)=>{let A=(b=M.legendItem||{}).y||0,C=Math.round(b.label.getBBox().height),O=g.length;(!O||A-g[O-1]>f&&(y||A)!==g[O-1])&&(g.push(y||A),O++),b.pageIx=O-1,y&&v&&(v.pageIx=O-1),T===u.length-1&&A+C-g[O-1]>f&&A>g[O-1]&&(g.push(A),b.pageIx=O),A!==y&&(y=A),v=b}),k||(k=e.clipRect=s.clipRect(0,n-2,9999,0),e.contentGroup.clip(k)),x(f),w||(this.nav=w=s.g().attr({zIndex:1}).add(this.group),this.up=s.symbol("triangle",0,0,p,p).add(w),m("upTracker").on("click",function(){e.scroll(-1,d)}),this.pager=s.text("",15,10).addClass("highcharts-legend-navigation"),!i.styledMode&&c.style&&this.pager.css(c.style),this.pager.add(w),this.down=s.symbol("triangle-down",0,0,p,p).add(w),m("downTracker").on("click",function(){e.scroll(1,d)})),e.scroll(0),t=S):w&&(x(),this.nav=w.destroy(),this.scrollGroup.attr({translateY:1}),this.clipHeight=0),t}scroll(t,e){let i=this.chart,s=this.pages,o=s.length,r=this.clipHeight,a=this.options.navigation,n=this.pager,l=this.padding,c=this.currentPage+t;c>o&&(c=o),c>0&&(e!==void 0&&Ld(e,i),this.nav.attr({translateX:l,translateY:r+this.padding+7+this.titleHeight,visibility:"inherit"}),[this.up,this.upTracker].forEach(function(d){d.attr({class:c===1?"highcharts-legend-nav-inactive":"highcharts-legend-nav-active"})}),n.attr({text:c+"/"+o}),[this.down,this.downTracker].forEach(function(d){d.attr({x:18+this.pager.getBBox().width,class:c===o?"highcharts-legend-nav-inactive":"highcharts-legend-nav-active"})},this),i.styledMode||(this.up.attr({fill:c===1?a.inactiveColor:a.activeColor}),this.upTracker.css({cursor:c===1?"default":"pointer"}),this.down.attr({fill:c===o?a.inactiveColor:a.activeColor}),this.downTracker.css({cursor:c===o?"default":"pointer"})),this.scrollOffset=-s[c-1]+this.initialItemY,this.scrollGroup.animate({translateY:this.scrollOffset}),this.currentPage=c,this.positionCheckboxes(),Hd(()=>{Bt(this,"afterScroll",{currentPage:c})},Pd(kt(e,i.renderer.globalAnimation,!0)).duration))}setItemEvents(t,e,i){let s=this,o=t.legendItem||{},r=s.chart.renderer.boxWrapper,a=t instanceof Zt,n=t instanceof ut,l="highcharts-legend-"+(a?"point":"series")+"-active",c=s.chart.styledMode,d=i?[e,o.symbol]:[o.group],p=g=>{s.allItems.forEach(u=>{t!==u&&[u].concat(u.linkedSeries||[]).forEach(x=>{x.setState(g,!a)})})};for(let g of d)g&&g.on("mouseover",function(){t.visible&&p("inactive"),t.setState("hover"),t.visible&&r.addClass(l),c||e.css(s.options.itemHoverStyle)}).on("mouseout",function(){s.chart.styledMode||e.css(Qt(t.visible?s.itemStyle:s.itemHiddenStyle)),p(""),r.removeClass(l),t.setState()}).on("click",function(u){let x=function(){t.setVisible&&t.setVisible(),p(t.visible?"inactive":"")};r.removeClass(l),Bt(s,"itemClick",{browserEvent:u,legendItem:t},x),a?t.firePointEvent("legendItemClick",{browserEvent:u}):n&&Bt(t,"legendItemClick",{browserEvent:u})})}createCheckboxForItem(t){t.checkbox=Dd("input",{type:"checkbox",className:"highcharts-legend-checkbox",checked:t.selected,defaultChecked:t.selected},this.options.itemCheckboxStyle,this.chart.container),Wi(t.checkbox,"click",function(e){let i=e.target;Bt(t.series||t,"checkboxClick",{checked:i.checked,item:t},function(){t.select()})})}};(qr=ti||(ti={})).compose=function(h){Rd(Od,"Core.Legend")&&Wi(h,"beforeMargins",function(){this.legend=new qr(this,this.options.legend)})};var ca=ti,{animate:Ns,animObject:Fd,setAnimation:zs}=at,{defaultOptions:Rs}=xt,{numberFormat:Yd}=yt,{registerEventOptions:pa}=Ki,{charts:te,doc:We,marginNames:ga,svg:Gd,win:ua}=P,{seriesTypes:Ws}=tt,{addEvent:Xs,attr:fa,createElement:Hs,css:wt,defined:Gt,diffObjects:ma,discardElement:jd,erase:Ud,error:Fs,extend:Vt,find:Ys,fireEvent:G,getAlignFactor:Vd,getStyle:Gs,isArray:$d,isNumber:fe,isObject:Zd,isString:Si,merge:Pt,objectEach:js,pick:ct,pInt:qd,relativeLength:xa,removeEvent:ya,splat:Ti,syncTimeout:Kd,uniqueKey:_d}=N,$t=class h{static chart(t,e,i){return new h(t,e,i)}constructor(t,e,i){this.sharedClips={};let s=[...arguments];(Si(t)||t.nodeName)&&(this.renderTo=s.shift()),this.init(s[0],s[1])}setZoomOptions(){let t=this.options.chart,e=t.zooming;this.zooming=Ce(It({},e),{type:ct(t.zoomType,e.type),key:ct(t.zoomKey,e.key),pinchType:ct(t.pinchType,e.pinchType),singleTouch:ct(t.zoomBySingleTouch,e.singleTouch,!1),resetButton:Pt(e.resetButton,t.resetZoomButton)})}init(t,e){G(this,"init",{args:arguments},function(){let i=Pt(Rs,t),s=i.chart,o=this.renderTo||s.renderTo;this.userOptions=Vt({},t),(this.renderTo=Si(o)?We.getElementById(o):o)||Fs(13,!0,this),this.margin=[],this.spacing=[],this.labelCollectors=[],this.callback=e,this.isResizing=0,this.options=i,this.axes=[],this.series=[],this.locale=i.lang.locale??this.renderTo.closest("[lang]")?.lang,this.time=new Eo(Vt(i.time||{},{locale:this.locale}),i.lang),i.time=this.time.options,this.numberFormatter=(s.numberFormatter||Yd).bind(this),this.styledMode=s.styledMode,this.hasCartesianSeries=s.showAxes,this.index=te.length,te.push(this),P.chartCount++,pa(this,s),this.xAxis=[],this.yAxis=[],this.pointCount=this.colorCounter=this.symbolCounter=0,this.setZoomOptions(),G(this,"afterInit"),this.firstRender()})}initSeries(t){let e=this.options.chart,i=t.type||e.type,s=Ws[i];s||Fs(17,!0,this,{missingModuleFor:i});let o=new s;return typeof o.init=="function"&&o.init(this,t),o}setSortedData(){this.getSeriesOrderByLinks().forEach(function(t){t.points||t.data||!t.enabledDataSorting||t.setData(t.options.data,!1)})}getSeriesOrderByLinks(){return this.series.concat().sort(function(t,e){return t.linkedSeries.length||e.linkedSeries.length?e.linkedSeries.length-t.linkedSeries.length:0})}orderItems(t,e=0){let i=this[t],s=this.options[t]=Ti(this.options[t]).slice(),o=this.userOptions[t]=this.userOptions[t]?Ti(this.userOptions[t]).slice():[];if(this.hasRendered&&(s.splice(e),o.splice(e)),i)for(let r=e,a=i.length;r<a;++r){let n=i[r];n&&(n.index=r,n instanceof ut&&(n.name=n.getName()),n.options.isInternal||(s[r]=n.options,o[r]=n.userOptions))}}getClipBox(t,e){let i=this.inverted,{xAxis:s,yAxis:o}=t||{},{x:r,y:a,width:n,height:l}=Pt(this.clipBox);return t&&(s&&s.len!==this.plotSizeX&&(n=s.len),o&&o.len!==this.plotSizeY&&(l=o.len),i&&!t.invertible&&([n,l]=[l,n])),e&&(r+=(i?o:s)?.pos??this.plotLeft,a+=(i?s:o)?.pos??this.plotTop),{x:r,y:a,width:n,height:l}}isInsidePlot(t,e,i={}){let{inverted:s,plotBox:o,plotLeft:r,plotTop:a,scrollablePlotBox:n}=this,{scrollLeft:l=0,scrollTop:c=0}=i.visiblePlotOnly&&this.scrollablePlotArea?.scrollingContainer||{},d=i.series,p=i.visiblePlotOnly&&n||o,g=i.inverted?e:t,u=i.inverted?t:e,x={x:g,y:u,isInsidePlot:!0,options:i};if(!i.ignoreX){let m=d&&(s&&!this.polar?d.yAxis:d.xAxis)||{pos:r,len:1/0},f=i.paneCoordinates?m.pos+g:r+g;f>=Math.max(l+r,m.pos)&&f<=Math.min(l+r+p.width,m.pos+m.len)||(x.isInsidePlot=!1)}if(!i.ignoreY&&x.isInsidePlot){let m=!s&&i.axis&&!i.axis.isXAxis&&i.axis||d&&(s?d.xAxis:d.yAxis)||{pos:a,len:1/0},f=i.paneCoordinates?m.pos+u:a+u;f>=Math.max(c+a,m.pos)&&f<=Math.min(c+a+p.height,m.pos+m.len)||(x.isInsidePlot=!1)}return G(this,"afterIsInsidePlot",x),x.isInsidePlot}redraw(t){G(this,"beforeRedraw");let e=this.hasCartesianSeries?this.axes:this.colorAxis||[],i=this.series,s=this.pointer,o=this.legend,r=this.userOptions.legend,a=this.renderer,n=a.isHidden(),l=[],c,d,p,g=this.isDirtyBox,u=this.isDirtyLegend,x;for(a.rootFontSize=a.boxWrapper.getStyle("font-size"),this.setResponsive&&this.setResponsive(!1),zs(!!this.hasRendered&&t,this),n&&this.temporaryDisplay(),this.layOutTitles(!1),p=i.length;p--;)if(((x=i[p]).options.stacking||x.options.centerInCategory)&&(d=!0,x.isDirty)){c=!0;break}if(c)for(p=i.length;p--;)(x=i[p]).options.stacking&&(x.isDirty=!0);i.forEach(function(m){m.isDirty&&(m.options.legendType==="point"?(typeof m.updateTotals=="function"&&m.updateTotals(),u=!0):r&&(r.labelFormatter||r.labelFormat)&&(u=!0)),m.isDirtyData&&G(m,"updatedData")}),u&&o&&o.options.enabled&&(o.render(),this.isDirtyLegend=!1),d&&this.getStacks(),e.forEach(function(m){m.updateNames(),m.setScale()}),this.getMargins(),e.forEach(function(m){m.isDirty&&(g=!0)}),e.forEach(function(m){let f=m.min+","+m.max;m.extKey!==f&&(m.extKey=f,l.push(function(){G(m,"afterSetExtremes",Vt(m.eventArgs,m.getExtremes())),delete m.eventArgs})),(g||d)&&m.redraw()}),g&&this.drawChartBox(),G(this,"predraw"),i.forEach(function(m){(g||m.isDirty)&&m.visible&&m.redraw(),m.isDirtyData=!1}),s&&s.reset(!0),a.draw(),G(this,"redraw"),G(this,"render"),n&&this.temporaryDisplay(!0),l.forEach(function(m){m.call()})}get(t){let e=this.series;function i(o){return o.id===t||o.options&&o.options.id===t}let s=Ys(this.axes,i)||Ys(this.series,i);for(let o=0;!s&&o<e.length;o++)s=Ys(e[o].points||[],i);return s}createAxes(){let t=this.userOptions;for(let e of(G(this,"createAxes"),["xAxis","yAxis"]))for(let i of t[e]=Ti(t[e]||{}))new oo(this,i,e);G(this,"afterCreateAxes")}getSelectedPoints(){return this.series.reduce((t,e)=>(e.getPointsCollection().forEach(i=>{ct(i.selectedStaging,i.selected)&&t.push(i)}),t),[])}getSelectedSeries(){return this.series.filter(t=>t.selected)}setTitle(t,e,i){this.applyDescription("title",t),this.applyDescription("subtitle",e),this.applyDescription("caption",void 0),this.layOutTitles(i)}applyDescription(t,e){let i=this,s=this.options[t]=Pt(this.options[t],e),o=this[t];o&&e&&(this[t]=o=o.destroy()),s&&!o&&((o=this.renderer.text(s.text,0,0,s.useHTML).attr({align:s.align,class:"highcharts-"+t,zIndex:s.zIndex||4}).css({textOverflow:"ellipsis",whiteSpace:"nowrap"}).add()).update=function(r,a){i.applyDescription(t,r),i.layOutTitles(a)},this.styledMode||o.css(Vt(t==="title"?{fontSize:this.options.isStock?"1em":"1.2em"}:{},s.style)),o.textPxLength=o.getBBox().width,o.css({whiteSpace:s.style?.whiteSpace}),this[t]=o)}layOutTitles(t=!0){let e=[0,0,0],{options:i,renderer:s,spacingBox:o}=this;["title","subtitle","caption"].forEach(a=>{let n=this[a],l=this.options[a],c=Pt(o),d=n?.textPxLength||0;if(n&&l){G(this,"layOutTitle",{alignTo:c,key:a,textPxLength:d});let p=s.fontMetrics(n),g=p.b,u=p.h,x=l.verticalAlign||"top",m=x==="top",f=m&&l.minScale||1,y=a==="title"?m?-3:0:m?e[0]+2:0,b=Math.min(c.width/d,1),v=Math.max(f,b),S=Pt({y:x==="bottom"?g:y+g},{align:a==="title"?b<f?"left":"center":this.title?.alignValue},l),w=(l.width||(b>f?this.chartWidth:c.width)/v)+"px";n.alignValue!==S.align&&(n.placed=!1);let k=Math.round(n.css({width:w}).getBBox(l.useHTML).height);if(S.height=k,n.align(S,!1,c).attr({align:S.align,scaleX:v,scaleY:v,"transform-origin":`${c.x+d*v*Vd(S.align)} ${u}`}),!l.floating){let M=k*(k<1.2*u?1:v);x==="top"?e[0]=Math.ceil(e[0]+M):x==="bottom"&&(e[2]=Math.ceil(e[2]+M))}}},this),e[0]&&(i.title?.verticalAlign||"top")==="top"&&(e[0]+=i.title?.margin||0),e[2]&&i.caption?.verticalAlign==="bottom"&&(e[2]+=i.caption?.margin||0);let r=!this.titleOffset||this.titleOffset.join(",")!==e.join(",");this.titleOffset=e,G(this,"afterLayOutTitles"),!this.isDirtyBox&&r&&(this.isDirtyBox=this.isDirtyLegend=r,this.hasRendered&&t&&this.isDirtyBox&&this.redraw())}getContainerBox(){let t=[].map.call(this.renderTo.children,i=>{if(i!==this.container){let s=i.style.display;return i.style.display="none",[i,s]}}),e={width:Gs(this.renderTo,"width",!0)||0,height:Gs(this.renderTo,"height",!0)||0};return t.filter(Boolean).forEach(([i,s])=>{i.style.display=s}),e}getChartSize(){let t=this.options.chart,e=t.width,i=t.height,s=this.getContainerBox(),o=s.height<=1||!this.renderTo.parentElement?.style.height&&this.renderTo.style.height==="100%";this.chartWidth=Math.max(0,e||s.width||600),this.chartHeight=Math.max(0,xa(i,this.chartWidth)||(o?400:s.height)),this.containerBox=s}temporaryDisplay(t){let e=this.renderTo,i;if(t)for(;e?.style;)e.hcOrigStyle&&(wt(e,e.hcOrigStyle),delete e.hcOrigStyle),e.hcOrigDetached&&(We.body.removeChild(e),e.hcOrigDetached=!1),e=e.parentNode;else for(;e?.style&&(We.body.contains(e)||e.parentNode||(e.hcOrigDetached=!0,We.body.appendChild(e)),(Gs(e,"display",!1)==="none"||e.hcOricDetached)&&(e.hcOrigStyle={display:e.style.display,height:e.style.height,overflow:e.style.overflow},i={display:"block",overflow:"hidden"},e!==this.renderTo&&(i.height=0),wt(e,i),e.offsetWidth||e.style.setProperty("display","block","important")),(e=e.parentNode)!==We.body););}setClassName(t){this.container.className="highcharts-container "+(t||"")}getContainer(){let t,e=this.options,i=e.chart,s="data-highcharts-chart",o=_d(),r=this.renderTo,a=qd(fa(r,s));fe(a)&&te[a]&&te[a].hasRendered&&te[a].destroy(),fa(r,s,this.index),r.innerHTML=ot.emptyHTML,i.skipClone||r.offsetWidth||this.temporaryDisplay(),this.getChartSize();let n=this.chartHeight,l=this.chartWidth;wt(r,{overflow:"hidden"}),this.styledMode||(t=Vt({position:"relative",overflow:"hidden",width:l+"px",height:n+"px",textAlign:"left",lineHeight:"normal",zIndex:0,"-webkit-tap-highlight-color":"rgba(0,0,0,0)",userSelect:"none","touch-action":"manipulation",outline:"none",padding:"0px"},i.style||{}));let c=Hs("div",{id:o},t,r);this.container=c,this.getChartSize(),l!==this.chartWidth&&(l=this.chartWidth,this.styledMode||wt(c,{width:ct(i.style?.width,l+"px")})),this.containerBox=this.getContainerBox(),this._cursor=c.style.cursor;let d=i.renderer||!Gd?ii.getRendererType(i.renderer):Se;if(this.renderer=new d(c,l,n,void 0,i.forExport,e.exporting?.allowHTML,this.styledMode),zs(void 0,this),this.setClassName(i.className),this.styledMode)for(let p in e.defs)this.renderer.definition(e.defs[p]);else this.renderer.setStyle(i.style);this.renderer.chartIndex=this.index,G(this,"afterGetContainer")}getMargins(t){let{spacing:e,margin:i,titleOffset:s}=this;this.resetMargins(),s[0]&&!Gt(i[0])&&(this.plotTop=Math.max(this.plotTop,s[0]+e[0])),s[2]&&!Gt(i[2])&&(this.marginBottom=Math.max(this.marginBottom,s[2]+e[2])),this.legend?.display&&this.legend.adjustMargins(i,e),G(this,"getMargins"),t||this.getAxisMargins()}getAxisMargins(){let t=this,e=t.axisOffset=[0,0,0,0],i=t.colorAxis,s=t.margin,o=r=>{r.forEach(a=>{a.visible&&a.getOffset()})};t.hasCartesianSeries?o(t.axes):i?.length&&o(i),ga.forEach((r,a)=>{Gt(s[a])||(t[r]+=e[a])}),t.setChartSize()}getOptions(){return ma(this.userOptions,Rs)}reflow(t){let e=this,i=e.containerBox,s=e.getContainerBox();delete e.pointer?.chartPosition,!e.exporting?.isPrinting&&!e.isResizing&&i&&s.width&&((s.width!==i.width||s.height!==i.height)&&(N.clearTimeout(e.reflowTimeout),e.reflowTimeout=Kd(function(){e.container&&e.setSize(void 0,void 0,!1)},100*!!t)),e.containerBox=s)}setReflow(){let t=this,e=i=>{t.options?.chart.reflow&&t.hasLoaded&&t.reflow(i)};if(typeof ResizeObserver=="function")new ResizeObserver(e).observe(t.renderTo);else{let i=Xs(ua,"resize",e);Xs(this,"destroy",i)}}setSize(t,e,i){let s=this,o=s.renderer;s.isResizing+=1,zs(i,s);let r=o.globalAnimation;s.oldChartHeight=s.chartHeight,s.oldChartWidth=s.chartWidth,t!==void 0&&(s.options.chart.width=t),e!==void 0&&(s.options.chart.height=e),s.getChartSize();let{chartWidth:a,chartHeight:n,scrollablePixelsX:l=0,scrollablePixelsY:c=0}=s;(s.isDirtyBox||a!==s.oldChartWidth||n!==s.oldChartHeight)&&(s.styledMode||(r?Ns:wt)(s.container,{width:`${a+l}px`,height:`${n+c}px`},r),s.setChartSize(!0),o.setSize(a,n,r),s.axes.forEach(function(d){d.isDirty=!0,d.setScale()}),s.isDirtyLegend=!0,s.isDirtyBox=!0,s.layOutTitles(),s.getMargins(),s.redraw(r),s.oldChartHeight=void 0,G(s,"resize"),setTimeout(()=>{s&&G(s,"endResize")},Fd(r).duration)),s.isResizing-=1}setChartSize(t){let e,i,s,o,{chartHeight:r,chartWidth:a,inverted:n,spacing:l,renderer:c}=this,d=this.clipOffset,p=Math[n?"floor":"round"];this.plotLeft=e=Math.round(this.plotLeft),this.plotTop=i=Math.round(this.plotTop),this.plotWidth=s=Math.max(0,Math.round(a-e-(this.marginRight??0))),this.plotHeight=o=Math.max(0,Math.round(r-i-(this.marginBottom??0))),this.plotSizeX=n?o:s,this.plotSizeY=n?s:o,this.spacingBox=c.spacingBox={x:l[3],y:l[0],width:a-l[3]-l[1],height:r-l[0]-l[2]},this.plotBox=c.plotBox={x:e,y:i,width:s,height:o},d&&(this.clipBox={x:p(d[3]),y:p(d[0]),width:p(this.plotSizeX-d[1]-d[3]),height:p(this.plotSizeY-d[0]-d[2])}),t||(this.axes.forEach(function(g){g.setAxisSize(),g.setAxisTranslation()}),c.alignElements()),G(this,"afterSetChartSize",{skipAxes:t})}resetMargins(){G(this,"resetMargins");let t=this,e=t.options.chart,i=e.plotBorderWidth||0,s=Math.round(i)/2;["margin","spacing"].forEach(o=>{let r=e[o],a=Zd(r)?r:[r,r,r,r];["Top","Right","Bottom","Left"].forEach((n,l)=>{t[o][l]=e[`${o}${n}`]??a[l]})}),ga.forEach((o,r)=>{t[o]=t.margin[r]??t.spacing[r]}),t.axisOffset=[0,0,0,0],t.clipOffset=[s,s,s,s],t.plotBorderWidth=i}drawChartBox(){let t=this.options.chart,e=this.renderer,i=this.chartWidth,s=this.chartHeight,o=this.styledMode,r=this.plotBGImage,a=t.backgroundColor,n=t.plotBackgroundColor,l=t.plotBackgroundImage,c=this.plotLeft,d=this.plotTop,p=this.plotWidth,g=this.plotHeight,u=this.plotBox,x=this.clipRect,m=this.clipBox,f=this.chartBackground,y=this.plotBackground,b=this.plotBorder,v,S,w,k="animate";f||(this.chartBackground=f=e.rect().addClass("highcharts-background").add(),k="attr"),o?v=S=f.strokeWidth():(S=(v=t.borderWidth||0)+8*!!t.shadow,w={fill:a||"none"},(v||f["stroke-width"])&&(w.stroke=t.borderColor,w["stroke-width"]=v),f.attr(w).shadow(t.shadow)),f[k]({x:S/2,y:S/2,width:i-S-v%2,height:s-S-v%2,r:t.borderRadius}),k="animate",y||(k="attr",this.plotBackground=y=e.rect().addClass("highcharts-plot-background").add()),y[k](u),!o&&(y.attr({fill:n||"none"}).shadow(t.plotShadow),l&&(r?(l!==r.attr("href")&&r.attr("href",l),r.animate(u)):this.plotBGImage=e.image(l,c,d,p,g).add())),x?x.animate({width:m.width,height:m.height}):this.clipRect=e.clipRect(m),k="animate",b||(k="attr",this.plotBorder=b=e.rect().addClass("highcharts-plot-border").attr({zIndex:1}).add()),o||b.attr({stroke:t.plotBorderColor,"stroke-width":t.plotBorderWidth||0,fill:"none"}),b[k](b.crisp(u,-b.strokeWidth())),this.isDirtyBox=!1,G(this,"afterDrawChartBox")}propFromSeries(){let t,e,i,s=this,o=s.options.chart,r=s.options.series;["inverted","angular","polar"].forEach(function(a){for(e=Ws[o.type],i=o[a]||e&&e.prototype[a],t=r?.length;!i&&t--;)(e=Ws[r[t].type])&&e.prototype[a]&&(i=!0);s[a]=i})}linkSeries(t){let e=this,i=e.series;i.forEach(function(s){s.linkedSeries.length=0}),i.forEach(function(s){let{linkedTo:o}=s.options;if(Si(o)){let r;(r=o===":previous"?e.series[s.index-1]:e.get(o))&&r.linkedParent!==s&&(r.linkedSeries.push(s),s.linkedParent=r,r.enabledDataSorting&&s.setDataSortingOptions(),s.visible=ct(s.options.visible,r.options.visible,s.visible))}}),G(this,"afterLinkSeries",{isUpdating:t})}renderSeries(){this.series.forEach(function(t){t.translate(),t.render()})}render(){let t=this.axes,e=this.colorAxis,i=this.renderer,s=this.options.chart.axisLayoutRuns||2,o=c=>{c.forEach(d=>{d.visible&&d.render()})},r=0,a=!0,n,l=0;for(let c of(this.setTitle(),G(this,"beforeMargins"),this.getStacks?.(),this.getMargins(!0),this.setChartSize(),t)){let{options:d}=c,{labels:p}=d;if(this.hasCartesianSeries&&c.horiz&&c.visible&&p.enabled&&c.series.length&&c.coll!=="colorAxis"&&!this.polar){r=d.tickLength,c.createGroups();let g=new be(c,0,"",!0),u=g.createLabel("x",p);if(g.destroy(),u&&ct(p.reserveSpace,!fe(d.crossing))&&(r=u.getBBox().height+p.distance+Math.max(d.offset||0,0)),r){u?.destroy();break}}}for(this.plotHeight=Math.max(this.plotHeight-r,0);(a||n||s>1)&&l<s;){let c=this.plotWidth,d=this.plotHeight;for(let p of t)l===0?p.setScale():(p.horiz&&a||!p.horiz&&n)&&p.setTickInterval(!0);l===0?this.getAxisMargins():this.getMargins(),a=c/this.plotWidth>(l?1:1.1),n=d/this.plotHeight>(l?1:1.05),l++}this.drawChartBox(),this.hasCartesianSeries?o(t):e?.length&&o(e),this.seriesGroup||(this.seriesGroup=i.g("series-group").attr({zIndex:3}).shadow(this.options.chart.seriesGroupShadow).add()),this.dataLabelsGroup||(this.dataLabelsGroup=i.g("datalabels-group").attr({zIndex:6}).add()),this.renderSeries(),this.addCredits(),this.setResponsive&&this.setResponsive(),this.hasRendered=!0}addCredits(t){let e=this,i=Pt(!0,this.options.credits,t);i.enabled&&!this.credits&&(this.credits=this.renderer.text(i.text+(this.mapCredits||""),0,0).addClass("highcharts-credits").on("click",function(){i.href&&(ua.location.href=i.href)}).attr({align:i.position.align,zIndex:8}),e.styledMode||this.credits.css(i.style),this.credits.add().align(i.position),this.credits.update=function(s){e.credits=e.credits.destroy(),e.addCredits(s)})}destroy(){let t,e=this,i=e.axes,s=e.series,o=e.container,r=o?.parentNode;for(G(e,"destroy"),e.renderer.forExport?Ud(te,e):te[e.index]=void 0,P.chartCount--,e.renderTo.removeAttribute("data-highcharts-chart"),ya(e),t=i.length;t--;)i[t]=i[t].destroy();for(this.scroller?.destroy?.(),t=s.length;t--;)s[t]=s[t].destroy();["title","subtitle","chartBackground","plotBackground","plotBGImage","plotBorder","seriesGroup","clipRect","credits","pointer","rangeSelector","legend","resetZoomButton","tooltip","renderer"].forEach(a=>{e[a]=e[a]?.destroy?.()}),o&&(o.innerHTML=ot.emptyHTML,ya(o),r&&jd(o)),js(e,function(a,n){delete e[n]})}firstRender(){let t=this,e=t.options;t.getContainer(),t.resetMargins(),t.setChartSize(),t.propFromSeries(),t.createAxes();let i=$d(e.series)?e.series:[];e.series=[],i.forEach(function(s){t.initSeries(s)}),t.linkSeries(),t.setSortedData(),G(t,"beforeRender"),t.render(),t.pointer?.getChartPosition(),t.renderer.imgCount||t.hasLoaded||t.onload(),t.temporaryDisplay(!0)}onload(){this.callbacks.concat([this.callback]).forEach(function(t){t&&this.index!==void 0&&t.apply(this,[this])},this),G(this,"load"),G(this,"render"),Gt(this.index)&&this.setReflow(),this.warnIfA11yModuleNotLoaded(),this.hasLoaded=!0}warnIfA11yModuleNotLoaded(){let{options:t,title:e}=this;t&&!this.accessibility&&(this.renderer.boxWrapper.attr({role:"img","aria-label":(e?.element.textContent||"").replace(/</g,"<")}),t.accessibility&&t.accessibility.enabled===!1||Fs('Highcharts warning: Consider including the "accessibility.js" module to make your chart more usable for people with disabilities. Set the "accessibility.enabled" option to false to remove this warning. See https://www.highcharts.com/docs/accessibility/accessibility-module.',!1,this))}addSeries(t,e,i){let s,o=this;return t&&(e=ct(e,!0),G(o,"addSeries",{options:t},function(){s=o.initSeries(t),o.isDirtyLegend=!0,o.linkSeries(),s.enabledDataSorting&&s.setData(t.data,!1),G(o,"afterAddSeries",{series:s}),e&&o.redraw(i)})),s}addAxis(t,e,i,s){return this.createAxis(e?"xAxis":"yAxis",{axis:t,redraw:i,animation:s})}addColorAxis(t,e,i){return this.createAxis("colorAxis",{axis:t,redraw:e,animation:i})}createAxis(t,e){let i=new oo(this,e.axis,t);return ct(e.redraw,!0)&&this.redraw(e.animation),i}showLoading(t){let e=this,i=e.options,s=i.loading,o=function(){r&&wt(r,{left:e.plotLeft+"px",top:e.plotTop+"px",width:e.plotWidth+"px",height:e.plotHeight+"px"})},r=e.loadingDiv,a=e.loadingSpan;r||(e.loadingDiv=r=Hs("div",{className:"highcharts-loading highcharts-loading-hidden"},null,e.container)),a||(e.loadingSpan=a=Hs("span",{className:"highcharts-loading-inner"},null,r),Xs(e,"redraw",o)),r.className="highcharts-loading",ot.setElementHTML(a,ct(t,i.lang.loading,"")),!e.styledMode&&(wt(r,Vt(s.style,{zIndex:10})),wt(a,s.labelStyle),e.loadingShown||(wt(r,{opacity:0,display:""}),Ns(r,{opacity:s.style.opacity||.5},{duration:s.showDuration||0}))),e.loadingShown=!0,o()}hideLoading(){let t=this.options,e=this.loadingDiv;e&&(e.className="highcharts-loading highcharts-loading-hidden",this.styledMode||Ns(e,{opacity:0},{duration:t.loading.hideDuration||100,complete:function(){wt(e,{display:"none"})}})),this.loadingShown=!1}update(t,e,i,s){let o,r,a,n=this,l={credits:"addCredits",title:"setTitle",subtitle:"setSubtitle",caption:"setCaption"},c=t.isResponsiveOptions,d=[];G(n,"update",{options:t}),c||n.setResponsive(!1,!0),t=ma(t,n.options),n.userOptions=Pt(n.userOptions,t);let p=t.chart;p&&(Pt(!0,n.options.chart,p),this.setZoomOptions(),"className"in p&&n.setClassName(p.className),("inverted"in p||"polar"in p||"type"in p)&&(n.propFromSeries(),o=!0),"alignTicks"in p&&(o=!0),"events"in p&&pa(this,p),js(p,function(x,m){n.propsRequireUpdateSeries.indexOf("chart."+m)!==-1&&(r=!0),n.propsRequireDirtyBox.indexOf(m)!==-1&&(n.isDirtyBox=!0),n.propsRequireReflow.indexOf(m)!==-1&&(n.isDirtyBox=!0,c||(a=!0))}),!n.styledMode&&p.style&&n.renderer.setStyle(n.options.chart.style||{})),!n.styledMode&&t.colors&&(this.options.colors=t.colors),js(t,function(x,m){n[m]&&typeof n[m].update=="function"?n[m].update(x,!1):typeof n[l[m]]=="function"?n[l[m]](x):m!=="colors"&&n.collectionsWithUpdate.indexOf(m)===-1&&Pt(!0,n.options[m],t[m]),m!=="chart"&&n.propsRequireUpdateSeries.indexOf(m)!==-1&&(r=!0)}),this.collectionsWithUpdate.forEach(function(x){t[x]&&(Ti(t[x]).forEach(function(m,f){let y,b=Gt(m.id);b&&(y=n.get(m.id)),!y&&n[x]&&(y=n[x][ct(m.index,f)])&&(b&&Gt(y.options.id)||y.options.isInternal)&&(y=void 0),y&&y.coll===x&&(y.update(m,!1),i&&(y.touched=!0)),!y&&i&&n.collectionsWithInit[x]&&(n.collectionsWithInit[x][0].apply(n,[m].concat(n.collectionsWithInit[x][1]||[]).concat([!1])).touched=!0)}),i&&n[x].forEach(function(m){m.touched||m.options.isInternal?delete m.touched:d.push(m)}))}),d.forEach(function(x){x.chart&&x.remove&&x.remove(!1)}),o&&n.axes.forEach(function(x){x.update({},!1)}),r&&n.getSeriesOrderByLinks().forEach(function(x){x.chart&&x.update({},!1)},this);let g=p?.width,u=p&&(Si(p.height)?xa(p.height,g||n.chartWidth):p.height);a||fe(g)&&g!==n.chartWidth||fe(u)&&u!==n.chartHeight?n.setSize(g,u,s):ct(e,!0)&&n.redraw(s),G(n,"afterUpdate",{options:t,redraw:e,animation:s})}setSubtitle(t,e){this.applyDescription("subtitle",t),this.layOutTitles(e)}setCaption(t,e){this.applyDescription("caption",t),this.layOutTitles(e)}showResetZoom(){let t=this,e=Rs.lang,i=t.zooming.resetButton,s=i.theme,o=i.relativeTo==="chart"||i.relativeTo==="spacingBox"?null:"plotBox";function r(){t.zoomOut()}G(this,"beforeShowResetZoom",null,function(){t.resetZoomButton=t.renderer.button(e.resetZoom,null,null,r,s).attr({align:i.position.align,title:e.resetZoomTitle}).addClass("highcharts-reset-zoom").add().align(i.position,!1,o)}),G(this,"afterShowResetZoom")}zoomOut(){G(this,"selection",{resetSelection:!0},()=>this.transform({reset:!0,trigger:"zoom"}))}pan(t,e){let i=this,s=typeof e=="object"?e:{enabled:e,type:"x"},o=s.type,r=o&&i[{x:"xAxis",xy:"axes",y:"yAxis"}[o]].filter(n=>n.options.panningEnabled&&!n.options.isInternal),a=i.options.chart;a?.panning&&(a.panning=s),G(this,"pan",{originalEvent:t},()=>{i.transform({axes:r,event:t,to:{x:t.chartX-(i.mouseDownX||0),y:t.chartY-(i.mouseDownY||0)},trigger:"pan"}),wt(i.container,{cursor:"move"})})}transform(t){let{axes:e=this.axes,event:i,from:s={},reset:o,selection:r,to:a={},trigger:n}=t,{inverted:l,time:c}=this;this.hoverPoints?.forEach(u=>u.setState()),G(this,"transform",t);let d=t.hasZoomed||!1,p,g;for(let u of e){let{horiz:x,len:m,minPointOffset:f=0,options:y,reversed:b}=u,v=x?"width":"height",S=x?"x":"y",w=ct(a[v],u.len),k=ct(s[v],u.len),M=10>Math.abs(w)?1:w/k,T=(s[S]||0)+k/2-u.pos,A=T-((a[S]??u.pos)+w/2-u.pos)/M,C=b&&!l||!b&&l?-1:1;if(!o&&(T<0||T>u.len))continue;let O=u.chart.polar||u.isOrdinal?0:f*C||0,D=u.toValue(A,!0),B=u.toValue(A+m/M,!0),E=D+O,L=B-O,I=u.allExtremes;if(r&&r[u.coll].push({axis:u,min:Math.min(D,B),max:Math.max(D,B)}),E>L&&([E,L]=[L,E]),M===1&&!o&&u.coll==="yAxis"&&!I){for(let dt of u.series){let Mt=dt.getExtremes(dt.getProcessedData(!0).modified.getColumn("y")||[],!0);I??(I={dataMin:Number.MAX_VALUE,dataMax:-Number.MAX_VALUE}),fe(Mt.dataMin)&&fe(Mt.dataMax)&&(I.dataMin=Math.min(Mt.dataMin,I.dataMin),I.dataMax=Math.max(Mt.dataMax,I.dataMax))}u.allExtremes=I}let{dataMin:V,dataMax:Y,min:ht,max:W}=Vt(u.getExtremes(),I||{}),R=c.parse(y.min),j=c.parse(y.max),F=V??R,$=Y??j,Z=L-E,U=u.categories?0:Math.min(Z,$-F),K=F-U*(Gt(R)?0:y.minPadding),lt=$+U*(Gt(j)?0:y.maxPadding),gt=u.allowZoomOutside||M===1||n!=="zoom"&&M>1,zt=Math.min(R??K,K,gt?ht:K),bt=Math.max(j??lt,lt,gt?W:lt);(!u.isOrdinal||M!==1||o)&&(E<zt&&(E=zt,M>=1&&(L=E+Z)),L>bt&&(L=bt,M>=1&&(E=L-Z)),(o||u.series.length&&(E!==ht||L!==W)&&E>=zt&&L<=bt)&&(r?r[u.coll].push({axis:u,min:E,max:L}):(u.isPanning=n!=="zoom",u.isPanning&&(g=!0),u.setExtremes(o?void 0:E,o?void 0:L,!1,!1,{move:A,trigger:n,scale:M}),!o&&(E>zt||L<bt)&&n!=="mousewheel"&&(p=!0)),d=!0),this.hasCartesianSeries||o||n==="mousewheel"||(p=!0),i&&(this[x?"mouseDownX":"mouseDownY"]=i[x?"chartX":"chartY"]))}return d&&(r?G(this,"selection",r,()=>{delete t.selection,t.trigger="zoom",this.transform(t)}):(!p||g||this.resetZoomButton?!p&&this.resetZoomButton&&(this.resetZoomButton=this.resetZoomButton.destroy()):this.showResetZoom(),this.redraw(n==="zoom"&&(this.options.chart.animation??this.pointCount<100)))),d}};Vt($t.prototype,{callbacks:[],collectionsWithInit:{xAxis:[$t.prototype.addAxis,[!0]],yAxis:[$t.prototype.addAxis,[!1]],series:[$t.prototype.addSeries]},collectionsWithUpdate:["xAxis","yAxis","series"],propsRequireDirtyBox:["backgroundColor","borderColor","borderWidth","borderRadius","plotBackgroundColor","plotBackgroundImage","plotBorderColor","plotBorderWidth","plotShadow","shadow"],propsRequireReflow:["margin","marginTop","marginRight","marginBottom","marginLeft","spacing","spacingTop","spacingRight","spacingBottom","spacingLeft"],propsRequireUpdateSeries:["chart.inverted","chart.polar","chart.ignoreHiddenSeries","chart.type","colors","plotOptions","time","tooltip"]});var{stop:Jd}=at,{composed:Qd}=P,{addEvent:jt,createElement:Ci,css:Us,defined:Vs,erase:tc,merge:ba,pushUnique:va}=N;function ec(){let h=this.scrollablePlotArea;(this.scrollablePixelsX||this.scrollablePixelsY)&&!h&&(this.scrollablePlotArea=h=new Ja(this)),h?.applyFixed()}function ka(){this.chart.scrollablePlotArea&&(this.chart.scrollablePlotArea.isDirty=!0)}var Ja=(()=>{class h{static compose(e,i,s){va(Qd,this.compose)&&(jt(e,"afterInit",ka),jt(i,"afterSetChartSize",o=>this.afterSetSize(o.target,o)),jt(i,"render",ec),jt(s,"show",ka))}static afterSetSize(e,i){let s,o,r,{minWidth:a,minHeight:n}=e.options.chart.scrollablePlotArea||{},{clipBox:l,plotBox:c,inverted:d,renderer:p}=e;if(!p.forExport)if(a?(e.scrollablePixelsX=s=Math.max(0,a-e.chartWidth),s&&(e.scrollablePlotBox=ba(e.plotBox),c.width=e.plotWidth+=s,l[d?"height":"width"]+=s,r=!0)):n&&(e.scrollablePixelsY=o=Math.max(0,n-e.chartHeight),Vs(o)&&(e.scrollablePlotBox=ba(e.plotBox),c.height=e.plotHeight+=o,l[d?"width":"height"]+=o,r=!1)),Vs(r)){if(!i.skipAxes)for(let g of e.axes)(g.horiz===r||e.hasParallelCoordinates&&g.coll==="yAxis")&&(g.setAxisSize(),g.setAxisTranslation())}else delete e.scrollablePlotBox}constructor(e){let i,s=e.options.chart,o=ii.getRendererType(),r=s.scrollablePlotArea||{},a=this.moveFixedElements.bind(this),n={WebkitOverflowScrolling:"touch",overflowX:"hidden",overflowY:"hidden"};e.scrollablePixelsX&&(n.overflowX="auto"),e.scrollablePixelsY&&(n.overflowY="auto"),this.chart=e;let l=this.parentDiv=Ci("div",{className:"highcharts-scrolling-parent"},{position:"relative"},e.renderTo),c=this.scrollingContainer=Ci("div",{className:"highcharts-scrolling"},n,l),d=this.innerContainer=Ci("div",{className:"highcharts-inner-container"},void 0,c),p=this.fixedDiv=Ci("div",{className:"highcharts-fixed"},{position:"absolute",overflow:"hidden",pointerEvents:"none",zIndex:(s.style?.zIndex||0)+2,top:0},void 0,!0),g=this.fixedRenderer=new o(p,e.chartWidth,e.chartHeight,s.style);this.mask=g.path().attr({fill:s.backgroundColor||"#fff","fill-opacity":r.opacity??.85,zIndex:-1}).addClass("highcharts-scrollable-mask").add(),c.parentNode.insertBefore(p,c),Us(e.renderTo,{overflow:"visible"}),jt(e,"afterShowResetZoom",a),jt(e,"afterApplyDrilldown",a),jt(e,"afterLayOutTitles",a),jt(c,"scroll",()=>{let{pointer:u,hoverPoint:x}=e;u&&(delete u.chartPosition,x&&(i=x),u.runPointActions(void 0,i,!0))}),d.appendChild(e.container)}applyFixed(){let{chart:e,fixedRenderer:i,isDirty:s,scrollingContainer:o}=this,{axisOffset:r,chartWidth:a,chartHeight:n,container:l,plotHeight:c,plotLeft:d,plotTop:p,plotWidth:g,scrollablePixelsX:u=0,scrollablePixelsY:x=0}=e,{scrollPositionX:m=0,scrollPositionY:f=0}=e.options.chart.scrollablePlotArea||{},y=a+u,b=n+x;i.setSize(a,n),(s??!0)&&(this.isDirty=!1,this.moveFixedElements()),Jd(e.container),Us(l,{width:`${y}px`,height:`${b}px`}),e.renderer.boxWrapper.attr({width:y,height:b,viewBox:[0,0,y,b].join(" ")}),e.chartBackground?.attr({width:y,height:b}),Us(o,{width:`${a}px`,height:`${n}px`}),Vs(s)||(o.scrollLeft=u*m,o.scrollTop=x*f);let v=p-r[0]-1,S=d-r[3]-1,w=p+c+r[2]+1,k=d+g+r[1]+1,M=d+g-u,T=p+c-x,A=[["M",0,0]];u?A=[["M",0,v],["L",d-1,v],["L",d-1,w],["L",0,w],["Z"],["M",M,v],["L",a,v],["L",a,w],["L",M,w],["Z"]]:x&&(A=[["M",S,0],["L",S,p-1],["L",k,p-1],["L",k,0],["Z"],["M",S,T],["L",S,n],["L",k,n],["L",k,T],["Z"]]),e.redrawTrigger!=="adjustHeight"&&this.mask.attr({d:A})}moveFixedElements(){let e,{container:i,inverted:s,scrollablePixelsX:o,scrollablePixelsY:r}=this.chart,a=this.fixedRenderer,n=h.fixedSelectors;if(o&&!s?e=".highcharts-yaxis":o&&s||r&&!s?e=".highcharts-xaxis":r&&s&&(e=".highcharts-yaxis"),e&&!(this.chart.hasParallelCoordinates&&e===".highcharts-yaxis"))for(let l of[`${e}:not(.highcharts-radial-axis)`,`${e}-labels:not(.highcharts-radial-axis-labels)`])va(n,l);else for(let l of[".highcharts-xaxis",".highcharts-yaxis"])for(let c of[`${l}:not(.highcharts-radial-axis)`,`${l}-labels:not(.highcharts-radial-axis-labels)`])tc(n,c);for(let l of n)[].forEach.call(i.querySelectorAll(l),c=>{(c.namespaceURI===a.SVG_NS?a.box:a.box.parentNode).appendChild(c),c.style.pointerEvents="auto"})}}return h.fixedSelectors=[".highcharts-breadcrumbs-group",".highcharts-contextbutton",".highcharts-caption",".highcharts-credits",".highcharts-drillup-button",".highcharts-legend",".highcharts-legend-checkbox",".highcharts-navigator-series",".highcharts-navigator-xaxis",".highcharts-navigator-yaxis",".highcharts-navigator",".highcharts-range-selector-group",".highcharts-reset-zoom",".highcharts-scrollbar",".highcharts-subtitle",".highcharts-title"],h})(),{format:ic}=yt,{series:sc}=tt,{destroyObjectProperties:oc,fireEvent:wa,getAlignFactor:$s,isNumber:Zs,pick:Xe}=N,Qa=class{constructor(h,t,e,i,s){let o=h.chart.inverted,r=h.reversed;this.axis=h;let a=this.isNegative=!!e!=!!r;this.options=t=t||{},this.x=i,this.total=null,this.cumulative=null,this.points={},this.hasValidPoints=!1,this.stack=s,this.leftCliff=0,this.rightCliff=0,this.alignOptions={align:t.align||(o?a?"left":"right":"center"),verticalAlign:t.verticalAlign||(o?"middle":a?"bottom":"top"),y:t.y,x:t.x},this.textAlign=t.textAlign||(o?a?"right":"left":"center")}destroy(){oc(this,this.axis)}render(h){let t=this.axis.chart,e=this.options,i=e.format,s=i?ic(i,this,t):e.formatter.call(this);if(this.label)this.label.attr({text:s,visibility:"hidden"});else{this.label=t.renderer.label(s,null,void 0,e.shape,void 0,void 0,e.useHTML,!1,"stack-labels");let o={r:e.borderRadius||0,text:s,padding:Xe(e.padding,5),visibility:"hidden"};t.styledMode||(o.fill=e.backgroundColor,o.stroke=e.borderColor,o["stroke-width"]=e.borderWidth,this.label.css(e.style||{})),this.label.attr(o),this.label.added||this.label.add(h)}this.label.labelrank=t.plotSizeY,wa(this,"afterRender")}setOffset(h,t,e,i,s,o){let{alignOptions:r,axis:a,label:n,options:l,textAlign:c}=this,d=a.chart,p=this.getStackBox({xOffset:h,width:t,boxBottom:e,boxTop:i,defaultX:s,xAxis:o}),{verticalAlign:g}=r;if(n&&p){let u=n.getBBox(void 0,0),x=n.padding,m=Xe(l.overflow,"justify")==="justify",f;r.x=l.x||0,r.y=l.y||0;let{x:y,y:b}=this.adjustStackPosition({labelBox:u,verticalAlign:g,textAlign:c});p.x-=y,p.y-=b,n.align(r,!1,p),(f=d.isInsidePlot(n.alignAttr.x+r.x+y,n.alignAttr.y+r.y+b))||(m=!1),m&&sc.prototype.justifyDataLabel.call(a,n,r,n.alignAttr,u,p),n.attr({x:n.alignAttr.x,y:n.alignAttr.y,rotation:l.rotation,rotationOriginX:u.width*$s(l.textAlign||"center"),rotationOriginY:u.height/2}),Xe(!m&&l.crop,!0)&&(f=Zs(n.x)&&Zs(n.y)&&d.isInsidePlot(n.x-x+(n.width||0),n.y)&&d.isInsidePlot(n.x+x,n.y)),n[f?"show":"hide"]()}wa(this,"afterSetOffset",{xOffset:h,width:t})}adjustStackPosition({labelBox:h,verticalAlign:t,textAlign:e}){return{x:h.width/2+h.width/2*(2*$s(e)-1),y:h.height/2*2*(1-$s(t))}}getStackBox(h){let t=this.axis,e=t.chart,{boxTop:i,defaultX:s,xOffset:o,width:r,boxBottom:a}=h,n=t.stacking.usePercentage?100:Xe(i,this.total,0),l=t.toPixels(n),c=h.xAxis||e.xAxis[0],d=Xe(s,c.translate(this.x))+o,p=Math.abs(l-t.toPixels(a||Zs(t.min)&&t.logarithmic&&t.logarithmic.lin2log(t.min)||0)),g=e.inverted,u=this.isNegative;return g?{x:(u?l:l-p)-e.plotLeft,y:c.height-d-r+c.top-e.plotTop,width:p,height:r}:{x:d+c.transB-e.plotLeft,y:(u?l-p:l)-e.plotTop,width:r,height:p}}},{getDeferredAnimation:rc}=at,{series:{prototype:ac}}=tt,{addEvent:Ma,correctFloat:je,defined:tn,destroyObjectProperties:nc,fireEvent:hc,isNumber:To,objectEach:se,pick:Co}=N;function lc(){let h=this.inverted;this.axes.forEach(t=>{t.stacking?.stacks&&t.hasVisibleSeries&&(t.stacking.oldStacks=t.stacking.stacks)}),this.series.forEach(t=>{let e=t.xAxis?.options||{};t.options.stacking&&t.reserveSpace()&&(t.stackKey=[t.type,Co(t.options.stack,""),h?e.top:e.left,h?e.height:e.width].join(","))})}function dc(){let h=this.stacking;if(h){let t=h.stacks;se(t,(e,i)=>{nc(e),delete t[i]}),h.stackTotalGroup?.destroy()}}function cc(){this.stacking||(this.stacking=new Ao(this))}function pc(h,t,e,i){return!tn(h)||h.x!==t||i&&h.stackKey!==i?h={x:t,index:0,key:i,stackKey:i}:h.index++,h.key=[e,t,h.index].join(","),h}function gc(){let h,t=this,e=t.yAxis,i=t.stackKey||"",s=e.stacking.stacks,o=t.getColumn("x",!0),r=t.options.stacking,a=t[r+"Stacker"];a&&[i,"-"+i].forEach(n=>{let l=o.length,c,d,p;for(;l--;)c=o[l],h=t.getStackIndicator(h,c,t.index,n),d=s[n]?.[c],(p=d?.points[h.key||""])&&a.call(t,p,d,l)})}function uc(h,t,e){let i=t.total?100/t.total:0;h[0]=je(h[0]*i),h[1]=je(h[1]*i),this.stackedYData[e]=h[1]}function fc(h){(this.is("column")||this.is("columnrange"))&&(this.options.centerInCategory&&this.chart.series.length>1?ac.setStackedPoints.call(this,h,"group"):h.stacking.resetStacks())}function mc(h,t){let e,i,s,o,r,a,n,l=t||this.options.stacking;if(!l||!this.reserveSpace()||({group:"xAxis"}[l]||"yAxis")!==h.coll)return;let c=this.getColumn("x",!0),d=this.getColumn(this.pointValKey||"y",!0),p=[],g=d.length,u=this.options,x=u.threshold||0,m=u.startFromThreshold?x:0,f=u.stack,y=t?`${this.type},${l}`:this.stackKey||"",b="-"+y,v=this.negStacks,S=h.stacking,w=S.stacks,k=S.oldStacks;for(S.stacksTouched+=1,n=0;n<g;n++){let M=c[n]||0,T=d[n],A=To(T)&&T||0;a=(e=this.getStackIndicator(e,M,this.index)).key||"",w[r=(i=v&&A<(m?0:x))?b:y]||(w[r]={}),w[r][M]||(k[r]?.[M]?(w[r][M]=k[r][M],w[r][M].total=null):w[r][M]=new Qa(h,h.options.stackLabels,!!i,M,f)),s=w[r][M],T!==null?(s.points[a]=s.points[this.index]=[Co(s.cumulative,m)],tn(s.cumulative)||(s.base=a),s.touched=S.stacksTouched,e.index>0&&this.singleStacks===!1&&(s.points[a][0]=s.points[this.index+","+M+",0"][0])):(delete s.points[a],delete s.points[this.index]);let C=s.total||0;l==="percent"?(o=i?y:b,C=v&&w[o]?.[M]?(o=w[o][M]).total=Math.max(o.total||0,C)+Math.abs(A):je(C+Math.abs(A))):l==="group"?To(T)&&C++:C=je(C+A),l==="group"?s.cumulative=(C||1)-1:s.cumulative=je(Co(s.cumulative,m)+A),s.total=C,T!==null&&(s.points[a].push(s.cumulative),p[n]=s.cumulative,s.hasValidPoints=!0)}l==="percent"&&(S.usePercentage=!0),l!=="group"&&(this.stackedYData=p),S.oldStacks={}}var Ao=class{constructor(t){this.oldStacks={},this.stacks={},this.stacksTouched=0,this.axis=t}buildStacks(){let t,e,i=this.axis,s=i.series,o=i.coll==="xAxis",r=i.options.reversedStacks,a=s.length;for(this.resetStacks(),this.usePercentage=!1,e=a;e--;)t=s[r?e:a-e-1],o&&t.setGroupedPoints(i),t.setStackedPoints(i);if(!o)for(e=0;e<a;e++)s[e].modifyStacks();hc(i,"afterBuildStacks")}cleanStacks(){this.oldStacks&&(this.stacks=this.oldStacks,se(this.stacks,t=>{se(t,e=>{e.cumulative=e.total})}))}resetStacks(){se(this.stacks,t=>{se(t,(e,i)=>{To(e.touched)&&e.touched<this.stacksTouched?(e.destroy(),delete t[i]):(e.total=null,e.cumulative=null)})})}renderStackTotals(){let t=this.axis,e=t.chart,i=e.renderer,s=this.stacks,o=rc(e,t.options.stackLabels?.animation||!1),r=this.stackTotalGroup=this.stackTotalGroup||i.g("stack-labels").attr({zIndex:6,opacity:0}).add();r.translate(e.plotLeft,e.plotTop),se(s,a=>{se(a,n=>{n.render(r)})}),r.animate({opacity:1},o)}};(yo||(yo={})).compose=function(h,t,e){let i=t.prototype,s=e.prototype;i.getStacks||(Ma(h,"init",cc),Ma(h,"destroy",dc),i.getStacks=lc,s.getStackIndicator=pc,s.modifyStacks=gc,s.percentStacker=uc,s.setGroupedPoints=fc,s.setStackedPoints=mc)};var xc=yo,{defined:yc,merge:en,isObject:bc}=N,Ui=class extends ut{drawGraph(){let t=this.options,e=(this.gappedPath||this.getGraphPath).call(this),i=this.chart.styledMode;[this,...this.zones].forEach((s,o)=>{let r,a=s.graph,n=a?"animate":"attr",l=s.dashStyle||t.dashStyle;a?(a.endX=this.preventGraphAnimation?null:e.xMap,a.animate({d:e})):e.length&&(s.graph=a=this.chart.renderer.path(e).addClass("highcharts-graph"+(o?` highcharts-zone-graph-${o-1} `:" ")+(o&&s.className||"")).attr({zIndex:1}).add(this.group)),a&&!i&&(r={stroke:!o&&t.lineColor||s.color||this.color||"#cccccc","stroke-width":t.lineWidth||0,fill:this.fillGraph&&this.color||"none"},l?r.dashstyle=l:t.linecap!=="square"&&(r["stroke-linecap"]=r["stroke-linejoin"]="round"),a[n](r).shadow(t.shadow&&en({filterUnits:"userSpaceOnUse"},bc(t.shadow)?t.shadow:{}))),a&&(a.startX=e.xMap,a.isArea=e.isArea)})}getGraphPath(t,e,i){let s=this,o=s.options,r=[],a=[],n,l=o.step,c=(t=t||s.points).reversed;return c&&t.reverse(),(l={right:1,center:2}[l]||l&&3)&&c&&(l=4-l),(t=this.getValidPoints(t,!1,o.nullInteraction||!(o.connectNulls&&!e&&!i))).forEach(function(d,p){let g,u=d.plotX,x=d.plotY,m=t[p-1],f=d.isNull||typeof x!="number";(d.leftCliff||m?.rightCliff)&&!i&&(n=!0),f&&!yc(e)&&p>0?n=!o.connectNulls:f&&!e?n=!0:(p===0||n?g=[["M",d.plotX,d.plotY]]:s.getPointSpline?g=[s.getPointSpline(t,d,p)]:l?(g=l===1?[["L",m.plotX,x]]:l===2?[["L",(m.plotX+u)/2,m.plotY],["L",(m.plotX+u)/2,x]]:[["L",u,m.plotY]]).push(["L",u,x]):g=[["L",u,x]],a.push(d.x),l&&(a.push(d.x),l===2&&a.push(d.x)),r.push.apply(r,g),n=!1)}),r.xMap=a,s.graphPath=r,r}};Ui.defaultOptions=en(ut.defaultOptions,{legendSymbol:"lineMarker"}),tt.registerSeriesType("line",Ui);var{seriesTypes:{line:Po}}=tt,{extend:vc,merge:kc,objectEach:wc,pick:Ai}=N,Ue=class extends Po{drawGraph(){this.areaPath=[],super.drawGraph.apply(this);let{areaPath:t,options:e}=this;[this,...this.zones].forEach((i,s)=>{let o={},r=i.fillColor||e.fillColor,a=i.area,n=a?"animate":"attr";a?(a.endX=this.preventGraphAnimation?null:t.xMap,a.animate({d:t})):(o.zIndex=0,(a=i.area=this.chart.renderer.path(t).addClass("highcharts-area"+(s?` highcharts-zone-area-${s-1} `:" ")+(s&&i.className||"")).add(this.group)).isArea=!0),this.chart.styledMode||(o.fill=r||i.color||this.color,o["fill-opacity"]=r?1:e.fillOpacity??.75,a.css({pointerEvents:this.stickyTracking?"none":"auto"})),a[n](o),a.startX=t.xMap,a.shiftUnit=e.step?2:1})}getGraphPath(t){let e,i,s,o=Po.prototype.getGraphPath,r=this.options,a=r.stacking,n=this.yAxis,l=[],c=[],d=this.index,p=n.stacking.stacks[this.stackKey],g=r.threshold,u=Math.round(n.getThreshold(r.threshold)),x=Ai(r.connectNulls,a==="percent"),m=function(w,k,M){let T=t[w],A=a&&p[T.x].points[d],C=T[M+"Null"]||0,O=T[M+"Cliff"]||0,D,B,E=!0;O||C?(D=(C?A[0]:A[1])+O,B=A[0]+O,E=!!C):!a&&t[k]&&t[k].isNull&&(D=B=g),D!==void 0&&(c.push({plotX:e,plotY:D===null?u:n.getThreshold(D),isNull:E,isCliff:!0}),l.push({plotX:e,plotY:B===null?u:n.getThreshold(B),doCurve:!1}))};t=t||this.points,a&&(t=this.getStackPoints(t));for(let w=0,k=t.length;w<k;++w)a||(t[w].leftCliff=t[w].rightCliff=t[w].leftNull=t[w].rightNull=void 0),i=t[w].isNull,e=Ai(t[w].rectPlotX,t[w].plotX),s=a?Ai(t[w].yBottom,u):u,(!i||x)&&(x||m(w,w-1,"left"),i&&!a&&x||(c.push(t[w]),l.push({x:w,plotX:e,plotY:s})),x||m(w,w+1,"right"));let f=o.call(this,c,!0,!0);l.reversed=!0;let y=o.call(this,l,!0,!0),b=y[0];b&&b[0]==="M"&&(y[0]=["L",b[1],b[2]]);let v=f.concat(y);v.length&&v.push(["Z"]);let S=o.call(this,c,!1,x);return this.chart.series.length>1&&a&&c.some(w=>w.isCliff)&&(v.hasStackedCliffs=S.hasStackedCliffs=!0),v.xMap=f.xMap,this.areaPath=v,S}getStackPoints(t){let e=this,i=[],s=[],o=this.xAxis,r=this.yAxis,a=r.stacking.stacks[this.stackKey],n={},l=r.series,c=l.length,d=r.options.reversedStacks?1:-1,p=l.indexOf(e);if(t=t||this.points,this.options.stacking){for(let u=0;u<t.length;u++)t[u].leftNull=t[u].rightNull=void 0,n[t[u].x]=t[u];wc(a,function(u,x){u.total!==null&&s.push(x)}),s.sort(function(u,x){return u-x});let g=l.map(u=>u.visible);s.forEach(function(u,x){let m=0,f,y;if(n[u]&&!n[u].isNull)i.push(n[u]),[-1,1].forEach(function(b){let v=b===1?"rightNull":"leftNull",S=a[s[x+b]],w=0;if(S){let k=p;for(;k>=0&&k<c;){let M=l[k].index;!(f=S.points[M])&&(M===e.index?n[u][v]=!0:g[k]&&(y=a[u].points[M])&&(w-=y[1]-y[0])),k+=d}}n[u][b===1?"rightCliff":"leftCliff"]=w});else{let b=p;for(;b>=0&&b<c;){let v=l[b].index;if(f=a[u].points[v]){m=f[1];break}b+=d}m=Ai(m,0),m=r.translate(m,0,1,0,1),i.push({isNull:!0,plotX:o.translate(u,0,0,0,1),x:u,plotY:m,yBottom:m})}})}return i}};Ue.defaultOptions=kc(Po.defaultOptions,{threshold:0,legendSymbol:"areaMarker"}),vc(Ue.prototype,{singleStacks:!1}),tt.registerSeriesType("area",Ue);var{line:sn}=tt.seriesTypes,{merge:Mc,pick:Pi}=N,ei=class extends sn{getPointSpline(t,e,i){let s,o,r,a,n=e.plotX||0,l=e.plotY||0,c=t[i-1],d=t[i+1];function p(u){return u&&!u.isNull&&u.doCurve!==!1&&!e.isCliff}if(p(c)&&p(d)){let u=c.plotX||0,x=c.plotY||0,m=d.plotX||0,f=d.plotY||0,y=0;s=(1.5*n+u)/2.5,o=(1.5*l+x)/2.5,r=(1.5*n+m)/2.5,a=(1.5*l+f)/2.5,r!==s&&(y=(a-o)*(r-n)/(r-s)+l-a),o+=y,a+=y,o>x&&o>l?(o=Math.max(x,l),a=2*l-o):o<x&&o<l&&(o=Math.min(x,l),a=2*l-o),a>f&&a>l?(a=Math.max(f,l),o=2*l-a):a<f&&a<l&&(a=Math.min(f,l),o=2*l-a),e.rightContX=r,e.rightContY=a,e.controlPoints={low:[s,o],high:[r,a]}}let g=["C",Pi(c.rightContX,c.plotX,0),Pi(c.rightContY,c.plotY,0),Pi(s,n,0),Pi(o,l,0),n,l];return c.rightContX=c.rightContY=void 0,g}};ei.defaultOptions=Mc(sn.defaultOptions),tt.registerSeriesType("spline",ei);var on=ei,{area:Sc,area:{prototype:qs}}=tt.seriesTypes,{extend:Tc,merge:Cc}=N,Ve=class extends on{};Ve.defaultOptions=Cc(on.defaultOptions,Sc.defaultOptions),Tc(Ve.prototype,{getGraphPath:qs.getGraphPath,getStackPoints:qs.getStackPoints,drawGraph:qs.drawGraph}),tt.registerSeriesType("areaspline",Ve);var{animObject:Ac}=at,{parse:Pc}=nt,{noop:Lc}=P,{clamp:Li,crisp:Oi,defined:Sa,extend:rn,fireEvent:Ta,isArray:Ca,isNumber:Ei,merge:Lo,pick:He,objectEach:Oc}=N,Me=class extends ut{animate(t){let e,i,s=this,o=this.yAxis,r=o.pos,a=o.reversed,n=s.options,{clipOffset:l,inverted:c}=this.chart,d={},p=c?"translateX":"translateY";t&&l?(d.scaleY=.001,i=Li(o.toPixels(n.threshold||0),r,r+o.len),c?d.translateX=(i+=a?-Math.floor(l[0]):Math.ceil(l[2]))-o.len:d.translateY=i+=a?Math.ceil(l[0]):-Math.floor(l[2]),s.clipBox&&s.setClip(),s.group.attr(d)):(e=Number(s.group.attr(p)),s.group.animate({scaleY:1},rn(Ac(s.options.animation),{step:function(g,u){s.group&&(d[p]=e+u.pos*(r-e),s.group.attr(d))}})))}init(t,e){super.init.apply(this,arguments);let i=this;(t=i.chart).hasRendered&&t.series.forEach(function(s){s.type===i.type&&(s.isDirty=!0)})}getColumnMetrics(){let t=this,e=t.options,i=t.xAxis,s=t.yAxis,o=i.options.reversedStacks,r=i.reversed&&!o||!i.reversed&&o,a={},n,l=0;e.grouping===!1?l=1:t.chart.series.forEach(function(x){let m,f=x.yAxis,y=x.options;x.type===t.type&&x.reserveSpace()&&s.len===f.len&&s.pos===f.pos&&(y.stacking&&y.stacking!=="group"?(a[n=x.stackKey]===void 0&&(a[n]=l++),m=a[n]):y.grouping!==!1&&(m=l++),x.columnIndex=m)});let c=Math.min(Math.abs(i.transA)*(!i.brokenAxis?.hasBreaks&&i.ordinal?.slope||e.pointRange||i.closestPointRange||i.tickInterval||1),i.len),d=c*e.groupPadding,p=(c-2*d)/(l||1),g=Math.min(e.maxPointWidth||i.len,He(e.pointWidth,p*(1-2*e.pointPadding))),u=(t.columnIndex||0)+ +!!r;return t.columnMetrics={width:g,offset:(p-g)/2+(d+u*p-c/2)*(r?-1:1),paddedWidth:p,columnCount:l},t.columnMetrics}crispCol(t,e,i,s){let o=this.borderWidth,r=this.chart.inverted;return s=Oi(e+s,o,r)-(e=Oi(e,o,r)),this.options.crisp&&(i=Oi(t+i,o)-(t=Oi(t,o))),{x:t,y:e,width:i,height:s}}adjustForMissingColumns(t,e,i,s){if(!i.isNull&&s.columnCount>1){let o=this.xAxis.series.filter(l=>l.visible).map(l=>l.index),r=0,a=0;Oc(this.xAxis.stacking?.stacks,l=>{let c=typeof i.x=="number"?l[i.x.toString()]?.points:void 0,d=c?.[this.index],p={};if(c&&Ca(d)){let g=this.index,u=Object.keys(c).filter(x=>!x.match(",")&&c[x]&&c[x].length>1).map(parseFloat).filter(x=>o.indexOf(x)!==-1).filter(x=>{let m=this.chart.series[x].options,f=m.stacking&&m.stack;if(Sa(f)){if(Ei(p[f]))return g===x&&(g=p[f]),!1;p[f]=x}return!0}).sort((x,m)=>m-x);r=u.indexOf(g),a=u.length}}),r=this.xAxis.reversed?a-1-r:r;let n=(a-1)*s.paddedWidth+e;t=(i.plotX||0)+n/2-e-r*s.paddedWidth}return t}translate(){let t=this,e=t.chart,i=t.options,s=t.dense=t.closestPointRange*t.xAxis.transA<2,o=t.borderWidth=He(i.borderWidth,+!s),r=t.xAxis,a=t.yAxis,n=i.threshold,l=He(i.minPointLength,5),c=t.getColumnMetrics(),d=c.width,p=t.pointXOffset=c.offset,g=t.dataMin,u=t.dataMax,x=t.translatedThreshold=a.getThreshold(n),m=t.barW=Math.max(d,1+2*o);i.pointPadding&&i.crisp&&(m=Math.ceil(m)),ut.prototype.translate.apply(t),t.points.forEach(function(f){let y=He(f.yBottom,x),b=999+Math.abs(y),v=f.plotX||0,S=Li(f.plotY,-b,a.len+b),w,k=Math.min(S,y),M=Math.max(S,y)-k,T=d,A=v+p,C=m;l&&Math.abs(M)<l&&(M=l,w=!a.reversed&&!f.negative||a.reversed&&f.negative,Ei(n)&&Ei(u)&&f.y===n&&u<=n&&(a.min||0)<n&&(g!==u||(a.max||0)<=n)&&(w=!w,f.negative=!f.negative),k=Math.abs(k-x)>l?y-l:x-(w?l:0)),Sa(f.options.pointWidth)&&(A-=Math.round(((T=C=Math.ceil(f.options.pointWidth))-d)/2)),i.centerInCategory&&(A=t.adjustForMissingColumns(A,T,f,c)),f.barX=A,f.pointWidth=T,f.tooltipPos=e.inverted?[Li(a.len+a.pos-e.plotLeft-S,a.pos-e.plotLeft,a.len+a.pos-e.plotLeft),r.len+r.pos-e.plotTop-A-C/2,M]:[r.left-e.plotLeft+A+C/2,Li(S+a.pos-e.plotTop,a.pos-e.plotTop,a.len+a.pos-e.plotTop),M],f.shapeType=t.pointClass.prototype.shapeType||"roundedRect",f.shapeArgs=t.crispCol(A,k,C,f.isNull?0:M)}),Ta(this,"afterColumnTranslate")}drawGraph(){this.group[this.dense?"addClass":"removeClass"]("highcharts-dense-data")}pointAttribs(t,e){let i=this.options,s=this.pointAttrToOptions||{},o=s.stroke||"borderColor",r=s["stroke-width"]||"borderWidth",a,n,l,c=t&&t.color||this.color,d=t&&t[o]||i[o]||c,p=t&&t.options.dashStyle||i.dashStyle,g=t&&t[r]||i[r]||this[r]||0,u=t?.isNull&&i.nullInteraction?0:t?.opacity??i.opacity??1;t&&this.zones.length&&(n=t.getZone(),c=t.options.color||n&&(n.color||t.nonZonedColor)||this.color,n&&(d=n.borderColor||d,p=n.dashStyle||p,g=n.borderWidth||g)),e&&t&&(l=(a=Lo(i.states[e],t.options.states&&t.options.states[e]||{})).brightness,c=a.color||l!==void 0&&Pc(c).brighten(a.brightness).get()||c,d=a[o]||d,g=a[r]||g,p=a.dashStyle||p,u=He(a.opacity,u));let x={fill:c,stroke:d,"stroke-width":g,opacity:u};return p&&(x.dashstyle=p),x}drawPoints(t=this.points){let e,i=this,s=this.chart,o=i.options,r=o.nullInteraction,a=s.renderer,n=o.animationLimit||250;t.forEach(function(l){let c=l.plotY,d=l.graphic,p=!!d,g=d&&s.pointCount<n?"animate":"attr";Ei(c)&&(l.y!==null||r)?(e=l.shapeArgs,d&&l.hasNewShapeType()&&(d=d.destroy()),i.enabledDataSorting&&(l.startXPos=i.xAxis.reversed?-(e&&e.width||0):i.xAxis.width),!d&&(l.graphic=d=a[l.shapeType](e).add(l.group||i.group),d&&i.enabledDataSorting&&s.hasRendered&&s.pointCount<n&&(d.attr({x:l.startXPos}),p=!0,g="animate")),d&&p&&d[g](Lo(e)),s.styledMode||d[g](i.pointAttribs(l,l.selected&&"select")).shadow(l.allowShadow!==!1&&o.shadow),d&&(d.addClass(l.getClassName(),!0),d.attr({visibility:l.visible?"inherit":"hidden"}))):d&&(l.graphic=d.destroy())})}drawTracker(t=this.points){let e,i=this,s=i.chart,o=s.pointer,r=function(a){o?.normalize(a);let n=o?.getPointFromEvent(a);o&&n&&i.options.enableMouseTracking&&(s.isInsidePlot(a.chartX-s.plotLeft,a.chartY-s.plotTop,{visiblePlotOnly:!0})||o?.inClass(a.target,"highcharts-data-label"))&&(o.isDirectTouch=!0,n.onMouseOver(a))};t.forEach(function(a){e=Ca(a.dataLabels)?a.dataLabels:a.dataLabel?[a.dataLabel]:[],a.graphic&&(a.graphic.element.point=a),e.forEach(function(n){(n.div||n.element).point=a})}),i._hasTracking||(i.trackerGroups.forEach(function(a){i[a]&&(i[a].addClass("highcharts-tracker").on("mouseover",r).on("mouseout",function(n){o?.onTrackerMouseOut(n)}).on("touchstart",r),!s.styledMode&&i.options.cursor&&i[a].css({cursor:i.options.cursor}))}),i._hasTracking=!0),Ta(this,"afterDrawTracker")}remove(){let t=this,e=t.chart;e.hasRendered&&e.series.forEach(function(i){i.type===t.type&&(i.isDirty=!0)}),ut.prototype.remove.apply(t,arguments)}};Me.defaultOptions=Lo(ut.defaultOptions,{borderRadius:3,centerInCategory:!1,groupPadding:.2,marker:null,pointPadding:.1,minPointLength:0,cropThreshold:50,pointRange:null,states:{hover:{halo:!1,brightness:.1},select:{color:"#cccccc",borderColor:"#000000"}},dataLabels:{align:void 0,verticalAlign:void 0,y:void 0},startFromThreshold:!0,stickyTracking:!1,tooltip:{distance:6},threshold:0,borderColor:"#ffffff"}),rn(Me.prototype,{directTouch:!0,getSymbol:Lc,negStacks:!0,trackerGroups:["group","dataLabelsGroup"]}),tt.registerSeriesType("column",Me);var Vi=Me,{getDeferredAnimation:Ec}=at,{format:Ic}=yt,{defined:ee,extend:Aa,fireEvent:Ks,getAlignFactor:Pa,isArray:Ut,isString:Fe,merge:Ye,objectEach:Dc,pick:Ge,pInt:Bc,splat:La}=N;(function(h){function t(){return n(this).some(c=>c?.enabled)}function e(c,d,p,g,u){let{chart:x,enabledDataSorting:m}=this,f=this.isCartesian&&x.inverted,y=c.plotX,b=c.plotY,v=p.rotation||0,S=ee(y)&&ee(b)&&x.isInsidePlot(y,Math.round(b),{inverted:f,paneCoordinates:!0,series:this}),w=v===0&&Ge(p.overflow,m?"none":"justify")==="justify",k=this.visible&&c.visible!==!1&&ee(y)&&(c.series.forceDL||m&&!w||S||Ge(p.inside,!!this.options.stacking)&&g&&x.isInsidePlot(y,f?g.x+1:g.y+g.height-1,{inverted:f,paneCoordinates:!0,series:this})),M=c.pos();if(k&&M){var T;let A=d.getBBox(),C=d.getBBox(void 0,0);if(g=Aa({x:M[0],y:Math.round(M[1]),width:0,height:0},g||{}),p.alignTo==="plotEdges"&&this.isCartesian&&(g[f?"x":"y"]=0,g[f?"width":"height"]=this.yAxis?.len||0),Aa(p,{width:A.width,height:A.height}),T=g,m&&this.xAxis&&!w&&this.setDataLabelStartPos(c,d,u,S,T),d.align(Ye(p,{width:C.width,height:C.height}),!1,g,!1),d.alignAttr.x+=Pa(p.align)*(C.width-A.width),d.alignAttr.y+=Pa(p.verticalAlign)*(C.height-A.height),d[d.placed?"animate":"attr"]({"text-align":d.alignAttr["text-align"]||"center",x:d.alignAttr.x+(A.width-C.width)/2,y:d.alignAttr.y+(A.height-C.height)/2,rotationOriginX:(d.width||0)/2,rotationOriginY:(d.height||0)/2}),w&&g.height>=0)this.justifyDataLabel(d,p,d.alignAttr,A,g,u);else if(Ge(p.crop,!0)){let{x:O,y:D}=d.alignAttr;k=x.isInsidePlot(O,D,{paneCoordinates:!0,series:this})&&x.isInsidePlot(O+A.width-1,D+A.height-1,{paneCoordinates:!0,series:this})}p.shape&&!v&&d[u?"attr":"animate"]({anchorX:M[0],anchorY:M[1]})}u&&m&&(d.placed=!1),k||m&&!w?(d.show(),d.placed=!0):(d.hide(),d.placed=!1)}function i(){return this.plotGroup("dataLabelsGroup","data-labels",this.hasRendered?"inherit":"hidden",this.options.dataLabels.zIndex||6,this.chart.dataLabelsGroup)}function s(c){let d=this.hasRendered||0,p=this.initDataLabelsGroup().attr({opacity:+d});return!d&&p&&(this.visible&&p.show(),this.options.animation?p.animate({opacity:1},c):p.attr({opacity:1})),p}function o(c){let d;c=c||this.points;let p=this,g=p.chart,u=p.options,x=g.renderer,{backgroundColor:m,plotBackgroundColor:f}=g.options.chart,y=x.getContrast(Fe(f)&&f||Fe(m)&&m||"#000000"),b=n(p),{animation:v,defer:S}=b[0],w=S?Ec(g,v,p):{defer:0,duration:0};Ks(this,"drawDataLabels"),p.hasDataLabels?.()&&(d=this.initDataLabels(w),c.forEach(k=>{let M=k.dataLabels||[],T=k.color||p.color;La(a(b,k.dlOptions||k.options?.dataLabels)).forEach((C,O)=>{let D=C.enabled&&(k.visible||k.dataLabelOnHidden)&&(!k.isNull||k.dataLabelOnNull)&&function($,Z){let U=Z.filter;if(U){let K=U.operator,lt=$[U.property],gt=U.value;return K===">"&<>gt||K==="<"&<<gt||K===">="&<>=gt||K==="<="&<<=gt||K==="=="&<==gt||K==="==="&<===gt||K==="!="&<!=gt||K==="!=="&<!==gt||!1}return!0}(k,C),{backgroundColor:B,borderColor:E,distance:L,style:I={}}=C,V,Y,ht,W={},R=M[O],j=!R,F;D&&(Y=ee(V=Ge(C[k.formatPrefix+"Format"],C.format))?Ic(V,k,g):(C[k.formatPrefix+"Formatter"]||C.formatter).call(k,C),ht=C.rotation,!g.styledMode&&(I.color=Ge(C.color,I.color,Fe(p.color)?p.color:void 0,"#000000"),I.color==="contrast"?(B!=="none"&&(F=B),k.contrastColor=x.getContrast(F!=="auto"&&Fe(F)&&F||(Fe(T)?T:"")),I.color=F||!ee(L)&&C.inside||0>Bc(L||0)||u.stacking?k.contrastColor:y):delete k.contrastColor,u.cursor&&(I.cursor=u.cursor)),W={r:C.borderRadius||0,rotation:ht,padding:C.padding,zIndex:1},g.styledMode||(W.fill=B==="auto"?k.color:B,W.stroke=E==="auto"?k.color:E,W["stroke-width"]=C.borderWidth),Dc(W,($,Z)=>{$===void 0&&delete W[Z]})),!R||D&&ee(Y)&&!!(R.div||R.text?.foreignObject)==!!C.useHTML&&(R.rotation&&C.rotation||R.rotation===C.rotation)||(R=void 0,j=!0),D&&ee(Y)&&Y!==""&&(R?W.text=Y:(R=x.label(Y,0,0,C.shape,void 0,void 0,C.useHTML,void 0,"data-label")).addClass(" highcharts-data-label-color-"+k.colorIndex+" "+(C.className||"")+(C.useHTML?" highcharts-tracker":"")),R&&(R.options=C,R.attr(W),g.styledMode?I.width&&R.css({width:I.width,textOverflow:I.textOverflow,whiteSpace:I.whiteSpace}):R.css(I).shadow(C.shadow),Ks(R,"beforeAddingDataLabel",{labelOptions:C,point:k}),R.added||R.add(d),p.alignDataLabel(k,R,C,void 0,j),R.isActive=!0,M[O]&&M[O]!==R&&M[O].destroy(),M[O]=R))});let A=M.length;for(;A--;)M[A]?.isActive?M[A].isActive=!1:(M[A]?.destroy(),M.splice(A,1));k.dataLabel=M[0],k.dataLabels=M})),Ks(this,"afterDrawDataLabels")}function r(c,d,p,g,u,x){let m=this.chart,f=d.align,y=d.verticalAlign,b=c.box?0:c.padding||0,v=m.inverted?this.yAxis:this.xAxis,S=v?v.left-m.plotLeft:0,w=m.inverted?this.xAxis:this.yAxis,k=w?w.top-m.plotTop:0,{x:M=0,y:T=0}=d,A,C;return(A=(p.x||0)+b+S)<0&&(f==="right"&&M>=0?(d.align="left",d.inside=!0):M-=A,C=!0),(A=(p.x||0)+g.width-b+S)>m.plotWidth&&(f==="left"&&M<=0?(d.align="right",d.inside=!0):M+=m.plotWidth-A,C=!0),(A=p.y+b+k)<0&&(y==="bottom"&&T>=0?(d.verticalAlign="top",d.inside=!0):T-=A,C=!0),(A=(p.y||0)+g.height-b+k)>m.plotHeight&&(y==="top"&&T<=0?(d.verticalAlign="bottom",d.inside=!0):T+=m.plotHeight-A,C=!0),C&&(d.x=M,d.y=T,c.placed=!x,c.align(d,void 0,u)),C}function a(c,d){let p=[],g;if(Ut(c)&&!Ut(d))p=c.map(function(u){return Ye(u,d)});else if(Ut(d)&&!Ut(c))p=d.map(function(u){return Ye(c,u)});else if(Ut(c)||Ut(d)){if(Ut(c)&&Ut(d))for(g=Math.max(c.length,d.length);g--;)p[g]=Ye(c[g],d[g])}else p=Ye(c,d);return p}function n(c){let d=c.chart.options.plotOptions;return La(a(a(d?.series?.dataLabels,d?.[c.type]?.dataLabels),c.options.dataLabels))}function l(c,d,p,g,u){let x=this.chart,m=x.inverted,f=this.xAxis,y=f.reversed,b=((m?d.height:d.width)||0)/2,v=c.pointWidth,S=v?v/2:0;d.startXPos=m?u.x:y?-b-S:f.width-b+S,d.startYPos=m?y?this.yAxis.height-b+S:-b-S:u.y,g?d.visibility==="hidden"&&(d.show(),d.attr({opacity:0}).animate({opacity:1})):d.attr({opacity:1}).animate({opacity:0},void 0,d.hide),x.hasRendered&&(p&&d.attr({x:d.startXPos,y:d.startYPos}),d.placed=!0)}h.compose=function(c){let d=c.prototype;d.initDataLabels||(d.initDataLabels=s,d.initDataLabelsGroup=i,d.alignDataLabel=e,d.drawDataLabels=o,d.justifyDataLabel=r,d.mergeArrays=a,d.setDataLabelStartPos=l,d.hasDataLabels=t)}})(bo||(bo={}));var $i=bo,{composed:Nc}=P,{series:an}=tt,{merge:zc,pushUnique:Rc}=N;function Wc(h,t,e,i,s){let{chart:o,options:r}=this,a=o.inverted,n=this.xAxis?.len||o.plotSizeX||0,l=this.yAxis?.len||o.plotSizeY||0,c=h.dlBox||h.shapeArgs,d=h.below??(h.plotY||0)>(this.translatedThreshold??l),p=e.inside??!!r.stacking;if(c){if(i=zc(c),e.overflow!=="allow"||e.crop!==!1||r.clip!==!1){i.y<0&&(i.height+=i.y,i.y=0);let g=i.y+i.height-l;g>0&&g<i.height-1&&(i.height-=g)}a&&(i={x:l-i.y-i.height,y:n-i.x-i.width,width:i.height,height:i.width}),p||(a?(i.x+=d?0:i.width,i.width=0):(i.y+=d?i.height:0,i.height=0))}e.align??(e.align=!a||p?"center":d?"right":"left"),e.verticalAlign??(e.verticalAlign=a||p?"middle":d?"top":"bottom"),an.prototype.alignDataLabel.call(this,h,t,e,i,s),e.inside&&h.contrastColor&&t.css({color:h.contrastColor})}(vo||(vo={})).compose=function(h){$i.compose(an),Rc(Nc,"ColumnDataLabel")&&(h.prototype.alignDataLabel=Wc)};var Xc=vo,{extend:Hc,merge:Fc}=N,$e=class extends Vi{};$e.defaultOptions=Fc(Vi.defaultOptions,{}),Hc($e.prototype,{inverted:!0}),tt.registerSeriesType("bar",$e);var{column:Yc,line:nn}=tt.seriesTypes,{addEvent:Gc,extend:jc,merge:Uc}=N,ve=class extends nn{applyJitter(){let t=this,e=this.options.jitter,i=this.points.length;e&&this.points.forEach(function(s,o){["x","y"].forEach(function(r,a){if(e[r]&&!s.isNull){let n=`plot${r.toUpperCase()}`,l=t[`${r}Axis`],c=e[r]*l.transA;if(l&&!l.logarithmic){let d=Math.max(0,(s[n]||0)-c),p=Math.min(l.len,(s[n]||0)+c);s[n]=d+(p-d)*function(g){let u=1e4*Math.sin(g);return u-Math.floor(u)}(o+a*i),r==="x"&&(s.clientX=s.plotX)}}})})}drawGraph(){this.options.lineWidth?super.drawGraph():this.graph&&(this.graph=this.graph.destroy())}};ve.defaultOptions=Uc(nn.defaultOptions,{lineWidth:0,findNearestPointBy:"xy",jitter:{x:0,y:0},marker:{enabled:!0},tooltip:{headerFormat:'<span style="color:{point.color}">\u25CF</span> <span style="font-size: 0.8em"> {series.name}</span><br/>',pointFormat:"x: <b>{point.x}</b><br/>y: <b>{point.y}</b><br/>"}}),jc(ve.prototype,{drawTracker:Yc.prototype.drawTracker,sorted:!1,requireSorting:!1,noSharedTooltip:!0,trackerGroups:["group","markerGroup","dataLabelsGroup"]}),Gc(ve,"afterTranslate",function(){this.applyJitter()}),tt.registerSeriesType("scatter",ve);var{deg2rad:Oa}=P,{fireEvent:Vc,isNumber:_s,pick:Ii,relativeLength:$c}=N;(Kr=ko||(ko={})).getCenter=function(){let h=this.options,t=this.chart,e=2*(h.slicedOffset||0),i=t.plotWidth-2*e,s=t.plotHeight-2*e,o=h.center,r=Math.min(i,s),a=h.thickness,n,l=h.size,c=h.innerSize||0,d,p;typeof l=="string"&&(l=parseFloat(l)),typeof c=="string"&&(c=parseFloat(c));let g=[Ii(o?.[0],"50%"),Ii(o?.[1],"50%"),Ii(l&&l<0?void 0:h.size,"100%"),Ii(c&&c<0?void 0:h.innerSize||0,"0%")];for(!t.angular||this instanceof ut||(g[3]=0),d=0;d<4;++d)p=g[d],n=d<2||d===2&&/%$/.test(p),g[d]=$c(p,[i,s,r,g[2]][d])+(n?e:0);return g[3]>g[2]&&(g[3]=g[2]),_s(a)&&2*a<g[2]&&a>0&&(g[3]=g[2]-2*a),Vc(this,"afterGetCenter",{positions:g}),g},Kr.getStartAndEndRadians=function(h,t){let e=_s(h)?h:0,i=_s(t)&&t>e&&t-e<360?t:e+360;return{start:Oa*(e+-90),end:Oa*(i+-90)}};var hn=ko,{setAnimation:Zc}=at,{addEvent:Ea,defined:qc,extend:Kc,isNumber:_c,pick:Jc,relativeLength:Qc}=N,Zi=class extends Zt{getConnectorPath(t){let e=t.dataLabelPosition,i=t.options||{},s=i.connectorShape,o=this.connectorShapes[s]||s;return e&&o.call(this,Ce(It({},e.computed),{alignment:e.alignment}),e.connectorPosition,i)||[]}getTranslate(){return this.sliced&&this.slicedTranslation||{translateX:0,translateY:0}}haloPath(t){let e=this.shapeArgs;return this.sliced||!this.visible?[]:this.series.chart.renderer.symbols.arc(e.x,e.y,e.r+t,e.r+t,{innerR:e.r-1,start:e.start,end:e.end,borderRadius:e.borderRadius})}constructor(t,e,i){super(t,e,i),this.half=0,this.name??(this.name=t.chart.options.lang.pieSliceName);let s=o=>{this.slice(o.type==="select")};Ea(this,"select",s),Ea(this,"unselect",s)}isValid(){return _c(this.y)&&this.y>=0}setVisible(t,e=!0){t!==this.visible&&this.update({visible:t??!this.visible},e,void 0,!1)}slice(t,e,i){let s=this.series;Zc(i,s.chart),e=Jc(e,!0),this.sliced=this.options.sliced=t=qc(t)?t:!this.sliced,s.options.data[s.data.indexOf(this)]=this.options,this.graphic&&this.graphic.animate(this.getTranslate())}};Kc(Zi.prototype,{connectorShapes:{fixedOffset:function(h,t,e){let i=t.breakAt,s=t.touchingSliceAt,o=e.softConnector?["C",h.x+(h.alignment==="left"?-5:5),h.y,2*i.x-s.x,2*i.y-s.y,i.x,i.y]:["L",i.x,i.y];return[["M",h.x,h.y],o,["L",s.x,s.y]]},straight:function(h,t){let e=t.touchingSliceAt;return[["M",h.x,h.y],["L",e.x,e.y]]},crookedLine:function(h,t,e){let{angle:i=this.angle||0,breakAt:s,touchingSliceAt:o}=t,{series:r}=this,[a,n,l]=r.center,c=l/2,{plotLeft:d,plotWidth:p}=r.chart,g=h.alignment==="left",{x:u,y:x}=h,m=s.x;if(e.crookDistance){let y=Qc(e.crookDistance,1);m=g?a+c+(p+d-a-c)*(1-y):d+(a-c)*y}else m=a+(n-x)*Math.tan(i-Math.PI/2);let f=[["M",u,x]];return(g?m<=u&&m>=s.x:m>=u&&m<=s.x)&&f.push(["L",m,x]),f.push(["L",s.x,s.y],["L",o.x,o.y]),f}}});var{getStartAndEndRadians:tp}=hn,{noop:Ia}=P,{clamp:ep,extend:ip,fireEvent:Da,merge:Oo,pick:sp}=N,Ze=class extends ut{animate(t){let e=this,i=e.points,s=e.startAngleRad;t||i.forEach(function(o){let r=o.graphic,a=o.shapeArgs;r&&a&&(r.attr({r:sp(o.startR,e.center&&e.center[3]/2),start:s,end:s}),r.animate({r:a.r,start:a.start,end:a.end},e.options.animation))})}drawEmpty(){let t,e,i=this.startAngleRad,s=this.endAngleRad,o=this.options;this.total===0&&this.center?(t=this.center[0],e=this.center[1],this.graph||(this.graph=this.chart.renderer.arc(t,e,this.center[1]/2,0,i,s).addClass("highcharts-empty-series").add(this.group)),this.graph.attr({d:$a.arc(t,e,this.center[2]/2,0,{start:i,end:s,innerR:this.center[3]/2})}),this.chart.styledMode||this.graph.attr({"stroke-width":o.borderWidth,fill:o.fillColor||"none",stroke:o.color||"#cccccc"})):this.graph&&(this.graph=this.graph.destroy())}drawPoints(){let t=this.chart.renderer;this.points.forEach(function(e){e.graphic&&e.hasNewShapeType()&&(e.graphic=e.graphic.destroy()),e.graphic||(e.graphic=t[e.shapeType](e.shapeArgs).add(e.series.group),e.delayedRendering=!0)})}generatePoints(){super.generatePoints(),this.updateTotals()}getX(t,e,i,s){let o=this.center,r=this.radii?this.radii[i.index]||0:o[2]/2,a=s.dataLabelPosition,n=a?.distance||0,l=Math.asin(ep((t-o[1])/(r+n),-1,1));return o[0]+Math.cos(l)*(r+n)*(e?-1:1)+(n>0?(e?-1:1)*(s.padding||0):0)}hasData(){return this.points.some(t=>t.visible)}redrawPoints(){let t,e,i,s,o=this,r=o.chart;this.drawEmpty(),o.group&&!r.styledMode&&o.group.shadow(o.options.shadow),o.points.forEach(function(a){let n={};e=a.graphic,!a.isNull&&e?(s=a.shapeArgs,t=a.getTranslate(),r.styledMode||(i=o.pointAttribs(a,a.selected&&"select")),a.delayedRendering?(e.setRadialReference(o.center).attr(s).attr(t),r.styledMode||e.attr(i).attr({"stroke-linejoin":"round"}),a.delayedRendering=!1):(e.setRadialReference(o.center),r.styledMode||Oo(!0,n,i),Oo(!0,n,s,t),e.animate(n)),e.attr({visibility:a.visible?"inherit":"hidden"}),e.addClass(a.getClassName(),!0)):e&&(a.graphic=e.destroy())})}sortByAngle(t,e){t.sort(function(i,s){return i.angle!==void 0&&(s.angle-i.angle)*e})}translate(t){Da(this,"translate"),this.generatePoints();let e=this.options,i=e.slicedOffset,s=tp(e.startAngle,e.endAngle),o=this.startAngleRad=s.start,r=(this.endAngleRad=s.end)-o,a=this.points,n=e.ignoreHiddenPoint,l=a.length,c,d,p,g,u,x,m,f=0;for(t||(this.center=t=this.getCenter()),x=0;x<l;x++){m=a[x],c=o+f*r,m.isValid()&&(!n||m.visible)&&(f+=m.percentage/100),d=o+f*r;let y={x:t[0],y:t[1],r:t[2]/2,innerR:t[3]/2,start:Math.round(1e3*c)/1e3,end:Math.round(1e3*d)/1e3};m.shapeType="arc",m.shapeArgs=y,(p=(d+c)/2)>1.5*Math.PI?p-=2*Math.PI:p<-Math.PI/2&&(p+=2*Math.PI),m.slicedTranslation={translateX:Math.round(Math.cos(p)*i),translateY:Math.round(Math.sin(p)*i)},g=Math.cos(p)*t[2]/2,u=Math.sin(p)*t[2]/2,m.tooltipPos=[t[0]+.7*g,t[1]+.7*u],m.half=+(p<-Math.PI/2||p>Math.PI/2),m.angle=p}Da(this,"afterTranslate")}updateTotals(){let t=this.points,e=t.length,i=this.options.ignoreHiddenPoint,s,o,r=0;for(s=0;s<e;s++)(o=t[s]).isValid()&&(!i||o.visible)&&(r+=o.y);for(s=0,this.total=r;s<e;s++)(o=t[s]).percentage=r>0&&(o.visible||!i)?o.y/r*100:0,o.total=r}};Ze.defaultOptions=Oo(ut.defaultOptions,{borderRadius:3,center:[null,null],clip:!1,colorByPoint:!0,dataLabels:{connectorPadding:5,connectorShape:"crookedLine",crookDistance:void 0,distance:30,enabled:!0,formatter:function(){return this.isNull?void 0:this.name},softConnector:!0,x:0},fillColor:void 0,ignoreHiddenPoint:!0,inactiveOtherPoints:!0,legendType:"point",marker:null,size:null,showInLegend:!1,slicedOffset:10,stickyTracking:!1,tooltip:{followPointer:!0},borderColor:"#ffffff",borderWidth:1,lineWidth:void 0,states:{hover:{brightness:.1}}}),ip(Ze.prototype,{axisTypes:[],directTouch:!0,drawGraph:void 0,drawTracker:Vi.prototype.drawTracker,getCenter:hn.getCenter,getSymbol:Ia,invertible:!1,isCartesian:!1,noSharedTooltip:!0,pointAttribs:Vi.prototype.pointAttribs,pointClass:Zi,requireSorting:!1,searchPoint:Ia,trackerGroups:["group","dataLabelsGroup"]}),tt.registerSeriesType("pie",Ze);var{composed:op,noop:rp}=P,{distribute:ap}=qi,{series:Ba}=tt,{arrayMax:np,clamp:Na,defined:za,isNumber:hp,pick:lp,pushUnique:dp,relativeLength:Ra}=N;(function(h){let t={radialDistributionY:function(r,a){return(a.dataLabelPosition?.top||0)+r.distributeBox.pos},radialDistributionX:function(r,a,n,l,c){let d=c.dataLabelPosition;return r.getX(n<(d?.top||0)+2||n>(d?.bottom||0)-2?l:n,a.half,a,c)},justify:function(r,a,n,l){return l[0]+(r.half?-1:1)*(n+(a.dataLabelPosition?.distance||0))},alignToPlotEdges:function(r,a,n,l){let c=r.getBBox().width;return a?c+l:n-c-l},alignToConnectors:function(r,a,n,l){let c=0,d;return r.forEach(function(p){(d=p.dataLabel.getBBox().width)>c&&(c=d)}),a?c+l:n-c-l}};function e(r,a){let n=Math.PI/2,{start:l=0,end:c=0}=r.shapeArgs||{},d=r.angle||0;a>0&&l<n&&c>n&&d>n/2&&d<1.5*n&&(d=d<=n?Math.max(n/2,(l+n)/2):Math.min(1.5*n,(n+c)/2));let{center:p,options:g}=this,u=p[2]/2,x=Math.cos(d),m=Math.sin(d),f=p[0]+x*u,y=p[1]+m*u,b=Math.min((g.slicedOffset||0)+(g.borderWidth||0),a/5);return{natural:{x:f+x*a,y:y+m*a},computed:{},alignment:a<0?"center":r.half?"right":"left",connectorPosition:{angle:d,breakAt:{x:f+x*b,y:y+m*b},touchingSliceAt:{x:f,y}},distance:a}}function i(){let r=this,a=r.points,n=r.chart,l=n.plotWidth,c=n.plotHeight,d=n.plotLeft,p=Math.round(n.chartWidth/3),g=r.center,u=g[2]/2,x=g[1],m=[[],[]],f=[0,0,0,0],y=r.dataLabelPositioners,b,v,S,w=0;r.visible&&r.hasDataLabels?.()&&(a.forEach(k=>{(k.dataLabels||[]).forEach(M=>{M.shortened&&(M.attr({width:"auto"}).css({width:"auto",textOverflow:"clip"}),M.shortened=!1)})}),Ba.prototype.drawDataLabels.apply(r),a.forEach(k=>{(k.dataLabels||[]).forEach((M,T)=>{let A=g[2]/2,C=M.options,O=Ra(C?.distance||0,A);T===0&&m[k.half].push(k),!za(C?.style?.width)&&M.getBBox().width>p&&(M.css({width:Math.round(.7*p)+"px"}),M.shortened=!0),M.dataLabelPosition=this.getDataLabelPosition(k,O),w=Math.max(w,O)})}),m.forEach((k,M)=>{let T=k.length,A=[],C,O,D=0,B;T&&(r.sortByAngle(k,M-.5),w>0&&(C=Math.max(0,x-u-w),O=Math.min(x+u+w,n.plotHeight),k.forEach(E=>{(E.dataLabels||[]).forEach(L=>{let I=L.dataLabelPosition;I&&I.distance>0&&(I.top=Math.max(0,x-u-I.distance),I.bottom=Math.min(x+u+I.distance,n.plotHeight),D=L.getBBox().height||21,L.lineHeight=n.renderer.fontMetrics(L.text||L).h+2*L.padding,E.distributeBox={target:(L.dataLabelPosition?.natural.y||0)-I.top+L.lineHeight/2,size:D,rank:E.y},A.push(E.distributeBox))})}),ap(A,B=O+D-C,B/5)),k.forEach(E=>{(E.dataLabels||[]).forEach(L=>{let I=L.options||{},V=E.distributeBox,Y=L.dataLabelPosition,ht=Y?.natural.y||0,W=I.connectorPadding||0,R=L.lineHeight||21,j=(R-L.getBBox().height)/2,F=0,$=ht,Z="inherit";if(Y){if(A&&za(V)&&Y.distance>0&&(V.pos===void 0?Z="hidden":(S=V.size,$=y.radialDistributionY(E,L))),I.justify)F=y.justify(E,L,u,g);else switch(I.alignTo){case"connectors":F=y.alignToConnectors(k,M,l,d);break;case"plotEdges":F=y.alignToPlotEdges(L,M,l,d);break;default:F=y.radialDistributionX(r,E,$-j,ht,L)}if(Y.attribs={visibility:Z,align:Y.alignment},Y.posAttribs={x:F+(I.x||0)+({left:W,right:-W}[Y.alignment]||0),y:$+(I.y||0)-R/2},Y.computed.x=F,Y.computed.y=$-j,lp(I.crop,!0)){let U;F-(v=L.getBBox().width)<W&&M===1?(U=Math.round(v-F+W),f[3]=Math.max(U,f[3])):F+v>l-W&&M===0&&(U=Math.round(F+v-l+W),f[1]=Math.max(U,f[1])),$-S/2<0?f[0]=Math.max(Math.round(-$+S/2),f[0]):$+S/2>c&&(f[2]=Math.max(Math.round($+S/2-c),f[2])),Y.sideOverflow=U}}})}))}),(np(f)===0||this.verifyDataLabelOverflow(f))&&(this.placeDataLabels(),this.points.forEach(k=>{(k.dataLabels||[]).forEach(M=>{let{connectorColor:T,connectorWidth:A=1}=M.options||{},C=M.dataLabelPosition;if(hp(A)){let O;b=M.connector,C&&C.distance>0?(O=!b,b||(M.connector=b=n.renderer.path().addClass("highcharts-data-label-connector highcharts-color-"+k.colorIndex+(k.className?" "+k.className:"")).add(r.dataLabelsGroup)),n.styledMode||b.attr({"stroke-width":A,stroke:T||k.color||"#666666"}),b[O?"attr":"animate"]({d:k.getConnectorPath(M)}),b.attr({visibility:C.attribs?.visibility})):b&&(M.connector=b.destroy())}})})))}function s(){this.points.forEach(r=>{(r.dataLabels||[]).forEach(a=>{let n=a.dataLabelPosition;n?(n.sideOverflow&&(a.css({width:Math.max(a.getBBox().width-n.sideOverflow,0)+"px",textOverflow:a.options?.style?.textOverflow||"ellipsis"}),a.shortened=!0),a.attr(n.attribs),a[a.moved?"animate":"attr"](n.posAttribs),a.moved=!0):a&&a.attr({y:-9999})}),delete r.distributeBox},this)}function o(r){let a=this.center,n=this.options,l=n.center,c=n.minSize||80,d=c,p=n.size!==null;return!p&&(l[0]!==null?d=Math.max(a[2]-Math.max(r[1],r[3]),c):(d=Math.max(a[2]-r[1]-r[3],c),a[0]+=(r[3]-r[1])/2),l[1]!==null?d=Na(d,c,a[2]-Math.max(r[0],r[2])):(d=Na(d,c,a[2]-r[0]-r[2]),a[1]+=(r[0]-r[2])/2),d<a[2]?(a[2]=d,a[3]=Math.min(n.thickness?Math.max(0,d-2*n.thickness):Math.max(0,Ra(n.innerSize||0,d)),d),this.translate(a),this.drawDataLabels&&this.drawDataLabels()):p=!0),p}h.compose=function(r){if($i.compose(Ba),dp(op,"PieDataLabel")){let a=r.prototype;a.dataLabelPositioners=t,a.alignDataLabel=rp,a.drawDataLabels=i,a.getDataLabelPosition=e,a.placeDataLabels=s,a.verifyDataLabelOverflow=o}}})(wo||(wo={}));var cp=wo;(ki=Mo||(Mo={})).getCenterOfPoints=function(h){let t=h.reduce((e,i)=>(e.x+=i.x,e.y+=i.y,e),{x:0,y:0});return{x:t.x/h.length,y:t.y/h.length}},ki.getDistanceBetweenPoints=function(h,t){return Math.sqrt(Math.pow(t.x-h.x,2)+Math.pow(t.y-h.y,2))},ki.getAngleBetweenPoints=function(h,t){return Math.atan2(t.x-h.x,t.y-h.y)},ki.pointInPolygon=function({x:h,y:t},e){let i=e.length,s,o,r=!1;for(s=0,o=i-1;s<i;o=s++){let[a,n]=e[s],[l,c]=e[o];n>t!=c>t&&h<(l-a)*(t-n)/(c-n)+a&&(r=!r)}return r};var{pointInPolygon:pp}=Mo,{addEvent:gp,getAlignFactor:up,fireEvent:ln,objectEach:Wa,pick:fp}=N;function mp(h){let t=h.length,e=(c,d)=>!(d.x>=c.x+c.width||d.x+d.width<=c.x||d.y>=c.y+c.height||d.y+d.height<=c.y),i=(c,d)=>{for(let p of c)if(pp({x:p[0],y:p[1]},d))return!0;return!1},s,o,r,a,n,l=!1;for(let c=0;c<t;c++)(s=h[c])&&(s.oldOpacity=s.opacity,s.newOpacity=1,s.absoluteBox=function(d){if(d&&(!d.alignAttr||d.placed)){let p=d.box?0:d.padding||0,g=d.alignAttr||{x:d.attr("x"),y:d.attr("y")},{height:u,polygon:x,width:m}=d.getBBox(),f=up(d.alignValue)*m;return d.width=m,d.height=u,{x:g.x+(d.parentGroup?.translateX||0)+p-f,y:g.y+(d.parentGroup?.translateY||0)+p,width:m-2*p,height:u-2*p,polygon:x}}}(s));h.sort((c,d)=>(d.labelrank||0)-(c.labelrank||0));for(let c=0;c<t;++c){a=(o=h[c])&&o.absoluteBox;let d=a?.polygon;for(let p=c+1;p<t;++p){n=(r=h[p])&&r.absoluteBox;let g=!1;if(a&&n&&o!==r&&o.newOpacity!==0&&r.newOpacity!==0&&o.visibility!=="hidden"&&r.visibility!=="hidden"){let u=n.polygon;if(d&&u&&d!==u?i(d,u)&&(g=!0):e(a,n)&&(g=!0),g){let x=o.labelrank<r.labelrank?o:r,m=x.text;x.newOpacity=0,m?.element.querySelector("textPath")&&m.hide()}}}}for(let c of h)dn(c,this)&&(l=!0);l&&ln(this,"afterHideAllOverlappingLabels")}function dn(h,t){let e,i=!1;return h&&(e=h.newOpacity,h.oldOpacity!==e&&(h.hasClass("highcharts-data-label")?(h[e?"removeClass":"addClass"]("highcharts-data-label-hidden"),i=!0,h[h.isOld?"animate":"attr"]({opacity:e},void 0,function(){t.styledMode||h.css({pointerEvents:e?"auto":"none"})}),ln(t,"afterHideOverlappingLabel")):h.attr({opacity:e})),h.isOld=!0),i}function xp(){let h=this,t=[];for(let e of h.labelCollectors||[])t=t.concat(e());for(let e of h.yAxis||[])e.stacking&&e.options.stackLabels&&!e.options.stackLabels.allowOverlap&&Wa(e.stacking.stacks,i=>{Wa(i,s=>{s.label&&t.push(s.label)})});for(let e of h.series||[])if(e.visible&&e.hasDataLabels?.()){let i=s=>{for(let o of s)o.visible&&(o.dataLabels||[]).forEach(r=>{let a=r.options||{};r.labelrank=fp(a.labelrank,o.labelrank,o.shapeArgs?.height),a.allowOverlap??Number(a.distance)>0?(r.oldOpacity=r.opacity,r.newOpacity=1,dn(r,h)):t.push(r)})};i(e.nodes||[]),i(e.points)}this.hideOverlappingLabels(t)}var Xa={compose:function(h){let t=h.prototype;t.hideOverlappingLabels||(t.hideOverlappingLabels=mp,gp(h,"render",xp))}},{defaultOptions:yp}=xt,{noop:cn}=P,{addEvent:Ha,extend:bp,isObject:pn,merge:vp,relativeLength:Io}=N,kp={radius:0,scope:"stack",where:void 0},gn=cn,un=cn;function wp(h,t,e,i,s={}){let o=gn(h,t,e,i,s),{brStart:r=!0,brEnd:a=!0,innerR:n=0,r:l=e,start:c=0,end:d=0}=s;if(s.open||!s.borderRadius)return o;let p=d-c,g=Math.sin(p/2),u=Math.max(Math.min(Io(s.borderRadius||0,l-n),(l-n)/2,l*g/(1+g)),0),x=Math.min(u,p/Math.PI*2*n),m=o.length-1;for(;m--;)(r||m!==0&&m!==3)&&(a||m!==1&&m!==2)&&function(f,y,b){let v,S,w,k=f[y],M=f[y+1];if(M[0]==="Z"&&(M=f[0]),(k[0]==="M"||k[0]==="L")&&M[0]==="A"?(v=k,S=M,w=!0):k[0]==="A"&&(M[0]==="M"||M[0]==="L")&&(v=M,S=k),v&&S&&S.params){let T=S[1],A=S[5],C=S.params,{start:O,end:D,cx:B,cy:E}=C,L=A?T-b:T+b,I=L?Math.asin(b/L):0,V=A?I:-I,Y=Math.cos(I)*L;w?(C.start=O+V,v[1]=B+Y*Math.cos(O),v[2]=E+Y*Math.sin(O),f.splice(y+1,0,["A",b,b,0,0,1,B+T*Math.cos(C.start),E+T*Math.sin(C.start)])):(C.end=D-V,S[6]=B+T*Math.cos(C.end),S[7]=E+T*Math.sin(C.end),f.splice(y+1,0,["A",b,b,0,0,1,B+Y*Math.cos(D),E+Y*Math.sin(D)])),S[4]=Math.abs(C.end-C.start)<Math.PI?0:1}}(o,m,m>1?x:u);return o}function Mp(){if(this.options.borderRadius&&!(this.chart.is3d&&this.chart.is3d())){let{options:h,yAxis:t}=this,e=h.stacking==="percent",i=yp.plotOptions?.[this.type]?.borderRadius,s=Do(h.borderRadius,pn(i)?i:{}),o=t.options.reversed;for(let r of this.points){let{shapeArgs:a}=r;if(r.shapeType==="roundedRect"&&a){let{width:n=0,height:l=0,y:c=0}=a,d=c,p=l;if(s.scope==="stack"&&r.stackTotal){let m=t.translate(e?100:r.stackTotal,!1,!0,!1,!0),f=t.translate(h.threshold||0,!1,!0,!1,!0),y=this.crispCol(0,Math.min(m,f),0,Math.abs(m-f));d=y.y,p=y.height}let g=(r.negative?-1:1)*(o?-1:1)==-1,u=s.where;!u&&this.is("waterfall")&&Math.abs((r.yBottom||0)-(this.translatedThreshold||0))>this.borderWidth&&(u="all"),u||(u="end");let x=Math.min(Io(s.radius,n),n/2,u==="all"?l/2:1/0)||0;u==="end"&&(g&&(d-=x),p+=x),bp(a,{brBoxHeight:p,brBoxY:d,r:x})}}}}function Do(h,t){return pn(h)||(h={radius:h||0}),vp(kp,t,h)}function Sp(){let h=Do(this.options.borderRadius);for(let t of this.points){let e=t.shapeArgs;e&&(e.borderRadius=Io(h.radius,(e.r||0)-(e.innerR||0)))}}function Tp(h,t,e,i,s={}){let o=un(h,t,e,i,s),{r=0,brBoxHeight:a=i,brBoxY:n=t}=s,l=t-n,c=n+a-(t+i),d=l-r>-.1?0:r,p=c-r>-.1?0:r,g=Math.max(d&&l,0),u=Math.max(p&&c,0),x=[h+d,t],m=[h+e-d,t],f=[h+e,t+d],y=[h+e,t+i-p],b=[h+e-p,t+i],v=[h+p,t+i],S=[h,t+i-p],w=[h,t+d],k=(M,T)=>Math.sqrt(Math.pow(M,2)-Math.pow(T,2));if(g){let M=k(d,d-g);x[0]-=M,m[0]+=M,f[1]=w[1]=t+d-g}if(i<d-g){let M=k(d,d-g-i);f[0]=y[0]=h+e-d+M,b[0]=Math.min(f[0],b[0]),v[0]=Math.max(y[0],v[0]),S[0]=w[0]=h+d-M,f[1]=w[1]=t+i}if(u){let M=k(p,p-u);b[0]+=M,v[0]-=M,y[1]=S[1]=t+i-p+u}if(i<p-u){let M=k(p,p-u-i);f[0]=y[0]=h+e-p+M,m[0]=Math.min(f[0],m[0]),x[0]=Math.max(y[0],x[0]),S[0]=w[0]=h+p-M,y[1]=S[1]=t}return o.length=0,o.push(["M",...x],["L",...m],["A",d,d,0,0,1,...f],["L",...y],["A",p,p,0,0,1,...b],["L",...v],["A",p,p,0,0,1,...S],["L",...w],["A",d,d,0,0,1,...x],["Z"]),o}var{diffObjects:Cp,extend:Ap,find:Pp,merge:Lp,pick:Di,uniqueKey:Op}=N;function Ep(h,t){let e=h.condition;(e.callback||function(){return this.chartWidth<=Di(e.maxWidth,Number.MAX_VALUE)&&this.chartHeight<=Di(e.maxHeight,Number.MAX_VALUE)&&this.chartWidth>=Di(e.minWidth,0)&&this.chartHeight>=Di(e.minHeight,0)}).call(this)&&t.push(h._id)}function Ip(h,t){let e=this.options.responsive,i=this.currentResponsive,s=[],o;!t&&e&&e.rules&&e.rules.forEach(n=>{n._id===void 0&&(n._id=Op()),this.matchResponsiveRule(n,s)},this);let r=Lp(...s.map(n=>Pp(e?.rules||[],l=>l._id===n)).map(n=>n?.chartOptions));r.isResponsiveOptions=!0,s=s.toString()||void 0;let a=i?.ruleIds;s!==a&&(i&&(this.currentResponsive=void 0,this.updatingResponsive=!0,this.update(i.undoOptions,h,!0),this.updatingResponsive=!1),s?((o=Cp(r,this.options,!0,this.collectionsWithUpdate)).isResponsiveOptions=!0,this.currentResponsive={ruleIds:s,mergedOptions:r,undoOptions:o},this.updatingResponsive||this.update(r,h,!0)):this.currentResponsive=void 0)}(So||(So={})).compose=function(h){let t=h.prototype;return t.matchResponsiveRule||Ap(t,{matchResponsiveRule:Ep,setResponsive:Ip}),h};var Dp=So;P.AST=ot,P.Axis=oo,P.Chart=$t,P.Color=nt,P.DataLabel=$i,P.DataTableCore=Ri,P.Fx=ae,P.HTMLElement=Je,P.Legend=ca,P.LegendSymbol=Ka,P.OverlappingDataLabels=P.OverlappingDataLabels||Xa,P.PlotLineOrBand=ji,P.Point=Zt,P.Pointer=Gr,P.RendererRegistry=ii,P.Series=ut,P.SeriesRegistry=tt,P.StackItem=Qa,P.SVGElement=Et,P.SVGRenderer=Se,P.Templating=yt,P.Tick=be,P.Time=Eo,P.Tooltip=Wr,P.animate=at.animate,P.animObject=at.animObject,P.chart=$t.chart,P.color=nt.parse,P.dateFormat=yt.dateFormat,P.defaultOptions=xt.defaultOptions,P.distribute=qi.distribute,P.format=yt.format,P.getDeferredAnimation=at.getDeferredAnimation,P.getOptions=xt.getOptions,P.numberFormat=yt.numberFormat,P.seriesType=tt.seriesType,P.setAnimation=at.setAnimation,P.setOptions=xt.setOptions,P.stop=at.stop,P.time=xt.defaultTime,P.timers=ae.timers,{compose:function(h,t,e){let i=h.types.pie;if(!t.symbolCustomAttribs.includes("borderRadius")){let s=e.prototype.symbols;Ha(h,"afterColumnTranslate",Mp,{order:9}),Ha(i,"afterTranslate",Sp),t.symbolCustomAttribs.push("borderRadius","brBoxHeight","brBoxY","brEnd","brStart"),gn=s.arc,un=s.roundedRect,s.arc=wp,s.roundedRect=Tp}},optionsToObject:Do}.compose(P.Series,P.SVGElement,P.SVGRenderer),Xc.compose(P.Series.types.column),$i.compose(P.Series),bl.compose(P.Axis),Je.compose(P.SVGRenderer),ca.compose(P.Chart),wl.compose(P.Axis),Xa.compose(P.Chart),cp.compose(P.Series.types.pie),ji.compose(P.Chart,P.Axis),Gr.compose(P.Chart),Dp.compose(P.Chart),Ja.compose(P.Axis,P.Chart,P.Series),xc.compose(P.Axis,P.Chart,P.Series),Wr.compose(P.Pointer),N.extend(P,N);var Bp=P;export{Bp as default};
|