dealpos 25.44.4 → 25.45.1

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.
Files changed (429) hide show
  1. package/browser/chunk-2JU7KFOZ.js +2 -0
  2. package/browser/chunk-2QD46TNT.js +191 -0
  3. package/browser/chunk-2SM2HFRR.js +3 -0
  4. package/browser/{chunk-AJM4N35T.js → chunk-2TXCUXTF.js} +1 -1
  5. package/browser/{chunk-VHAM2DWK.js → chunk-33B62QHS.js} +1 -1
  6. package/browser/chunk-36JFFXJO.js +82 -0
  7. package/browser/{chunk-4SKJU2FQ.js → chunk-3CZ6HKSM.js} +1 -1
  8. package/browser/chunk-3IWVFLM3.js +1 -0
  9. package/browser/chunk-3LPZYQS6.js +33 -0
  10. package/browser/chunk-3MU2GNGM.js +2 -0
  11. package/browser/chunk-43CXFI4D.js +1 -0
  12. package/browser/chunk-4AUOGTXI.js +137 -0
  13. package/browser/{chunk-QUHI6RHC.js → chunk-4CFMB4IK.js} +1 -1
  14. package/browser/chunk-4JCHCMUR.js +1095 -0
  15. package/browser/chunk-4JVPFRFP.js +1 -0
  16. package/browser/chunk-4KMN7PSV.js +2 -0
  17. package/browser/chunk-4NLZJJA4.js +1 -0
  18. package/browser/chunk-4ZFVM7K7.js +1 -0
  19. package/browser/chunk-55FE5P6P.js +1 -0
  20. package/browser/{chunk-OKIBXXRJ.js → chunk-5DXDXIDO.js} +1 -1
  21. package/browser/chunk-5VUKKQUZ.js +4 -0
  22. package/browser/chunk-67UQKMLX.js +2 -0
  23. package/browser/chunk-6ASBLKNZ.js +1 -0
  24. package/browser/{chunk-6PGUQ3CR.js → chunk-6BGTH62C.js} +1 -1
  25. package/browser/chunk-6DRTZA6S.js +2 -0
  26. package/browser/chunk-6MU3ID6Q.js +507 -0
  27. package/browser/chunk-7IRMDCKA.js +2 -0
  28. package/browser/chunk-7O6Z7YZS.js +1 -0
  29. package/browser/chunk-7TEDBCUJ.js +16 -0
  30. package/browser/chunk-A4SCCZAY.js +1 -0
  31. package/browser/chunk-AASKAWJ4.js +5 -0
  32. package/browser/chunk-AMUMNTYT.js +1 -0
  33. package/browser/chunk-B235RUOX.js +1 -0
  34. package/browser/chunk-B3EZEY4B.js +1 -0
  35. package/browser/chunk-B3LNBFJF.js +1 -0
  36. package/browser/chunk-B5ORO5G4.js +1 -0
  37. package/browser/{chunk-JMQDEPZK.js → chunk-BA466YBV.js} +1 -1
  38. package/browser/{chunk-JPXXXD26.js → chunk-BG6GTLXF.js} +1 -1
  39. package/browser/chunk-BJG2UU2M.js +1 -0
  40. package/browser/{chunk-XMYLHF4C.js → chunk-BJKHMXAA.js} +1 -1
  41. package/browser/chunk-BLQKJ5OK.js +1 -0
  42. package/browser/{chunk-57Q3ENW2.js → chunk-BQAKWHPC.js} +1 -1
  43. package/browser/chunk-BRHHRJLT.js +39 -0
  44. package/browser/chunk-BZ44CISC.js +149 -0
  45. package/browser/chunk-BZVCDBQR.js +257 -0
  46. package/browser/chunk-CKGJCUHW.js +1 -0
  47. package/browser/chunk-CRLFATTL.js +1 -0
  48. package/browser/chunk-D5RACD33.js +4 -0
  49. package/browser/{chunk-7VKFVS7K.js → chunk-DB3W42KN.js} +1 -1
  50. package/browser/{chunk-MO4GVGHJ.js → chunk-DC5TNUBW.js} +1 -1
  51. package/browser/{chunk-WEQFFBAF.js → chunk-DELGLVJJ.js} +1 -1
  52. package/browser/chunk-DV6Z7FPV.js +22 -0
  53. package/browser/chunk-E2XUBZDW.js +1 -0
  54. package/browser/chunk-E424AX7J.js +1 -0
  55. package/browser/chunk-E4GYCB3G.js +4 -0
  56. package/browser/chunk-EAXUIPR5.js +1 -0
  57. package/browser/chunk-EBHLJ7D3.js +18 -0
  58. package/browser/chunk-EGUIWOC3.js +14 -0
  59. package/browser/{chunk-6774R2EL.js → chunk-EHXTW46H.js} +6 -6
  60. package/browser/chunk-EIH377TR.js +2 -0
  61. package/browser/{chunk-RKCLO5OA.js → chunk-ELTC3POX.js} +1 -1
  62. package/browser/chunk-EOJJS4LU.js +334 -0
  63. package/browser/{chunk-APF7PDRI.js → chunk-EPINEYFX.js} +1 -1
  64. package/browser/chunk-EQLHPWVB.js +1 -0
  65. package/browser/chunk-ETTSYVEZ.js +2 -0
  66. package/browser/{chunk-YZHVQD5P.js → chunk-F7EO5OHI.js} +1 -1
  67. package/browser/chunk-FADT3LJL.js +663 -0
  68. package/browser/chunk-FDH4S2DG.js +1 -0
  69. package/browser/chunk-FFOK3ZNC.js +1 -0
  70. package/browser/{chunk-MPCAKU6Y.js → chunk-FPO73IWN.js} +1 -1
  71. package/browser/chunk-FQTHN2D5.js +1 -0
  72. package/browser/{chunk-DH3PTQ3P.js → chunk-FR4CH42S.js} +1 -1
  73. package/browser/{chunk-EWZ63XSS.js → chunk-FR6L6XAP.js} +1 -1
  74. package/browser/{chunk-TLJ2NGVG.js → chunk-FV3VHB7N.js} +1 -1
  75. package/browser/chunk-G4D3XN53.js +1 -0
  76. package/browser/chunk-G7HGWSUU.js +1 -0
  77. package/browser/{chunk-SGFSKIUE.js → chunk-GDPQI6PI.js} +1 -1
  78. package/browser/chunk-GDRHD33K.js +157 -0
  79. package/browser/{chunk-5M3JINH2.js → chunk-GJIFUWGQ.js} +1 -1
  80. package/browser/{chunk-AEHOR4RJ.js → chunk-GWL7ZN37.js} +1 -1
  81. package/browser/{chunk-A3JFNOMC.js → chunk-GYYMO4YR.js} +1 -1
  82. package/browser/chunk-H3RJALHH.js +1 -0
  83. package/browser/chunk-HDJJJAZJ.js +1 -0
  84. package/browser/chunk-HK2NKWCI.js +1 -0
  85. package/browser/{chunk-OXQJYOVG.js → chunk-HMKM466S.js} +1 -1
  86. package/browser/chunk-HPPKFGND.js +1 -0
  87. package/browser/{chunk-J4HLBSTR.js → chunk-HQWW3C2M.js} +1 -1
  88. package/browser/chunk-HVRLWPZX.js +1 -0
  89. package/browser/{chunk-TSIYPTYI.js → chunk-HYXSN2J6.js} +1 -1
  90. package/browser/chunk-I24HJLN4.js +5 -0
  91. package/browser/chunk-I26CNUBY.js +376 -0
  92. package/browser/chunk-I4WJ5CEN.js +5 -0
  93. package/browser/chunk-IBZF5QXJ.js +1 -0
  94. package/browser/chunk-ICDZ6ZG2.js +1 -0
  95. package/browser/chunk-IFARYZIK.js +1 -0
  96. package/browser/chunk-IGHHLZWC.js +149 -0
  97. package/browser/{chunk-RDMLIBMG.js → chunk-IKJNYXIS.js} +1 -1
  98. package/browser/chunk-IMM7CUI7.js +14 -0
  99. package/browser/{chunk-UWGTJ4UH.js → chunk-IR75FMI5.js} +1 -1
  100. package/browser/chunk-ISY4SDFY.js +5 -0
  101. package/browser/chunk-IVBM4Y3J.js +1 -0
  102. package/browser/chunk-IVR7R22T.js +24 -0
  103. package/browser/chunk-IZQ5FNXP.js +1 -0
  104. package/browser/chunk-J5FCCS76.js +1 -0
  105. package/browser/{chunk-B5VF422M.js → chunk-JGYO4OTZ.js} +1 -1
  106. package/browser/chunk-JKBJ3O3G.js +5 -0
  107. package/browser/chunk-JRM47ALM.js +1 -0
  108. package/browser/chunk-JRP5O56W.js +1 -0
  109. package/browser/chunk-JTRNQBXF.js +1 -0
  110. package/browser/{chunk-GKFPNF3O.js → chunk-JTTRYU4G.js} +1 -1
  111. package/browser/{chunk-Z2LCSWV4.js → chunk-JXHHT6R2.js} +1 -1
  112. package/browser/{chunk-DAIHPIA2.js → chunk-JXXEYFN7.js} +1 -1
  113. package/browser/chunk-KFDGG6IE.js +1 -0
  114. package/browser/chunk-KFUPP33B.js +92 -0
  115. package/browser/chunk-KLZBTT2P.js +1 -0
  116. package/browser/chunk-KMIXT3V6.js +209 -0
  117. package/browser/chunk-KMYTSO3Q.js +1 -0
  118. package/browser/chunk-KNQEOPID.js +1 -0
  119. package/browser/{chunk-7IDMO3VZ.js → chunk-KPZU3ZPZ.js} +1 -1
  120. package/browser/chunk-KQXOXN6S.js +57 -0
  121. package/browser/{chunk-S4Z6ZYZ4.js → chunk-KWDQGODG.js} +1 -1
  122. package/browser/chunk-L5HF7UAT.js +2 -0
  123. package/browser/chunk-LAQMHKSP.js +1 -0
  124. package/browser/{chunk-XA6BOS45.js → chunk-LDDG4GE7.js} +1 -1
  125. package/browser/{chunk-K7KRPIN7.js → chunk-LFHXGZHT.js} +1 -1
  126. package/browser/chunk-LJMHI6I5.js +1 -0
  127. package/browser/chunk-LKKENA2L.js +1 -0
  128. package/browser/{chunk-42T2PR4J.js → chunk-LODGW3WU.js} +1 -1
  129. package/browser/chunk-LP2YX47Z.js +1 -0
  130. package/browser/{chunk-PDDA2XEV.js → chunk-M6SFCHJQ.js} +1 -1
  131. package/browser/chunk-MFHN36L5.js +1 -0
  132. package/browser/chunk-MNZLKEWQ.js +118 -0
  133. package/browser/chunk-MOLMIGZ2.js +1 -0
  134. package/browser/chunk-MREFZR3I.js +5 -0
  135. package/browser/chunk-MTU6753J.js +1 -0
  136. package/browser/chunk-NBMH5YL2.css +1 -0
  137. package/browser/chunk-NCT5IK4R.js +1 -0
  138. package/browser/chunk-NGRJ35NF.js +1 -0
  139. package/browser/chunk-NJB3X4XL.js +1 -0
  140. package/browser/chunk-NNONJUQ3.js +1 -0
  141. package/browser/chunk-NSNUUKNK.js +1 -0
  142. package/browser/chunk-O4IQZBVW.js +9 -0
  143. package/browser/chunk-O4SFEWMN.js +2 -0
  144. package/browser/chunk-OGN6JWED.js +1 -0
  145. package/browser/chunk-OJ5SEYSF.js +1 -0
  146. package/browser/{chunk-NSXJCO22.js → chunk-OMKIT3Z4.js} +1 -1
  147. package/browser/chunk-OND3CFSL.js +1 -0
  148. package/browser/chunk-OTIPYKW7.js +1 -0
  149. package/browser/{chunk-YNDNTAII.js → chunk-OTT6RJHI.js} +1 -1
  150. package/browser/{chunk-WDQ4UKKY.js → chunk-OYO4SRAO.js} +1 -1
  151. package/browser/{chunk-MBJ5EVQM.js → chunk-OZGLZGND.js} +1 -1
  152. package/browser/chunk-P2CKEL54.js +1 -0
  153. package/browser/{chunk-OYSMMJMB.js → chunk-P2FSLJ4X.js} +1 -1
  154. package/browser/{chunk-TSEZZNO5.js → chunk-PCAFUCUK.js} +1 -1
  155. package/browser/chunk-PIYVELLT.js +1 -0
  156. package/browser/chunk-PLVOH67J.js +1 -0
  157. package/browser/chunk-PQ65IMRY.js +3 -0
  158. package/browser/chunk-PQFMYP23.js +1 -0
  159. package/browser/chunk-PQS3RLPI.js +1 -0
  160. package/browser/{chunk-C2KD7R6L.js → chunk-PROSYUA2.js} +1 -1
  161. package/browser/chunk-PTQCXOVM.js +1 -0
  162. package/browser/chunk-PUXE7FLT.js +1 -0
  163. package/browser/chunk-PXKNGMLL.js +1 -0
  164. package/browser/chunk-PXOXHTNI.js +6 -0
  165. package/browser/chunk-PYATA4SM.js +1 -0
  166. package/browser/chunk-Q7YUJXQP.js +1 -0
  167. package/browser/chunk-QCCKEP2R.js +1 -0
  168. package/browser/chunk-QGYIPOLS.js +7 -0
  169. package/browser/chunk-QHWRBSOD.js +1 -0
  170. package/browser/chunk-QMFA3PF5.js +1 -0
  171. package/browser/chunk-QUAMZZS6.js +1 -0
  172. package/browser/{chunk-QHRP323Q.js → chunk-RCC5SUNH.js} +1 -1
  173. package/browser/chunk-RFVQHGYD.js +112 -0
  174. package/browser/chunk-RMIJZMA5.js +480 -0
  175. package/browser/chunk-RNEU5YBN.js +1 -0
  176. package/browser/chunk-RO5PWDCR.js +3 -0
  177. package/browser/{chunk-O2QTP22K.js → chunk-RPJIPLQS.js} +2 -2
  178. package/browser/{chunk-MK4KDIMG.js → chunk-RRYYS272.js} +1 -1
  179. package/browser/chunk-RVKNSR2K.js +2 -0
  180. package/browser/chunk-S4ZRXSPZ.js +1 -0
  181. package/browser/chunk-SA67OWFV.js +1 -0
  182. package/browser/chunk-SGSOCLV7.js +21 -0
  183. package/browser/chunk-SH3T5X7H.js +152 -0
  184. package/browser/chunk-SNAKHGZS.js +1 -0
  185. package/browser/chunk-SXPVIX36.js +1 -0
  186. package/browser/chunk-SYMXIBEB.js +1 -0
  187. package/browser/chunk-THGBNMLF.js +1 -0
  188. package/browser/chunk-TIGG24TH.js +311 -0
  189. package/browser/chunk-TMQ7NWGZ.js +1 -0
  190. package/browser/chunk-TNZMSOM3.js +2 -0
  191. package/browser/{chunk-7ENDP7TZ.js → chunk-TPKU52VV.js} +1 -1
  192. package/browser/chunk-TR5NO2CB.js +1 -0
  193. package/browser/chunk-TS6CZC3J.js +1 -0
  194. package/browser/chunk-TX6ZFPHY.js +90 -0
  195. package/browser/{chunk-DK2SUVKT.js → chunk-TYUL4J6N.js} +1 -1
  196. package/browser/{chunk-WO3LDDSF.js → chunk-U3EOEZ3B.js} +1 -1
  197. package/browser/chunk-U3WVC6SN.js +1 -0
  198. package/browser/chunk-U5HTULBC.js +1 -0
  199. package/browser/chunk-UAOWLJEF.js +2 -0
  200. package/browser/chunk-UEMKVZMR.js +3 -0
  201. package/browser/chunk-UH2PJXPG.js +3 -0
  202. package/browser/chunk-UP2UDOTJ.js +1 -0
  203. package/browser/chunk-UPC37DMP.js +1 -0
  204. package/browser/chunk-V432I4ZE.js +21 -0
  205. package/browser/{chunk-AGTR6PKD.js → chunk-V6MKE6LP.js} +1 -1
  206. package/browser/{chunk-FTRVMNGV.js → chunk-V75YVSP3.js} +1 -1
  207. package/browser/chunk-V7HBROQ5.js +54 -0
  208. package/browser/{chunk-NMR7EZWC.js → chunk-VCQBS5CA.js} +1 -1
  209. package/browser/chunk-VO3NT5EH.js +1 -0
  210. package/browser/chunk-VPBOQNZA.js +131 -0
  211. package/browser/chunk-VQBUIUJC.js +2 -0
  212. package/browser/chunk-VS3RTXZC.js +5 -0
  213. package/browser/chunk-VVB7545X.js +1 -0
  214. package/browser/chunk-W6PT2SCS.js +1 -0
  215. package/browser/{chunk-AER2U57P.js → chunk-WAAJYULE.js} +1 -1
  216. package/browser/chunk-WACBOZDR.js +3 -0
  217. package/browser/chunk-WAXYETAG.js +151 -0
  218. package/browser/chunk-WFMAM73Y.js +1 -0
  219. package/browser/{chunk-XZR3IMWZ.js → chunk-WKB7BKHN.js} +1 -1
  220. package/browser/chunk-WQNTJH2X.js +1 -0
  221. package/browser/chunk-X6MBRJTG.js +3 -0
  222. package/browser/chunk-XIXREDEB.js +2 -0
  223. package/browser/chunk-XTMUP2BA.js +2 -0
  224. package/browser/chunk-XWWKCPZS.js +1 -0
  225. package/browser/chunk-XXNLATCJ.js +1 -0
  226. package/browser/chunk-XZFHDKIK.js +1 -0
  227. package/browser/chunk-XZXNHGZ2.js +1 -0
  228. package/browser/chunk-Y6JQWF34.js +315 -0
  229. package/browser/chunk-YL6HCV6T.js +11 -0
  230. package/browser/chunk-YMVBGQ2W.js +1 -0
  231. package/browser/chunk-YQ5GJPDB.js +1 -0
  232. package/browser/chunk-YTOGQOIP.js +1 -0
  233. package/browser/{chunk-4JM455M6.js → chunk-YXNBLVK4.js} +1 -1
  234. package/browser/chunk-YY3636UT.js +1 -0
  235. package/browser/chunk-YZP4FX7D.js +15 -0
  236. package/browser/chunk-ZGSYDQBM.js +1 -0
  237. package/browser/chunk-ZRHYTE5S.js +1 -0
  238. package/browser/index.html +2 -2
  239. package/browser/main-WPNH2WGQ.css +1 -0
  240. package/browser/main-WVCGTGWV.js +3 -0
  241. package/browser/polyfills-KVI7ACYJ.js +2 -0
  242. package/browser/scripts-Z64TTWXD.js +10 -0
  243. package/browser/styles-J6LGFNKV.css +1 -0
  244. package/package.json +1 -1
  245. package/browser/chunk-23PJKOTU.js +0 -108
  246. package/browser/chunk-2CXL6IDS.js +0 -947
  247. package/browser/chunk-2GALXGGK.js +0 -16
  248. package/browser/chunk-2HLP4RJY.js +0 -2
  249. package/browser/chunk-2OWHEMAL.js +0 -671
  250. package/browser/chunk-2YDEXJE5.js +0 -2
  251. package/browser/chunk-3AW2HE63.js +0 -1
  252. package/browser/chunk-3CUWPIMQ.js +0 -2
  253. package/browser/chunk-3GOO5E5D.js +0 -33
  254. package/browser/chunk-3LBZDIW2.js +0 -1
  255. package/browser/chunk-3YKVLHZG.js +0 -7
  256. package/browser/chunk-42NBSIMT.js +0 -449
  257. package/browser/chunk-43CYJJ7R.js +0 -1
  258. package/browser/chunk-4G344XSZ.js +0 -1
  259. package/browser/chunk-4NHG4RRM.js +0 -1
  260. package/browser/chunk-4PPRFE5H.js +0 -1
  261. package/browser/chunk-4QQTEPQT.js +0 -51
  262. package/browser/chunk-4UYZJCFI.js +0 -5
  263. package/browser/chunk-4XV2ANDU.js +0 -1
  264. package/browser/chunk-57UEET7E.js +0 -18
  265. package/browser/chunk-5FSR4IZJ.js +0 -1
  266. package/browser/chunk-5HX73JZ3.js +0 -1
  267. package/browser/chunk-5JJSLRVS.js +0 -70
  268. package/browser/chunk-5YRS6BWA.js +0 -2
  269. package/browser/chunk-6647Y35T.js +0 -3
  270. package/browser/chunk-6CWGCLY5.js +0 -3
  271. package/browser/chunk-6JAL37Y4.js +0 -93
  272. package/browser/chunk-6XO6NT6E.js +0 -231
  273. package/browser/chunk-7DCB7DB2.js +0 -1
  274. package/browser/chunk-7LEIOTZN.js +0 -22
  275. package/browser/chunk-7QWJJPNG.js +0 -1
  276. package/browser/chunk-7QZ26SB7.js +0 -1
  277. package/browser/chunk-7WKHBXTJ.js +0 -1
  278. package/browser/chunk-ABOGLWVN.js +0 -6
  279. package/browser/chunk-ALNSA73T.js +0 -1
  280. package/browser/chunk-B5SDXVDR.js +0 -1
  281. package/browser/chunk-B6LPY2IZ.js +0 -2
  282. package/browser/chunk-BBGWXLHJ.js +0 -1
  283. package/browser/chunk-BKK7PT4Q.js +0 -1
  284. package/browser/chunk-BLSJR63P.js +0 -82
  285. package/browser/chunk-BQOD2C6M.js +0 -1
  286. package/browser/chunk-BXQFYW4R.js +0 -1
  287. package/browser/chunk-BXSCBMI2.js +0 -1
  288. package/browser/chunk-C6DVD3VG.js +0 -1
  289. package/browser/chunk-CDCIW4H7.js +0 -1
  290. package/browser/chunk-CM4CUWDT.js +0 -1
  291. package/browser/chunk-CSQD5JSK.js +0 -1
  292. package/browser/chunk-CWITQVZH.js +0 -1
  293. package/browser/chunk-CXKH3Y7Q.js +0 -1
  294. package/browser/chunk-D7I2I6EI.js +0 -1
  295. package/browser/chunk-DDJ6XGOR.js +0 -1
  296. package/browser/chunk-DEBIFZGN.js +0 -1
  297. package/browser/chunk-DOYS2PZE.js +0 -3
  298. package/browser/chunk-DTFMCXRP.js +0 -1
  299. package/browser/chunk-DWZ6HNBA.js +0 -1
  300. package/browser/chunk-E4DPE3J5.js +0 -1
  301. package/browser/chunk-ECOW7JD7.js +0 -5
  302. package/browser/chunk-EDXMXTEK.js +0 -1
  303. package/browser/chunk-EEEAUYZ6.js +0 -193
  304. package/browser/chunk-EGRFS63E.js +0 -1
  305. package/browser/chunk-EIYVPVSH.js +0 -1
  306. package/browser/chunk-EKX3MMTJ.js +0 -1
  307. package/browser/chunk-ENVG4BZI.js +0 -105
  308. package/browser/chunk-EOVI4KWG.js +0 -2
  309. package/browser/chunk-ESIVNWIY.js +0 -1
  310. package/browser/chunk-ESMCBLSB.js +0 -5
  311. package/browser/chunk-EUY2EQVP.js +0 -1
  312. package/browser/chunk-EY2BEKKH.js +0 -1
  313. package/browser/chunk-FDFNWO3I.js +0 -1
  314. package/browser/chunk-FEHHVG4G.js +0 -57
  315. package/browser/chunk-FEW55RO5.js +0 -285
  316. package/browser/chunk-FIHWJAIR.js +0 -2
  317. package/browser/chunk-FKDZ5OWB.js +0 -297
  318. package/browser/chunk-FP4HFB5J.js +0 -1
  319. package/browser/chunk-FRDFUCRO.js +0 -2
  320. package/browser/chunk-G454AF6P.js +0 -1
  321. package/browser/chunk-GCBG44YQ.js +0 -1
  322. package/browser/chunk-GGOZMZWR.js +0 -1
  323. package/browser/chunk-GIDGCFLX.js +0 -5
  324. package/browser/chunk-GN6RJLLA.js +0 -1
  325. package/browser/chunk-GQO3Q75J.js +0 -1
  326. package/browser/chunk-GUURROIV.js +0 -24
  327. package/browser/chunk-H273QYYR.js +0 -1
  328. package/browser/chunk-H3OZSV6V.js +0 -11
  329. package/browser/chunk-H7F34T25.js +0 -17
  330. package/browser/chunk-HKJLMHAD.js +0 -1
  331. package/browser/chunk-HRDXDHQN.js +0 -14
  332. package/browser/chunk-HT35KHLT.js +0 -1
  333. package/browser/chunk-HWEYOOFD.js +0 -1
  334. package/browser/chunk-IQHU4MKW.js +0 -1
  335. package/browser/chunk-IYV6WHO4.js +0 -1
  336. package/browser/chunk-JLXCN2NR.js +0 -1
  337. package/browser/chunk-JOXTERIM.js +0 -2
  338. package/browser/chunk-JUYFABKK.js +0 -1
  339. package/browser/chunk-K7BQAEUZ.js +0 -1
  340. package/browser/chunk-KH3Y6E5S.js +0 -1
  341. package/browser/chunk-KHILQH3P.js +0 -1
  342. package/browser/chunk-KTCV3KOE.js +0 -30
  343. package/browser/chunk-KWTU2B2D.js +0 -1
  344. package/browser/chunk-KZDE63UL.js +0 -1
  345. package/browser/chunk-L7RHCBKX.js +0 -1
  346. package/browser/chunk-L7YSVT7G.js +0 -1
  347. package/browser/chunk-LAJ6WFQN.js +0 -1
  348. package/browser/chunk-LE3BKIDY.js +0 -15
  349. package/browser/chunk-LED2YGBL.js +0 -1
  350. package/browser/chunk-LFGL4ACG.css +0 -1
  351. package/browser/chunk-LKII7K7T.js +0 -397
  352. package/browser/chunk-LKXAGCSU.js +0 -1
  353. package/browser/chunk-LMJVRREP.js +0 -180
  354. package/browser/chunk-LQ63SW7R.js +0 -222
  355. package/browser/chunk-M3HHWYKD.js +0 -1
  356. package/browser/chunk-M4TPGDOJ.js +0 -21
  357. package/browser/chunk-MB5ABPXA.js +0 -127
  358. package/browser/chunk-MBRMFZQD.js +0 -5
  359. package/browser/chunk-MFCXEITE.js +0 -2
  360. package/browser/chunk-MJYYXEWE.js +0 -1
  361. package/browser/chunk-ML4F7QSG.js +0 -1
  362. package/browser/chunk-MPSML3FA.js +0 -1
  363. package/browser/chunk-MUJ6277G.js +0 -5
  364. package/browser/chunk-NMBTXI33.js +0 -1
  365. package/browser/chunk-NVWJ6HZD.js +0 -1
  366. package/browser/chunk-OISKO6QJ.js +0 -1
  367. package/browser/chunk-PD445FIT.js +0 -1
  368. package/browser/chunk-PIYM2FOP.js +0 -1
  369. package/browser/chunk-PKRB5QHY.js +0 -1
  370. package/browser/chunk-PMFQUQRF.js +0 -112
  371. package/browser/chunk-Q4CKRRGM.js +0 -430
  372. package/browser/chunk-QHBWVJIQ.js +0 -1
  373. package/browser/chunk-QO6OCZ2F.js +0 -4
  374. package/browser/chunk-RFO7MTFT.js +0 -2
  375. package/browser/chunk-RHUDY63D.js +0 -4
  376. package/browser/chunk-RJEOTZXL.js +0 -2
  377. package/browser/chunk-RVXZOIFQ.js +0 -1
  378. package/browser/chunk-RX7JS4CO.js +0 -1
  379. package/browser/chunk-S5QHJZP7.js +0 -3
  380. package/browser/chunk-SEFALU4U.js +0 -1
  381. package/browser/chunk-SJIRHP7T.js +0 -1
  382. package/browser/chunk-SRRURHLT.js +0 -9
  383. package/browser/chunk-SXKMJUZG.js +0 -1
  384. package/browser/chunk-T4LU2Z4H.js +0 -1
  385. package/browser/chunk-TAVO3B4U.js +0 -1
  386. package/browser/chunk-U6TUYK6J.js +0 -1
  387. package/browser/chunk-UBWKI2NL.js +0 -158
  388. package/browser/chunk-UGRZNVJI.js +0 -1
  389. package/browser/chunk-UO2JNN6O.js +0 -3
  390. package/browser/chunk-UTP22HZJ.js +0 -1
  391. package/browser/chunk-UXRO4UFY.js +0 -8
  392. package/browser/chunk-V2LFW5D3.js +0 -1
  393. package/browser/chunk-V3Y7QS6E.js +0 -140
  394. package/browser/chunk-V7UEUV6F.js +0 -2
  395. package/browser/chunk-VFTGIP5A.js +0 -78
  396. package/browser/chunk-VHLIFXL2.js +0 -1
  397. package/browser/chunk-VK6JMOTL.js +0 -1
  398. package/browser/chunk-VPQTKMSG.js +0 -1
  399. package/browser/chunk-VQBXUZ6U.js +0 -2
  400. package/browser/chunk-VTUDAX3L.js +0 -2
  401. package/browser/chunk-VZEPVRCY.js +0 -5
  402. package/browser/chunk-WEZJHAOW.js +0 -1
  403. package/browser/chunk-WOQG2RJS.js +0 -1
  404. package/browser/chunk-WTXHMI64.js +0 -3
  405. package/browser/chunk-WXQELZWQ.js +0 -1
  406. package/browser/chunk-XBRBYCWJ.js +0 -2
  407. package/browser/chunk-XJ7SOVB2.js +0 -2
  408. package/browser/chunk-XKUQPHUA.js +0 -1
  409. package/browser/chunk-XM2Q4S3I.js +0 -1
  410. package/browser/chunk-XPZUZ5XJ.js +0 -1
  411. package/browser/chunk-XQOLOZQF.js +0 -1
  412. package/browser/chunk-XYB3YDKL.js +0 -2
  413. package/browser/chunk-XZELBTQR.js +0 -94
  414. package/browser/chunk-Y75LR4GR.js +0 -1
  415. package/browser/chunk-YAFVFDTG.js +0 -156
  416. package/browser/chunk-YEDKRNXU.js +0 -1
  417. package/browser/chunk-YPHODEQB.js +0 -141
  418. package/browser/chunk-YRGGDRUH.js +0 -25
  419. package/browser/chunk-YTS3IROV.js +0 -178
  420. package/browser/chunk-ZB4A4IBA.js +0 -1
  421. package/browser/chunk-ZHY3BUQJ.js +0 -3
  422. package/browser/chunk-ZVDY66SR.js +0 -1
  423. package/browser/chunk-ZZGSAFGO.js +0 -1
  424. package/browser/chunk-ZZYILM3B.js +0 -1
  425. package/browser/main-CNAQ374V.js +0 -3
  426. package/browser/main-YYIZ54AR.css +0 -1
  427. package/browser/polyfills-22A7LMHG.js +0 -2
  428. package/browser/scripts-3E2G6IZ4.js +0 -10
  429. package/browser/styles-NK7HCBOK.css +0 -1
@@ -0,0 +1,2 @@
1
+ import{a as Lt,b as Te}from"./chunk-SNAKHGZS.js";var qs,Ks,_s,Js,Qs,to,eo,io,so,oo,ro,ao,no,ho,lo,co,po,go,X,re,Io,Do,Bo,No,zo,Ro,ii,uo,Ki,si;(X=qs||(qs={})).SVG_NS="http://www.w3.org/2000/svg",X.product="Highcharts",X.version="12.2.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=qs,{charts:cn,doc:Wi,win:te}=P;function Ze(h,t,e,i){let s=t?"Highcharts error":"Highcharts warning";h===32&&(h=`${s}: Deprecated member`);let o=mo(h),r=o?`${s} #${h}: www.highcharts.com/errors/${h}/`:h.toString();if(i!==void 0){let a="";o&&(r+="?"),ee(i,function(n,l){a+=`
2
+ - ${l}: ${n}`,o&&(r+=encodeURI(l)+"="+encodeURI(n))}),r+=a}Fa(P,"displayError",{chart:e,code:h,message:r,params:i},function(){if(t)throw Error(r);te.console&&Ze.messages.indexOf(r)===-1&&console.warn(r)}),Ze.messages.push(r)}function Wo(h,t){return parseInt(h,t||10)}function qe(h){return typeof h=="string"}function Xi(h){let t=Object.prototype.toString.call(h);return t==="[object Array]"||t==="[object Array Iterator]"}function fe(h,t){return!!h&&typeof h=="object"&&(!t||!Xi(h))}function fo(h){return fe(h)&&typeof h.nodeType=="number"}function Xo(h){let t=h?.constructor;return!!(fe(h,!0)&&!fo(h)&&t?.name&&t.name!=="Object")}function mo(h){return typeof h=="number"&&!isNaN(h)&&h<1/0&&h>-1/0}function me(h){return h!=null}function Ha(h,t,e){let i,s=qe(t)&&!me(e),o=(r,a)=>{me(r)?h.setAttribute(a,r):s?(i=h.getAttribute(a))||a!=="class"||(i=h.getAttribute(a+"Name")):h.removeAttribute(a)};return qe(t)?o(e,t):ee(t,o),i}function Ho(h){return Xi(h)?h:[h]}function be(h,t){let e;for(e in h||(h={}),t)h[e]=t[e];return h}function Ce(){let h=arguments,t=h.length;for(let e=0;e<t;e++){let i=h[e];if(i!=null)return i}}function _i(h,t){be(h.style,t)}function Fo(h){return Math.pow(10,Math.floor(Math.log(h)/Math.LN10))}function Yo(h,t){return h>1e14?h:parseFloat(h.toPrecision(t||14))}(Ze||(Ze={})).messages=[],Math.easeInOutSine=function(h){return-.5*(Math.cos(Math.PI*h)-1)};var pn=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 ee(h,t,e){for(let i in h)Object.hasOwnProperty.call(h,i)&&t.call(e||h[i],h[i],i,h)}function Go(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,ee(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 Fa(h,t,e,i){if(e=e||{},Wi?.createEvent&&(h.dispatchEvent||h.fireEvent&&h!==P)){let s=Wi.createEvent("Events");s.initEvent(t,!0,!0),e=be(s,e),h.dispatchEvent?h.dispatchEvent(e):h.fireEvent(t,e)}else if(h.hcEvents){e.target||be(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 gn=(function(){let h=Math.random().toString(36).substring(2,9)+"-",t=0;return function(){return"highcharts-"+(uo?"":h)+t++}})();te.jQuery&&(te.jQuery.fn.highcharts=function(){let h=[].slice.call(arguments);if(this[0])return h[0]?(new P[qe(h[0])?h.shift():"Chart"](this[0],h[0],h[1]),this):cn[Ha(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(){Go(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:Ha,clamp:function(h,t,e){return h>t?h<e?h:e:t},clearTimeout:function(h){me(h)&&clearTimeout(h)},correctFloat:Yo,createElement:function(h,t,e,i,s){let o=Wi.createElement(h);return t&&be(o,t),s&&_i(o,{padding:"0",border:"none",margin:"0"}),e&&_i(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:_i,defined:me,destroyObjectProperties:function(h,t,e){ee(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;ee(r,function(d,p){if(!l&&i&&i.indexOf(p)>-1&&a[p]){d=Ho(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 fe(d,!0)&&!d.nodeType?(n[p]=Xi(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:Ze,extend:be,extendClass:function(h,t){let e=function(){};return e.prototype=new h,be(e.prototype,t),e},find:pn,fireEvent:Fa,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:Fo,getNestedProperty:function(h,t){let e=h.split(".");for(;e.length&&me(t);){let i=e.shift();if(i===void 0||i==="__proto__")return;if(i==="this"){let o;return fe(t)&&(o=t["@this"]),o??t}let s=t[i.replace(/[\\'"]/g,"")];if(!me(s)||typeof s=="function"||typeof s.nodeType=="number"||s===te)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=te.getComputedStyle(t,void 0);return o&&(s=o.getPropertyValue(e),Ce(i,e!=="opacity")&&(s=Wo(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]||mo(i)&&i<Ce(t[e].options.index,t[e]._i)||t[e].options.isInternal){t.splice(e,0,h);break}return e},isArray:Xi,isClass:Xo,isDOMElement:fo,isFunction:function(h){return typeof h=="function"},isNumber:mo,isObject:fe,isString:qe,merge:function(h,...t){let e,i=[h,...t],s={},o=function(a,n){return typeof a!="object"&&(a={}),ee(n,function(l,c){c!=="__proto__"&&c!=="constructor"&&(!fe(l,!0)||Xo(l)||fo(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=Ce(e,Fo(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 Yo(r*e,-Math.round(Math.log(.001)/Math.LN10))},objectEach:ee,offset:function(h){let t=Wi.documentElement,e=h.parentElement||h.parentNode?h.getBoundingClientRect():{top:0,left:0,width:0,height:0};return{top:e.top+(te.pageYOffset||t.scrollTop)-(t.clientTop||0),left:e.left+(te.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:Ce,pInt:Wo,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:Go,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:Ho,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 qe(h)?h.substring(0,1).toUpperCase()+h.substring(1):String(h)},uniqueKey:gn,useSerialIds:function(h){return uo=Ce(h,uo)},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:un,win:Hi}=P,{defined:jo,error:Uo,extend:Ji,isNumber:Vo,isObject:Qi,isString:Ae,merge:fn,objectEach:mn,pad:Nt,splat:xn,timeUnits:ts,ucfirst:yn}=N,bn=P.isSafari&&Hi.Intl&&!Hi.Intl.DateTimeFormat.prototype.formatRange,vn=h=>h.main===void 0,kn=class{constructor(h,t){this.options={timezone:"UTC"},this.variableTimezone=!1,this.Date=Hi.Date,this.update(h),this.lang=t}update(h={}){this.dTLCache={},this.options=h=fn(!0,this.options,h);let{timezoneOffset:t,useUTC:e}=h;this.Date=h.Date||Hi.Date||Date;let i=h.timezone;jo(e)&&(i=e?"UTC":void 0),t&&t%60==0&&(i="Etc/GMT"+(t>0?"+":"")+t/60),this.variableTimezone=i!=="UTC"&&i?.indexOf("Etc/GMT")!==0,this.timezone=i,["months","shortMonths","weekdays","shortWeekdays"].forEach(s=>{let o=/months/i.test(s),r=/short/.test(s),a={timeZone:"UTC"};a[o?"month":"weekday"]=r?"short":"long",this[s]=(o?[0,1,2,3,4,5,6,7,8,9,10,11]:[3,4,5,6,7,8,9]).map(n=>this.dateFormat(a,(o?31:1)*24*36e5*n))})}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||un){let i=JSON.stringify(h)+e;Ae(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)?(Uo(34),h.timeZone="UTC",s=new Intl.DateTimeFormat(e,h)):Uo(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&&Ji(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)||bn||(a-=36e5)}}return a}parse(h){if(!Ae(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(Vo(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=-(36e5*(i+o/60));if(Vo(r))return r}return 0}dateFormat(h,t,e){let i=this.lang;if(!jo(t)||isNaN(t))return i?.invalidDate||"";if(Ae(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(Ae(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,f=i?.months||this.months,x=i?.shortMonths||this.shortMonths;mn(Ji({a:u?u[p]:g[p].substr(0,3),A:g[p],d:Nt(a),e:Nt(a,2," "),w:p,v:i?.weekFrom??"",b:x[r],B:f[r],m:Nt(r+1),o:r+1,y:o.toString().substr(2,2),Y:o,H:Nt(n),k:n,I:Nt(n%12||12),l:n%12||12,M:Nt(l),p:n<12?"AM":"PM",P:n<12?"am":"pm",S:Nt(c),L:Nt(d,3)},P.dateFormats),function(m,y){if(Ae(h))for(;h.indexOf("%"+y)!==-1;)h=h.replace("%"+y,typeof m=="function"?m.call(s,t):m)})}else if(Qi(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(Ji({timeZone:o},h),t)+a}return e?yn(h):h}resolveDTLFormat(h){return Qi(h,!0)?Qi(h,!0)&&vn(h)?{main:h}:h:{main:(h=xn(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 ts){if(h&&h===ts.week&&+this.dateFormat("%w",t)===e&&s.substr(6)===o.substr(6)){a="week";break}if(h&&ts[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:$o,extend:wn,timeUnits:et}=N,Po=class extends kn{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),f=(t||0)%1e3,x;if(i??(i=1),$o(t)){if(f=n>=et.second?0:a*Math.floor(f/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,f));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,f),s.variableTimezone&&$o(e)&&(x=e-t>4*et.month||s.getTimezoneOffset(t)!==s.getTimezoneOffset(e));let m=t,y=1;for(;m<e;)o.push(m),n===et.year?m=s.makeTime(l+y*a,0):n===et.month?m=s.makeTime(l,c+y*a):x&&(n===et.day||n===et.week)?m=s.makeTime(l,c,d+y*a*(n===et.day?1:7)):x&&n===et.hour&&a>1?m=s.makeTime(l,c,d,p+y*a):m+=n*a,y++;o.push(m),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=wn(h,{higherRanks:r,totalRange:n*a}),o}},{isTouchDevice:Mn}=P,{fireEvent:Sn,merge:Tn}=N,It={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:{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:Mn?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"}},es=new Po(It.time,It.lang),yt={defaultOptions:It,defaultTime:es,getOptions:function(){return It},setOptions:function(h){return Sn(P,"setOptions",{options:h}),Tn(!0,It,h),h.time&&es.update(It.time),h.lang&&"locale"in h.lang&&es.update({locale:h.lang.locale}),h.lang?.chartTitle&&(It.title=Te(Lt({},It.title),{text:h.lang.chartTitle})),It}},{win:Cn}=P,{isNumber:Pe,isString:An,merge:Pn,pInt:ct,defined:Zo}=N,qo=(h,t,e)=>`color-mix(in srgb,${h},${t} ${100*e}%)`,is=h=>An(h)&&!!h&&h!=="none",dt=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=Pn(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&&Pe(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(Pe(t)&&t!==0)if(Pe(e[0]))for(let i=0;i<3;i++)e[i]+=ct(255*t),e[i]<0&&(e[i]=0),e[i]>255&&(e[i]=255);else h.useColorMix&&is(this.input)&&(this.output=qo(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(!Pe(i[0])||!Pe(s[0]))return h.useColorMix&&is(this.input)&&is(t.input)&&e<.99?qo(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(",")+")"}};dt.names={white:"#ffffff",black:"#000000"},dt.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[ct(h[1]),ct(h[2]),ct(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[ct(h[1]),ct(h[2]),ct(h[3]),1]}},{regex:/^#([a-f0-9])([a-f0-9])([a-f0-9])([a-f0-9])?$/i,parse:function(h){return[ct(h[1]+h[1],16),ct(h[2]+h[2],16),ct(h[3]+h[3],16),Zo(h[4])?ct(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[ct(h[1],16),ct(h[2],16),ct(h[3],16),Zo(h[4])?ct(h[4],16)/255:1]}}],dt.useColorMix=Cn.CSS?.supports("color","color-mix(in srgb,red,blue 9%)"),dt.None=new dt("");var{parse:Ko}=dt,{win:Ln}=P,{isNumber:ss,objectEach:On}=N,ie=(()=>{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];ss(p)&&ss(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=Ln.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,On(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,f=i?.slice();if(!f||c)return[a,a];function x(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 m(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}if(o[0]===r[r.length-o.length+g]){d=g,u=!0;break}if(o[o.length-1]===r[r.length-o.length+g]){d=o.length-g;break}}d===void 0&&(f=[])}return f.length&&ss(d)&&(p=a.length+d*l,u?(x(f,a),m(a)):(x(a,f),m(f))),[f,a]}fillSetter(){h.prototype.strokeSetter.apply(this,arguments)}strokeSetter(){this.elem.attr(this.prop,Ko(this.start).tweenTo(Ko(this.end),this.pos),void 0,!0)}}return h.timers=[],h})(),{defined:En,getStyle:In,isArray:Dn,isNumber:Bn,isObject:xo,merge:Ya,objectEach:Nn,pick:zn}=N;function os(h){return xo(h)?Ya({duration:500,defer:0},h):{duration:500*!!h,defer:0}}function _o(h,t){let e=ie.timers.length;for(;e--;)ie.timers[e].elem!==h||t&&t!==ie.timers[e].prop||(ie.timers[e].stopped=!0)}var nt={animate:function(h,t,e){let i,s="",o,r,a;xo(e)||(a=arguments,e={duration:a[2],easing:a[3],complete:a[4]}),Bn(e.duration)||(e.duration=400),e.easing=typeof e.easing=="function"?e.easing:Math[e.easing]||Math.easeInOutSine,e.curAnim=Ya(t),Nn(t,function(n,l){_o(h,l),r=new ie(h,e,l),o=void 0,l==="d"&&Dn(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(In(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:os,getDeferredAnimation:function(h,t,e){let i=os(t),s=e?[e]:h.series,o=0,r=0;return s.forEach(a=>{let n=os(a.options.animation);o=xo(t)&&En(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=zn(h,t.options.chart.animation,!0)},stop:_o},{SVG_NS:Jo,win:Rn}=P,{attr:Wn,createElement:Xn,css:Hn,error:Qo,isFunction:Fn,isString:tr,objectEach:er,splat:Yn}=N,{trustedTypes:rs}=Rn,Fi=rs&&Fn(rs.createPolicy)&&rs.createPolicy("highcharts",{createHTML:h=>h}),Gn=Fi?Fi.createHTML(""):"",ot=class h{static filterUserAttributes(t){return er(t,(e,i)=>{let s=!0;h.allowedAttributes.indexOf(i)===-1&&(s=!1),["background","dynsrc","href","lowsrc","src"].indexOf(i)!==-1&&(s=tr(e)&&h.allowedReferences.some(o=>e.indexOf(o)===0)),s||(Qo(33,!1,void 0,{"Invalid attribute in config":`${i}`}),delete t[i]),tr(e)&&t[i]&&(t[i]=e.replace(/</g,"&lt;"))}),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 Yn(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"?Jo:s.namespaceURI||Jo,p=P.doc.createElementNS(d,n),g=r.attributes||{};er(r,function(u,f){f!=="tagName"&&f!=="attributes"&&f!=="children"&&f!=="style"&&f!=="textContent"&&(g[f]=u)}),Wn(p,c?g:h.filterUserAttributes(g)),r.style&&Hn(p,r.style),l&&p.appendChild(l),e(r.children||[],p),a=p}else Qo(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(Fi?Fi.createHTML(t):t,"text/html")}catch{}if(!e){let o=Xn("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","dx","dy","disabled","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","role","scope","slope","src","startOffset","stdDeviation","stroke","stroke-linecap","stroke-width","style","tableValues","result","rowspan","summary","target","tabindex","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=["a","abbr","b","br","button","caption","circle","clipPath","code","dd","defs","div","dl","dt","em","feComponentTransfer","feComposite","feDropShadow","feFlood","feFuncA","feFuncB","feFuncG","feFuncR","feGaussianBlur","feMorphology","feOffset","feMerge","feMergeNode","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","text","textPath","thead","title","tbody","tspan","td","th","tr","u","ul","#text"],ot.emptyHTML=Gn,ot.bypassHTMLFiltering=!1;var{defaultOptions:Ga,defaultTime:ja}=yt,{pageLang:jn}=P,{extend:Un,getNestedProperty:Vn,isArray:$n,isNumber:ir,isObject:Zn,isString:qn,pick:Kn,ucfirst:_n}=N,Di={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)=>Yi(t.body,Un(Zn(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:_n,unless:h=>!h},sr={},or=h=>/^["'].+["']$/.test(h);function Yi(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||Ga.lang,l=e?.time||ja,c=e?.numberFormatter||Ua,d=(x="")=>{let m;return x==="true"||x!=="false"&&((m=Number(x)).toString()===x?m:or(x)?x.slice(1,-1):Vn(x,t))},p,g,u=0,f;for(;(p=i.exec(h))!==null;){let x=p,m=s.exec(p[1]);m&&(p=m,f=!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?x:p)[1].split(" ")[0].replace("#","");Di[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(m&&!g?.isBlock)break}return o.forEach(x=>{let m,y,{body:b,elseBody:v,expression:S,fn:w}=x;if(w){let k=[x],M=[],T=S.length,C=0,A;for(y=0;y<=T;y++){let L=S.charAt(y);A||L!=='"'&&L!=="'"?A===L&&(A=""):A=L,A||L!==" "&&y!==T||(M.push(S.substr(C,y-C)),C=y+1)}for(y=Di[w].length;y--;)k.unshift(d(M[y+1]));m=Di[w].apply(t,k),x.isBlock&&typeof m=="boolean"&&(m=Yi(m?b:v,t,e))}else{let k=or(S)?[S]:S.split(":");if(m=d(k.shift()||""),k.length&&typeof m=="number"){let M=k.join(":");if(r.test(M)){let T=parseInt((M.match(a)||["","-1"])[1],10);m!==null&&(m=c(m,T,n.decimalPoint,M.indexOf(",")>-1?n.thousandsSep:""))}else m=l.dateFormat(M,m)}s.lastIndex=0,s.test(x.find)&&qn(m)&&(m=`"${m}"`)}h=h.replace(x.find,Kn(m,""))}),f?Yi(h,t,e):h}function Ua(h,t,e,i){t*=1;let s,o,[r,a]=(h=+h||0).toString().split("e").map(Number),n=this?.options?.lang||Ga.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):ir(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),ir(t)&&t>=0&&(d.minimumFractionDigits=t,d.maximumFractionDigits=t),i===""&&(d.useGrouping=!1);let p=i||e,g=p?"en":this?.locale||n.locale||jn,u=JSON.stringify(d)+g;return s=(sr[u]??(sr[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 bt={dateFormat:function(h,t,e){return ja.dateFormat(h,t,e)},format:Yi,helpers:Di,numberFormat:Ua};(re=Ks||(Ks={})).rendererTypes={},re.getRendererType=function(h=si){return re.rendererTypes[h]||re.rendererTypes[si]},re.registerRendererType=function(h,t,e){re.rendererTypes[h]=t,(!si||e)&&(si=h,P.Renderer=t)};var ei=Ks,{clamp:Jn,pick:Qn,pushUnique:th,stableSort:as}=N;(_s||(_s={})).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,f,x,m=0,y;for(d=n;d--;)m+=t[d].size;if(m>o){for(as(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&&m>o;)f=t[d=Math.floor(p)],th(l,d)&&(m-=f.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(as(t,r),t=t.map(b=>({size:b.size,targets:[b.target],align:Qn(b.align,.5)}));u;){for(d=t.length;d--;)f=t[d],x=(Math.min.apply(0,f.targets)+Math.max.apply(0,f.targets))/2,f.pos=Jn(x-f.size*f.align,0,e-f.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)))}),as(s,r),s};var Zi=_s,{animate:eh,animObject:ih,stop:rr}=nt,{deg2rad:ar,doc:ae,svg:sh,SVG_NS:oi,win:oh,isFirefox:rh}=P,{addEvent:ah,attr:ns,createElement:nh,crisp:ri,css:nr,defined:wt,erase:hh,extend:Le,fireEvent:hs,getAlignFactor:ls,isArray:hr,isFunction:lr,isNumber:lh,isObject:dh,isString:dr,merge:ds,objectEach:ne,pick:Ot,pInt:ai,pushUnique:ch,replaceNested:ph,syncTimeout:gh,uniqueKey:cr}=N,at=class h{_defaultGetter(t){let e=Ot(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||dr(i)?i||"renderer":void 0;n&&(a&&ch(r,this),i=void 0);let l=Ot(i,o[n],o),c=(l.x||0)+(t.x||0)+((l.width||0)-(t.width||0))*ls(t.align),d=(l.y||0)+(t.y||0)+((l.height||0)-(t.height||0))*ls(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=ih(Ot(e,this.renderer.globalAnimation,!0)),o=s.defer;return ae.hidden&&(s.duration=0),s.duration!==0?(i&&(s.complete=i),gh(()=>{this.element&&eh(this,t,s)},o)):(this.attr(t,void 0,i||s.complete),ne(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=ae.createElementNS(oi,"tspan");ns(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=ae.createElementNS(oi,"tspan");l.textContent="\u200B",ns(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):(ne(t,function(d,p){c=!1,s||rr(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=cr()+"-",i=this.renderer.createElement("clipPath").attr({id:e}).add(this.renderer.defs);Le(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 Le(t,{x:a,y:n,width:ri(o,e)-a,height:ri(r,e)-n}),wt(t.strokeWidth)&&(t.strokeWidth=e),t}complexColor(t,e,i){let s=this.renderer,o,r,a,n,l,c,d,p,g,u,f=[],x;hs(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,hr(a)&&(t[r]=a={x1:a[0],y1:a[1],x2:a[2],y2:a[3],gradientUnits:"userSpaceOnUse"}),r==="radialGradient"&&g&&!wt(a.gradientUnits)&&(n=a,a=ds(a,s.getRadialAttr(g,n),{gradientUnits:"userSpaceOnUse"})),ne(a,function(m,y){y!=="id"&&f.push(y,m)}),ne(c,function(m){f.push(m)}),l[f=f.join(",")])u=l[f].attr("id");else{a.id=u=cr();let m=l[f]=s.createElement(r).attr(a).add(s.defs);m.radAttr=n,m.stops=[],c.forEach(function(y){y[1].indexOf("rgba")===0?(d=(o=dt.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(m);m.stops.push(b)})}x="url("+s.url+"#"+u+")",i.setAttribute(e,x),i.gradient=f,t.toString=function(){return x}}})}css(t){let e=this.styles,i={},s=this.element,o,r=!e;if(e&&ne(t,function(a,n){e&&e[n]!==a&&(i[n]=a,r=!0)}),r){e&&(t=Le(e,i)),t.width===null||t.width==="auto"?delete this.textWidth:s.nodeName.toLowerCase()==="text"&&t.width&&(o=this.textWidth=ai(t.width)),Le(this.styles,t),o&&!sh&&this.renderer.forExport&&delete t.width;let a=rh&&t.fontSize||null;a&&(lh(a)||/^\d+$/.test(a))&&(t.fontSize+="px");let n=ds(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)),nr(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])*Ot(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,rr(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&&hh(i.alignedObjects,t),ne(t,(n,l)=>{(t[l]?.parentGroup===t||["connector","foreignObject"].indexOf(l)!==-1)&&t[l]?.destroy?.(),delete t[l]})}dSetter(t,e,i){hr(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,f=Ot(e,this.rotation,0),x=l.styledMode?n&&h.prototype.getStyle.call(n,"font-size"):c.fontSize;if(wt(d)&&((r=d.toString()).indexOf("<")===-1&&(r=r.replace(/\d/g,"0")),r+=["",l.rootFontSize,x,f,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&&nr(b,{display:y})},lr(o)&&o("none"),i=n.getBBox?Le({},n.getBBox()):{width:n.offsetWidth,height:n.offsetHeight,x:0,y:0},lr(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}[`${x||""},${Math.round(s)}`]||s),f&&(i=this.getRotatedBox(i,f));let m={bBox:i};hs(this,"afterGetBBox",m),i=m.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=ls(a),p=Number(this.element.getAttribute("y")||0)-(n?0:s),g=e*ar,u=(e-90)*ar,f=Math.cos(g),x=Math.sin(g),m=o*f,y=o*x,b=Math.cos(u),v=Math.sin(u),[[S,w],[k,M]]=[l,c].map(R=>[R-R*f,R*x]),T=i+d*(o-m)+S+M+p*b,C=T+m,A=C-r*b,L=A-m,O=s+p-d*y-w+k+p*v,I=O+y,D=I-r*v,E=D-y,B=Math.min(T,C,A,L),q=Math.min(O,I,D,E),Y=Math.max(T,C,A,L)-B,ht=Math.max(O,I,D,E)-q;return{x:B,y:q,width:Y,height:ht,polygon:[[T,O],[C,I],[A,D],[L,E]]}}getStyle(t){return oh.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"?nh(e):ae.createElementNS(this.SVG_NS,e),this.renderer=t,this.styles={},hs(this,"afterInit")}on(t,e){let{onEvents:i}=this;return i[t]&&i[t](),i[t]=ah(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(dr(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=ds(this.parentGroup?.rotation===90?{offsetX:-1,offsetY:-1}:{},dh(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!==""&&(ns(i=ae.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]=Ot(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]||ae.createElementNS(this.SVG_NS,"title");e.insertBefore?e.insertBefore(i,e.firstChild):e.appendChild(i),i.textContent=ph(Ot(t,""),[/<[^>]*>/g,""]).replace(/&lt;/g,"<").replace(/&gt;/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+")"];wt(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})),(wt(l)||wt(c))&&u.push("scale("+Ot(l,1)+" "+Ot(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(wt(t)?(r.setAttribute("data-z-index",t),t*=1,this[e]===t&&(g=!1)):wt(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=!wt(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&&(!wt(t)||t>=0))&&(o.insertBefore(r,n[u+1]),d=!0));d||(o.insertBefore(r,n[3*!!a]),d=!0)}return d}};at.symbolCustomAttribs=["anchorX","anchorY","clockwise","end","height","innerR","r","start","width","x","y"],at.prototype.strokeSetter=at.prototype.fillSetter,at.prototype.yGetter=at.prototype.xGetter,at.prototype.matrixSetter=at.prototype.rotationOriginXSetter=at.prototype.rotationOriginYSetter=at.prototype.rotationSetter=at.prototype.scaleXSetter=at.prototype.scaleYSetter=at.prototype.translateXSetter=at.prototype.translateYSetter=at.prototype.verticalAlignSetter=function(h,t){this[t]=h,this.doTransform=!0};var Pt=at,{defined:pr,extend:uh,getAlignFactor:gr,isNumber:Oe,merge:fh,pick:ni,removeEvent:ur}=N,Ke=class h extends Pt{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=gr(t);this.textAlign=t,e!==this.alignFactor&&(this.alignFactor=e,this.bBox&&Oe(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=fh(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 Pt.prototype.css.call(this,t)}destroy(){ur(this.element,"mouseenter"),ur(this.element,"mouseleave"),this.text&&this.text.destroy(),this.box&&(this.box=this.box.destroy()),Pt.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&&pr(this.anchorX)&&this.attr({anchorX:this.anchorX,anchorY:this.anchorY})}paddingSetter(t,e){Oe(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=(!Oe(this.widthSetting)||!Oe(this.heightSetting)||this.textAlign)&&pr(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(uh(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)+gr(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=Oe(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.xSetting=Math.round(t),this.attr("translateX",this.xSetting)}ySetter(t){this.ySetting=this.y=Math.round(t),this.attr("translateY",this.ySetting)}};Ke.emptyBBox={width:0,height:0,x:0,y:0},Ke.textProps=["color","direction","fontFamily","fontSize","fontStyle","fontWeight","lineClamp","lineHeight","textAlign","textDecoration","textOutline","textOverflow","whiteSpace","width"];var{defined:fr,isNumber:mh,pick:Ee}=N;function mr(h,t,e,i,s){let o=[];if(s){let r=s.start||0,a=s.end||0,n=Ee(s.r,e),l=Ee(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=Ee(s.open,d),u=Math.cos(r),f=Math.sin(r),x=Math.cos(a),m=Math.sin(a),y=Ee(s.longArc,a-r-Math.PI<c?0:1),b=["A",n,l,0,y,Ee(s.clockwise,1),h+n*x,t+l*m];b.params={start:r,end:a,cx:h,cy:t},o.push(["M",h+n*u,t+l*f],b),fr(p)&&((b=["A",p,p,0,y,fr(s.clockwise)?1-s.clockwise:0,h+p*u,t+p*f]).params={start:a,end:r,cx:h,cy:t},o.push(g?["M",h+p*x,t+p*m]:["L",h+p*x,t+p*m],b)),g||o.push(["Z"])}return o}function xr(h,t,e,i,s){return s?.r?yo(h,t,e,i,s):[["M",h,t],["L",h+e,t],["L",h+e,t+i],["L",h,t+i],["Z"]]}function yo(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 Va={arc:mr,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=yo(h,t,e,i,{r:o});if(!mh(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 mr(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:xr,roundedRect:yo,square:xr,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:cs,SVG_NS:xh,win:yr}=P,{attr:ps,extend:yh,fireEvent:bh,isString:vh,objectEach:kh,pick:wh}=N,gs=(h,t)=>h.substring(0,t)+"\u2026",Mh=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=wh(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||"",["&lt;","&gt;"])),r&&r.removeChild(t)}}else t.appendChild(cs.createTextNode(this.unescapeEntities(i)));vh(this.textOutline)&&h.applyTextOutline&&h.applyTextOutline(this.textOutline)}}modifyDOM(){let h,t=this.svgElement,e=ps(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)),ps(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 f=[],x=[];for(;a.firstChild&&a.firstChild!==r;)x.push(a.firstChild),a.removeChild(a.firstChild);for(;l.length;)if(l.length&&!this.noWrap&&g>0&&(f.push(r.textContent||""),r.textContent=l.join(" ").replace(/- /g,"-")),this.truncate(r,void 0,l,g===0&&u||0,i,p,(m,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,gs),r.textContent=r.textContent?.replace("\u2026","")+"\u2026");break}x.forEach(m=>{a.insertBefore(m,r)}),f.forEach(m=>{a.insertBefore(cs.createTextNode(m),r);let y=cs.createElementNS(xh,"tspan");y.textContent="\u200B",ps(y,{dy:d,x:e}),a.insertBefore(y,r)})}else this.ellipsis&&n&&this.truncate(r,n,void 0,0,i,p,gs)},o=r=>{[].slice.call(r.childNodes).forEach(a=>{a.nodeType===yr.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===yr.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"),yh(e,{attributes:s,style:r}),o&&o.filter(l=>l.tagName!=="#text").forEach(t)};h.forEach(t),bh(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 f=function(x,m){let y=m||x,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=f(h.textContent.length))>s){for(;p<=g;)u=Math.ceil((p+g)/2),e&&(a=r(e,u)),n=f(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,gs)}e&&e.splice(0,u),l.actualWidth=n,l.rotation=c}unescapeEntities(h,t){return kh(this.renderer.escapes,function(e,i){t&&t.indexOf(e)!==-1||(h=h.toString().replace(RegExp(e,"g"),i))}),h}},{defaultOptions:Sh}=yt,{charts:Th,deg2rad:br,doc:he,isFirefox:vr,isMS:kr,isWebKit:Ch,noop:Ah,SVG_NS:Ph,symbolSizes:us,win:fs}=P,{addEvent:hi,attr:li,createElement:Lh,crisp:wr,css:di,defined:$t,destroyObjectProperties:Oh,extend:Jt,isArray:Eh,isNumber:le,isObject:Ie,isString:Ih,merge:ms,pick:xs,pInt:Dh,replaceNested:Bh,uniqueKey:Nh}=N,we=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(he.createTextNode("Created with Highcharts 12.2.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),vr&&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(fs,"resize",n))}definition(t){return new ot([t]).addToDOM(this.defs.element)}getReferenceURL(){if((vr||Ch)&&he.getElementsByTagName("base").length){if(!$t(Ki)){let t=Nh(),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(he.body);di(e,{position:"fixed",top:0,left:0,zIndex:9e5}),Ki=he.elementFromPoint(6,6)?.id==="hitme",he.body.removeChild(e)}if(Ki)return Bh(fs.location.href.split("#")[0],[/<[^>]*>/g,""],[/([\('\)])/g,"\\$1"],[/ /g,"%20"])}return""}getStyle(t){return this.style=Jt({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(),Oh(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=ms({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 Mh(t).buildSVG()}getContrast(t){let e=dt.parse(t).rgba,i=" clamp(0,calc(9e9*(0.5 - (0.2126*r + 0.7152*g + 0.0722*b))),1)";if(le(e[0])||!dt.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=ms(Sh.global.buttonTheme,o),p&&(delete o.fill,delete o.stroke,delete o["stroke-width"]);let f=o.states||{},x=o.style||{};delete o.states,delete o.style;let m=[ot.filterUserAttributes(o)],y=[x];return p||["hover","select","disabled"].forEach((b,v)=>{m.push(ms(m[0],ot.filterUserAttributes(g[v+5]||f[b]||{}))),y.push(m[v+1].style),delete m[v+1].style}),hi(d.element,kr?"mouseover":"mouseenter",function(){u!==3&&d.setState(1)}),hi(d.element,kr?"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(m[b]);let v=y[b];Ie(v)&&d.css(v)}},d.attr(m[0]),!p&&(d.css(Jt({cursor:"default"},x)),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 $t(i[1])&&i[1]===s[1]&&(i[1]=s[1]=wr(i[1],e)),$t(i[2])&&i[2]===s[2]&&(i[2]=s[2]=wr(i[2],e)),t}path(t){let e=this.styledMode?{}:{fill:"none"};return Eh(t)?e.d=t:Ie(t)&&Jt(e,t),this.createElement("path").attr(e)}circle(t,e,i){let s=Ie(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;Ie(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=Ie(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,Jt(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:xs(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"};le(e)&&(a.x=e),le(i)&&(a.y=i),le(s)&&(a.width=s),le(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 fs.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"),f=u&&this.symbols[u];if(f)typeof e=="number"&&(n=f.call(this.symbols,e||0,i||0,s||0,o||0,r)),a=this.path(n),d.styledMode||a.attr("fill","none"),Jt(a,{symbolName:u||void 0,x:e,y:i,width:s,height:o}),r&&Jt(a,r);else if(g){l=t.match(p)[1];let x=a=this.image(l);x.imgwidth=xs(r?.width,us[l]?.width),x.imgheight=xs(r?.height,us[l]?.height),c=m=>m.attr({width:m.width,height:m.height}),["width","height"].forEach(m=>{x[`${m}Setter`]=function(y,b){this[b]=y;let{alignByTranslate:v,element:S,width:w,height:k,imgwidth:M,imgheight:T}=this,C=b==="width"?M:T,A=1;r&&r.backgroundSize==="within"&&w&&k&&M&&T?(A=Math.min(w/M,k/T),li(S,{width:Math.round(M*A),height:Math.round(T*A)})):S&&C&&S.setAttribute(b,C),!v&&M&&T&&this.translate(((w||0)-M*A)/2,((k||0)-T*A)/2)}}),$t(e)&&x.attr({x:e,y:i}),x.isImg=!0,x.symbolUrl=t,$t(x.imgwidth)&&$t(x.imgheight)?c(x):(x.attr({width:0,height:0}),Lh("img",{onload:function(){let m=Th[d.chartIndex];this.width===0&&(di(this,{position:"absolute",top:"-999em"}),he.body.appendChild(this)),us[l]={width:this.width,height:this.height},x.imgwidth=this.width,x.imgheight=this.height,x.element&&c(x),this.parentNode&&this.parentNode.removeChild(this),d.imgCount--,d.imgCount||!m||m.hasLoaded||m.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)),$t(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=Dh(Pt.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*br),4)),{x:-t/3*Math.sin(e*br),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++)Ih(i[0])&&le(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 Ke(this,t,e,i,s,o,r,a,n,l)}alignElements(){this.alignedObjects.forEach(t=>t.align())}};Jt(we.prototype,{Element:Pt,SVG_NS:Ph,escapes:{"&":"&amp;","<":"&lt;",">":"&gt;","'":"&#39;",'"':"&quot;"},symbols:Va,draw:Ah}),ei.registerRendererType("svg",we,!0);var{composed:zh,isFirefox:Rh}=P,{attr:Wh,css:zt,createElement:Xh,defined:Mr,extend:Hh,getAlignFactor:Fh,isNumber:ci,pInt:Yh,pushUnique:Gh}=N;function $a(h,t,e){let i=this.div?.style||e.style;Pt.prototype[`${t}Setter`].call(this,h,t,e),i&&(i[t]=h)}var jh=(h,t)=>{if(!h.div){let e=Wh(h.element,"class"),i=h.css,s=Xh("div",e?{className:e}:void 0,Te(Lt({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.opacitySetter=h.visibilitySetter=$a,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 Pt.prototype.on.apply({element:s,onEvents:h.onEvents},arguments),h},h.div=s}return h.div},_e=class h extends Pt{static compose(t){Gh(zh,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(Lt({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=Yh(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"),Hh(this.styles,t),zt(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:f=0,x=0,y:m=0}=this;if(e||zt(t,{marginLeft:`${u}px`,marginTop:`${f}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:(zt(t,{width:"",whiteSpace:d||"nowrap"}),t.offsetWidth),T=g||0,C=t.style.textOverflow===""&&t.style.webkitLineClamp;(T>i||M>T||C)&&(/[\-\s\u00AD]/.test(t.textContent||t.innerText)||t.style.textOverflow==="ellipsis")&&(zt(t,{width:(o||n||M>T||C)&&ci(g)?g+"px":"auto",display:c,whiteSpace:d||"normal"}),this.oldTextWidth=g)}e&&(zt(t,{display:"inline-block",verticalAlign:"top"}),e.attr({width:s.width,height:s.height})),b!==this.cTT&&(y=s.fontMetrics(t).b,Mr(o)&&!e&&(o!==(this.oldRotation||0)||p!==this.oldAlign)&&zt(t,{transform:`rotate(${o}deg)`,transformOrigin:`${v}% ${v}px`}),this.getSpanCorrection(!Mr(o)&&!this.textWidth&&this.textPxLength||t.offsetWidth,y,Fh(p)));let{xCorr:S=0,yCorr:w=0}=this,k={left:`${x+S}px`,top:`${m+w}px`,textAlign:p,transformOrigin:`${(r??x)-S-x-v}px ${(a??m)-w-m-v}px`};(n||l)&&(k.transform=`scale(${n??1},${l??1})`),e?(super.updateTransform(),ci(x)&&ci(m)?(e.attr({x:x+S,y:m+w,width:t.offsetWidth+3,height:t.offsetHeight,"transform-origin":t.getAttribute("transform-origin")||"0 0"}),zt(t,{display:c,textAlign:p})):Rh&&e.attr({width:0,height:0})):zt(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=jh(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}},Zt=_e.prototype;Zt.visibilitySetter=Zt.opacitySetter=$a,Zt.ySetter=Zt.rotationSetter=Zt.rotationOriginXSetter=Zt.rotationOriginYSetter=Zt.xSetter,(Io=Js||(Js={})).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"},Io.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 Uh=Js,{addEvent:Vh,isFunction:$h,objectEach:Zh,removeEvent:qh}=N;(Qs||(Qs={})).registerEventOptions=function(h,t){h.eventOptions=h.eventOptions||{},Zh(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,Vh(h,i,e,{order:0})))})};var qi=Qs,{deg2rad:ys}=P,{clamp:Kh,correctFloat:pi,defined:bs,destroyObjectProperties:_h,extend:Sr,fireEvent:De,getAlignFactor:Jh,isNumber:gi,merge:Qh,objectEach:tl,pick:Mt}=N,xe=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,De(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=Mt(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,f,x,m,y=this.parameters.category||(s?Mt(s[a],r[a],a):a);o&&gi(y)&&(y=pi(o.lin2log(y))),t.dateTime&&(g?f=(x=i.time.resolveDTLFormat(e.dateTimeLabelFormats[!e.grid&&g.higherRanks[a]||g.unitName])).main:gi(y)&&(f=t.dateTime.getXDateFormat(y,e.dateTimeLabelFormats||{}))),h.isFirst=c,h.isLast=d;let b={axis:t,chart:i,dateTimeLabelFormat:f,isFirst:c,isLast:d,pos:a,tick:h,tickPositionInfo:g,value:y};De(this,"labelFormat",b);let v=k=>n.formatter?n.formatter.call(k,k):n.format?(k.text=t.defaultLabelFormatter.call(k),bt.format(n.format,k,i)):t.defaultLabelFormatter.call(k),S=v.call(b,b),w=x?.list;w?h.shortenLabel=function(){for(m=0;m<w.length;m++)if(Sr(b,{dateTimeLabelFormat:w[m]}),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),bs(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=bs(h)&&t.enabled?s.text(h,e?.x,e?.y,t.useHTML).add(i.labelGroup):void 0;return a&&(o||a.css(Qh(t.style)),a.textPxLength=a.getBBox().width,!o&&r&&a.css({whiteSpace:r})),a}destroy(){_h(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=Kh(a.y,-1e9,1e9),De(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},f=i||c.reserveSpaceDefault?0:-c.labelOffset*(c.labelAlign==="center"?.5:1),x=s.distance,m={};return n=c.side===0?e.rotation?-x:-e.getBBox().height:c.side===2?u.y+x:Math.cos(e.rotation*ys)*(u.y-e.getBBox(!1,0).height/2),bs(s.y)&&(n=c.side===0&&c.horiz?s.y+n:s.y),h=h+Mt(s.x,[0,1,0,-1][c.side]*x)+f+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)),m.x=h,m.y=Math.round(t),De(this,"afterGetLabelPosition",{pos:m,tickmarkOffset:o,index:r}),m}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=Mt(t.labelLeft,Math.min(t.pos,o[3])),a=Mt(t.labelRight,Math.max(t.isRadial?0:t.pos+t.len,s-o[1])),n=this.label,l=this.rotation,c=Jh(t.labelAlign||n.attr("align")),d=n.getBBox().width,p=t.getSlotWidth(this),g=p,u=1,f;l||e.overflow!=="justify"?l<0&&i-c*d<r?f=Math.round(i/Math.cos(l*ys)-r):l>0&&i+c*d>a&&(f=Math.round((s-i)/Math.cos(l*ys))):(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)&&(f=g)),f&&n&&(this.shortenLabel?this.shortenLabel():n.css(Sr({},{width:Math.floor(f)+"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):tl(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=Mt(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=Mt(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,De(this,"afterRender")}renderGridLine(h,t){let e=this.axis,i=e.options,s={},o=this.pos,r=this.type,a=Mt(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=Mt(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=Mt(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:el}=nt,{xAxis:Tr,yAxis:il}=Uh,{defaultOptions:bo}=yt,{registerEventOptions:sl}=qi,{deg2rad:ol}=P,{arrayMax:Cr,arrayMin:rl,clamp:vs,correctFloat:gt,defined:Z,destroyObjectProperties:al,erase:Ar,error:ks,extend:Bi,fireEvent:_,getClosestDistance:Pr,insertItem:nl,isArray:Lr,isNumber:z,isString:Or,merge:Ni,normalizeTickInterval:hl,objectEach:ui,pick:H,relativeLength:fi,removeEvent:ll,splat:dl,syncTimeout:cl}=N,Er=(h,t)=>hl(t,void 0,void 0,H(h.options.allowDecimals,t<.5||h.tickAmount!==void 0),!!h.tickAmount);Bi(bo,{xAxis:Tr,yAxis:Ni(Tr,il)});var vo=(()=>{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=Lr(a.categories)&&a.categories||(this.hasNames?[]:void 0),this.names||(this.names=[],this.names.keys={}),this.plotLinesAndBandsGroups={},this.positiveValuesOnly=!!this.logarithmic,this.isLinked=Z(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,dl(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),nl(this,e[this.coll])),e.orderItems(this.coll),this.series=this.series||[],e.inverted&&!this.isZAxis&&o&&!Z(this.reversed)&&(this.reversed=!0),this.labelRotation=z(n.rotation)?n.rotation:void 0,sl(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=Ni(i,this.coll==="yAxis"?{title:{text:this.chart.options.lang.yAxisTitle}}:{},bo[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=bo.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)),Z(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,f=0;return u||(u=n.transA),s&&(p*=-1,g=n.len),n.reversed&&(p*=-1,g-=p*(n.sector||n.len)),i?(f=(e=e*p+g-c)/u+l,d&&(f=n.lin2val(f))):(d&&(e=n.val2lin(e)),f=p*(e-l)*u+g+p*c+(z(a)?u*a:0),n.isRadial||(f=gt(f))),f}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,f,x,m,y,b;function v(w,k,M){return u!=="pass"&&(w<k||w>M)&&(u?w=vs(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){f=m=(g=vs(g=H(g,i.translate(n,void 0,void 0,a)),-1e9,1e9))+p,x=y=c-g-p,z(g)?i.horiz?(x=r,y=c-i.bottom+(i.options.isInternal?0:s.scrollablePixelsY||0),f=m=v(f,o,o+i.width)):(f=o,m=d-i.right+(s.scrollablePixelsX||0),x=y=v(x,r,r+i.height)):(b=!0,u=!1),w.path=b&&!u?void 0:s.renderer.crispLine([["M",f,x],["L",m,y]],l||1)}),S.path}getLinearTickPositions(e,i,s){let o,r,a,n=gt(Math.floor(i/e)*e),l=gt(Math.ceil(s/e)*e),c=[];if(gt(n+e)===n&&(a=20),this.single)return[i];for(o=n;o<=l&&(c.push(o),(o=gt(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=Z(e.min)||Z(e.max)||Z(e.floor)||Z(e.ceiling)?null:Math.min(5*(Pr(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=Cr(c))+a,s.parse(e.max)??r+a],l&&(d[2]=i?i.log2lin(this.dataMax):this.dataMax),(o=rl(d))-r<a&&(c[0]=o-a,c[1]=s.parse(e.min)??o-a,r=Cr(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&&Z(r)&&o.reserveSpace()&&(i=Z(i)?Math.min(i,r):r)}),s.length&&(s.sort((o,r)=>o-r),e=Pr([s]))}return e&&i?Math.min(e,i):e||i}nameToX(e){let i=Lr(this.options.categories),s=i?this.categories:this.names,o=e.options.x,r;return e.series.requireSorting=!1,Z(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,f=g.options.pointPlacement;if(a=Math.max(a,u),!e.single||o){let x=g.is("xrange")?!r:r;l=Math.max(l,x&&Or(f)?0:u/2),c=Math.max(c,x&&f==="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:f,floor:x,linkedTo:m,softMax:y,softMin:b}=c,v=z(m)&&s[this.coll]?.[m],S=c.tickPixelInterval,w=c.maxPadding,k=c.minPadding,M=0,T,C=z(c.tickInterval)&&c.tickInterval>=0?c.tickInterval:void 0,A,L,O,I;if(a||i||v||this.getTickAmount(),O=H(this.userMin,p.parse(c.min)),I=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&&ks(11,!0,s)):(d&&Z(g)&&z(o)&&z(r)&&(r>=g?(A=g,k=0):o<=g&&(L=g,w=0)),this.min=H(O,A,r),this.max=H(I,L,o)),z(this.max)&&z(this.min)&&(l&&(this.positiveValuesOnly&&!e&&0>=Math.min(this.min,H(r,this.min))&&ks(10,!0,s),this.min=gt(l.log2lin(this.min),16),this.max=gt(l.log2lin(this.max),16)),this.range&&z(r)&&(this.userMin=this.min=O=Math.max(r,this.minFromRange()||0),this.userMax=I=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=O=b),!z(this.userMax)&&z(y)&&y>this.max&&(this.max=I=y),i||this.axisPointRange||this.stacking?.usePercentage||v||!(M=this.max-this.min)||(!Z(O)&&k&&(this.min-=M*k),Z(I)||!w||(this.max+=M*w)),!z(this.userMin)&&z(x)&&(this.min=Math.max(this.min,x)),!z(this.userMax)&&z(f)&&(this.max=Math.min(this.max,f)),d&&z(r)&&z(o)){let E=g||0;!Z(O)&&this.min<E&&r>=E?this.min=c.minRange?Math.min(E,this.max-u):E:!Z(I)&&this.max>E&&o<=E&&(this.max=c.minRange?Math.max(E,this.min+u):E)}!s.polar&&this.min>this.max&&(Z(c.min)?this.max=this.min:Z(c.max)&&(this.min=this.max)),M=this.max-this.min}if(this.min!==this.max&&z(this.min)&&z(this.max)?v&&!C&&S===v.options.tickPixelInterval?this.tickInterval=C=v.tickInterval:this.tickInterval=H(C,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 E=this.min!==this.old?.min||this.max!==this.old?.max;this.series.forEach(function(B){B.forceCrop=B.forceCropping?.(),B.processData(E)}),_(this,"postProcessData",{hasExtremesChanged:E})}this.setAxisTranslation(),_(this,"initialAxisTranslation"),this.pointRange&&!C&&(this.tickInterval=Math.max(this.pointRange,this.tickInterval));let D=H(c.minTickInterval,a&&!this.series.some(E=>!E.sorted)?this.closestPointRange:0);!C&&D&&this.tickInterval<D&&(this.tickInterval=D),a||l||C||(this.tickInterval=Er(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&&Z(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],ks(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=Er(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&&Z(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=vs((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;Z(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,f,x=()=>a.push(gt(a[a.length-1]+u)),m=()=>a.unshift(gt(a[0]-u));if(z(l)&&(f=l<.5?Math.ceil(l*(n-1)):Math.floor(l*(n-1)),r.reversed&&(f=n-1-f)),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(f)&&z(e.threshold)){for(;a[f]!==d||a.length!==n||a[0]>o||a[a.length-1]<s;){for(a.length=0,a.push(e.threshold);a.length<n;)a[f]===void 0||a[f]>e.threshold?m():x();if(u>8*e.tickInterval)break;u*=2}y()}else if(c<n){for(;a.length<n;)a.length%2||o===d?x():m();y()}if(Z(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=Bi(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?gt(e.lin2log(this.min)):this.min,max:e?gt(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=gt(.8*this.labelMetrics().h),l=Math.max(this.max-this.min,0),c=function(f){let x=(f+2*i)/(r||1);return(x=x>1?Math.ceil(x):1)*o>l&&f!==1/0&&r!==1/0&&l&&(x=Math.ceil(l/o)),gt(x*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 f,x;for(let m of u)(m===a||m&&m>=-90&&m<=90)&&(x=(f=c(Math.abs(n/Math.sin(ol*m))))+Math.abs(m/360))<g&&(g=x,p=m,d=f)}}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(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,f=g??(Math.floor(this.len/(s.length*p.h))||1),x=0;Or(r.rotation)||(d.rotation=r.rotation||0),s.forEach(function(m){let y=o[m];y.movedLabel&&y.replaceMovedLabel();let b=y.label?.textPxLength||0;b>x&&(x=b)}),this.maxLabelLength=x,this.autoRotation?x>c&&x>p.h?d.rotation=this.labelRotation:this.labelRotation=0:l&&(u=c),d.rotation&&(u=x>.5*e.chartHeight?.33*e.chartHeight:x,g||(f=1)),this.labelAlign=r.align||this.autoLabelAlign(this.labelRotation),this.labelAlign&&(d.align=this.labelAlign),s.forEach(function(m){let y=o[m],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(Bi(S,{width:`${u}px`,lineClamp:f})):!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&&Z(this.min)&&Z(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(Ni(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 xe(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),f=i.axisOffset,x=i.clipOffset,m=[-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,C){T.destroy(),delete a[C]}),p?.text&&p.enabled!==!1&&(e.addTitle(y),y&&!u&&p.reserveSpace!==!1&&(e.titleOffset=b=e.axisTitle.getBBox()[s?"height":"width"],S=Z(v=p.offset)?0:H(p.margin,s?5:10))),e.renderLine(),e.offset=m*H(o.offset,f[r]?f[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+=m*(s?H(g.y,e.tickRotCorr.y+m*g.distance):H(g.x,m*g.distance))),e.axisTitleMargin=H(v,k),e.getMaxLabelDimensions&&(e.maxLabelDimensions=e.getMaxLabelDimensions(a,n)),l!=="colorAxis"&&x){let T=this.tickSize("tick");f[r]=Math.max(f[r],(e.axisTitleMargin||0)+b+m*e.offset,k,n?.length&&T?T[0]+m*e.offset:0);let C=!e.axisLine||o.offset?0:e.axisLine.strokeWidth()/2;x[c]=Math.max(x[c],C)}_(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,f={low:n+(i?0:r),middle:n+r/2,high:n+(i?r:0)}[a.align],x=(i?o+this.height:s)+(i?1:-1)*(l?-1:1)*(this.axisTitleMargin||0)+[-u,u,g.f,-u][this.side],m={x:i?f+d:x+(l?this.width:0)+c+d,y:i?x+p-(l?this.height:0)+c:f+p};return _(this,"afterGetTitlePosition",{titlePosition:m}),m}renderMinorTick(e,i){let s=this.minorTicks;s[e]||(s[e]=new xe(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 xe(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,f=n.stackLabels,x=n.alternateGridColor,m=n.crossing,y=s.tickmarkOffset,b=s.axisLine,v=s.showAxis,S=el(a.globalAnimation);if(s.labelEdge.length=0,s.overlap=!1,[p,g,u].forEach(function(w){ui(w,function(k){k.isActive=!1})}),z(m)){let w=this.isXAxis?o.yAxis[0]:o.xAxis[0],k=[1,-1,-1,1][this.side];if(w){let M=w.toPixels(m,!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 xe(s,-1,null,!0)),p[-1].render(-1))),x&&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:x,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,C){T.isActive||(T.render(C,!1,0),T.isActive=!1,k.push(C))}),cl(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),f?.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||ll(i),[i.ticks,i.minorTicks,i.alternateBands].forEach(function(r){al(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&&(Z(i)||!o)!==!1){if(o?Z(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),Z(n)&&(d={value:i&&(this.isXAxis?i.x:H(i.stackY,i.y)),translatedValue:n},r.polar&&Bi(d,{isCrosshair:!0,chartX:e?.chartX,chartY:e?.chartY,point:i}),a=this.getPlotLinePath(d)||null),!Z(a)){this.hideCrosshair();return}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?dt.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=Ni(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);Ar(i.axes,this),Ar(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:pl,getMagnitude:gl,normalizeTickInterval:ul,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,pl(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=ul(o/l,c,n[0]==="year"?Math.max(gl(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})(to||(to={}));var fl=to,{addEvent:Ir,normalizeTickInterval:ml,pick:xl}=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"),Ir(s,"afterSetType",t),Ir(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,f,x,m,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(f=0,x=g.length;f<x&&!b;f++)(m=this.log2lin(this.lin2log(u)*g[f]))>r&&(!n||y<=a)&&y!==void 0&&p.push(y),y>a&&(b=!0),y=m}else{let g=this.lin2log(r),u=this.lin2log(a),f=n?l.getMinorTickInterval():d.tickInterval,x=d.tickPixelInterval/(n?5:1),m=n?c/l.tickPositions.length:c;o=ml(o=xl(f==="auto"?null:f,this.minorAutoInterval,(u-g)*x/(m||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})(eo||(eo={}));var yl=eo,{erase:bl,extend:vl,isNumber:Dr}=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,f=!Dr(this.min)||!Dr(this.max)||l<this.min&&c<this.min||l>this.max&&c>this.max,x=this.getPlotLinePath({value:l,force:!0,acrossPanes:d.acrossPanes}),m,y=1,b;if(x&&p)for(f&&(b=x.toString()===p.toString(),y=0),m=0;m<x.length;m+=2){let v=x[m],S=x[m+1],w=p[m],k=p[m+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&&bl(u,u[g])})}}function n(l){this.removePlotBandOrLine(l)}h.compose=function(l,c){let d=c.prototype;return d.addPlotBand||(t=l,vl(d,{addPlotBand:e,addPlotLine:s,addPlotBandOrLine:i,getPlotBandPath:o,removePlotBand:r,removePlotLine:n,removePlotBandOrLine:a})),c}})(io||(io={}));var kl=io,{addEvent:wl,arrayMax:Br,arrayMin:Nr,defined:St,destroyObjectProperties:Ml,erase:Sl,fireEvent:Tl,merge:zr,objectEach:Cl,pick:Al}=N,Gi=class h{static compose(t,e){return wl(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})}),kl.compose(h,e)}constructor(t,e){this.axis=t,this.options=e,this.id=e.id}render(){Tl(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,f=e.label,{label:x,svgElem:m}=this,y=[],b,v=St(p)&&St(d),S=St(g),w=!m,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"]=Al(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()),m||(this.svgElem=m=n.path().attr(k).add(b)),St(g))y=t.getPlotLinePath({value:s?.log2lin(g)??g,lineWidth:m.strokeWidth(),acrossPanes:e.acrossPanes});else{if(!(St(p)&&St(d)))return;y=t.getPlotBandPath(s?.log2lin(p)??p,s?.log2lin(d)??d,e)}return!this.eventsAdded&&r&&(Cl(r,(T,C)=>{m?.on(C,A=>{r[C].apply(this,[A])})}),this.eventsAdded=!0),(w||!m.d)&&y?.length?m.attr({d:y}):m&&(y?(m.show(),m.animate({d:y})):m.d&&(m.hide(),x&&(this.label=x=x.destroy()))),f&&(St(f.text)||St(f.formatter))&&y?.length&&t.width>0&&t.height>0&&!y.isFlat?(f=zr(Lt({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}:{}),f),this.renderLabel(f,y,v,a)):x&&x.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(zr({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=Nr(l),p=Nr(c),g=Br(l)-d;n.align(t,!1,{x:d,y:p,width:g,height:Br(c)-p}),n.alignAttr.y-=r.fontMetrics(n).b,(!n.alignValue||n.alignValue==="left"||St(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 St(t.formatter)?t.formatter.call(this):t.text}destroy(){Sl(this.axis.plotLinesAndBands,this),delete this.axis,Ml(this)}},{animObject:Pl}=nt,{format:Rr}=bt,{composed:Ll,dateFormats:Ol,doc:Wr,isSafari:El}=P,{distribute:Il}=Zi,{addEvent:Dl,clamp:de,css:Xr,discardElement:Bl,extend:Nl,fireEvent:Hr,getAlignFactor:Fr,isArray:zl,isNumber:Rl,isObject:Wl,isString:ws,merge:Xl,pick:ce,pushUnique:Hl,splat:Ms,syncTimeout:Fl}=N,Je=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||Ms(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(),Bl(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=Ms(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 l=0,c=0;t.forEach(function(d){let p=d.pos(!0);p&&(l+=p[0],c+=p[1])}),l/=t.length,c/=t.length,this.shared&&t.length>1&&e&&(r?l=e.chartX:c=e.chartY),i=[l-n,c-a]}return i.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-"+ce(t.colorIndex,o.colorIndex),r?.className].filter(ws).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=ei.getRendererType();this.container=a=P.doc.createElement("div"),a.className="highcharts-tooltip-container "+(l.renderTo.className.match(/(highcharts[a-zA-Z0-9-]+)\s?/gm)||""),Xr(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}=Wr,{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={},f=n&&i.h||0,{height:x,width:m}=this.getPlayingField(),y=a.getChartPosition(),b=D=>D*y.scaleX,v=D=>D*y.scaleY,S=D=>{let E=D==="x";return[D,E?m:x,E?t:e].concat(r?[E?b(t):v(e),E?y.left-s+b(p+l):y.top-s+v(g+c),0,E?m:x]:[E?t:e,E?p+l:g+c,E?l:c,E?l+o.plotWidth:c+o.plotHeight])},w=S("y"),k=S("x"),M,T=!!i.negative;!d&&o.hoverSeries?.yAxis?.reversed&&(T=!T);let C=!this.followPointer&&ce(i.ttBelow,!d&&!n===T),A=function(D,E,B,q,Y,ht,R){let W=r?D==="y"?v(s):b(s):s,G=(B-q)/2,F=q<Y-s,V=Y+s+q<E,$=Y-W-B+G,U=Y+W-G;if(C&&V)u[D]=U;else if(!C&&F)u[D]=$;else if(F)u[D]=Math.min(R-q,$-f<0?$:$-f);else{if(!V)return u[D]=0,!1;u[D]=Math.max(ht,U+f+B>E?U:U+f)}},L=function(D,E,B,q,Y){if(Y<s||Y>E-s)return!1;Y<B/2?u[D]=1:Y>E-q/2?u[D]=E-q-2:u[D]=Y-B/2},O=function(D){[w,k]=[k,w],M=D},I=()=>{A.apply(0,w)!==!1?L.apply(0,k)!==!1||M||(O(!0),I()):M?u.x=u.y=0:(O(!0),I())};return(n&&!d||this.len>1)&&O(),I(),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)*Fr(n.align)+n.x,y:d.y+(d.height-e)*Fr(n.verticalAlign)+(!a&&n.y||0)}}hide(t){let e=this;N.clearTimeout(this.hideTimer),t=ce(t,this.options.hideDelay),this.isHidden||(this.hideTimer=Fl(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=ce(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=Pl(!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=Ms(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=!(!zl(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],f=g[1];r&&this.allowShared&&(o.applyInactiveState(a),a.forEach(y=>y.setState("hover")),n.points=a),this.len=a.length;let x=ws(l)?Rr(l,n,i):c.call(n,this);n.points=void 0;let m=n.series;if(this.distance=ce(m.tooltipOptions.distance,16),x===!1)this.hide();else{if(this.split&&this.allowShared)this.renderSplit(x,a);else{let y=u,b=f;if(e&&o.isDirectTouch&&(y=e.chartX-i.plotLeft,b=e.chartY-i.plotTop),i.polar||m.options.clip===!1||a.some(v=>o.isDirectTouch||v.series.shouldShowTooltip(y,b))){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:x&&x.join?x.join(""):x}),this.outside&&v.attr({x:de(v.x||0,0,this.getPlayingField().width-(v.width||0)-1)}),d||v.attr({stroke:s.borderColor||n.color||m.color||"#666666"}),this.updatePosition({plotX:u,plotY:f,negative:n.negative,ttBelow:n.ttBelow,series:m,h:g[2]||0})}else{this.hide();return}}this.isHidden&&this.label&&this.label.attr({opacity:1}).show(),this.isHidden=!1}Hr(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:f,position:x,positioner:m},pointer:y}=i,{scrollLeft:b=0,scrollTop:v=0}=s.scrollablePlotArea?.scrollingContainer||{},S=i.outside&&typeof d!="number"?Wr.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:C}=y.getChartPosition(),A=m||f,L=l+v,O=0,I=a-c,D=function(R,W,G,F=[0,0],V=!0){let $,U;if(G.isHeader)U=M?0:I,$=de(F[0]-R/2,S.left,S.right-R-(i.outside?T:0));else if(f&&G){let K=i.getFixedPosition(R,W,G);$=K.x,U=K.y-L}else U=F[1]-L,$=de($=V?F[0]-R-g:F[0]+g,V?$:S.left,S.right);return{x:$,y:U}};ws(t)&&(t=[!1,t]);let E=t.slice(0,e.length+1).reduce(function(R,W,G){if(W!==!1&&W!==""){let F=e[G-1]||{isHeader:!0,plotX:e[0].plotX,plotY:a,series:{}},V=F.isHeader,$=V?i:F.series,U=$.tt=(function(se,ft,Me){let Bt=se,{isHeader:Vt,series:Se}=ft,vt=Se.tooltipOptions||u;if(!Bt){let oe={padding:vt.padding,r:vt.borderRadius};p||(oe.fill=vt.backgroundColor,oe["stroke-width"]=vt.borderWidth??(f&&!Vt?0:1)),Bt=k.label("",0,0,vt[Vt?"headerShape":"shape"]||(f&&!Vt?"rect":"callout"),void 0,void 0,vt.useHTML).addClass(i.getClassName(ft,!0,Vt)).attr(oe).add(w)}return Bt.isActive=!0,Bt.attr({text:Me}),p||Bt.css(vt.style).attr({stroke:vt.borderColor||ft.color||Se.color||"#333333"}),Bt})($.tt,F,W.toString()),K=U.getBBox(),lt=K.width+U.strokeWidth();V&&(O=K.height,I+=O,M&&(L-=O));let{anchorX:pt,anchorY:Dt}=(function(se){let ft,Me,{isHeader:Bt,plotX:Vt=0,plotY:Se=0,series:vt}=se;if(Bt)ft=Math.max(n+Vt,n),Me=l+a/2;else{let{xAxis:oe,yAxis:Eo}=vt;ft=oe.pos+de(Vt,-g,oe.len+g),vt.shouldShowTooltip(0,Eo.pos-l+Se,{ignoreX:!0})&&(Me=Eo.pos+Se)}return{anchorX:ft=de(ft,S.left-g,S.right+g),anchorY:Me}})(F);if(typeof Dt=="number"){let se=K.height+1,ft=(m||D).call(i,lt,se,F,[pt,Dt]);R.push({align:A?0:void 0,anchorX:pt,anchorY:Dt,boxWidth:lt,point:F,rank:ce(ft.rank,+!!V),size:se,target:ft.y,tt:U,x:ft.x})}else U.isActive=!1}return R},[]);!A&&E.some(R=>{let{outside:W}=i,G=(W?T:0)+R.anchorX;return G<S.left&&G+R.boxWidth<S.right||G<T-S.left+R.boxWidth&&S.right-G>G})&&(E=E.map(R=>{let{x:W,y:G}=D.call(this,R.boxWidth,R.size,R.point,[R.anchorX,R.anchorY],!1);return Nl(R,{target:G,x:W})})),i.cleanSplit(),Il(E,I);let B={left:T,right:T};E.forEach(function(R){let{x:W,boxWidth:G,isHeader:F}=R;!F&&(i.outside&&T+W<B.left&&(B.left=T+W),!F&&i.outside&&B.left+G>B.right&&(B.right=T+W))}),E.forEach(function(R){let{x:W,anchorX:G,anchorY:F,pos:V,point:{isHeader:$}}=R,U={visibility:V===void 0?"hidden":"inherit",x:W,y:(V||0)+L+(f&&x.y||0),anchorX:G,anchorY:F};if(i.outside&&W<G){let K=T-B.left;K>0&&($||(U.x=W+K,U.anchorX=G+K),$&&(U.x=(B.right-B.left)/2,U.anchorX=G+K))}R.tt.attr(U)});let{container:q,outside:Y,renderer:ht}=i;if(Y&&q&&ht){let{width:R,height:W,x:G,y:F}=w.getBBox();ht.setSize(R+G,W+F,!1),q.style.left=B.left+"px",q.style.top=C+"px"}El&&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 Hr(this,"headerFormatter",a,function(c){if(r&&!n&&Rl(t.key)&&(n=r.getXDateFormat(t.key,s.dateTimeLabelFormats)),r&&n){if(Wl(n)){let d=n;Ol[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=Rr(l,t,this.chart)}),a.text||""}update(t){this.destroy(),this.init(this.chart,Xl(!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:f}=r.getChartPosition(),x=(d||c&&this.getFixedPosition||this.getPosition).call(this,l,n,t),m=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||{};x.x+=S+p-s,x.y+=w+g-s}v=(o.borderWidth||0)+2*s+2,a.setSize(de(l+v,0,m.documentElement.clientWidth)-1,n+v,!1),(u!==1||f!==1)&&(Xr(i,{transform:`scale(${u}, ${f})`}),y*=u,b*=f),y+=p-x.x,b+=g-x.y}this.move(Math.round(x.x),Math.round(x.y||0),y,b)}};(Do=Je||(Je={})).compose=function(h){Hl(Ll,"Core.Tooltip")&&Dl(h,"afterInit",function(){let t=this.chart;t.options.tooltip&&(t.tooltip=new Do(t,t.options.tooltip,this))})};var Yr=Je,{animObject:Yl}=nt,{defaultOptions:Gl}=yt,{format:jl}=bt,{addEvent:Ul,crisp:Vl,erase:$l,extend:xi,fireEvent:Ss,getNestedProperty:Zl,isArray:ql,isFunction:Kl,isNumber:Rt,isObject:yi,merge:Gr,pick:Wt,syncTimeout:_l,removeEvent:jr,uniqueKey:Jl}=N,ko=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():Rt(t.x)&&i.options.relativeXValue?this.x=i.autoIncrement(t.x):typeof this.x=="string"&&(e??(e=i.chart.time.parse(this.x)),Rt(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=Yl(t.series.chart.renderer.globalAnimation),a=()=>{for(let n in(t.graphic||t.graphics||t.dataLabel||t.dataLabels)&&(jr(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(),_l(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)}),Ss(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){return t?t.indexOf("custom.")===0?Zl(t,this.options):this[t]:void 0}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=Jl()),this.resolveColor(),this.dataLabelOnNull??(this.dataLabelOnNull=t.options.nullInteraction),t.chart.pointCount++,Ss(this,"afterInit")}isValid(){return(Rt(this.x)||this.x instanceof Date)&&Rt(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(Rt(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(Rt(i)&&Rt(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=Wt(this.options.colorIndex,a),this.color=Wt(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}")}),jl(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 f of a.dataColumnKeys())u[f]=r[f];a.dataTable.setRow(u,o),c.data[o]=yi(c.data[o],!0)||yi(t,!0)?r.options:Wt(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=Wt(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=Wt(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=Gr(this.series.options.point,this.options),i=e.events?.[t];Kl(i)&&(!this.hcEvents?.[t]||this.hcEvents?.[t]?.map(s=>s.fn).indexOf(i)===-1)?(this.importedUserEvent?.(),this.importedUserEvent=Ul(this,t,i),this.hcEvents&&(this.hcEvents[t].userEvent=!0)):this.importedUserEvent&&!i&&this.hcEvents?.[t]&&this.hcEvents?.[t].userEvent&&(jr(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=Gl.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,f,x,m=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){f=i.pointAttribs(this,t),x=Wt(d.options.chart.animation,o.animation);let w=f.opacity;i.options.inactiveOtherPoints&&Rt(w)&&(this.dataLabels||[]).forEach(function(k){k&&!k.hasClass("highcharts-data-label-hidden")&&(k.animate({opacity:w},x),k.connector&&k.connector.animate({opacity:w},x))}),this.graphic.animate(f,x)}u&&this.graphic.animate(u,Wt(d.options.chart.animation,n.animation,r.animation)),m&&m.hide()}else t&&n&&(y=c.symbol||i.symbol,m&&m.currentSymbol!==y&&(m=m.destroy()),u&&(m?m[e?"animate":"attr"]({x:u.x,y:u.y}):y&&(i.stateMarkerGraphic=m=d.renderer.symbol(y,u.x,u.y,u.width,u.height,Gr(r,n)).add(i.markerGroup),m.currentSymbol=y)),!d.styledMode&&m&&this.state!=="inactive"&&m.attr(i.pointAttribs(this,t))),m&&(m[t&&this.isInside?"show":"hide"](),m.element.point=this,m.addClass(this.getClassName(),!0));let b=o.halo,v=this.graphic||m,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-"+Wt(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),Ss(this,"afterSetState",{state:t})}haloPath(t){let e=this.pos();return e?this.series.chart.renderer.symbols.circle(Vl(e[0],1)-t,e[1]-t,2*t,2*t):[]}},Ut=ko,{parse:Ql}=dt,{charts:Ts,composed:td,isTouchDevice:ed}=P,{addEvent:xt,attr:id,css:Cs,extend:As,find:Ur,fireEvent:Xt,isNumber:bi,isObject:vi,objectEach:sd,offset:od,pick:Tt,pushUnique:rd,splat:Vr}=N,ve=class h{applyInactiveState(t=[]){let e=[];t.forEach(i=>{let s=i.series;e.push(s),s.linkedParent&&e.push(s.linkedParent),s.linkedSeries&&e.push.apply(e,s.linkedSeries),s.navigatorSeries&&e.push(s.navigatorSeries),s.boosted&&s.markerGroup&&e.push.apply(e,this.chart.series.filter(o=>o.markerGroup===s.markerGroup))}),this.chart.series.forEach(i=>{e.indexOf(i)===-1?i.setState("inactive",!0):i.options.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),sd(t,function(e,i){t[i]=void 0})}getSelectionMarkerAttrs(t,e){let i={args:{chartX:t,chartY:e},attrs:{},shapeType:"rect"};return Xt(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,f=t.chartY,x,m=this.selectionMarker;if((!m||!m.touch)&&(u<n?u=n:u>n+c&&(u=n+c),f<l?f=l:f>l+d&&(f=l+d),this.hasDragged=Math.sqrt(Math.pow(i-u,2)+Math.pow(s-f,2)),this.hasDragged>10)){x=e.isInsidePlot(i-n,s-l,{visiblePlotOnly:!0});let{shapeType:y,attrs:b}=this.getSelectionMarkerAttrs(u,f);(e.hasCartesianSeries||e.mapView)&&this.hasZoom&&x&&!g&&!m&&(this.selectionMarker=m=e.renderer[y](),m.attr({class:"highcharts-selection-marker",zIndex:7}).add(),e.styledMode||m.attr({fill:a||Ql("#334eff").setOpacity(.25).get()})),m&&m.attr(b),x&&!m&&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 Xt(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:Lt({originalEvent:t,xAxis:[],yAxis:[]},o),from:o})}bi(i.index)&&(this.selectionMarker=s.destroy())}i&&bi(i.index)&&(Cs(i.container,{cursor:i._cursor}),i.cancelClick=this.hasDragged>10,i.mouseIsDown=!1,this.hasDragged=0,this.pinchDown=[])}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=od(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)&&Tt(g.options.enableMouseTracking,!0)},l=e,c,d={chartX:r?r.chartX:void 0,chartY:r?r.chartY:void 0,shared:o};Xt(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,f=Ur(g.points,function(x){return x.x===p.x&&(!x.isNull||!!u)});vi(f)&&(g.boosted&&g.boost&&(f=g.boost.getPoint(f)),a.push(f))}):a.push(p)),Xt(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=id(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(),Xt(this,"afterInit")}normalize(t,e){let i=t.touches,s=i?i.length?i.item(0):Tt(i.changedTouches,t.changedTouches)[0]:t;e||(e=this.getChartPosition());let o=s.pageX-e.left,r=s.pageY-e.top;return As(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")?(Xt(i.series,"click",As(s,{point:i})),e.hoverPoint&&i.firePointEvent("click",s)):(As(s,this.getCoordinates(s)),e.isInsidePlot(s.chartX-o,s.chartY-r,{visiblePlotOnly:!0})&&Xt(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}=Ts[Tt(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.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){Ts[Tt(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&&Tt(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&&(Xt(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&&Vr(n).forEach(function(l){l.series.isCartesian&&l.plotX===void 0&&(t=!1)}),t?a&&n&&Vr(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(f){p.indexOf(f)===-1&&f.setState()}),s.hoverSeries!==l&&l.onMouseOver(),this.applyInactiveState(p),(p||[]).forEach(function(f){f.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 f=r.getAnchor([{}],t);s.isInsidePlot(f[0],f[1],{visiblePlotOnly:!0})&&r.updatePosition({plotX:f[0],plotY:f[1]})}this.unDocMouseMove||(this.unDocMouseMove=xt(s.container.ownerDocument,"mousemove",f=>Ts[h.hoverChartIndex??-1]?.pointer?.onDocumentMouseMove(f)),this.eventsToUnbind.push(this.unDocMouseMove)),s.axes.forEach(function(f){let x,m=f.crosshair?.snap??!0;!m||(x=s.hoverPoint)&&x.series[f.coll]===f||(x=Ur(p,y=>y.series?.[f.coll]===f)),x||!m?f.drawCrosshair(t,x):f.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(xt(t,"mouseenter",this.onContainerMouseEnter.bind(this)),xt(t,"mouseleave",this.onContainerMouseLeave.bind(this))),h.unbindDocumentMouseUp.some(s=>s.doc===e)||h.unbindDocumentMouseUp.push({doc:e,unbind:xt(e,"mouseup",this.onDocumentMouseUp.bind(this))});let i=this.chart.renderTo.parentElement;for(;i&&i.tagName!=="BODY";)this.eventsToUnbind.push(xt(i,"scroll",()=>{delete this.chartPosition})),i=i.parentElement;this.eventsToUnbind.push(xt(t,"touchstart",this.onContainerTouchStart.bind(this),{passive:!1}),xt(t,"touchmove",this.onContainerTouchMove.bind(this),{passive:!1})),h.unbindDocumentTouchEnd||(h.unbindDocumentTouchEnd=xt(e,"touchend",this.onDocumentTouchEnd.bind(this),{passive:!1})),this.setPointerCapture(),xt(this.chart,"redraw",this.setPointerCapture.bind(this))}setPointerCapture(){if(!ed)return;let t=this.pointerCaptureEventsToUnbind,e=this.chart,i=e.container,s=Tt(e.options.tooltip?.followTouchMove,!0)&&e.series.some(o=>o.options.findNearestPointBy.indexOf("y")>-1);!this.hasPointerCapture&&s?(t.push(xt(i,"pointerdown",o=>{o.target?.hasPointerCapture(o.pointerId)&&o.target?.releasePointerCapture(o.pointerId)}),xt(i,"pointermove",o=>{e.pointer?.getPointFromEvent(o)?.onMouseOver(o)})),e.styledMode||Cs(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||Cs(i,{"touch-action":Tt(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[Tt(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.openMenu?(e&&this.runPointActions(t),t.type==="touchmove"&&(i=!!o[0]&&Math.pow(o[0].chartX-t.chartX,2)+Math.pow(o[0].chartY-t.chartY,2)>=16),Tt(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=Tt(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}};ve.unbindDocumentMouseUp=[],(Bo=ve||(ve={})).compose=function(h){rd(td,"Core.Pointer")&&xt(h,"beforeRender",function(){this.pointer=new Bo(this,this.options)})};var $r=ve;(No=so||(so={})).setLength=function(h,t,e){return Array.isArray(h)?(h.length=t,h):h[e?"subarray":"slice"](0,t)},No.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:ad,splice:Zr}=so,{fireEvent:Ps,objectEach:Be,uniqueKey:Ne}=N,zi=class{constructor(h={}){this.autoId=!h.id,this.columns={},this.id=h.id||Ne(),this.modified=this,this.rowCount=0,this.versionTag=Ne();let t=0;Be(h.columns||{},(e,i)=>{this.columns[i]=e.slice(),t=Math.max(t,e.length)}),this.applyRowCount(t)}applyRowCount(h){this.rowCount=h,Be(this.columns,(t,e)=>{t.length!==h&&(this.columns[e]=ad(t,h))})}deleteRows(h,t=1){if(t>0&&h<this.rowCount){let e=0;Be(this.columns,(i,s)=>{this.columns[s]=Zr(i,h,t).array,e=i.length}),this.rowCount=e}Ps(this,"afterDeleteRows",{rowIndex:h,rowCount:t}),this.versionTag=Ne()}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;Be(h,(s,o)=>{this.columns[o]=s.slice(),i=s.length}),this.applyRowCount(i),e?.silent||(Ps(this,"afterSetColumns"),this.versionTag=Ne())}setRow(h,t=this.rowCount,e,i){let{columns:s}=this,o=e?this.rowCount+1:t+1;Be(h,(r,a)=>{let n=s[a]||i?.addColumns!==!1&&Array(o);n&&(e?n=Zr(n,t,0,!0,[r]).array:n[t]=r,s[a]=n)}),o>this.rowCount&&this.applyRowCount(o),i?.silent||(Ps(this,"afterSetRows"),this.versionTag=Ne())}},{extend:nd,merge:hd,pick:qr}=N;(function(h){function t(e,i,s){let o=this.legendItem=this.legendItem||{},{chart:r,options:a}=this,{baseline:n=0,symbolWidth:l,symbolHeight:c}=e,d=this.symbol||"circle",p=c/2,g=r.renderer,u=o.group,f=n-Math.round((e.fontMetrics?.b||c)*(s?.4:.3)),x={},m,y=a.marker,b=0;if(r.styledMode||(x["stroke-width"]=Math.min(a.lineWidth||0,24),a.dashStyle?x.dashstyle=a.dashStyle:a.linecap==="square"||(x["stroke-linecap"]="round")),o.line=g.path().addClass("highcharts-graph").attr(x).add(u),s&&(o.area=g.path().addClass("highcharts-area").add(u)),x["stroke-linecap"]&&(b=Math.min(o.line.strokeWidth(),l)/2),l){let v=[["M",b,f],["L",l-b,f]];o.line.attr({d:v}),o.area?.attr({d:[...v,["L",l-b,n],["L",b,n]]})}if(y&&y.enabled!==!1&&l){let v=Math.min(qr(y.radius,p),p);d.indexOf("url")===0&&(y=hd(y,{width:c,height:c}),v=0),o.symbol=m=g.symbol(d,l/2-v,f-v,2*v,2*v,nd({context:"legend"},y)).addClass("highcharts-point").add(u),m.isMarker=!0}}h.areaMarker=function(e,i){t.call(this,e,i,!0)},h.lineMarker=t,h.rectangle=function(e,i){let s=i.legendItem||{},o=e.options,r=e.symbolHeight,a=o.squareSymbol,n=a?r:e.symbolWidth;s.symbol=this.chart.renderer.rect(a?(e.symbolWidth-r)/2:0,e.baseline-r+1,n,r,qr(e.options.symbolRadius,r/2)).addClass("highcharts-point").attr({zIndex:3}).add(s.group)}})(oo||(oo={}));var Za=oo,{defaultOptions:Kr}=yt,{extend:ld,extendClass:dd,merge:cd}=N;(function(h){function t(e,i){let s=Kr.plotOptions||{},o=i.defaultOptions,r=i.prototype;return r.type=e,r.pointClass||(r.pointClass=Ut),!h.seriesTypes[e]&&(o&&(s[e]=o),h.seriesTypes[e]=i,!0)}h.seriesTypes=P.seriesTypes,h.registerSeriesType=t,h.seriesType=function(e,i,s,o,r){let a=Kr.plotOptions||{};if(i=i||"",a[e]=cd(a[i],s),delete h.seriesTypes[e],t(e,dd(h.seriesTypes[i]||function(){},o)),h.seriesTypes[e].prototype.type=e,r){class n extends Ut{}ld(n.prototype,r),h.seriesTypes[e].prototype.pointClass=n}return h.seriesTypes[e]}})(ro||(ro={}));var tt=ro,{animObject:_r,setAnimation:pd}=nt,{defaultOptions:ki}=yt,{registerEventOptions:gd}=qi,{svg:ud,win:fd}=P,{seriesTypes:pe}=tt,{format:md}=bt,{arrayMax:Ls,arrayMin:Jr,clamp:Qr,correctFloat:ta,crisp:xd,defined:it,destroyObjectProperties:yd,diffObjects:bd,erase:ea,error:wi,extend:ue,find:vd,fireEvent:Q,getClosestDistance:kd,getNestedProperty:ia,insertItem:sa,isArray:oa,isNumber:st,isString:wd,merge:ze,objectEach:Os,pick:J,removeEvent:Md,syncTimeout:ra}=N,At=class h{constructor(){this.zoneAxis="y"}init(t,e){let i;Q(this,"init",{options:e}),this.dataTable??(this.dataTable=new zi);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(),ue(this,{name:o.name,state:"",visible:r,selected:o.selected===!0}),gd(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=J(i?._i,-1)+1,this.opacity=this.options.opacity,t.orderItems("series",sa(this,s)),o.dataSorting?.enabled?this.setDataSortingOptions():this.points||this.data||this.setData(o.data,!1),Q(this,"afterInit")}is(t){return pe[t]&&this instanceof pe[t]}bindAxes(){let t,e=this,i=e.options,s=e.chart;Q(this,"bindAxes",null,function(){(e.axisTypes||[]).forEach(function(o){(s[o]||[]).forEach(function(r){t=r.options,(J(i[o],0)===r.index||i[o]!==void 0&&i[o]===t.id)&&(sa(e,r.series),e[o]=r,r.isDirty=!0)}),e[o]||e.optionalAxis===o||wi(18,!0,s)})}),Q(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=J(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;ue(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=ze(t),a=i.styledMode,n={plotOptions:s,userOptions:r};Q(this,"setOptions",n);let l=n.plotOptions[this.type],c=o.plotOptions||{},d=c.series||{},p=ki.plotOptions[this.type]||{},g=c[this.type]||{};l.dataLabels=this.mergeArrays(p.dataLabels,l.dataLabels),this.userOptions=n.userOptions;let u=ze(l,s.series,g,r);this.tooltipOptions=ze(ki.tooltip,ki.plotOptions.series?.tooltip,p?.tooltip,i.userOptions.tooltip,c.series?.tooltip,g.tooltip,r.tooltip),this.stickyTracking=J(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 f=this.zones=(u.zones||[]).map(x=>Lt({},x));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),f.push(e)),f.length&&it(f[f.length-1].value)&&f.push(a?{}:{color:this.color,fillColor:this.fillColor}),Q(this,"afterSetOptions",{options:u}),u}getName(){return this.options.name??md(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=J(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||ki.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 Ut&&(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=vd(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((f,x)=>{let m,y=it(f)&&this.pointClass.prototype.optionsToObject.call({series:this},f)||{},{id:b,x:v}=y;b||st(v)?((m=this.findPointIndex(y,p))===-1||m===void 0?a.push(f):r[m]&&f!==i.data?.[m]?(r[m].update(f,!1,void 0,!1),r[m].touched=!0,s&&(p=m+1)):r[m]&&(r[m].touched=!0),(!n||x!==m||o?.enabled||this.hasDerivedData)&&(l=!0)):a.push(f)},this),l)for(c=r.length;c--;)(d=r[c])&&!d.touched&&d.remove?.(!1,e);else n&&!o?.enabled?(t.forEach((f,x)=>{f===r[x].y||r[x].destroyed||r[x].update(f,!1,void 0,!1)}),a.length=0):g=!1;if(r.forEach(f=>{f&&(f.touched=!1)}),!g)return!1;a.forEach(f=>{this.addPoint(f,!1,void 0,void 0,!1)},this);let u=this.getColumn("x");return this.xIncrement===null&&u.length&&(this.xIncrement=Ls(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",f=(this.pointArrayMap||[]).length,x=a.keys,m,y,b=0,v=1,S;n.options.chart.allowMutatingData||(a.data&&delete this.options.data,this.userOptions.data&&delete this.userOptions.data,S=ze(!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&&w>d;if(k){let M=this.getFirstValidPoint(t),T=this.getFirstValidPoint(t,w-1,-1),C=A=>!!(oa(A)&&(x||st(A[0])));if(st(M)&&st(T)){let A=[],L=[];for(let O of t)A.push(this.autoIncrement()),L.push(O);p.setColumns({x:A,[u]:L})}else if(C(M)&&C(T))if(f){let A=+(M.length===f),L=Array(g.length).fill(0).map(()=>[]);for(let O of t){A&&L[0].push(this.autoIncrement());for(let I=A;I<=f;I++)L[I]?.push(O[I-A])}p.setColumns(g.reduce((O,I,D)=>(O[I]=L[D],O),{}))}else{x&&(b=x.indexOf("x"),v=x.indexOf("y"),b=b>=0?b:0,v=v>=0?v:1),M.length===1&&(v=0);let A=[],L=[];if(b===v)for(let O of t)A.push(this.autoIncrement()),L.push(O[v]);else for(let O of t)A.push(O[b]),L.push(O[v]);p.setColumns({x:A,[u]:L})}else k=!1}if(!k){let M=g.reduce((T,C)=>(T[C]=[],T),{});for(m=0;m<w;m++){let T=this.pointClass.prototype.applyOptions.apply({series:this},[t[m]]);for(let C of g)M[C][m]=T[C]}p.setColumns(M)}for(wd(this.getColumn("y")[0])&&wi(14,!0,n),this.data=[],this.options.data=this.userOptions.data=t,m=r;m--;)o[m]?.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=ia(i,o),n=ia(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,f,x,m=e.getColumn("x"),y=i,b=!1;return r&&(f=(u=r.getExtremes()).min,x=u.max,b=!!(r.categories&&!r.names.length),s&&e.sorted&&!n&&(!a||c>a||e.forceCrop)&&(m[c-1]<f||m[0]>x?y=new zi:e.getColumn(e.pointValKey||"y").length&&(m[0]<f||m[c-1]>x)&&(y=(d=this.cropData(i,f,x)).modified,g=d.start,p=!0))),m=y.getColumn("x")||[],{modified:y,cropped:p,cropStart:g,closestPointRange:kd([l?m.map(l.log2lin):m],()=>e.requireSorting&&!b&&wi(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,Q(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 zi({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(),f,x,m,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++)x=a+y,n?((m=new o(this,i.getRow(y,u)||[])).dataGroup=this.groupMap[d+y],m.dataGroup?.options&&(m.options=m.dataGroup.options,ue(m,m.dataGroup.options),delete m.dataLabels)):(m=b[x],v=e?e[x]:i.getRow(y,g),m||v===void 0||(b[x]=m=new o(this,v,s[y]))),m&&(m.index=n?d+y:x,c[y]=m,m.category=p?.[m.x]??m.x,m.key=m.name??m.category);if(this.options.keys=l,b&&(r!==(f=b.length)||n))for(y=0;y<f;y++)y!==a||n||(y+=r),b[y]&&(b[y].destroyElements(),b[y].plotX=void 0);this.data=b,this.points=c,Q(this,"afterGeneratePoints")}getXExtremes(t){return{min:Jr(t),max:Ls(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,f,x,m,y=0,b=0;for(i&&(y=(f=i.getExtremes()).min,b=f.max),m=0;m<a;m++)if(x=c[m],u||(c[m+p]||x)>=y&&(c[m-p]||x)<=b)for(let S of l){let w=S[m];st(w)&&(w>0||!g)&&d.push(w)}let v={activeYData:d,dataMin:Jr(d),dataMax:Ls(d)};return Q(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,f,x,m=Number.MAX_VALUE;function y(b){return Qr(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,C=e&&o.stacking?.stacks[(this.negStacks&&M<(d?0:c)?"-":"")+this.stackKey];v.plotX=st(u=i.translate(S,!1,!1,!1,!0,n))?ta(y(u)):void 0,e&&this.visible&&C&&C[S]&&(x=this.getStackIndicator(x,S,this.index),!v.isNull&&x.key&&(k=(w=C[S]).points[x.key]),w&&oa(k)&&(T=k[0],M=k[1],T===d&&x.key===C[S].base&&(T=J(st(c)?c:o.min)),o.positiveValuesOnly&&it(T)&&T<=0&&(T=void 0),v.total=v.stackTotal=J(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?ta(i.translate(S,!1,!1,!1,!0,n)):u,v.negative=(v.y||0)<(c||0),v.isNull||v.visible===!1||(f!==void 0&&(m=Math.min(m,Math.abs(u-f))),f=u),v.zone=this.zones.length?v.getZone():void 0,!v.graphic&&this.group&&s&&(v.isNew=!0)}this.closestPointRangePx=m,Q(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=_r(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(),Os(this.chart.sharedClips,(t,e,i)=>{t&&!this.chart.container.querySelector(`[clip-path="url(#${t.id})"]`)&&(t.destroy(),delete i[e])}),this.finishedAnimating=!0,Q(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,f=this[this.specialGroup||"markerGroup"],x=this.xAxis,m=J(g.enabled,!x||!!x.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((m&&!it(r.enabled)||r.enabled)&&(!y||u)&&i.visible!==!1){let b=J(r.symbol,this.symbol,"rect");n=this.markerAttribs(i,i.selected&&"select"),this.enabledDataSorting&&(i.startXPos=x.reversed?-(n.width||0):x.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(f),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=J(o.radius,s?.radius);e&&(n=s.states[e],l=o.states&&o.states[e],c=J(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]=xd(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,f=J(r.lineWidth,s.lineWidth),x=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]||{},f=J((d=r.states&&r.states[e]||{}).lineWidth,c.lineWidth,f+J(d.lineWidthPlus,c.lineWidthPlus,0)),g=d.fillColor||c.fillColor||g,u=d.lineColor||c.lineColor||u,{stroke:u,"stroke-width":f,fill:g,opacity:x=J(d.opacity,c.opacity,x)}}destroy(t){let e,i,s=this,o=s.chart,r=/AppleWebKit\/533/.test(fd.navigator.userAgent),a=s.data||[];for(Q(s,"destroy",{keepEventsForUpdate:t}),this.removeEvents(t),(s.axisTypes||[]).forEach(function(n){i=s[n],i?.series&&(ea(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)yd(n,void 0,!0);N.clearTimeout(s.animationTimeout),Os(s,function(n,l){n instanceof Pt&&!n.survive&&n[r&&l==="group"?"hide":"destroy"]()}),o.hoverSeries===s&&(o.hoverSeries=void 0),ea(o.series,s),o.orderItems("series"),Os(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||{},f=(i?.strokeWidth()||0)/2+1,x=(m,y=0,b=0)=>{l&&(b=g-b);let{translated:v=0,lineClip:S}=m,w=b-v;S?.push(["L",y,Math.abs(w)<f?b-f*(w<=0?-1:1):v])};if(s.length&&(i||t)&&d&&st(d.min)){let m=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=Qr(d.toPixels(J(S.value,m),!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&&x(M,w,k),T&&x(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,C=0,A=0,L=r.len,O=a.len;p?(C=k,L=v):(A=k,O=v);let I=[["M",C,A],["L",L,A],["L",L,O],["L",C,O],["Z"]],D=[I[0],...w,I[1],I[2],...b,I[3],I[4]];b=w.reverse(),v=k,l&&(y(D),t&&y(I)),M?(M.animate({d:D}),T?.animate({d:I})):(M=S.clip=c.path(D),t&&(T=S.simpleClip=c.path(I))),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";return s.inverted&&(e=i,i=this.xAxis),{translateX:e?e.left:s.plotLeft,translateY:i?i.top:s.plotTop,rotation:90*!!o,rotationOriginX:o?(e.len-i.len)/2:0,rotationOriginY:o?(e.len+i.len)/2:0,scaleX:o?-1:1,scaleY:1}}removeEvents(t){let{eventsToUnbind:e}=this;t||Md(this),e.length&&(e.forEach(i=>{i()}),e.length=0)}render(){let t=this,{chart:e,options:i,hasRendered:s}=t,o=_r(i.animation),r=t.visible?"inherit":"hidden",a=i.zIndex,n=e.seriesGroup,l=t.finishedAnimating?0:o.duration;Q(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=ra(()=>{t.afterAnimate()},l||0)),t.isDirty=!1,t.hasRendered=!0,Q(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,ra(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,f,x)=>{let m=u[x]||0,y=f[x]||0;return[m===y&&u.index>f.index||m<y?u:f,!1]}),g=o||((u,f)=>u<f);if(this.kdTree||this.buildingKdTree||this.buildKDTree(i),this.kdTree)return(function u(f,x,m,y){let b=x.point,v=r.kdAxisArray[m%y],S=b,w=!1;(function(C,A){let L=C[a],O=A[a],I=it(L)&&it(O)?L-O:null,D=C[n],E=A[n],B=it(D)&&it(E)?D-E:0,q=d&&A.marker?.radius||0;A.dist=Math.sqrt((I&&I*I||0)+B*B)-q,A.distX=it(I)?Math.abs(I)-q:Number.MAX_VALUE})(f,b);let k=(f[v]||0)-(b[v]||0)+(d&&b.marker?.radius||0),M=k<0?"left":"right",T=k<0?"right":"left";return x[M]&&([S,w]=p(b,u(f,x[M],m+1,y),l)),x[T]&&g(Math.sqrt(k*k),S[l],w)&&(S=p(S,u(f,x[T],m+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,"+(ud?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))})),Q(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,f=this.getColumn("x");e=J(e,!0);let x={series:this};this.pointClass.prototype.applyOptions.apply(x,[t]);let m=x.x;if(a=f.length,this.requireSorting&&m<f[a-1])for(r=!0;a&&f[a-1]>m;)a--;d.setRow(x,a,!0,{addColumns:!1}),g&&x.name&&(g[m]=x.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&&Q(this,"addPoint",{point:x}),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()};pd(i,o),e=J(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),J(t,!0)&&r.redraw(e)}i!==!1?Q(o,"remove",null,a):a()}update(t,e){Q(this,"update",{options:t=bd(t,this.userOptions)});let i=this,s=i.chart,o=i.userOptions,r=i.initialType||i.type,a=s.options.plotOptions,n=pe[r].prototype,l=i.finishedAnimating&&{animation:!1},c={},d,p,g=h.keepProps.slice(),u=t.type||o.type||s.options.chart.type,f=!(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(m=>i.hasOptionChanged(m)));u=u||r,f?(g.push.apply(g,h.keepPropsForPoints),t.visible!==!1&&g.push("area","graph"),i.parallelArrays.forEach(function(m){g.push(m+"Data")}),t.data&&(t.dataSorting&&ue(i.options.dataSorting,t.dataSorting),this.setData(t.data,!1))):this.dataTable.modified=this.dataTable,t=ze(o,{index:o.index===void 0?i.index:o.index,pointStart:a?.series?.pointStart??o.pointStart??i.getColumn("x")[0]},!f&&{data:i.options.data},t,l),f&&t.data&&(t.data=i.options.data),(g=["group","markerGroup","dataLabelsGroup","transformGroup"].concat(g)).forEach(function(m){g[m]=i[m],delete i[m]});let x=!1;if(pe[u]){if(x=u!==i.type,i.remove(!1,!1,!1,!0),x)if(s.propFromSeries(),Object.setPrototypeOf)Object.setPrototypeOf(i,pe[u].prototype);else{let m=Object.hasOwnProperty.call(i,"hcEvents")&&i.hcEvents;for(p in n)i[p]=void 0;ue(i,pe[u].prototype),m?i.hcEvents=m:delete i.hcEvents}}else wi(17,!0,s,{missingModuleFor:u});if(g.forEach(function(m){i[m]=g[m]}),i.init(s,t),f&&this.points)for(let m 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))m?.series&&(m.resolveColor(),Object.keys(c).length&&m.destroyElements(c),d.showInLegend===!1&&m.legendItem&&s.legend.destroyItem(m));i.initialType=r,s.linkSeries(),s.setSortedData(),x&&i.linkedSeries.length&&(i.isDirtyData=!0),Q(this,"afterUpdate"),J(e,!0)&&s.redraw(!!f&&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=J(s?.[this.type]?.[t],s?.series?.[t]);return o&&!it(r)?i!==o:i!==J(r,i)}onMouseOver(){let t=this.chart,e=t.hoverSeries;t.pointer?.setHoverChartIndex(),e&&e!==this&&e.onMouseOut(),this.options.events.mouseOver&&Q(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&&Q(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=J(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=J(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),Q(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),Q(this,t?"select":"unselect")}shouldShowTooltip(t,e,i={}){return i.series=this,i.visiblePlotOnly=!0,this.chart.isInsidePlot(t,e,i)}drawLegendSymbol(t,e){Za[this.options.legendSymbol||"rectangle"]?.call(this,t,e)}};At.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"},At.types=tt.seriesTypes,At.registerType=tt.registerSeriesType,At.keepProps=["colorIndex","eventOptions","navigatorSeries","symbolIndex","baseSeries"],At.keepPropsForPoints=["data","isDirtyData","isDirtyCanvas","points","dataTable","processedData","xIncrement","cropped","_hasPointMarkers","hasDataLabels","nodes","layout","level","mapMap","mapData","minY","maxY","minX","maxX","transformGroups"],ue(At.prototype,{axisTypes:["xAxis","yAxis"],coll:"series",colorCounter:0,directTouch:!1,invertible:!0,isCartesian:!0,kdAxisArray:["clientX","plotY"],parallelArrays:["x","y"],pointClass:Ut,requireSorting:!0,sorted:!0}),tt.series=At;var ut=At,{animObject:Sd,setAnimation:Td}=nt,{registerEventOptions:aa}=qi,{composed:Cd,marginNames:na}=P,{distribute:Ad}=Zi,{format:Pd}=bt,{addEvent:Ri,createElement:Ld,css:Od,defined:Es,discardElement:Ed,find:Id,fireEvent:Et,isNumber:ha,merge:qt,pick:mt,pushUnique:Dd,relativeLength:Bd,stableSort:Nd,syncTimeout:zd}=N,Qe=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(),aa(this,e),Ri(this.chart,"endResize",function(){this.legend.positionCheckboxes()})),Ri(this.chart,"render",()=>{this.options.enabled&&this.proximate&&(this.proximatePositions(),this.positionItems())})}setOptions(t){let e=mt(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=mt(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&&aa(this,this.options),this.destroy(),i.isDirtyLegend=i.isDirtyBox=!0,mt(e,!0)&&i.redraw(),Et(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 Ut)&&(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,f=x=>(!e&&(x.fill&&(x.fill=c),x.stroke&&(x.stroke=c)),x);r?.css(qt(e?this.itemStyle:l)),a?.attr(f({stroke:g||t.color})),n&&n.attr(f(u&&n.isMarker?t.pointAttribs():{fill:t.color})),s?.attr(f({fill:d||t.color,"fill-opacity":d?1:p??.75}))}t.color=i,Et(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[Es(e.translateY)?"animate":"attr"](l,void 0,()=>{Et(this,"afterPositionItem",{item:t})})}n&&(n.x=i,n.y=s)}destroyItem(t){let e=t.checkbox,i=t.legendItem||{};for(let s of["group","label","line","symbol"])i[s]&&(i[s]=i[s].destroy());e&&Ed(e),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,Od(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?Pd(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?mt(o.itemDistance,20):0,p=!o.rtl,g=!t.series,u=!g&&t.series.drawLegendSymbol?t.series:t,f=u.options,x=!!this.createCheckboxForItem&&f&&f.showCheckbox,m=o.useHTML,y=t.options.className,b=e.label,v=a+n+d+20*!!x;!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,m),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=mt(o.symbolHeight,this.fontMetrics.f),o.squareSymbol&&(this.symbolWidth=mt(o.symbolWidth,Math.max(this.symbolHeight,16)),v=this.symbolWidth+n+d+20*!!x,p&&b.attr("x",this.symbolWidth+n))),u.drawLegendSymbol(this,t),this.setItemEvents&&this.setItemEvents(t,b,m)),x&&!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?mt(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&&mt(i.showInLegend,!Es(i.linkedTo)&&void 0,!0)&&(t=t.concat(e.legendItem?.labels||(i.legendType==="point"?e.data:e)))}),Et(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(function(r,a){r.test(o)&&!Es(t[a])&&(i[na[a]]=Math.max(i[na[a]],i.legend[(a+1)%2?"legendHeight":"legendWidth"]+[1,-1,-1,1][a]*s[a%2?"x":"y"]+mt(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=Id(l?r.points:r.points.slice(0).reverse(),function(p){return ha(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),Ad(i,e.plotHeight)))t=o.item.legendItem||{},ha(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=Bd(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(),Nd(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(),Et(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=mt(c.animation,!0),p=c.arrowSize||12,g=this.pages,u=this.allItems,f=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")},x=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]},m,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=m=Math.max(S-20-this.titleHeight-n,0),this.currentPage=mt(this.currentPage,1),this.fullHeight=t,u.forEach((M,T)=>{let C=(b=M.legendItem||{}).y||0,A=Math.round(b.label.getBBox().height),L=g.length;(!L||C-g[L-1]>m&&(y||C)!==g[L-1])&&(g.push(y||C),L++),b.pageIx=L-1,y&&v&&(v.pageIx=L-1),T===u.length-1&&C+A-g[L-1]>m&&C>g[L-1]&&(g.push(C),b.pageIx=L),C!==y&&(y=C),v=b}),k||(k=e.clipRect=s.clipRect(0,n-2,9999,0),e.contentGroup.clip(k)),f(m),w||(this.nav=w=s.g().attr({zIndex:1}).add(this.group),this.up=s.symbol("triangle",0,0,p,p).add(w),x("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),x("downTracker").on("click",function(){e.scroll(1,d)})),e.scroll(0),t=S):w&&(f(),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&&Td(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(),zd(()=>{Et(this,"afterScroll",{currentPage:c})},Sd(mt(e,i.renderer.globalAnimation,!0)).duration))}setItemEvents(t,e,i){let s=this,o=t.legendItem||{},r=s.chart.renderer.boxWrapper,a=t instanceof Ut,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(f=>{f.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 f=function(){t.setVisible&&t.setVisible(),p(t.visible?"inactive":"")};r.removeClass(l),Et(s,"itemClick",{browserEvent:u,legendItem:t},f),a?t.firePointEvent("legendItemClick",{browserEvent:u}):n&&Et(t,"legendItemClick",{browserEvent:u})})}createCheckboxForItem(t){t.checkbox=Ld("input",{type:"checkbox",className:"highcharts-legend-checkbox",checked:t.selected,defaultChecked:t.selected},this.options.itemCheckboxStyle,this.chart.container),Ri(t.checkbox,"click",function(e){let i=e.target;Et(t.series||t,"checkboxClick",{checked:i.checked,item:t},function(){t.select()})})}};(zo=Qe||(Qe={})).compose=function(h){Dd(Cd,"Core.Legend")&&Ri(h,"beforeMargins",function(){this.legend=new zo(this,this.options.legend)})};var la=Qe,{animate:Is,animObject:Rd,setAnimation:Ds}=nt,{defaultOptions:Bs}=yt,{numberFormat:Wd}=bt,{registerEventOptions:da}=qi,{charts:Kt,doc:Re,marginNames:ca,svg:Xd,win:pa}=P,{seriesTypes:Ns}=tt,{addEvent:zs,attr:ga,createElement:Rs,css:kt,defined:Ht,diffObjects:ua,discardElement:Hd,erase:Fd,error:Ws,extend:Gt,find:Xs,fireEvent:j,getAlignFactor:Yd,getStyle:Hs,isArray:Gd,isNumber:ge,isObject:jd,isString:Mi,merge:Ct,objectEach:Fs,pick:rt,pInt:Ud,relativeLength:fa,removeEvent:ma,splat:Si,syncTimeout:Vd,uniqueKey:$d}=N,jt=class h{static chart(t,e,i){return new h(t,e,i)}constructor(t,e,i){this.sharedClips={};let s=[...arguments];(Mi(t)||t.nodeName)&&(this.renderTo=s.shift()),this.init(s[0],s[1])}setZoomOptions(){let t=this.options.chart,e=t.zooming;this.zooming=Te(Lt({},e),{type:rt(t.zoomType,e.type),key:rt(t.zoomKey,e.key),pinchType:rt(t.pinchType,e.pinchType),singleTouch:rt(t.zoomBySingleTouch,e.singleTouch,!1),resetButton:Ct(e.resetButton,t.resetZoomButton)})}init(t,e){j(this,"init",{args:arguments},function(){let i=Ct(Bs,t),s=i.chart,o=this.renderTo||s.renderTo;this.userOptions=Gt({},t),(this.renderTo=Mi(o)?Re.getElementById(o):o)||Ws(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 Po(Gt(i.time||{},{locale:this.locale}),i.lang),i.time=this.time.options,this.numberFormatter=(s.numberFormatter||Wd).bind(this),this.styledMode=s.styledMode,this.hasCartesianSeries=s.showAxes,this.index=Kt.length,Kt.push(this),P.chartCount++,da(this,s),this.xAxis=[],this.yAxis=[],this.pointCount=this.colorCounter=this.symbolCounter=0,this.setZoomOptions(),j(this,"afterInit"),this.firstRender()})}initSeries(t){let e=this.options.chart,i=t.type||e.type,s=Ns[i];s||Ws(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]=Si(this.options[t]).slice(),o=this.userOptions[t]=this.userOptions[t]?Si(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}=Ct(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,f={x:g,y:u,isInsidePlot:!0,options:i};if(!i.ignoreX){let x=d&&(s&&!this.polar?d.yAxis:d.xAxis)||{pos:r,len:1/0},m=i.paneCoordinates?x.pos+g:r+g;m>=Math.max(l+r,x.pos)&&m<=Math.min(l+r+p.width,x.pos+x.len)||(f.isInsidePlot=!1)}if(!i.ignoreY&&f.isInsidePlot){let x=!s&&i.axis&&!i.axis.isXAxis&&i.axis||d&&(s?d.xAxis:d.yAxis)||{pos:a,len:1/0},m=i.paneCoordinates?x.pos+u:a+u;m>=Math.max(c+a,x.pos)&&m<=Math.min(c+a+p.height,x.pos+x.len)||(f.isInsidePlot=!1)}return j(this,"afterIsInsidePlot",f),f.isInsidePlot}redraw(t){j(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,f;for(a.rootFontSize=a.boxWrapper.getStyle("font-size"),this.setResponsive&&this.setResponsive(!1),Ds(!!this.hasRendered&&t,this),n&&this.temporaryDisplay(),this.layOutTitles(!1),p=i.length;p--;)if(((f=i[p]).options.stacking||f.options.centerInCategory)&&(d=!0,f.isDirty)){c=!0;break}if(c)for(p=i.length;p--;)(f=i[p]).options.stacking&&(f.isDirty=!0);i.forEach(function(x){x.isDirty&&(x.options.legendType==="point"?(typeof x.updateTotals=="function"&&x.updateTotals(),u=!0):r&&(r.labelFormatter||r.labelFormat)&&(u=!0)),x.isDirtyData&&j(x,"updatedData")}),u&&o&&o.options.enabled&&(o.render(),this.isDirtyLegend=!1),d&&this.getStacks(),e.forEach(function(x){x.updateNames(),x.setScale()}),this.getMargins(),e.forEach(function(x){x.isDirty&&(g=!0)}),e.forEach(function(x){let m=x.min+","+x.max;x.extKey!==m&&(x.extKey=m,l.push(function(){j(x,"afterSetExtremes",Gt(x.eventArgs,x.getExtremes())),delete x.eventArgs})),(g||d)&&x.redraw()}),g&&this.drawChartBox(),j(this,"predraw"),i.forEach(function(x){(g||x.isDirty)&&x.visible&&x.redraw(),x.isDirtyData=!1}),s&&s.reset(!0),a.draw(),j(this,"redraw"),j(this,"render"),n&&this.temporaryDisplay(!0),l.forEach(function(x){x.call()})}get(t){let e=this.series;function i(o){return o.id===t||o.options&&o.options.id===t}let s=Xs(this.axes,i)||Xs(this.series,i);for(let o=0;!s&&o<e.length;o++)s=Xs(e[o].points||[],i);return s}createAxes(){let t=this.userOptions;for(let e of(j(this,"createAxes"),["xAxis","yAxis"]))for(let i of t[e]=Si(t[e]||{}))new vo(this,i,e);j(this,"afterCreateAxes")}getSelectedPoints(){return this.series.reduce((t,e)=>(e.getPointsCollection().forEach(i=>{rt(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]=Ct(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(Gt(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=Ct(o),d=n?.textPxLength||0;if(n&&l){j(this,"layOutTitle",{alignTo:c,key:a,textPxLength:d});let p=s.fontMetrics(n),g=p.b,u=p.h,f=l.verticalAlign||"top",x=f==="top",m=x&&l.minScale||1,y=a==="title"?x?-3:0:x?e[0]+2:0,b=Math.min(c.width/d,1),v=Math.max(m,b),S=Ct({y:f==="bottom"?g:y+g},{align:a==="title"?b<m?"left":"center":this.title?.alignValue},l),w=(l.width||(b>m?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*Yd(S.align)} ${u}`}),!l.floating){let M=k*(k<1.2*u?1:v);f==="top"?e[0]=Math.ceil(e[0]+M):f==="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,j(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:Hs(this.renderTo,"width",!0)||0,height:Hs(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,fa(i,this.chartWidth)||(o?400:s.height)),this.containerBox=s}temporaryDisplay(t){let e=this.renderTo,i;if(t)for(;e?.style;)e.hcOrigStyle&&(kt(e,e.hcOrigStyle),delete e.hcOrigStyle),e.hcOrigDetached&&(Re.body.removeChild(e),e.hcOrigDetached=!1),e=e.parentNode;else for(;e?.style&&(Re.body.contains(e)||e.parentNode||(e.hcOrigDetached=!0,Re.body.appendChild(e)),(Hs(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),kt(e,i),e.offsetWidth||e.style.setProperty("display","block","important")),(e=e.parentNode)!==Re.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=Ud(ga(r,s));ge(a)&&Kt[a]&&Kt[a].hasRendered&&Kt[a].destroy(),ga(r,s,this.index),r.innerHTML=ot.emptyHTML,i.skipClone||r.offsetWidth||this.temporaryDisplay(),this.getChartSize();let n=this.chartHeight,l=this.chartWidth;kt(r,{overflow:"hidden"}),this.styledMode||(t=Gt({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=Rs("div",{id:o},t,r);this.container=c,this.getChartSize(),l===this.chartWidth||(l=this.chartWidth,this.styledMode||kt(c,{width:rt(i.style?.width,l+"px")})),this.containerBox=this.getContainerBox(),this._cursor=c.style.cursor;let d=i.renderer||!Xd?ei.getRendererType(i.renderer):we;if(this.renderer=new d(c,l,n,void 0,i.forExport,e.exporting?.allowHTML,this.styledMode),Ds(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,j(this,"afterGetContainer")}getMargins(t){let{spacing:e,margin:i,titleOffset:s}=this;this.resetMargins(),s[0]&&!Ht(i[0])&&(this.plotTop=Math.max(this.plotTop,s[0]+e[0])),s[2]&&!Ht(i[2])&&(this.marginBottom=Math.max(this.marginBottom,s[2]+e[2])),this.legend?.display&&this.legend.adjustMargins(i,e),j(this,"getMargins"),t||this.getAxisMargins()}getAxisMargins(){let t=this,e=t.axisOffset=[0,0,0,0],i=t.colorAxis,s=t.margin,o=function(r){r.forEach(function(a){a.visible&&a.getOffset()})};t.hasCartesianSeries?o(t.axes):i?.length&&o(i),ca.forEach(function(r,a){Ht(s[a])||(t[r]+=e[a])}),t.setChartSize()}getOptions(){return ua(this.userOptions,Bs)}reflow(t){let e=this,i=e.containerBox,s=e.getContainerBox();delete e.pointer?.chartPosition,!e.isPrinting&&!e.isResizing&&i&&s.width&&((s.width!==i.width||s.height!==i.height)&&(N.clearTimeout(e.reflowTimeout),e.reflowTimeout=Vd(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=zs(pa,"resize",e);zs(this,"destroy",i)}}setSize(t,e,i){let s=this,o=s.renderer;s.isResizing+=1,Ds(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?Is:kt)(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,j(s,"resize"),setTimeout(()=>{s&&j(s,"endResize")},Rd(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()),j(this,"afterSetChartSize",{skipAxes:t})}resetMargins(){j(this,"resetMargins");let t=this,e=t.options.chart,i=e.plotBorderWidth||0,s=Math.round(i)/2;["margin","spacing"].forEach(function(o){let r=e[o],a=jd(r)?r:[r,r,r,r];["Top","Right","Bottom","Left"].forEach(function(n,l){t[o][l]=rt(e[o+n],a[l])})}),ca.forEach(function(o,r){t[o]=rt(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,f=this.clipRect,x=this.clipBox,m=this.chartBackground,y=this.plotBackground,b=this.plotBorder,v,S,w,k="animate";m||(this.chartBackground=m=e.rect().addClass("highcharts-background").add(),k="attr"),o?v=S=m.strokeWidth():(S=(v=t.borderWidth||0)+8*!!t.shadow,w={fill:a||"none"},(v||m["stroke-width"])&&(w.stroke=t.borderColor,w["stroke-width"]=v),m.attr(w).shadow(t.shadow)),m[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())),f?f.animate({width:x.width,height:x.height}):this.clipRect=e.clipRect(x),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,j(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=Ns[o.type],i=o[a]||e&&e.prototype[a],t=r?.length;!i&&t--;)(e=Ns[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(Mi(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=rt(s.options.visible,r.options.visible,s.visible))}}),j(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(),j(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 xe(c,0,"",!0),u=g.createLabel("x",p);if(g.destroy(),u&&rt(p.reserveSpace,!ge(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.renderSeries(),this.addCredits(),this.setResponsive&&this.setResponsive(),this.hasRendered=!0}addCredits(t){let e=this,i=Ct(!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&&(pa.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(j(e,"destroy"),e.renderer.forExport?Fd(Kt,e):Kt[e.index]=void 0,P.chartCount--,e.renderTo.removeAttribute("data-highcharts-chart"),ma(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,ma(o),r&&Hd(o)),Fs(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=Gd(e.series)?e.series:[];e.series=[],i.forEach(function(s){t.initSeries(s)}),t.linkSeries(),t.setSortedData(),j(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),j(this,"load"),j(this,"render"),Ht(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,"&lt;")}),t.accessibility&&t.accessibility.enabled===!1||Ws('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=rt(e,!0),j(o,"addSeries",{options:t},function(){s=o.initSeries(t),o.isDirtyLegend=!0,o.linkSeries(),s.enabledDataSorting&&s.setData(t.data,!1),j(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 vo(this,e.axis,t);return rt(e.redraw,!0)&&this.redraw(e.animation),i}showLoading(t){let e=this,i=e.options,s=i.loading,o=function(){r&&kt(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=Rs("div",{className:"highcharts-loading highcharts-loading-hidden"},null,e.container)),a||(e.loadingSpan=a=Rs("span",{className:"highcharts-loading-inner"},null,r),zs(e,"redraw",o)),r.className="highcharts-loading",ot.setElementHTML(a,rt(t,i.lang.loading,"")),e.styledMode||(kt(r,Gt(s.style,{zIndex:10})),kt(a,s.labelStyle),e.loadingShown||(kt(r,{opacity:0,display:""}),Is(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||Is(e,{opacity:0},{duration:t.loading.hideDuration||100,complete:function(){kt(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=[];j(n,"update",{options:t}),c||n.setResponsive(!1,!0),t=ua(t,n.options),n.userOptions=Ct(n.userOptions,t);let p=t.chart;p&&(Ct(!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&&da(this,p),Fs(p,function(f,x){n.propsRequireUpdateSeries.indexOf("chart."+x)!==-1&&(r=!0),n.propsRequireDirtyBox.indexOf(x)!==-1&&(n.isDirtyBox=!0),n.propsRequireReflow.indexOf(x)===-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),Fs(t,function(f,x){n[x]&&typeof n[x].update=="function"?n[x].update(f,!1):typeof n[l[x]]=="function"?n[l[x]](f):x!=="colors"&&n.collectionsWithUpdate.indexOf(x)===-1&&Ct(!0,n.options[x],t[x]),x!=="chart"&&n.propsRequireUpdateSeries.indexOf(x)!==-1&&(r=!0)}),this.collectionsWithUpdate.forEach(function(f){t[f]&&(Si(t[f]).forEach(function(x,m){let y,b=Ht(x.id);b&&(y=n.get(x.id)),!y&&n[f]&&(y=n[f][rt(x.index,m)])&&(b&&Ht(y.options.id)||y.options.isInternal)&&(y=void 0),y&&y.coll===f&&(y.update(x,!1),i&&(y.touched=!0)),!y&&i&&n.collectionsWithInit[f]&&(n.collectionsWithInit[f][0].apply(n,[x].concat(n.collectionsWithInit[f][1]||[]).concat([!1])).touched=!0)}),i&&n[f].forEach(function(x){x.touched||x.options.isInternal?delete x.touched:d.push(x)}))}),d.forEach(function(f){f.chart&&f.remove&&f.remove(!1)}),o&&n.axes.forEach(function(f){f.update({},!1)}),r&&n.getSeriesOrderByLinks().forEach(function(f){f.chart&&f.update({},!1)},this);let g=p?.width,u=p&&(Mi(p.height)?fa(p.height,g||n.chartWidth):p.height);a||ge(g)&&g!==n.chartWidth||ge(u)&&u!==n.chartHeight?n.setSize(g,u,s):rt(e,!0)&&n.redraw(s),j(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=Bs.lang,i=t.zooming.resetButton,s=i.theme,o=i.relativeTo==="chart"||i.relativeTo==="spacingBox"?null:"plotBox";function r(){t.zoomOut()}j(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)}),j(this,"afterShowResetZoom")}zoomOut(){j(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),j(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"}),kt(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,d=!1,p,g;for(let u of(this.hoverPoints?.forEach(f=>f.setState()),e)){let{horiz:f,len:x,minPointOffset:m=0,options:y,reversed:b}=u,v=f?"width":"height",S=f?"x":"y",w=rt(a[v],u.len),k=rt(s[v],u.len),M=10>Math.abs(w)?1:w/k,T=(s[S]||0)+k/2-u.pos,C=T-((a[S]??u.pos)+w/2-u.pos)/M,A=b&&!l||!b&&l?-1:1;if(!o&&(T<0||T>u.len))continue;let L=u.toValue(C,!0)+(r||u.isOrdinal?0:m*A),O=u.toValue(C+x/M,!0)-(r||u.isOrdinal?0:m*A||0),I=u.allExtremes;if(L>O&&([L,O]=[O,L]),M===1&&!o&&u.coll==="yAxis"&&!I){for(let pt of u.series){let Dt=pt.getExtremes(pt.getProcessedData(!0).modified.getColumn("y")||[],!0);I??(I={dataMin:Number.MAX_VALUE,dataMax:-Number.MAX_VALUE}),ge(Dt.dataMin)&&ge(Dt.dataMax)&&(I.dataMin=Math.min(Dt.dataMin,I.dataMin),I.dataMax=Math.max(Dt.dataMax,I.dataMax))}u.allExtremes=I}let{dataMin:D,dataMax:E,min:B,max:q}=Gt(u.getExtremes(),I||{}),Y=c.parse(y.min),ht=c.parse(y.max),R=D??Y,W=E??ht,G=O-L,F=u.categories?0:Math.min(G,W-R),V=R-F*(Ht(Y)?0:y.minPadding),$=W+F*(Ht(ht)?0:y.maxPadding),U=u.allowZoomOutside||M===1||n!=="zoom"&&M>1,K=Math.min(Y??V,V,U?B:V),lt=Math.max(ht??$,$,U?q:$);(!u.isOrdinal||u.options.overscroll||M!==1||o)&&(L<K&&(L=K,M>=1&&(O=L+G)),O>lt&&(O=lt,M>=1&&(L=O-G)),(o||u.series.length&&(L!==B||O!==q)&&L>=K&&O<=lt)&&(r?r[u.coll].push({axis:u,min:L,max:O}):(u.isPanning=n!=="zoom",u.isPanning&&(g=!0),u.setExtremes(o?void 0:L,o?void 0:O,!1,!1,{move:C,trigger:n,scale:M}),!o&&(L>K||O<lt)&&n!=="mousewheel"&&(p=!0)),d=!0),i&&(this[f?"mouseDownX":"mouseDownY"]=i[f?"chartX":"chartY"]))}return d&&(r?j(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}};Gt(jt.prototype,{callbacks:[],collectionsWithInit:{xAxis:[jt.prototype.addAxis,[!0]],yAxis:[jt.prototype.addAxis,[!1]],series:[jt.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:Zd}=nt,{composed:qd}=P,{addEvent:Ft,createElement:Ti,css:Ys,defined:Gs,erase:Kd,merge:xa,pushUnique:ya}=N;function _d(){let h=this.scrollablePlotArea;(this.scrollablePixelsX||this.scrollablePixelsY)&&!h&&(this.scrollablePlotArea=h=new qa(this)),h?.applyFixed()}function ba(){this.chart.scrollablePlotArea&&(this.chart.scrollablePlotArea.isDirty=!0)}var qa=(()=>{class h{static compose(e,i,s){ya(qd,this.compose)&&(Ft(e,"afterInit",ba),Ft(i,"afterSetChartSize",o=>this.afterSetSize(o.target,o)),Ft(i,"render",_d),Ft(s,"show",ba))}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&&(a?(e.scrollablePixelsX=s=Math.max(0,a-e.chartWidth),s&&(e.scrollablePlotBox=xa(e.plotBox),c.width=e.plotWidth+=s,l[d?"height":"width"]+=s,r=!0)):n&&(e.scrollablePixelsY=o=Math.max(0,n-e.chartHeight),Gs(o)&&(e.scrollablePlotBox=xa(e.plotBox),c.height=e.plotHeight+=o,l[d?"width":"height"]+=o,r=!1)),Gs(r)&&!i.skipAxes))for(let g of e.axes)(g.horiz===r||e.hasParallelCoordinates&&g.coll==="yAxis")&&(g.setAxisSize(),g.setAxisTranslation())}constructor(e){let i,s=e.options.chart,o=ei.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=Ti("div",{className:"highcharts-scrolling-parent"},{position:"relative"},e.renderTo),c=this.scrollingContainer=Ti("div",{className:"highcharts-scrolling"},n,l),d=this.innerContainer=Ti("div",{className:"highcharts-inner-container"},void 0,c),p=this.fixedDiv=Ti("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),Ys(e.renderTo,{overflow:"visible"}),Ft(e,"afterShowResetZoom",a),Ft(e,"afterApplyDrilldown",a),Ft(e,"afterLayOutTitles",a),Ft(c,"scroll",()=>{let{pointer:u,hoverPoint:f}=e;u&&(delete u.chartPosition,f&&(i=f),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:f=0}=e,{scrollPositionX:x=0,scrollPositionY:m=0}=e.options.chart.scrollablePlotArea||{},y=a+u,b=n+f;i.setSize(a,n),(s??!0)&&(this.isDirty=!1,this.moveFixedElements()),Zd(e.container),Ys(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}),Ys(o,{width:`${a}px`,height:`${n}px`}),Gs(s)||(o.scrollLeft=u*x,o.scrollTop=f*m);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-f,C=[["M",0,0]];u?C=[["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"]]:f&&(C=[["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:C})}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)`])ya(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)`])Kd(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:Jd}=bt,{series:Qd}=tt,{destroyObjectProperties:tc,fireEvent:va,getAlignFactor:js,isNumber:Us,pick:We}=N,Ka=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(){tc(this,this.axis)}render(h){let t=this.axis.chart,e=this.options,i=e.format,s=i?Jd(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:We(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,va(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),f=n.padding,x=We(l.overflow,"justify")==="justify",m;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),(m=d.isInsidePlot(n.alignAttr.x+r.x+y,n.alignAttr.y+r.y+b))||(x=!1),x&&Qd.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*js(l.textAlign||"center"),rotationOriginY:u.height/2}),We(!x&&l.crop,!0)&&(m=Us(n.x)&&Us(n.y)&&d.isInsidePlot(n.x-f+(n.width||0),n.y)&&d.isInsidePlot(n.x+f,n.y)),n[m?"show":"hide"]()}va(this,"afterSetOffset",{xOffset:h,width:t})}adjustStackPosition({labelBox:h,verticalAlign:t,textAlign:e}){return{x:h.width/2+h.width/2*(2*js(e)-1),y:h.height/2*2*(1-js(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:We(i,this.total,0),l=t.toPixels(n),c=h.xAxis||e.xAxis[0],d=We(s,c.translate(this.x))+o,p=Math.abs(l-t.toPixels(a||Us(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:ec}=nt,{series:{prototype:ic}}=tt,{addEvent:ka,correctFloat:Ge,defined:_a,destroyObjectProperties:sc,fireEvent:oc,isNumber:wo,objectEach:Qt,pick:Mo}=N;function rc(){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,Mo(t.options.stack,""),h?e.top:e.left,h?e.height:e.width].join(","))})}function ac(){let h=this.stacking;if(h){let t=h.stacks;Qt(t,(e,i)=>{sc(e),delete t[i]}),h.stackTotalGroup?.destroy()}}function nc(){this.stacking||(this.stacking=new So(this))}function hc(h,t,e,i){return!_a(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 lc(){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 dc(h,t,e){let i=t.total?100/t.total:0;h[0]=Ge(h[0]*i),h[1]=Ge(h[1]*i),this.stackedYData[e]=h[1]}function cc(h){(this.is("column")||this.is("columnrange"))&&(this.options.centerInCategory&&this.chart.series.length>1?ic.setStackedPoints.call(this,h,"group"):h.stacking.resetStacks())}function pc(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,f=u.threshold||0,x=u.startFromThreshold?f:0,m=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],C=wo(T)&&T||0;a=(e=this.getStackIndicator(e,M,this.index)).key||"",w[r=(i=v&&C<(x?0:f))?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 Ka(h,h.options.stackLabels,!!i,M,m)),s=w[r][M],T!==null?(s.points[a]=s.points[this.index]=[Mo(s.cumulative,x)],_a(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 A=s.total||0;l==="percent"?(o=i?y:b,A=v&&w[o]?.[M]?(o=w[o][M]).total=Math.max(o.total||0,A)+Math.abs(C):Ge(A+Math.abs(C))):l==="group"?wo(T)&&A++:A=Ge(A+C),l==="group"?s.cumulative=(A||1)-1:s.cumulative=Ge(Mo(s.cumulative,x)+C),s.total=A,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 So=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();oc(i,"afterBuildStacks")}cleanStacks(){this.oldStacks&&(this.stacks=this.oldStacks,Qt(this.stacks,t=>{Qt(t,e=>{e.cumulative=e.total})}))}resetStacks(){Qt(this.stacks,t=>{Qt(t,(e,i)=>{wo(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=ec(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),Qt(s,a=>{Qt(a,n=>{n.render(r)})}),r.animate({opacity:1},o)}};(ao||(ao={})).compose=function(h,t,e){let i=t.prototype,s=e.prototype;i.getStacks||(ka(h,"init",nc),ka(h,"destroy",ac),i.getStacks=rc,s.getStackIndicator=hc,s.modifyStacks=lc,s.percentStacker=dc,s.setGroupedPoints=cc,s.setStackedPoints=pc)};var gc=ao,{defined:uc,merge:Ja,isObject:fc}=N,ji=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&&Ja({filterUnits:"userSpaceOnUse"},fc(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,f=d.plotY,x=t[p-1],m=d.isNull||typeof f!="number";(d.leftCliff||x?.rightCliff)&&!i&&(n=!0),m&&!uc(e)&&p>0?n=!o.connectNulls:m&&!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",x.plotX,f]]:l===2?[["L",(x.plotX+u)/2,x.plotY],["L",(x.plotX+u)/2,f]]:[["L",u,x.plotY]]).push(["L",u,f]):g=[["L",u,f]],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}};ji.defaultOptions=Ja(ut.defaultOptions,{legendSymbol:"lineMarker"}),tt.registerSeriesType("line",ji);var{seriesTypes:{line:To}}=tt,{extend:mc,merge:xc,objectEach:yc,pick:Ci}=N,je=class extends To{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=To.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)),f=Ci(r.connectNulls,a==="percent"),x=function(w,k,M){let T=t[w],C=a&&p[T.x].points[d],A=T[M+"Null"]||0,L=T[M+"Cliff"]||0,O,I,D=!0;L||A?(O=(A?C[0]:C[1])+L,I=C[0]+L,D=!!A):!a&&t[k]&&t[k].isNull&&(O=I=g),O!==void 0&&(c.push({plotX:e,plotY:O===null?u:n.getThreshold(O),isNull:D,isCliff:!0}),l.push({plotX:e,plotY:I===null?u:n.getThreshold(I),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=Ci(t[w].rectPlotX,t[w].plotX),s=a?Ci(t[w].yBottom,u):u,i&&!f||(f||x(w,w-1,"left"),i&&!a&&f||(c.push(t[w]),l.push({x:w,plotX:e,plotY:s})),f||x(w,w+1,"right"));let m=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=m.concat(y);v.length&&v.push(["Z"]);let S=o.call(this,c,!1,f);return this.chart.series.length>1&&a&&c.some(w=>w.isCliff)&&(v.hasStackedCliffs=S.hasStackedCliffs=!0),v.xMap=m.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];yc(a,function(u,f){u.total!==null&&s.push(f)}),s.sort(function(u,f){return u-f});let g=l.map(u=>u.visible);s.forEach(function(u,f){let x=0,m,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[f+b]],w=0;if(S){let k=p;for(;k>=0&&k<c;){let M=l[k].index;!(m=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(m=a[u].points[v]){x=m[1];break}b+=d}x=Ci(x,0),x=r.translate(x,0,1,0,1),i.push({isNull:!0,plotX:o.translate(u,0,0,0,1),x:u,plotY:x,yBottom:x})}})}return i}};je.defaultOptions=xc(To.defaultOptions,{threshold:0,legendSymbol:"areaMarker"}),mc(je.prototype,{singleStacks:!1}),tt.registerSeriesType("area",je);var{line:Qa}=tt.seriesTypes,{merge:bc,pick:Ai}=N,ti=class extends Qa{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,f=c.plotY||0,x=d.plotX||0,m=d.plotY||0,y=0;s=(1.5*n+u)/2.5,o=(1.5*l+f)/2.5,r=(1.5*n+x)/2.5,a=(1.5*l+m)/2.5,r!==s&&(y=(a-o)*(r-n)/(r-s)+l-a),o+=y,a+=y,o>f&&o>l?(o=Math.max(f,l),a=2*l-o):o<f&&o<l&&(o=Math.min(f,l),a=2*l-o),a>m&&a>l?(a=Math.max(m,l),o=2*l-a):a<m&&a<l&&(a=Math.min(m,l),o=2*l-a),e.rightContX=r,e.rightContY=a,e.controlPoints={low:[s,o],high:[r,a]}}let g=["C",Ai(c.rightContX,c.plotX,0),Ai(c.rightContY,c.plotY,0),Ai(s,n,0),Ai(o,l,0),n,l];return c.rightContX=c.rightContY=void 0,g}};ti.defaultOptions=bc(Qa.defaultOptions),tt.registerSeriesType("spline",ti);var tn=ti,{area:vc,area:{prototype:Vs}}=tt.seriesTypes,{extend:kc,merge:wc}=N,Ue=class extends tn{};Ue.defaultOptions=wc(tn.defaultOptions,vc.defaultOptions),kc(Ue.prototype,{getGraphPath:Vs.getGraphPath,getStackPoints:Vs.getStackPoints,drawGraph:Vs.drawGraph}),tt.registerSeriesType("areaspline",Ue);var{animObject:Mc}=nt,{parse:Sc}=dt,{noop:Tc}=P,{clamp:Pi,crisp:Li,defined:wa,extend:en,fireEvent:Ma,isArray:Sa,isNumber:Oi,merge:Co,pick:Xe,objectEach:Cc}=N,ke=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=Pi(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},en(Mc(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(f){let x,m=f.yAxis,y=f.options;f.type===t.type&&f.reserveSpace()&&s.len===m.len&&s.pos===m.pos&&(y.stacking&&y.stacking!=="group"?(a[n=f.stackKey]===void 0&&(a[n]=l++),x=a[n]):y.grouping!==!1&&(x=l++),f.columnIndex=x)});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,Xe(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=Li(e+s,o,r)-(e=Li(e,o,r)),this.options.crisp&&(i=Li(t+i,o)-(t=Li(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;Cc(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&&Sa(d)){let g=this.index,u=Object.keys(c).filter(f=>!f.match(",")&&c[f]&&c[f].length>1).map(parseFloat).filter(f=>o.indexOf(f)!==-1).filter(f=>{let x=this.chart.series[f].options,m=x.stacking&&x.stack;if(wa(m)){if(Oi(p[m]))return g===f&&(g=p[m]),!1;p[m]=f}return!0}).sort((f,x)=>x-f);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=Xe(i.borderWidth,+!s),r=t.xAxis,a=t.yAxis,n=i.threshold,l=Xe(i.minPointLength,5),c=t.getColumnMetrics(),d=c.width,p=t.pointXOffset=c.offset,g=t.dataMin,u=t.dataMax,f=t.translatedThreshold=a.getThreshold(n),x=t.barW=Math.max(d,1+2*o);i.pointPadding&&i.crisp&&(x=Math.ceil(x)),ut.prototype.translate.apply(t),t.points.forEach(function(m){let y=Xe(m.yBottom,f),b=999+Math.abs(y),v=m.plotX||0,S=Pi(m.plotY,-b,a.len+b),w,k=Math.min(S,y),M=Math.max(S,y)-k,T=d,C=v+p,A=x;l&&Math.abs(M)<l&&(M=l,w=!a.reversed&&!m.negative||a.reversed&&m.negative,Oi(n)&&Oi(u)&&m.y===n&&u<=n&&(a.min||0)<n&&(g!==u||(a.max||0)<=n)&&(w=!w,m.negative=!m.negative),k=Math.abs(k-f)>l?y-l:f-(w?l:0)),wa(m.options.pointWidth)&&(C-=Math.round(((T=A=Math.ceil(m.options.pointWidth))-d)/2)),i.centerInCategory&&(C=t.adjustForMissingColumns(C,T,m,c)),m.barX=C,m.pointWidth=T,m.tooltipPos=e.inverted?[Pi(a.len+a.pos-e.plotLeft-S,a.pos-e.plotLeft,a.len+a.pos-e.plotLeft),r.len+r.pos-e.plotTop-C-A/2,M]:[r.left-e.plotLeft+C+A/2,Pi(S+a.pos-e.plotTop,a.pos-e.plotTop,a.len+a.pos-e.plotTop),M],m.shapeType=t.pointClass.prototype.shapeType||"roundedRect",m.shapeArgs=t.crispCol(C,k,A,m.isNull?0:M)}),Ma(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=Co(i.states[e],t.options.states&&t.options.states[e]||{})).brightness,c=a.color||l!==void 0&&Sc(c).brighten(a.brightness).get()||c,d=a[o]||d,g=a[r]||g,p=a.dashStyle||p,u=Xe(a.opacity,u));let f={fill:c,stroke:d,"stroke-width":g,opacity:u};return p&&(f.dashstyle=p),f}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";Oi(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](Co(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=Sa(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),Ma(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)}};ke.defaultOptions=Co(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"}),en(ke.prototype,{directTouch:!0,getSymbol:Tc,negStacks:!0,trackerGroups:["group","dataLabelsGroup"]}),tt.registerSeriesType("column",ke);var Ui=ke,{getDeferredAnimation:Ac}=nt,{format:Pc}=bt,{defined:_t,extend:Ta,fireEvent:$s,getAlignFactor:Ca,isArray:Yt,isString:He,merge:Fe,objectEach:Lc,pick:Ye,pInt:Oc,splat:Aa}=N;(function(h){function t(){return n(this).some(c=>c?.enabled)}function e(c,d,p,g,u){let{chart:f,enabledDataSorting:x}=this,m=this.isCartesian&&f.inverted,y=c.plotX,b=c.plotY,v=p.rotation||0,S=_t(y)&&_t(b)&&f.isInsidePlot(y,Math.round(b),{inverted:m,paneCoordinates:!0,series:this}),w=v===0&&Ye(p.overflow,x?"none":"justify")==="justify",k=this.visible&&c.visible!==!1&&_t(y)&&(c.series.forceDL||x&&!w||S||Ye(p.inside,!!this.options.stacking)&&g&&f.isInsidePlot(y,m?g.x+1:g.y+g.height-1,{inverted:m,paneCoordinates:!0,series:this})),M=c.pos();if(k&&M){var T;let C=d.getBBox(),A=d.getBBox(void 0,0);if(g=Ta({x:M[0],y:Math.round(M[1]),width:0,height:0},g||{}),p.alignTo==="plotEdges"&&this.isCartesian&&(g[m?"x":"y"]=0,g[m?"width":"height"]=this.yAxis?.len||0),Ta(p,{width:C.width,height:C.height}),T=g,x&&this.xAxis&&!w&&this.setDataLabelStartPos(c,d,u,S,T),d.align(Fe(p,{width:A.width,height:A.height}),!1,g,!1),d.alignAttr.x+=Ca(p.align)*(A.width-C.width),d.alignAttr.y+=Ca(p.verticalAlign)*(A.height-C.height),d[d.placed?"animate":"attr"]({"text-align":d.alignAttr["text-align"]||"center",x:d.alignAttr.x+(C.width-A.width)/2,y:d.alignAttr.y+(C.height-A.height)/2,rotationOriginX:(d.width||0)/2,rotationOriginY:(d.height||0)/2}),w&&g.height>=0)this.justifyDataLabel(d,p,d.alignAttr,C,g,u);else if(Ye(p.crop,!0)){let{x:L,y:O}=d.alignAttr;k=f.isInsidePlot(L,O,{paneCoordinates:!0,series:this})&&f.isInsidePlot(L+C.width-1,O+C.height-1,{paneCoordinates:!0,series:this})}p.shape&&!v&&d[u?"attr":"animate"]({anchorX:M[0],anchorY:M[1]})}u&&x&&(d.placed=!1),k||x&&!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)}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,f=g.renderer,{backgroundColor:x,plotBackgroundColor:m}=g.options.chart,y=f.getContrast(He(m)&&m||He(x)&&x||"#000000"),b=n(p),{animation:v,defer:S}=b[0],w=S?Ac(g,v,p):{defer:0,duration:0};$s(this,"drawDataLabels"),p.hasDataLabels?.()&&(d=this.initDataLabels(w),c.forEach(k=>{let M=k.dataLabels||[],T=k.color||p.color;Aa(a(b,k.dlOptions||k.options?.dataLabels)).forEach((A,L)=>{let O=A.enabled&&(k.visible||k.dataLabelOnHidden)&&(!k.isNull||k.dataLabelOnNull)&&(function(V,$){let U=$.filter;if(U){let K=U.operator,lt=V[U.property],pt=U.value;return K===">"&&lt>pt||K==="<"&&lt<pt||K===">="&&lt>=pt||K==="<="&&lt<=pt||K==="=="&&lt==pt||K==="==="&&lt===pt||K==="!="&&lt!=pt||K==="!=="&&lt!==pt||!1}return!0})(k,A),{backgroundColor:I,borderColor:D,distance:E,style:B={}}=A,q,Y,ht,R={},W=M[L],G=!W,F;O&&(Y=_t(q=Ye(A[k.formatPrefix+"Format"],A.format))?Pc(q,k,g):(A[k.formatPrefix+"Formatter"]||A.formatter).call(k,A),ht=A.rotation,!g.styledMode&&(B.color=Ye(A.color,B.color,He(p.color)?p.color:void 0,"#000000"),B.color==="contrast"?(I!=="none"&&(F=I),k.contrastColor=f.getContrast(F!=="auto"&&He(F)&&F||(He(T)?T:"")),B.color=F||!_t(E)&&A.inside||0>Oc(E||0)||u.stacking?k.contrastColor:y):delete k.contrastColor,u.cursor&&(B.cursor=u.cursor)),R={r:A.borderRadius||0,rotation:ht,padding:A.padding,zIndex:1},g.styledMode||(R.fill=I==="auto"?k.color:I,R.stroke=D==="auto"?k.color:D,R["stroke-width"]=A.borderWidth),Lc(R,(V,$)=>{V===void 0&&delete R[$]})),!W||O&&_t(Y)&&!!(W.div||W.text?.foreignObject)==!!A.useHTML&&(W.rotation&&A.rotation||W.rotation===A.rotation)||(W=void 0,G=!0),O&&_t(Y)&&(W?R.text=Y:(W=f.label(Y,0,0,A.shape,void 0,void 0,A.useHTML,void 0,"data-label")).addClass(" highcharts-data-label-color-"+k.colorIndex+" "+(A.className||"")+(A.useHTML?" highcharts-tracker":"")),W&&(W.options=A,W.attr(R),g.styledMode?B.width&&W.css({width:B.width,textOverflow:B.textOverflow,whiteSpace:B.whiteSpace}):W.css(B).shadow(A.shadow),$s(W,"beforeAddingDataLabel",{labelOptions:A,point:k}),W.added||W.add(d),p.alignDataLabel(k,W,A,void 0,G),W.isActive=!0,M[L]&&M[L]!==W&&M[L].destroy(),M[L]=W))});let C=M.length;for(;C--;)M[C]?.isActive?M[C].isActive=!1:(M[C]?.destroy(),M.splice(C,1));k.dataLabel=M[0],k.dataLabels=M})),$s(this,"afterDrawDataLabels")}function r(c,d,p,g,u,f){let x=this.chart,m=d.align,y=d.verticalAlign,b=c.box?0:c.padding||0,v=x.inverted?this.yAxis:this.xAxis,S=v?v.left-x.plotLeft:0,w=x.inverted?this.xAxis:this.yAxis,k=w?w.top-x.plotTop:0,{x:M=0,y:T=0}=d,C,A;return(C=(p.x||0)+b+S)<0&&(m==="right"&&M>=0?(d.align="left",d.inside=!0):M-=C,A=!0),(C=(p.x||0)+g.width-b+S)>x.plotWidth&&(m==="left"&&M<=0?(d.align="right",d.inside=!0):M+=x.plotWidth-C,A=!0),(C=p.y+b+k)<0&&(y==="bottom"&&T>=0?(d.verticalAlign="top",d.inside=!0):T-=C,A=!0),(C=(p.y||0)+g.height-b+k)>x.plotHeight&&(y==="top"&&T<=0?(d.verticalAlign="bottom",d.inside=!0):T+=x.plotHeight-C,A=!0),A&&(d.x=M,d.y=T,c.placed=!f,c.align(d,void 0,u)),A}function a(c,d){let p=[],g;if(Yt(c)&&!Yt(d))p=c.map(function(u){return Fe(u,d)});else if(Yt(d)&&!Yt(c))p=d.map(function(u){return Fe(c,u)});else if(Yt(c)||Yt(d)){if(Yt(c)&&Yt(d))for(g=Math.max(c.length,d.length);g--;)p[g]=Fe(c[g],d[g])}else p=Fe(c,d);return p}function n(c){let d=c.chart.options.plotOptions;return Aa(a(a(d?.series?.dataLabels,d?.[c.type]?.dataLabels),c.options.dataLabels))}function l(c,d,p,g,u){let f=this.chart,x=f.inverted,m=this.xAxis,y=m.reversed,b=((x?d.height:d.width)||0)/2,v=c.pointWidth,S=v?v/2:0;d.startXPos=x?u.x:y?-b-S:m.width-b+S,d.startYPos=x?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),f.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)}})(no||(no={}));var Vi=no,{composed:Ec}=P,{series:Pa}=tt,{merge:Ic,pushUnique:Dc}=N;(function(h){function t(e,i,s,o,r){let{chart:a,options:n}=this,l=a.inverted,c=this.xAxis?.len||a.plotSizeX||0,d=this.yAxis?.len||a.plotSizeY||0,p=e.dlBox||e.shapeArgs,g=e.below??(e.plotY||0)>(this.translatedThreshold??d),u=s.inside??!!n.stacking;if(p){if(o=Ic(p),s.overflow!=="allow"||s.crop!==!1||n.clip!==!1){o.y<0&&(o.height+=o.y,o.y=0);let f=o.y+o.height-d;f>0&&f<o.height-1&&(o.height-=f)}l&&(o={x:d-o.y-o.height,y:c-o.x-o.width,width:o.height,height:o.width}),u||(l?(o.x+=g?0:o.width,o.width=0):(o.y+=g?o.height:0,o.height=0))}s.align??(s.align=!l||u?"center":g?"right":"left"),s.verticalAlign??(s.verticalAlign=l||u?"middle":g?"top":"bottom"),Pa.prototype.alignDataLabel.call(this,e,i,s,o,r),s.inside&&e.contrastColor&&i.css({color:e.contrastColor})}h.compose=function(e){Vi.compose(Pa),Dc(Ec,"ColumnDataLabel")&&(e.prototype.alignDataLabel=t)}})(ho||(ho={}));var Bc=ho,{extend:Nc,merge:zc}=N,Ve=class extends Ui{};Ve.defaultOptions=zc(Ui.defaultOptions,{}),Nc(Ve.prototype,{inverted:!0}),tt.registerSeriesType("bar",Ve);var{column:Rc,line:sn}=tt.seriesTypes,{addEvent:Wc,extend:Xc,merge:Hc}=N,ye=class extends sn{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())}};ye.defaultOptions=Hc(sn.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/>"}}),Xc(ye.prototype,{drawTracker:Rc.prototype.drawTracker,sorted:!1,requireSorting:!1,noSharedTooltip:!0,trackerGroups:["group","markerGroup","dataLabelsGroup"]}),Wc(ye,"afterTranslate",function(){this.applyJitter()}),tt.registerSeriesType("scatter",ye);var{deg2rad:La}=P,{fireEvent:Fc,isNumber:Zs,pick:Ei,relativeLength:Yc}=N;(Ro=lo||(lo={})).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=[Ei(o?.[0],"50%"),Ei(o?.[1],"50%"),Ei(l&&l<0?void 0:h.size,"100%"),Ei(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]=Yc(p,[i,s,r,g[2]][d])+(n?e:0);return g[3]>g[2]&&(g[3]=g[2]),Zs(a)&&2*a<g[2]&&a>0&&(g[3]=g[2]-2*a),Fc(this,"afterGetCenter",{positions:g}),g},Ro.getStartAndEndRadians=function(h,t){let e=Zs(h)?h:0,i=Zs(t)&&t>e&&t-e<360?t:e+360;return{start:La*(e+-90),end:La*(i+-90)}};var on=lo,{setAnimation:Gc}=nt,{addEvent:Oa,defined:jc,extend:Uc,isNumber:Vc,pick:$c,relativeLength:Zc}=N,$i=class extends Ut{getConnectorPath(t){let e=t.dataLabelPosition,i=t.options||{},s=i.connectorShape,o=this.connectorShapes[s]||s;return e&&o.call(this,Te(Lt({},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")};Oa(this,"select",s),Oa(this,"unselect",s)}isValid(){return Vc(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;Gc(i,s.chart),e=$c(e,!0),this.sliced=this.options.sliced=t=jc(t)?t:!this.sliced,s.options.data[s.data.indexOf(this)]=this.options,this.graphic&&this.graphic.animate(this.getTranslate())}};Uc($i.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:f}=h,x=s.x;if(e.crookDistance){let y=Zc(e.crookDistance,1);x=g?a+c+(p+d-a-c)*(1-y):d+(a-c)*y}else x=a+(n-f)*Math.tan(i-Math.PI/2);let m=[["M",u,f]];return(g?x<=u&&x>=s.x:x>=u&&x<=s.x)&&m.push(["L",x,f]),m.push(["L",s.x,s.y],["L",o.x,o.y]),m}}});var{getStartAndEndRadians:qc}=on,{noop:Ea}=P,{clamp:Kc,extend:_c,fireEvent:Ia,merge:Ao,pick:Jc}=N,$e=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:Jc(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:Va.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(Kc((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.dataTable.rowCount}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||Ao(!0,n,i),Ao(!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){Ia(this,"translate"),this.generatePoints();let e=this.options,i=e.slicedOffset,s=qc(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,f,x,m=0;for(t||(this.center=t=this.getCenter()),f=0;f<l;f++){x=a[f],c=o+m*r,x.isValid()&&(!n||x.visible)&&(m+=x.percentage/100),d=o+m*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};x.shapeType="arc",x.shapeArgs=y,(p=(d+c)/2)>1.5*Math.PI?p-=2*Math.PI:p<-Math.PI/2&&(p+=2*Math.PI),x.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,x.tooltipPos=[t[0]+.7*g,t[1]+.7*u],x.half=+(p<-Math.PI/2||p>Math.PI/2),x.angle=p}Ia(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}};$e.defaultOptions=Ao(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}}}),_c($e.prototype,{axisTypes:[],directTouch:!0,drawGraph:void 0,drawTracker:Ui.prototype.drawTracker,getCenter:on.getCenter,getSymbol:Ea,invertible:!1,isCartesian:!1,noSharedTooltip:!0,pointAttribs:Ui.prototype.pointAttribs,pointClass:$i,requireSorting:!1,searchPoint:Ea,trackerGroups:["group","dataLabelsGroup"]}),tt.registerSeriesType("pie",$e);var{composed:Qc,noop:tp}=P,{distribute:ep}=Zi,{series:Da}=tt,{arrayMax:ip,clamp:Ba,defined:Na,pick:sp,pushUnique:op,relativeLength:za}=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,f=Math.cos(d),x=Math.sin(d),m=p[0]+f*u,y=p[1]+x*u,b=Math.min((g.slicedOffset||0)+(g.borderWidth||0),a/5);return{natural:{x:m+f*a,y:y+x*a},computed:{},alignment:a<0?"center":r.half?"right":"left",connectorPosition:{angle:d,breakAt:{x:m+f*b,y:y+x*b},touchingSliceAt:{x:m,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,f=g[1],x=[[],[]],m=[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)})}),Da.prototype.drawDataLabels.apply(r),a.forEach(k=>{(k.dataLabels||[]).forEach((M,T)=>{let C=g[2]/2,A=M.options,L=za(A?.distance||0,C);T===0&&x[k.half].push(k),!Na(A?.style?.width)&&M.getBBox().width>p&&(M.css({width:Math.round(.7*p)+"px"}),M.shortened=!0),M.dataLabelPosition=this.getDataLabelPosition(k,L),w=Math.max(w,L)})}),x.forEach((k,M)=>{let T=k.length,C=[],A,L,O=0,I;T&&(r.sortByAngle(k,M-.5),w>0&&(A=Math.max(0,f-u-w),L=Math.min(f+u+w,n.plotHeight),k.forEach(D=>{(D.dataLabels||[]).forEach(E=>{let B=E.dataLabelPosition;B&&B.distance>0&&(B.top=Math.max(0,f-u-B.distance),B.bottom=Math.min(f+u+B.distance,n.plotHeight),O=E.getBBox().height||21,E.lineHeight=n.renderer.fontMetrics(E.text||E).h+2*E.padding,D.distributeBox={target:(E.dataLabelPosition?.natural.y||0)-B.top+E.lineHeight/2,size:O,rank:D.y},C.push(D.distributeBox))})}),ep(C,I=L+O-A,I/5)),k.forEach(D=>{(D.dataLabels||[]).forEach(E=>{let B=E.options||{},q=D.distributeBox,Y=E.dataLabelPosition,ht=Y?.natural.y||0,R=B.connectorPadding||0,W=E.lineHeight||21,G=(W-E.getBBox().height)/2,F=0,V=ht,$="inherit";if(Y){if(C&&Na(q)&&Y.distance>0&&(q.pos===void 0?$="hidden":(S=q.size,V=y.radialDistributionY(D,E))),B.justify)F=y.justify(D,E,u,g);else switch(B.alignTo){case"connectors":F=y.alignToConnectors(k,M,l,d);break;case"plotEdges":F=y.alignToPlotEdges(E,M,l,d);break;default:F=y.radialDistributionX(r,D,V-G,ht,E)}if(Y.attribs={visibility:$,align:Y.alignment},Y.posAttribs={x:F+(B.x||0)+({left:R,right:-R}[Y.alignment]||0),y:V+(B.y||0)-W/2},Y.computed.x=F,Y.computed.y=V-G,sp(B.crop,!0)){let U;F-(v=E.getBBox().width)<R&&M===1?(U=Math.round(v-F+R),m[3]=Math.max(U,m[3])):F+v>l-R&&M===0&&(U=Math.round(F+v-l+R),m[1]=Math.max(U,m[1])),V-S/2<0?m[0]=Math.max(Math.round(-V+S/2),m[0]):V+S/2>c&&(m[2]=Math.max(Math.round(V+S/2-c),m[2])),Y.sideOverflow=U}}})}))}),(ip(m)===0||this.verifyDataLabelOverflow(m))&&(this.placeDataLabels(),this.points.forEach(k=>{(k.dataLabels||[]).forEach(M=>{let{connectorColor:T,connectorWidth:C=1}=M.options||{},A=M.dataLabelPosition;if(C){let L;b=M.connector,A&&A.distance>0?(L=!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":C,stroke:T||k.color||"#666666"}),b[L?"attr":"animate"]({d:k.getConnectorPath(M)}),b.attr({visibility:A.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=Ba(d,c,a[2]-Math.max(r[0],r[2])):(d=Ba(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,za(n.innerSize||0,d)),d),this.translate(a),this.drawDataLabels&&this.drawDataLabels()):p=!0),p}h.compose=function(r){if(Vi.compose(Da),op(Qc,"PieDataLabel")){let a=r.prototype;a.dataLabelPositioners=t,a.alignDataLabel=tp,a.drawDataLabels=i,a.getDataLabelPosition=e,a.placeDataLabels=s,a.verifyDataLabelOverflow=o}}})(co||(co={}));var rp=co;(ii=po||(po={})).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}},ii.getDistanceBetweenPoints=function(h,t){return Math.sqrt(Math.pow(t.x-h.x,2)+Math.pow(t.y-h.y,2))},ii.getAngleBetweenPoints=function(h,t){return Math.atan2(t.x-h.x,t.y-h.y)},ii.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:ap}=po,{addEvent:np,getAlignFactor:hp,fireEvent:rn,objectEach:Ra,pick:lp}=N;function dp(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(ap({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:f,width:x}=d.getBBox(),m=hp(d.alignValue)*x;return d.width=x,d.height=u,{x:g.x+(d.parentGroup?.translateX||0)+p-m,y:g.y+(d.parentGroup?.translateY||0)+p,width:x-2*p,height:u-2*p,polygon:f}}})(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 f=o.labelrank<r.labelrank?o:r,x=f.text;f.newOpacity=0,x?.element.querySelector("textPath")&&x.hide()}}}}for(let c of h)an(c,this)&&(l=!0);l&&rn(this,"afterHideAllOverlappingLabels")}function an(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"})}),rn(t,"afterHideOverlappingLabel")):h.attr({opacity:e})),h.isOld=!0),i}function cp(){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&&Ra(e.stacking.stacks,i=>{Ra(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=lp(a.labelrank,o.labelrank,o.shapeArgs?.height),a.allowOverlap??Number(a.distance)>0?(r.oldOpacity=r.opacity,r.newOpacity=1,an(r,h)):t.push(r)})};i(e.nodes||[]),i(e.points)}this.hideOverlappingLabels(t)}var Wa={compose:function(h){let t=h.prototype;t.hideOverlappingLabels||(t.hideOverlappingLabels=dp,np(h,"render",cp))}},{defaultOptions:pp}=yt,{noop:nn}=P,{addEvent:Xa,extend:gp,isObject:hn,merge:up,relativeLength:Lo}=N,fp={radius:0,scope:"stack",where:void 0},ln=nn,dn=nn;function mp(h,t,e,i,s={}){let o=ln(h,t,e,i,s),{innerR:r=0,r:a=e,start:n=0,end:l=0}=s;if(s.open||!s.borderRadius)return o;let c=l-n,d=Math.sin(c/2),p=Math.max(Math.min(Lo(s.borderRadius||0,a-r),(a-r)/2,a*d/(1+d)),0),g=Math.min(p,c/Math.PI*2*r),u=o.length-1;for(;u--;)(function(f,x,m){let y,b,v,S=f[x],w=f[x+1];if(w[0]==="Z"&&(w=f[0]),(S[0]==="M"||S[0]==="L")&&w[0]==="A"?(y=S,b=w,v=!0):S[0]==="A"&&(w[0]==="M"||w[0]==="L")&&(y=w,b=S),y&&b&&b.params){let k=b[1],M=b[5],T=b.params,{start:C,end:A,cx:L,cy:O}=T,I=M?k-m:k+m,D=I?Math.asin(m/I):0,E=M?D:-D,B=Math.cos(D)*I;v?(T.start=C+E,y[1]=L+B*Math.cos(C),y[2]=O+B*Math.sin(C),f.splice(x+1,0,["A",m,m,0,0,1,L+k*Math.cos(T.start),O+k*Math.sin(T.start)])):(T.end=A-E,b[6]=L+k*Math.cos(T.end),b[7]=O+k*Math.sin(T.end),f.splice(x+1,0,["A",m,m,0,0,1,L+B*Math.cos(A),O+B*Math.sin(A)])),b[4]=Math.abs(T.end-T.start)<Math.PI?0:1}})(o,u,u>1?g:p);return o}function xp(){if(this.options.borderRadius&&!(this.chart.is3d&&this.chart.is3d())){let{options:h,yAxis:t}=this,e=h.stacking==="percent",i=pp.plotOptions?.[this.type]?.borderRadius,s=Oo(h.borderRadius,hn(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 x=t.translate(e?100:r.stackTotal,!1,!0,!1,!0),m=t.translate(h.threshold||0,!1,!0,!1,!0),y=this.crispCol(0,Math.min(x,m),0,Math.abs(x-m));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 f=Math.min(Lo(s.radius,n),n/2,u==="all"?l/2:1/0)||0;u==="end"&&(g&&(d-=f),p+=f),gp(a,{brBoxHeight:p,brBoxY:d,r:f})}}}}function Oo(h,t){return hn(h)||(h={radius:h||0}),up(fp,t,h)}function yp(){let h=Oo(this.options.borderRadius);for(let t of this.points){let e=t.shapeArgs;e&&(e.borderRadius=Lo(h.radius,(e.r||0)-(e.innerR||0)))}}function bp(h,t,e,i,s={}){let o=dn(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),f=[h+d,t],x=[h+e-d,t],m=[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);f[0]-=M,x[0]+=M,m[1]=w[1]=t+d-g}if(i<d-g){let M=k(d,d-g-i);m[0]=y[0]=h+e-d+M,b[0]=Math.min(m[0],b[0]),v[0]=Math.max(y[0],v[0]),S[0]=w[0]=h+d-M,m[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);m[0]=y[0]=h+e-p+M,x[0]=Math.min(m[0],x[0]),f[0]=Math.max(y[0],f[0]),S[0]=w[0]=h+p-M,y[1]=S[1]=t}return o.length=0,o.push(["M",...f],["L",...x],["A",d,d,0,0,1,...m],["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,...f],["Z"]),o}var{diffObjects:vp,extend:kp,find:wp,merge:Mp,pick:Ii,uniqueKey:Sp}=N;(function(h){function t(i,s){let o=i.condition;(o.callback||function(){return this.chartWidth<=Ii(o.maxWidth,Number.MAX_VALUE)&&this.chartHeight<=Ii(o.maxHeight,Number.MAX_VALUE)&&this.chartWidth>=Ii(o.minWidth,0)&&this.chartHeight>=Ii(o.minHeight,0)}).call(this)&&s.push(i._id)}function e(i,s){let o=this.options.responsive,r=this.currentResponsive,a=[],n;!s&&o&&o.rules&&o.rules.forEach(d=>{d._id===void 0&&(d._id=Sp()),this.matchResponsiveRule(d,a)},this);let l=Mp(...a.map(d=>wp(o?.rules||[],p=>p._id===d)).map(d=>d?.chartOptions));l.isResponsiveOptions=!0,a=a.toString()||void 0;let c=r?.ruleIds;a===c||(r&&(this.currentResponsive=void 0,this.updatingResponsive=!0,this.update(r.undoOptions,i,!0),this.updatingResponsive=!1),a?((n=vp(l,this.options,!0,this.collectionsWithUpdate)).isResponsiveOptions=!0,this.currentResponsive={ruleIds:a,mergedOptions:l,undoOptions:n},this.updatingResponsive||this.update(l,i,!0)):this.currentResponsive=void 0)}h.compose=function(i){let s=i.prototype;return s.matchResponsiveRule||kp(s,{matchResponsiveRule:t,setResponsive:e}),i}})(go||(go={}));var Tp=go;P.AST=ot,P.Axis=vo,P.Chart=jt,P.Color=dt,P.DataLabel=Vi,P.DataTableCore=zi,P.Fx=ie,P.HTMLElement=_e,P.Legend=la,P.LegendSymbol=Za,P.OverlappingDataLabels=P.OverlappingDataLabels||Wa,P.PlotLineOrBand=Gi,P.Point=Ut,P.Pointer=$r,P.RendererRegistry=ei,P.Series=ut,P.SeriesRegistry=tt,P.StackItem=Ka,P.SVGElement=Pt,P.SVGRenderer=we,P.Templating=bt,P.Tick=xe,P.Time=Po,P.Tooltip=Yr,P.animate=nt.animate,P.animObject=nt.animObject,P.chart=jt.chart,P.color=dt.parse,P.dateFormat=bt.dateFormat,P.defaultOptions=yt.defaultOptions,P.distribute=Zi.distribute,P.format=bt.format,P.getDeferredAnimation=nt.getDeferredAnimation,P.getOptions=yt.getOptions,P.numberFormat=bt.numberFormat,P.seriesType=tt.seriesType,P.setAnimation=nt.setAnimation,P.setOptions=yt.setOptions,P.stop=nt.stop,P.time=yt.defaultTime,P.timers=ie.timers,{compose:function(h,t,e){let i=h.types.pie;if(!t.symbolCustomAttribs.includes("borderRadius")){let s=e.prototype.symbols;Xa(h,"afterColumnTranslate",xp,{order:9}),Xa(i,"afterTranslate",yp),t.symbolCustomAttribs.push("borderRadius","brBoxHeight","brBoxY"),ln=s.arc,dn=s.roundedRect,s.arc=mp,s.roundedRect=bp}},optionsToObject:Oo}.compose(P.Series,P.SVGElement,P.SVGRenderer),Bc.compose(P.Series.types.column),Vi.compose(P.Series),fl.compose(P.Axis),_e.compose(P.SVGRenderer),la.compose(P.Chart),yl.compose(P.Axis),Wa.compose(P.Chart),rp.compose(P.Series.types.pie),Gi.compose(P.Chart,P.Axis),$r.compose(P.Chart),Tp.compose(P.Chart),qa.compose(P.Axis,P.Chart,P.Series),gc.compose(P.Axis,P.Chart,P.Series),Yr.compose(P.Pointer),N.extend(P,N);var Cp=P;export{Cp as default};