Kilton937342 9fbd7ced9c frontend
2022-10-12 22:14:28 +02:00

8 lines
184 KiB
Plaintext

{
"version": 3,
"sources": ["../../.pnpm/chroma-js@2.4.2/node_modules/chroma-js/chroma.js", "dep:chroma-js"],
"sourcesContent": ["/**\n * chroma.js - JavaScript library for color conversions\n *\n * Copyright (c) 2011-2019, Gregor Aisch\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without\n * modification, are permitted provided that the following conditions are met:\n *\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n *\n * 2. Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the documentation\n * and/or other materials provided with the distribution.\n *\n * 3. The name Gregor Aisch may not be used to endorse or promote products\n * derived from this software without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,\n * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,\n * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,\n * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY\n * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING\n * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,\n * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n *\n * -------------------------------------------------------\n *\n * chroma.js includes colors from colorbrewer2.org, which are released under\n * the following license:\n *\n * Copyright (c) 2002 Cynthia Brewer, Mark Harrower,\n * and The Pennsylvania State University.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing,\n * software distributed under the License is distributed on an\n * \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,\n * either express or implied. See the License for the specific\n * language governing permissions and limitations under the License.\n *\n * ------------------------------------------------------\n *\n * Named colors are taken from X11 Color Names.\n * http://www.w3.org/TR/css3-color/#svg-color\n *\n * @preserve\n */\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.chroma = factory());\n})(this, (function () { 'use strict';\n\n var limit$2 = function (x, min, max) {\n if ( min === void 0 ) min=0;\n if ( max === void 0 ) max=1;\n\n return x < min ? min : x > max ? max : x;\n };\n\n var limit$1 = limit$2;\n\n var clip_rgb$3 = function (rgb) {\n rgb._clipped = false;\n rgb._unclipped = rgb.slice(0);\n for (var i=0; i<=3; i++) {\n if (i < 3) {\n if (rgb[i] < 0 || rgb[i] > 255) { rgb._clipped = true; }\n rgb[i] = limit$1(rgb[i], 0, 255);\n } else if (i === 3) {\n rgb[i] = limit$1(rgb[i], 0, 1);\n }\n }\n return rgb;\n };\n\n // ported from jQuery's $.type\n var classToType = {};\n for (var i$1 = 0, list$1 = ['Boolean', 'Number', 'String', 'Function', 'Array', 'Date', 'RegExp', 'Undefined', 'Null']; i$1 < list$1.length; i$1 += 1) {\n var name = list$1[i$1];\n\n classToType[(\"[object \" + name + \"]\")] = name.toLowerCase();\n }\n var type$p = function(obj) {\n return classToType[Object.prototype.toString.call(obj)] || \"object\";\n };\n\n var type$o = type$p;\n\n var unpack$B = function (args, keyOrder) {\n if ( keyOrder === void 0 ) keyOrder=null;\n\n \t// if called with more than 3 arguments, we return the arguments\n if (args.length >= 3) { return Array.prototype.slice.call(args); }\n // with less than 3 args we check if first arg is object\n // and use the keyOrder string to extract and sort properties\n \tif (type$o(args[0]) == 'object' && keyOrder) {\n \t\treturn keyOrder.split('')\n \t\t\t.filter(function (k) { return args[0][k] !== undefined; })\n \t\t\t.map(function (k) { return args[0][k]; });\n \t}\n \t// otherwise we just return the first argument\n \t// (which we suppose is an array of args)\n return args[0];\n };\n\n var type$n = type$p;\n\n var last$4 = function (args) {\n if (args.length < 2) { return null; }\n var l = args.length-1;\n if (type$n(args[l]) == 'string') { return args[l].toLowerCase(); }\n return null;\n };\n\n var PI$2 = Math.PI;\n\n var utils = {\n \tclip_rgb: clip_rgb$3,\n \tlimit: limit$2,\n \ttype: type$p,\n \tunpack: unpack$B,\n \tlast: last$4,\n \tPI: PI$2,\n \tTWOPI: PI$2*2,\n \tPITHIRD: PI$2/3,\n \tDEG2RAD: PI$2 / 180,\n \tRAD2DEG: 180 / PI$2\n };\n\n var input$h = {\n \tformat: {},\n \tautodetect: []\n };\n\n var last$3 = utils.last;\n var clip_rgb$2 = utils.clip_rgb;\n var type$m = utils.type;\n var _input = input$h;\n\n var Color$D = function Color() {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var me = this;\n if (type$m(args[0]) === 'object' &&\n args[0].constructor &&\n args[0].constructor === this.constructor) {\n // the argument is already a Color instance\n return args[0];\n }\n\n // last argument could be the mode\n var mode = last$3(args);\n var autodetect = false;\n\n if (!mode) {\n autodetect = true;\n if (!_input.sorted) {\n _input.autodetect = _input.autodetect.sort(function (a,b) { return b.p - a.p; });\n _input.sorted = true;\n }\n // auto-detect format\n for (var i = 0, list = _input.autodetect; i < list.length; i += 1) {\n var chk = list[i];\n\n mode = chk.test.apply(chk, args);\n if (mode) { break; }\n }\n }\n\n if (_input.format[mode]) {\n var rgb = _input.format[mode].apply(null, autodetect ? args : args.slice(0,-1));\n me._rgb = clip_rgb$2(rgb);\n } else {\n throw new Error('unknown format: '+args);\n }\n\n // add alpha channel\n if (me._rgb.length === 3) { me._rgb.push(1); }\n };\n\n Color$D.prototype.toString = function toString () {\n if (type$m(this.hex) == 'function') { return this.hex(); }\n return (\"[\" + (this._rgb.join(',')) + \"]\");\n };\n\n var Color_1 = Color$D;\n\n var chroma$k = function () {\n \tvar args = [], len = arguments.length;\n \twhile ( len-- ) args[ len ] = arguments[ len ];\n\n \treturn new (Function.prototype.bind.apply( chroma$k.Color, [ null ].concat( args) ));\n };\n\n chroma$k.Color = Color_1;\n chroma$k.version = '2.4.2';\n\n var chroma_1 = chroma$k;\n\n var unpack$A = utils.unpack;\n var max$2 = Math.max;\n\n var rgb2cmyk$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$A(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n r = r / 255;\n g = g / 255;\n b = b / 255;\n var k = 1 - max$2(r,max$2(g,b));\n var f = k < 1 ? 1 / (1-k) : 0;\n var c = (1-r-k) * f;\n var m = (1-g-k) * f;\n var y = (1-b-k) * f;\n return [c,m,y,k];\n };\n\n var rgb2cmyk_1 = rgb2cmyk$1;\n\n var unpack$z = utils.unpack;\n\n var cmyk2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$z(args, 'cmyk');\n var c = args[0];\n var m = args[1];\n var y = args[2];\n var k = args[3];\n var alpha = args.length > 4 ? args[4] : 1;\n if (k === 1) { return [0,0,0,alpha]; }\n return [\n c >= 1 ? 0 : 255 * (1-c) * (1-k), // r\n m >= 1 ? 0 : 255 * (1-m) * (1-k), // g\n y >= 1 ? 0 : 255 * (1-y) * (1-k), // b\n alpha\n ];\n };\n\n var cmyk2rgb_1 = cmyk2rgb;\n\n var chroma$j = chroma_1;\n var Color$C = Color_1;\n var input$g = input$h;\n var unpack$y = utils.unpack;\n var type$l = utils.type;\n\n var rgb2cmyk = rgb2cmyk_1;\n\n Color$C.prototype.cmyk = function() {\n return rgb2cmyk(this._rgb);\n };\n\n chroma$j.cmyk = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$C, [ null ].concat( args, ['cmyk']) ));\n };\n\n input$g.format.cmyk = cmyk2rgb_1;\n\n input$g.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$y(args, 'cmyk');\n if (type$l(args) === 'array' && args.length === 4) {\n return 'cmyk';\n }\n }\n });\n\n var unpack$x = utils.unpack;\n var last$2 = utils.last;\n var rnd = function (a) { return Math.round(a*100)/100; };\n\n /*\n * supported arguments:\n * - hsl2css(h,s,l)\n * - hsl2css(h,s,l,a)\n * - hsl2css([h,s,l], mode)\n * - hsl2css([h,s,l,a], mode)\n * - hsl2css({h,s,l,a}, mode)\n */\n var hsl2css$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var hsla = unpack$x(args, 'hsla');\n var mode = last$2(args) || 'lsa';\n hsla[0] = rnd(hsla[0] || 0);\n hsla[1] = rnd(hsla[1]*100) + '%';\n hsla[2] = rnd(hsla[2]*100) + '%';\n if (mode === 'hsla' || (hsla.length > 3 && hsla[3]<1)) {\n hsla[3] = hsla.length > 3 ? hsla[3] : 1;\n mode = 'hsla';\n } else {\n hsla.length = 3;\n }\n return (mode + \"(\" + (hsla.join(',')) + \")\");\n };\n\n var hsl2css_1 = hsl2css$1;\n\n var unpack$w = utils.unpack;\n\n /*\n * supported arguments:\n * - rgb2hsl(r,g,b)\n * - rgb2hsl(r,g,b,a)\n * - rgb2hsl([r,g,b])\n * - rgb2hsl([r,g,b,a])\n * - rgb2hsl({r,g,b,a})\n */\n var rgb2hsl$3 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$w(args, 'rgba');\n var r = args[0];\n var g = args[1];\n var b = args[2];\n\n r /= 255;\n g /= 255;\n b /= 255;\n\n var min = Math.min(r, g, b);\n var max = Math.max(r, g, b);\n\n var l = (max + min) / 2;\n var s, h;\n\n if (max === min){\n s = 0;\n h = Number.NaN;\n } else {\n s = l < 0.5 ? (max - min) / (max + min) : (max - min) / (2 - max - min);\n }\n\n if (r == max) { h = (g - b) / (max - min); }\n else if (g == max) { h = 2 + (b - r) / (max - min); }\n else if (b == max) { h = 4 + (r - g) / (max - min); }\n\n h *= 60;\n if (h < 0) { h += 360; }\n if (args.length>3 && args[3]!==undefined) { return [h,s,l,args[3]]; }\n return [h,s,l];\n };\n\n var rgb2hsl_1 = rgb2hsl$3;\n\n var unpack$v = utils.unpack;\n var last$1 = utils.last;\n var hsl2css = hsl2css_1;\n var rgb2hsl$2 = rgb2hsl_1;\n var round$6 = Math.round;\n\n /*\n * supported arguments:\n * - rgb2css(r,g,b)\n * - rgb2css(r,g,b,a)\n * - rgb2css([r,g,b], mode)\n * - rgb2css([r,g,b,a], mode)\n * - rgb2css({r,g,b,a}, mode)\n */\n var rgb2css$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgba = unpack$v(args, 'rgba');\n var mode = last$1(args) || 'rgb';\n if (mode.substr(0,3) == 'hsl') {\n return hsl2css(rgb2hsl$2(rgba), mode);\n }\n rgba[0] = round$6(rgba[0]);\n rgba[1] = round$6(rgba[1]);\n rgba[2] = round$6(rgba[2]);\n if (mode === 'rgba' || (rgba.length > 3 && rgba[3]<1)) {\n rgba[3] = rgba.length > 3 ? rgba[3] : 1;\n mode = 'rgba';\n }\n return (mode + \"(\" + (rgba.slice(0,mode==='rgb'?3:4).join(',')) + \")\");\n };\n\n var rgb2css_1 = rgb2css$1;\n\n var unpack$u = utils.unpack;\n var round$5 = Math.round;\n\n var hsl2rgb$1 = function () {\n var assign;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n args = unpack$u(args, 'hsl');\n var h = args[0];\n var s = args[1];\n var l = args[2];\n var r,g,b;\n if (s === 0) {\n r = g = b = l*255;\n } else {\n var t3 = [0,0,0];\n var c = [0,0,0];\n var t2 = l < 0.5 ? l * (1+s) : l+s-l*s;\n var t1 = 2 * l - t2;\n var h_ = h / 360;\n t3[0] = h_ + 1/3;\n t3[1] = h_;\n t3[2] = h_ - 1/3;\n for (var i=0; i<3; i++) {\n if (t3[i] < 0) { t3[i] += 1; }\n if (t3[i] > 1) { t3[i] -= 1; }\n if (6 * t3[i] < 1)\n { c[i] = t1 + (t2 - t1) * 6 * t3[i]; }\n else if (2 * t3[i] < 1)\n { c[i] = t2; }\n else if (3 * t3[i] < 2)\n { c[i] = t1 + (t2 - t1) * ((2 / 3) - t3[i]) * 6; }\n else\n { c[i] = t1; }\n }\n (assign = [round$5(c[0]*255),round$5(c[1]*255),round$5(c[2]*255)], r = assign[0], g = assign[1], b = assign[2]);\n }\n if (args.length > 3) {\n // keep alpha channel\n return [r,g,b,args[3]];\n }\n return [r,g,b,1];\n };\n\n var hsl2rgb_1 = hsl2rgb$1;\n\n var hsl2rgb = hsl2rgb_1;\n var input$f = input$h;\n\n var RE_RGB = /^rgb\\(\\s*(-?\\d+),\\s*(-?\\d+)\\s*,\\s*(-?\\d+)\\s*\\)$/;\n var RE_RGBA = /^rgba\\(\\s*(-?\\d+),\\s*(-?\\d+)\\s*,\\s*(-?\\d+)\\s*,\\s*([01]|[01]?\\.\\d+)\\)$/;\n var RE_RGB_PCT = /^rgb\\(\\s*(-?\\d+(?:\\.\\d+)?)%,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var RE_RGBA_PCT = /^rgba\\(\\s*(-?\\d+(?:\\.\\d+)?)%,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*([01]|[01]?\\.\\d+)\\)$/;\n var RE_HSL = /^hsl\\(\\s*(-?\\d+(?:\\.\\d+)?),\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*\\)$/;\n var RE_HSLA = /^hsla\\(\\s*(-?\\d+(?:\\.\\d+)?),\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*(-?\\d+(?:\\.\\d+)?)%\\s*,\\s*([01]|[01]?\\.\\d+)\\)$/;\n\n var round$4 = Math.round;\n\n var css2rgb$1 = function (css) {\n css = css.toLowerCase().trim();\n var m;\n\n if (input$f.format.named) {\n try {\n return input$f.format.named(css);\n } catch (e) {\n // eslint-disable-next-line\n }\n }\n\n // rgb(250,20,0)\n if ((m = css.match(RE_RGB))) {\n var rgb = m.slice(1,4);\n for (var i=0; i<3; i++) {\n rgb[i] = +rgb[i];\n }\n rgb[3] = 1; // default alpha\n return rgb;\n }\n\n // rgba(250,20,0,0.4)\n if ((m = css.match(RE_RGBA))) {\n var rgb$1 = m.slice(1,5);\n for (var i$1=0; i$1<4; i$1++) {\n rgb$1[i$1] = +rgb$1[i$1];\n }\n return rgb$1;\n }\n\n // rgb(100%,0%,0%)\n if ((m = css.match(RE_RGB_PCT))) {\n var rgb$2 = m.slice(1,4);\n for (var i$2=0; i$2<3; i$2++) {\n rgb$2[i$2] = round$4(rgb$2[i$2] * 2.55);\n }\n rgb$2[3] = 1; // default alpha\n return rgb$2;\n }\n\n // rgba(100%,0%,0%,0.4)\n if ((m = css.match(RE_RGBA_PCT))) {\n var rgb$3 = m.slice(1,5);\n for (var i$3=0; i$3<3; i$3++) {\n rgb$3[i$3] = round$4(rgb$3[i$3] * 2.55);\n }\n rgb$3[3] = +rgb$3[3];\n return rgb$3;\n }\n\n // hsl(0,100%,50%)\n if ((m = css.match(RE_HSL))) {\n var hsl = m.slice(1,4);\n hsl[1] *= 0.01;\n hsl[2] *= 0.01;\n var rgb$4 = hsl2rgb(hsl);\n rgb$4[3] = 1;\n return rgb$4;\n }\n\n // hsla(0,100%,50%,0.5)\n if ((m = css.match(RE_HSLA))) {\n var hsl$1 = m.slice(1,4);\n hsl$1[1] *= 0.01;\n hsl$1[2] *= 0.01;\n var rgb$5 = hsl2rgb(hsl$1);\n rgb$5[3] = +m[4]; // default alpha = 1\n return rgb$5;\n }\n };\n\n css2rgb$1.test = function (s) {\n return RE_RGB.test(s) ||\n RE_RGBA.test(s) ||\n RE_RGB_PCT.test(s) ||\n RE_RGBA_PCT.test(s) ||\n RE_HSL.test(s) ||\n RE_HSLA.test(s);\n };\n\n var css2rgb_1 = css2rgb$1;\n\n var chroma$i = chroma_1;\n var Color$B = Color_1;\n var input$e = input$h;\n var type$k = utils.type;\n\n var rgb2css = rgb2css_1;\n var css2rgb = css2rgb_1;\n\n Color$B.prototype.css = function(mode) {\n return rgb2css(this._rgb, mode);\n };\n\n chroma$i.css = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$B, [ null ].concat( args, ['css']) ));\n };\n\n input$e.format.css = css2rgb;\n\n input$e.autodetect.push({\n p: 5,\n test: function (h) {\n var rest = [], len = arguments.length - 1;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];\n\n if (!rest.length && type$k(h) === 'string' && css2rgb.test(h)) {\n return 'css';\n }\n }\n });\n\n var Color$A = Color_1;\n var chroma$h = chroma_1;\n var input$d = input$h;\n var unpack$t = utils.unpack;\n\n input$d.format.gl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgb = unpack$t(args, 'rgba');\n rgb[0] *= 255;\n rgb[1] *= 255;\n rgb[2] *= 255;\n return rgb;\n };\n\n chroma$h.gl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$A, [ null ].concat( args, ['gl']) ));\n };\n\n Color$A.prototype.gl = function() {\n var rgb = this._rgb;\n return [rgb[0]/255, rgb[1]/255, rgb[2]/255, rgb[3]];\n };\n\n var unpack$s = utils.unpack;\n\n var rgb2hcg$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$s(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var min = Math.min(r, g, b);\n var max = Math.max(r, g, b);\n var delta = max - min;\n var c = delta * 100 / 255;\n var _g = min / (255 - delta) * 100;\n var h;\n if (delta === 0) {\n h = Number.NaN;\n } else {\n if (r === max) { h = (g - b) / delta; }\n if (g === max) { h = 2+(b - r) / delta; }\n if (b === max) { h = 4+(r - g) / delta; }\n h *= 60;\n if (h < 0) { h += 360; }\n }\n return [h, c, _g];\n };\n\n var rgb2hcg_1 = rgb2hcg$1;\n\n var unpack$r = utils.unpack;\n var floor$3 = Math.floor;\n\n /*\n * this is basically just HSV with some minor tweaks\n *\n * hue.. [0..360]\n * chroma .. [0..1]\n * grayness .. [0..1]\n */\n\n var hcg2rgb = function () {\n var assign, assign$1, assign$2, assign$3, assign$4, assign$5;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n args = unpack$r(args, 'hcg');\n var h = args[0];\n var c = args[1];\n var _g = args[2];\n var r,g,b;\n _g = _g * 255;\n var _c = c * 255;\n if (c === 0) {\n r = g = b = _g;\n } else {\n if (h === 360) { h = 0; }\n if (h > 360) { h -= 360; }\n if (h < 0) { h += 360; }\n h /= 60;\n var i = floor$3(h);\n var f = h - i;\n var p = _g * (1 - c);\n var q = p + _c * (1 - f);\n var t = p + _c * f;\n var v = p + _c;\n switch (i) {\n case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break\n case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break\n case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break\n case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break\n case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break\n case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break\n }\n }\n return [r, g, b, args.length > 3 ? args[3] : 1];\n };\n\n var hcg2rgb_1 = hcg2rgb;\n\n var unpack$q = utils.unpack;\n var type$j = utils.type;\n var chroma$g = chroma_1;\n var Color$z = Color_1;\n var input$c = input$h;\n\n var rgb2hcg = rgb2hcg_1;\n\n Color$z.prototype.hcg = function() {\n return rgb2hcg(this._rgb);\n };\n\n chroma$g.hcg = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$z, [ null ].concat( args, ['hcg']) ));\n };\n\n input$c.format.hcg = hcg2rgb_1;\n\n input$c.autodetect.push({\n p: 1,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$q(args, 'hcg');\n if (type$j(args) === 'array' && args.length === 3) {\n return 'hcg';\n }\n }\n });\n\n var unpack$p = utils.unpack;\n var last = utils.last;\n var round$3 = Math.round;\n\n var rgb2hex$2 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$p(args, 'rgba');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var a = ref[3];\n var mode = last(args) || 'auto';\n if (a === undefined) { a = 1; }\n if (mode === 'auto') {\n mode = a < 1 ? 'rgba' : 'rgb';\n }\n r = round$3(r);\n g = round$3(g);\n b = round$3(b);\n var u = r << 16 | g << 8 | b;\n var str = \"000000\" + u.toString(16); //#.toUpperCase();\n str = str.substr(str.length - 6);\n var hxa = '0' + round$3(a * 255).toString(16);\n hxa = hxa.substr(hxa.length - 2);\n switch (mode.toLowerCase()) {\n case 'rgba': return (\"#\" + str + hxa);\n case 'argb': return (\"#\" + hxa + str);\n default: return (\"#\" + str);\n }\n };\n\n var rgb2hex_1 = rgb2hex$2;\n\n var RE_HEX = /^#?([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;\n var RE_HEXA = /^#?([A-Fa-f0-9]{8}|[A-Fa-f0-9]{4})$/;\n\n var hex2rgb$1 = function (hex) {\n if (hex.match(RE_HEX)) {\n // remove optional leading #\n if (hex.length === 4 || hex.length === 7) {\n hex = hex.substr(1);\n }\n // expand short-notation to full six-digit\n if (hex.length === 3) {\n hex = hex.split('');\n hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2];\n }\n var u = parseInt(hex, 16);\n var r = u >> 16;\n var g = u >> 8 & 0xFF;\n var b = u & 0xFF;\n return [r,g,b,1];\n }\n\n // match rgba hex format, eg #FF000077\n if (hex.match(RE_HEXA)) {\n if (hex.length === 5 || hex.length === 9) {\n // remove optional leading #\n hex = hex.substr(1);\n }\n // expand short-notation to full eight-digit\n if (hex.length === 4) {\n hex = hex.split('');\n hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2]+hex[3]+hex[3];\n }\n var u$1 = parseInt(hex, 16);\n var r$1 = u$1 >> 24 & 0xFF;\n var g$1 = u$1 >> 16 & 0xFF;\n var b$1 = u$1 >> 8 & 0xFF;\n var a = Math.round((u$1 & 0xFF) / 0xFF * 100) / 100;\n return [r$1,g$1,b$1,a];\n }\n\n // we used to check for css colors here\n // if _input.css? and rgb = _input.css hex\n // return rgb\n\n throw new Error((\"unknown hex color: \" + hex));\n };\n\n var hex2rgb_1 = hex2rgb$1;\n\n var chroma$f = chroma_1;\n var Color$y = Color_1;\n var type$i = utils.type;\n var input$b = input$h;\n\n var rgb2hex$1 = rgb2hex_1;\n\n Color$y.prototype.hex = function(mode) {\n return rgb2hex$1(this._rgb, mode);\n };\n\n chroma$f.hex = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$y, [ null ].concat( args, ['hex']) ));\n };\n\n input$b.format.hex = hex2rgb_1;\n input$b.autodetect.push({\n p: 4,\n test: function (h) {\n var rest = [], len = arguments.length - 1;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];\n\n if (!rest.length && type$i(h) === 'string' && [3,4,5,6,7,8,9].indexOf(h.length) >= 0) {\n return 'hex';\n }\n }\n });\n\n var unpack$o = utils.unpack;\n var TWOPI$2 = utils.TWOPI;\n var min$2 = Math.min;\n var sqrt$4 = Math.sqrt;\n var acos = Math.acos;\n\n var rgb2hsi$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n /*\n borrowed from here:\n http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/rgb2hsi.cpp\n */\n var ref = unpack$o(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n r /= 255;\n g /= 255;\n b /= 255;\n var h;\n var min_ = min$2(r,g,b);\n var i = (r+g+b) / 3;\n var s = i > 0 ? 1 - min_/i : 0;\n if (s === 0) {\n h = NaN;\n } else {\n h = ((r-g)+(r-b)) / 2;\n h /= sqrt$4((r-g)*(r-g) + (r-b)*(g-b));\n h = acos(h);\n if (b > g) {\n h = TWOPI$2 - h;\n }\n h /= TWOPI$2;\n }\n return [h*360,s,i];\n };\n\n var rgb2hsi_1 = rgb2hsi$1;\n\n var unpack$n = utils.unpack;\n var limit = utils.limit;\n var TWOPI$1 = utils.TWOPI;\n var PITHIRD = utils.PITHIRD;\n var cos$4 = Math.cos;\n\n /*\n * hue [0..360]\n * saturation [0..1]\n * intensity [0..1]\n */\n var hsi2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n /*\n borrowed from here:\n http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/hsi2rgb.cpp\n */\n args = unpack$n(args, 'hsi');\n var h = args[0];\n var s = args[1];\n var i = args[2];\n var r,g,b;\n\n if (isNaN(h)) { h = 0; }\n if (isNaN(s)) { s = 0; }\n // normalize hue\n if (h > 360) { h -= 360; }\n if (h < 0) { h += 360; }\n h /= 360;\n if (h < 1/3) {\n b = (1-s)/3;\n r = (1+s*cos$4(TWOPI$1*h)/cos$4(PITHIRD-TWOPI$1*h))/3;\n g = 1 - (b+r);\n } else if (h < 2/3) {\n h -= 1/3;\n r = (1-s)/3;\n g = (1+s*cos$4(TWOPI$1*h)/cos$4(PITHIRD-TWOPI$1*h))/3;\n b = 1 - (r+g);\n } else {\n h -= 2/3;\n g = (1-s)/3;\n b = (1+s*cos$4(TWOPI$1*h)/cos$4(PITHIRD-TWOPI$1*h))/3;\n r = 1 - (g+b);\n }\n r = limit(i*r*3);\n g = limit(i*g*3);\n b = limit(i*b*3);\n return [r*255, g*255, b*255, args.length > 3 ? args[3] : 1];\n };\n\n var hsi2rgb_1 = hsi2rgb;\n\n var unpack$m = utils.unpack;\n var type$h = utils.type;\n var chroma$e = chroma_1;\n var Color$x = Color_1;\n var input$a = input$h;\n\n var rgb2hsi = rgb2hsi_1;\n\n Color$x.prototype.hsi = function() {\n return rgb2hsi(this._rgb);\n };\n\n chroma$e.hsi = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$x, [ null ].concat( args, ['hsi']) ));\n };\n\n input$a.format.hsi = hsi2rgb_1;\n\n input$a.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$m(args, 'hsi');\n if (type$h(args) === 'array' && args.length === 3) {\n return 'hsi';\n }\n }\n });\n\n var unpack$l = utils.unpack;\n var type$g = utils.type;\n var chroma$d = chroma_1;\n var Color$w = Color_1;\n var input$9 = input$h;\n\n var rgb2hsl$1 = rgb2hsl_1;\n\n Color$w.prototype.hsl = function() {\n return rgb2hsl$1(this._rgb);\n };\n\n chroma$d.hsl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$w, [ null ].concat( args, ['hsl']) ));\n };\n\n input$9.format.hsl = hsl2rgb_1;\n\n input$9.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$l(args, 'hsl');\n if (type$g(args) === 'array' && args.length === 3) {\n return 'hsl';\n }\n }\n });\n\n var unpack$k = utils.unpack;\n var min$1 = Math.min;\n var max$1 = Math.max;\n\n /*\n * supported arguments:\n * - rgb2hsv(r,g,b)\n * - rgb2hsv([r,g,b])\n * - rgb2hsv({r,g,b})\n */\n var rgb2hsl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$k(args, 'rgb');\n var r = args[0];\n var g = args[1];\n var b = args[2];\n var min_ = min$1(r, g, b);\n var max_ = max$1(r, g, b);\n var delta = max_ - min_;\n var h,s,v;\n v = max_ / 255.0;\n if (max_ === 0) {\n h = Number.NaN;\n s = 0;\n } else {\n s = delta / max_;\n if (r === max_) { h = (g - b) / delta; }\n if (g === max_) { h = 2+(b - r) / delta; }\n if (b === max_) { h = 4+(r - g) / delta; }\n h *= 60;\n if (h < 0) { h += 360; }\n }\n return [h, s, v]\n };\n\n var rgb2hsv$1 = rgb2hsl;\n\n var unpack$j = utils.unpack;\n var floor$2 = Math.floor;\n\n var hsv2rgb = function () {\n var assign, assign$1, assign$2, assign$3, assign$4, assign$5;\n\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n args = unpack$j(args, 'hsv');\n var h = args[0];\n var s = args[1];\n var v = args[2];\n var r,g,b;\n v *= 255;\n if (s === 0) {\n r = g = b = v;\n } else {\n if (h === 360) { h = 0; }\n if (h > 360) { h -= 360; }\n if (h < 0) { h += 360; }\n h /= 60;\n\n var i = floor$2(h);\n var f = h - i;\n var p = v * (1 - s);\n var q = v * (1 - s * f);\n var t = v * (1 - s * (1 - f));\n\n switch (i) {\n case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break\n case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break\n case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break\n case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break\n case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break\n case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break\n }\n }\n return [r,g,b,args.length > 3?args[3]:1];\n };\n\n var hsv2rgb_1 = hsv2rgb;\n\n var unpack$i = utils.unpack;\n var type$f = utils.type;\n var chroma$c = chroma_1;\n var Color$v = Color_1;\n var input$8 = input$h;\n\n var rgb2hsv = rgb2hsv$1;\n\n Color$v.prototype.hsv = function() {\n return rgb2hsv(this._rgb);\n };\n\n chroma$c.hsv = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$v, [ null ].concat( args, ['hsv']) ));\n };\n\n input$8.format.hsv = hsv2rgb_1;\n\n input$8.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$i(args, 'hsv');\n if (type$f(args) === 'array' && args.length === 3) {\n return 'hsv';\n }\n }\n });\n\n var labConstants = {\n // Corresponds roughly to RGB brighter/darker\n Kn: 18,\n\n // D65 standard referent\n Xn: 0.950470,\n Yn: 1,\n Zn: 1.088830,\n\n t0: 0.137931034, // 4 / 29\n t1: 0.206896552, // 6 / 29\n t2: 0.12841855, // 3 * t1 * t1\n t3: 0.008856452, // t1 * t1 * t1\n };\n\n var LAB_CONSTANTS$3 = labConstants;\n var unpack$h = utils.unpack;\n var pow$a = Math.pow;\n\n var rgb2lab$2 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$h(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var ref$1 = rgb2xyz(r,g,b);\n var x = ref$1[0];\n var y = ref$1[1];\n var z = ref$1[2];\n var l = 116 * y - 16;\n return [l < 0 ? 0 : l, 500 * (x - y), 200 * (y - z)];\n };\n\n var rgb_xyz = function (r) {\n if ((r /= 255) <= 0.04045) { return r / 12.92; }\n return pow$a((r + 0.055) / 1.055, 2.4);\n };\n\n var xyz_lab = function (t) {\n if (t > LAB_CONSTANTS$3.t3) { return pow$a(t, 1 / 3); }\n return t / LAB_CONSTANTS$3.t2 + LAB_CONSTANTS$3.t0;\n };\n\n var rgb2xyz = function (r,g,b) {\n r = rgb_xyz(r);\n g = rgb_xyz(g);\n b = rgb_xyz(b);\n var x = xyz_lab((0.4124564 * r + 0.3575761 * g + 0.1804375 * b) / LAB_CONSTANTS$3.Xn);\n var y = xyz_lab((0.2126729 * r + 0.7151522 * g + 0.0721750 * b) / LAB_CONSTANTS$3.Yn);\n var z = xyz_lab((0.0193339 * r + 0.1191920 * g + 0.9503041 * b) / LAB_CONSTANTS$3.Zn);\n return [x,y,z];\n };\n\n var rgb2lab_1 = rgb2lab$2;\n\n var LAB_CONSTANTS$2 = labConstants;\n var unpack$g = utils.unpack;\n var pow$9 = Math.pow;\n\n /*\n * L* [0..100]\n * a [-100..100]\n * b [-100..100]\n */\n var lab2rgb$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$g(args, 'lab');\n var l = args[0];\n var a = args[1];\n var b = args[2];\n var x,y,z, r,g,b_;\n\n y = (l + 16) / 116;\n x = isNaN(a) ? y : y + a / 500;\n z = isNaN(b) ? y : y - b / 200;\n\n y = LAB_CONSTANTS$2.Yn * lab_xyz(y);\n x = LAB_CONSTANTS$2.Xn * lab_xyz(x);\n z = LAB_CONSTANTS$2.Zn * lab_xyz(z);\n\n r = xyz_rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z); // D65 -> sRGB\n g = xyz_rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z);\n b_ = xyz_rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z);\n\n return [r,g,b_,args.length > 3 ? args[3] : 1];\n };\n\n var xyz_rgb = function (r) {\n return 255 * (r <= 0.00304 ? 12.92 * r : 1.055 * pow$9(r, 1 / 2.4) - 0.055)\n };\n\n var lab_xyz = function (t) {\n return t > LAB_CONSTANTS$2.t1 ? t * t * t : LAB_CONSTANTS$2.t2 * (t - LAB_CONSTANTS$2.t0)\n };\n\n var lab2rgb_1 = lab2rgb$1;\n\n var unpack$f = utils.unpack;\n var type$e = utils.type;\n var chroma$b = chroma_1;\n var Color$u = Color_1;\n var input$7 = input$h;\n\n var rgb2lab$1 = rgb2lab_1;\n\n Color$u.prototype.lab = function() {\n return rgb2lab$1(this._rgb);\n };\n\n chroma$b.lab = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$u, [ null ].concat( args, ['lab']) ));\n };\n\n input$7.format.lab = lab2rgb_1;\n\n input$7.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$f(args, 'lab');\n if (type$e(args) === 'array' && args.length === 3) {\n return 'lab';\n }\n }\n });\n\n var unpack$e = utils.unpack;\n var RAD2DEG = utils.RAD2DEG;\n var sqrt$3 = Math.sqrt;\n var atan2$2 = Math.atan2;\n var round$2 = Math.round;\n\n var lab2lch$2 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$e(args, 'lab');\n var l = ref[0];\n var a = ref[1];\n var b = ref[2];\n var c = sqrt$3(a * a + b * b);\n var h = (atan2$2(b, a) * RAD2DEG + 360) % 360;\n if (round$2(c*10000) === 0) { h = Number.NaN; }\n return [l, c, h];\n };\n\n var lab2lch_1 = lab2lch$2;\n\n var unpack$d = utils.unpack;\n var rgb2lab = rgb2lab_1;\n var lab2lch$1 = lab2lch_1;\n\n var rgb2lch$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$d(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var ref$1 = rgb2lab(r,g,b);\n var l = ref$1[0];\n var a = ref$1[1];\n var b_ = ref$1[2];\n return lab2lch$1(l,a,b_);\n };\n\n var rgb2lch_1 = rgb2lch$1;\n\n var unpack$c = utils.unpack;\n var DEG2RAD = utils.DEG2RAD;\n var sin$3 = Math.sin;\n var cos$3 = Math.cos;\n\n var lch2lab$2 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n /*\n Convert from a qualitative parameter h and a quantitative parameter l to a 24-bit pixel.\n These formulas were invented by David Dalrymple to obtain maximum contrast without going\n out of gamut if the parameters are in the range 0-1.\n\n A saturation multiplier was added by Gregor Aisch\n */\n var ref = unpack$c(args, 'lch');\n var l = ref[0];\n var c = ref[1];\n var h = ref[2];\n if (isNaN(h)) { h = 0; }\n h = h * DEG2RAD;\n return [l, cos$3(h) * c, sin$3(h) * c]\n };\n\n var lch2lab_1 = lch2lab$2;\n\n var unpack$b = utils.unpack;\n var lch2lab$1 = lch2lab_1;\n var lab2rgb = lab2rgb_1;\n\n var lch2rgb$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$b(args, 'lch');\n var l = args[0];\n var c = args[1];\n var h = args[2];\n var ref = lch2lab$1 (l,c,h);\n var L = ref[0];\n var a = ref[1];\n var b_ = ref[2];\n var ref$1 = lab2rgb (L,a,b_);\n var r = ref$1[0];\n var g = ref$1[1];\n var b = ref$1[2];\n return [r, g, b, args.length > 3 ? args[3] : 1];\n };\n\n var lch2rgb_1 = lch2rgb$1;\n\n var unpack$a = utils.unpack;\n var lch2rgb = lch2rgb_1;\n\n var hcl2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var hcl = unpack$a(args, 'hcl').reverse();\n return lch2rgb.apply(void 0, hcl);\n };\n\n var hcl2rgb_1 = hcl2rgb;\n\n var unpack$9 = utils.unpack;\n var type$d = utils.type;\n var chroma$a = chroma_1;\n var Color$t = Color_1;\n var input$6 = input$h;\n\n var rgb2lch = rgb2lch_1;\n\n Color$t.prototype.lch = function() { return rgb2lch(this._rgb); };\n Color$t.prototype.hcl = function() { return rgb2lch(this._rgb).reverse(); };\n\n chroma$a.lch = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$t, [ null ].concat( args, ['lch']) ));\n };\n chroma$a.hcl = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$t, [ null ].concat( args, ['hcl']) ));\n };\n\n input$6.format.lch = lch2rgb_1;\n input$6.format.hcl = hcl2rgb_1;\n\n ['lch','hcl'].forEach(function (m) { return input$6.autodetect.push({\n p: 2,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$9(args, m);\n if (type$d(args) === 'array' && args.length === 3) {\n return m;\n }\n }\n }); });\n\n /**\n \tX11 color names\n\n \thttp://www.w3.org/TR/css3-color/#svg-color\n */\n\n var w3cx11$1 = {\n aliceblue: '#f0f8ff',\n antiquewhite: '#faebd7',\n aqua: '#00ffff',\n aquamarine: '#7fffd4',\n azure: '#f0ffff',\n beige: '#f5f5dc',\n bisque: '#ffe4c4',\n black: '#000000',\n blanchedalmond: '#ffebcd',\n blue: '#0000ff',\n blueviolet: '#8a2be2',\n brown: '#a52a2a',\n burlywood: '#deb887',\n cadetblue: '#5f9ea0',\n chartreuse: '#7fff00',\n chocolate: '#d2691e',\n coral: '#ff7f50',\n cornflower: '#6495ed',\n cornflowerblue: '#6495ed',\n cornsilk: '#fff8dc',\n crimson: '#dc143c',\n cyan: '#00ffff',\n darkblue: '#00008b',\n darkcyan: '#008b8b',\n darkgoldenrod: '#b8860b',\n darkgray: '#a9a9a9',\n darkgreen: '#006400',\n darkgrey: '#a9a9a9',\n darkkhaki: '#bdb76b',\n darkmagenta: '#8b008b',\n darkolivegreen: '#556b2f',\n darkorange: '#ff8c00',\n darkorchid: '#9932cc',\n darkred: '#8b0000',\n darksalmon: '#e9967a',\n darkseagreen: '#8fbc8f',\n darkslateblue: '#483d8b',\n darkslategray: '#2f4f4f',\n darkslategrey: '#2f4f4f',\n darkturquoise: '#00ced1',\n darkviolet: '#9400d3',\n deeppink: '#ff1493',\n deepskyblue: '#00bfff',\n dimgray: '#696969',\n dimgrey: '#696969',\n dodgerblue: '#1e90ff',\n firebrick: '#b22222',\n floralwhite: '#fffaf0',\n forestgreen: '#228b22',\n fuchsia: '#ff00ff',\n gainsboro: '#dcdcdc',\n ghostwhite: '#f8f8ff',\n gold: '#ffd700',\n goldenrod: '#daa520',\n gray: '#808080',\n green: '#008000',\n greenyellow: '#adff2f',\n grey: '#808080',\n honeydew: '#f0fff0',\n hotpink: '#ff69b4',\n indianred: '#cd5c5c',\n indigo: '#4b0082',\n ivory: '#fffff0',\n khaki: '#f0e68c',\n laserlemon: '#ffff54',\n lavender: '#e6e6fa',\n lavenderblush: '#fff0f5',\n lawngreen: '#7cfc00',\n lemonchiffon: '#fffacd',\n lightblue: '#add8e6',\n lightcoral: '#f08080',\n lightcyan: '#e0ffff',\n lightgoldenrod: '#fafad2',\n lightgoldenrodyellow: '#fafad2',\n lightgray: '#d3d3d3',\n lightgreen: '#90ee90',\n lightgrey: '#d3d3d3',\n lightpink: '#ffb6c1',\n lightsalmon: '#ffa07a',\n lightseagreen: '#20b2aa',\n lightskyblue: '#87cefa',\n lightslategray: '#778899',\n lightslategrey: '#778899',\n lightsteelblue: '#b0c4de',\n lightyellow: '#ffffe0',\n lime: '#00ff00',\n limegreen: '#32cd32',\n linen: '#faf0e6',\n magenta: '#ff00ff',\n maroon: '#800000',\n maroon2: '#7f0000',\n maroon3: '#b03060',\n mediumaquamarine: '#66cdaa',\n mediumblue: '#0000cd',\n mediumorchid: '#ba55d3',\n mediumpurple: '#9370db',\n mediumseagreen: '#3cb371',\n mediumslateblue: '#7b68ee',\n mediumspringgreen: '#00fa9a',\n mediumturquoise: '#48d1cc',\n mediumvioletred: '#c71585',\n midnightblue: '#191970',\n mintcream: '#f5fffa',\n mistyrose: '#ffe4e1',\n moccasin: '#ffe4b5',\n navajowhite: '#ffdead',\n navy: '#000080',\n oldlace: '#fdf5e6',\n olive: '#808000',\n olivedrab: '#6b8e23',\n orange: '#ffa500',\n orangered: '#ff4500',\n orchid: '#da70d6',\n palegoldenrod: '#eee8aa',\n palegreen: '#98fb98',\n paleturquoise: '#afeeee',\n palevioletred: '#db7093',\n papayawhip: '#ffefd5',\n peachpuff: '#ffdab9',\n peru: '#cd853f',\n pink: '#ffc0cb',\n plum: '#dda0dd',\n powderblue: '#b0e0e6',\n purple: '#800080',\n purple2: '#7f007f',\n purple3: '#a020f0',\n rebeccapurple: '#663399',\n red: '#ff0000',\n rosybrown: '#bc8f8f',\n royalblue: '#4169e1',\n saddlebrown: '#8b4513',\n salmon: '#fa8072',\n sandybrown: '#f4a460',\n seagreen: '#2e8b57',\n seashell: '#fff5ee',\n sienna: '#a0522d',\n silver: '#c0c0c0',\n skyblue: '#87ceeb',\n slateblue: '#6a5acd',\n slategray: '#708090',\n slategrey: '#708090',\n snow: '#fffafa',\n springgreen: '#00ff7f',\n steelblue: '#4682b4',\n tan: '#d2b48c',\n teal: '#008080',\n thistle: '#d8bfd8',\n tomato: '#ff6347',\n turquoise: '#40e0d0',\n violet: '#ee82ee',\n wheat: '#f5deb3',\n white: '#ffffff',\n whitesmoke: '#f5f5f5',\n yellow: '#ffff00',\n yellowgreen: '#9acd32'\n };\n\n var w3cx11_1 = w3cx11$1;\n\n var Color$s = Color_1;\n var input$5 = input$h;\n var type$c = utils.type;\n\n var w3cx11 = w3cx11_1;\n var hex2rgb = hex2rgb_1;\n var rgb2hex = rgb2hex_1;\n\n Color$s.prototype.name = function() {\n var hex = rgb2hex(this._rgb, 'rgb');\n for (var i = 0, list = Object.keys(w3cx11); i < list.length; i += 1) {\n var n = list[i];\n\n if (w3cx11[n] === hex) { return n.toLowerCase(); }\n }\n return hex;\n };\n\n input$5.format.named = function (name) {\n name = name.toLowerCase();\n if (w3cx11[name]) { return hex2rgb(w3cx11[name]); }\n throw new Error('unknown color name: '+name);\n };\n\n input$5.autodetect.push({\n p: 5,\n test: function (h) {\n var rest = [], len = arguments.length - 1;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];\n\n if (!rest.length && type$c(h) === 'string' && w3cx11[h.toLowerCase()]) {\n return 'named';\n }\n }\n });\n\n var unpack$8 = utils.unpack;\n\n var rgb2num$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$8(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n return (r << 16) + (g << 8) + b;\n };\n\n var rgb2num_1 = rgb2num$1;\n\n var type$b = utils.type;\n\n var num2rgb = function (num) {\n if (type$b(num) == \"number\" && num >= 0 && num <= 0xFFFFFF) {\n var r = num >> 16;\n var g = (num >> 8) & 0xFF;\n var b = num & 0xFF;\n return [r,g,b,1];\n }\n throw new Error(\"unknown num color: \"+num);\n };\n\n var num2rgb_1 = num2rgb;\n\n var chroma$9 = chroma_1;\n var Color$r = Color_1;\n var input$4 = input$h;\n var type$a = utils.type;\n\n var rgb2num = rgb2num_1;\n\n Color$r.prototype.num = function() {\n return rgb2num(this._rgb);\n };\n\n chroma$9.num = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$r, [ null ].concat( args, ['num']) ));\n };\n\n input$4.format.num = num2rgb_1;\n\n input$4.autodetect.push({\n p: 5,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n if (args.length === 1 && type$a(args[0]) === 'number' && args[0] >= 0 && args[0] <= 0xFFFFFF) {\n return 'num';\n }\n }\n });\n\n var chroma$8 = chroma_1;\n var Color$q = Color_1;\n var input$3 = input$h;\n var unpack$7 = utils.unpack;\n var type$9 = utils.type;\n var round$1 = Math.round;\n\n Color$q.prototype.rgb = function(rnd) {\n if ( rnd === void 0 ) rnd=true;\n\n if (rnd === false) { return this._rgb.slice(0,3); }\n return this._rgb.slice(0,3).map(round$1);\n };\n\n Color$q.prototype.rgba = function(rnd) {\n if ( rnd === void 0 ) rnd=true;\n\n return this._rgb.slice(0,4).map(function (v,i) {\n return i<3 ? (rnd === false ? v : round$1(v)) : v;\n });\n };\n\n chroma$8.rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$q, [ null ].concat( args, ['rgb']) ));\n };\n\n input$3.format.rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgba = unpack$7(args, 'rgba');\n if (rgba[3] === undefined) { rgba[3] = 1; }\n return rgba;\n };\n\n input$3.autodetect.push({\n p: 3,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$7(args, 'rgba');\n if (type$9(args) === 'array' && (args.length === 3 ||\n args.length === 4 && type$9(args[3]) == 'number' && args[3] >= 0 && args[3] <= 1)) {\n return 'rgb';\n }\n }\n });\n\n /*\n * Based on implementation by Neil Bartlett\n * https://github.com/neilbartlett/color-temperature\n */\n\n var log$1 = Math.log;\n\n var temperature2rgb$1 = function (kelvin) {\n var temp = kelvin / 100;\n var r,g,b;\n if (temp < 66) {\n r = 255;\n g = temp < 6 ? 0 : -155.25485562709179 - 0.44596950469579133 * (g = temp-2) + 104.49216199393888 * log$1(g);\n b = temp < 20 ? 0 : -254.76935184120902 + 0.8274096064007395 * (b = temp-10) + 115.67994401066147 * log$1(b);\n } else {\n r = 351.97690566805693 + 0.114206453784165 * (r = temp-55) - 40.25366309332127 * log$1(r);\n g = 325.4494125711974 + 0.07943456536662342 * (g = temp-50) - 28.0852963507957 * log$1(g);\n b = 255;\n }\n return [r,g,b,1];\n };\n\n var temperature2rgb_1 = temperature2rgb$1;\n\n /*\n * Based on implementation by Neil Bartlett\n * https://github.com/neilbartlett/color-temperature\n **/\n\n var temperature2rgb = temperature2rgb_1;\n var unpack$6 = utils.unpack;\n var round = Math.round;\n\n var rgb2temperature$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var rgb = unpack$6(args, 'rgb');\n var r = rgb[0], b = rgb[2];\n var minTemp = 1000;\n var maxTemp = 40000;\n var eps = 0.4;\n var temp;\n while (maxTemp - minTemp > eps) {\n temp = (maxTemp + minTemp) * 0.5;\n var rgb$1 = temperature2rgb(temp);\n if ((rgb$1[2] / rgb$1[0]) >= (b / r)) {\n maxTemp = temp;\n } else {\n minTemp = temp;\n }\n }\n return round(temp);\n };\n\n var rgb2temperature_1 = rgb2temperature$1;\n\n var chroma$7 = chroma_1;\n var Color$p = Color_1;\n var input$2 = input$h;\n\n var rgb2temperature = rgb2temperature_1;\n\n Color$p.prototype.temp =\n Color$p.prototype.kelvin =\n Color$p.prototype.temperature = function() {\n return rgb2temperature(this._rgb);\n };\n\n chroma$7.temp =\n chroma$7.kelvin =\n chroma$7.temperature = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$p, [ null ].concat( args, ['temp']) ));\n };\n\n input$2.format.temp =\n input$2.format.kelvin =\n input$2.format.temperature = temperature2rgb_1;\n\n var unpack$5 = utils.unpack;\n var cbrt = Math.cbrt;\n var pow$8 = Math.pow;\n var sign$1 = Math.sign;\n\n var rgb2oklab$2 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n // OKLab color space implementation taken from\n // https://bottosson.github.io/posts/oklab/\n var ref = unpack$5(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var ref$1 = [rgb2lrgb(r / 255), rgb2lrgb(g / 255), rgb2lrgb(b / 255)];\n var lr = ref$1[0];\n var lg = ref$1[1];\n var lb = ref$1[2];\n var l = cbrt(0.4122214708 * lr + 0.5363325363 * lg + 0.0514459929 * lb);\n var m = cbrt(0.2119034982 * lr + 0.6806995451 * lg + 0.1073969566 * lb);\n var s = cbrt(0.0883024619 * lr + 0.2817188376 * lg + 0.6299787005 * lb);\n\n return [\n 0.2104542553 * l + 0.793617785 * m - 0.0040720468 * s,\n 1.9779984951 * l - 2.428592205 * m + 0.4505937099 * s,\n 0.0259040371 * l + 0.7827717662 * m - 0.808675766 * s\n ];\n };\n\n var rgb2oklab_1 = rgb2oklab$2;\n\n function rgb2lrgb(c) {\n var abs = Math.abs(c);\n if (abs < 0.04045) {\n return c / 12.92;\n }\n return (sign$1(c) || 1) * pow$8((abs + 0.055) / 1.055, 2.4);\n }\n\n var unpack$4 = utils.unpack;\n var pow$7 = Math.pow;\n var sign = Math.sign;\n\n /*\n * L* [0..100]\n * a [-100..100]\n * b [-100..100]\n */\n var oklab2rgb$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$4(args, 'lab');\n var L = args[0];\n var a = args[1];\n var b = args[2];\n\n var l = pow$7(L + 0.3963377774 * a + 0.2158037573 * b, 3);\n var m = pow$7(L - 0.1055613458 * a - 0.0638541728 * b, 3);\n var s = pow$7(L - 0.0894841775 * a - 1.291485548 * b, 3);\n\n return [\n 255 * lrgb2rgb(+4.0767416621 * l - 3.3077115913 * m + 0.2309699292 * s),\n 255 * lrgb2rgb(-1.2684380046 * l + 2.6097574011 * m - 0.3413193965 * s),\n 255 * lrgb2rgb(-0.0041960863 * l - 0.7034186147 * m + 1.707614701 * s),\n args.length > 3 ? args[3] : 1\n ];\n };\n\n var oklab2rgb_1 = oklab2rgb$1;\n\n function lrgb2rgb(c) {\n var abs = Math.abs(c);\n if (abs > 0.0031308) {\n return (sign(c) || 1) * (1.055 * pow$7(abs, 1 / 2.4) - 0.055);\n }\n return c * 12.92;\n }\n\n var unpack$3 = utils.unpack;\n var type$8 = utils.type;\n var chroma$6 = chroma_1;\n var Color$o = Color_1;\n var input$1 = input$h;\n\n var rgb2oklab$1 = rgb2oklab_1;\n\n Color$o.prototype.oklab = function () {\n return rgb2oklab$1(this._rgb);\n };\n\n chroma$6.oklab = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$o, [ null ].concat( args, ['oklab']) ));\n };\n\n input$1.format.oklab = oklab2rgb_1;\n\n input$1.autodetect.push({\n p: 3,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$3(args, 'oklab');\n if (type$8(args) === 'array' && args.length === 3) {\n return 'oklab';\n }\n }\n });\n\n var unpack$2 = utils.unpack;\n var rgb2oklab = rgb2oklab_1;\n var lab2lch = lab2lch_1;\n\n var rgb2oklch$1 = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var ref = unpack$2(args, 'rgb');\n var r = ref[0];\n var g = ref[1];\n var b = ref[2];\n var ref$1 = rgb2oklab(r, g, b);\n var l = ref$1[0];\n var a = ref$1[1];\n var b_ = ref$1[2];\n return lab2lch(l, a, b_);\n };\n\n var rgb2oklch_1 = rgb2oklch$1;\n\n var unpack$1 = utils.unpack;\n var lch2lab = lch2lab_1;\n var oklab2rgb = oklab2rgb_1;\n\n var oklch2rgb = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack$1(args, 'lch');\n var l = args[0];\n var c = args[1];\n var h = args[2];\n var ref = lch2lab(l, c, h);\n var L = ref[0];\n var a = ref[1];\n var b_ = ref[2];\n var ref$1 = oklab2rgb(L, a, b_);\n var r = ref$1[0];\n var g = ref$1[1];\n var b = ref$1[2];\n return [r, g, b, args.length > 3 ? args[3] : 1];\n };\n\n var oklch2rgb_1 = oklch2rgb;\n\n var unpack = utils.unpack;\n var type$7 = utils.type;\n var chroma$5 = chroma_1;\n var Color$n = Color_1;\n var input = input$h;\n\n var rgb2oklch = rgb2oklch_1;\n\n Color$n.prototype.oklch = function () {\n return rgb2oklch(this._rgb);\n };\n\n chroma$5.oklch = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n return new (Function.prototype.bind.apply( Color$n, [ null ].concat( args, ['oklch']) ));\n };\n\n input.format.oklch = oklch2rgb_1;\n\n input.autodetect.push({\n p: 3,\n test: function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n args = unpack(args, 'oklch');\n if (type$7(args) === 'array' && args.length === 3) {\n return 'oklch';\n }\n }\n });\n\n var Color$m = Color_1;\n var type$6 = utils.type;\n\n Color$m.prototype.alpha = function(a, mutate) {\n if ( mutate === void 0 ) mutate=false;\n\n if (a !== undefined && type$6(a) === 'number') {\n if (mutate) {\n this._rgb[3] = a;\n return this;\n }\n return new Color$m([this._rgb[0], this._rgb[1], this._rgb[2], a], 'rgb');\n }\n return this._rgb[3];\n };\n\n var Color$l = Color_1;\n\n Color$l.prototype.clipped = function() {\n return this._rgb._clipped || false;\n };\n\n var Color$k = Color_1;\n var LAB_CONSTANTS$1 = labConstants;\n\n Color$k.prototype.darken = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \tvar me = this;\n \tvar lab = me.lab();\n \tlab[0] -= LAB_CONSTANTS$1.Kn * amount;\n \treturn new Color$k(lab, 'lab').alpha(me.alpha(), true);\n };\n\n Color$k.prototype.brighten = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \treturn this.darken(-amount);\n };\n\n Color$k.prototype.darker = Color$k.prototype.darken;\n Color$k.prototype.brighter = Color$k.prototype.brighten;\n\n var Color$j = Color_1;\n\n Color$j.prototype.get = function (mc) {\n var ref = mc.split('.');\n var mode = ref[0];\n var channel = ref[1];\n var src = this[mode]();\n if (channel) {\n var i = mode.indexOf(channel) - (mode.substr(0, 2) === 'ok' ? 2 : 0);\n if (i > -1) { return src[i]; }\n throw new Error((\"unknown channel \" + channel + \" in mode \" + mode));\n } else {\n return src;\n }\n };\n\n var Color$i = Color_1;\n var type$5 = utils.type;\n var pow$6 = Math.pow;\n\n var EPS = 1e-7;\n var MAX_ITER = 20;\n\n Color$i.prototype.luminance = function(lum) {\n if (lum !== undefined && type$5(lum) === 'number') {\n if (lum === 0) {\n // return pure black\n return new Color$i([0,0,0,this._rgb[3]], 'rgb');\n }\n if (lum === 1) {\n // return pure white\n return new Color$i([255,255,255,this._rgb[3]], 'rgb');\n }\n // compute new color using...\n var cur_lum = this.luminance();\n var mode = 'rgb';\n var max_iter = MAX_ITER;\n\n var test = function (low, high) {\n var mid = low.interpolate(high, 0.5, mode);\n var lm = mid.luminance();\n if (Math.abs(lum - lm) < EPS || !max_iter--) {\n // close enough\n return mid;\n }\n return lm > lum ? test(low, mid) : test(mid, high);\n };\n\n var rgb = (cur_lum > lum ? test(new Color$i([0,0,0]), this) : test(this, new Color$i([255,255,255]))).rgb();\n return new Color$i(rgb.concat( [this._rgb[3]]));\n }\n return rgb2luminance.apply(void 0, (this._rgb).slice(0,3));\n };\n\n\n var rgb2luminance = function (r,g,b) {\n // relative luminance\n // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n r = luminance_x(r);\n g = luminance_x(g);\n b = luminance_x(b);\n return 0.2126 * r + 0.7152 * g + 0.0722 * b;\n };\n\n var luminance_x = function (x) {\n x /= 255;\n return x <= 0.03928 ? x/12.92 : pow$6((x+0.055)/1.055, 2.4);\n };\n\n var interpolator$1 = {};\n\n var Color$h = Color_1;\n var type$4 = utils.type;\n var interpolator = interpolator$1;\n\n var mix$1 = function (col1, col2, f) {\n if ( f === void 0 ) f=0.5;\n var rest = [], len = arguments.length - 3;\n while ( len-- > 0 ) rest[ len ] = arguments[ len + 3 ];\n\n var mode = rest[0] || 'lrgb';\n if (!interpolator[mode] && !rest.length) {\n // fall back to the first supported mode\n mode = Object.keys(interpolator)[0];\n }\n if (!interpolator[mode]) {\n throw new Error((\"interpolation mode \" + mode + \" is not defined\"));\n }\n if (type$4(col1) !== 'object') { col1 = new Color$h(col1); }\n if (type$4(col2) !== 'object') { col2 = new Color$h(col2); }\n return interpolator[mode](col1, col2, f)\n .alpha(col1.alpha() + f * (col2.alpha() - col1.alpha()));\n };\n\n var Color$g = Color_1;\n var mix = mix$1;\n\n Color$g.prototype.mix =\n Color$g.prototype.interpolate = function(col2, f) {\n \tif ( f === void 0 ) f=0.5;\n \tvar rest = [], len = arguments.length - 2;\n \twhile ( len-- > 0 ) rest[ len ] = arguments[ len + 2 ];\n\n \treturn mix.apply(void 0, [ this, col2, f ].concat( rest ));\n };\n\n var Color$f = Color_1;\n\n Color$f.prototype.premultiply = function(mutate) {\n \tif ( mutate === void 0 ) mutate=false;\n\n \tvar rgb = this._rgb;\n \tvar a = rgb[3];\n \tif (mutate) {\n \t\tthis._rgb = [rgb[0]*a, rgb[1]*a, rgb[2]*a, a];\n \t\treturn this;\n \t} else {\n \t\treturn new Color$f([rgb[0]*a, rgb[1]*a, rgb[2]*a, a], 'rgb');\n \t}\n };\n\n var Color$e = Color_1;\n var LAB_CONSTANTS = labConstants;\n\n Color$e.prototype.saturate = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \tvar me = this;\n \tvar lch = me.lch();\n \tlch[1] += LAB_CONSTANTS.Kn * amount;\n \tif (lch[1] < 0) { lch[1] = 0; }\n \treturn new Color$e(lch, 'lch').alpha(me.alpha(), true);\n };\n\n Color$e.prototype.desaturate = function(amount) {\n \tif ( amount === void 0 ) amount=1;\n\n \treturn this.saturate(-amount);\n };\n\n var Color$d = Color_1;\n var type$3 = utils.type;\n\n Color$d.prototype.set = function (mc, value, mutate) {\n if ( mutate === void 0 ) mutate = false;\n\n var ref = mc.split('.');\n var mode = ref[0];\n var channel = ref[1];\n var src = this[mode]();\n if (channel) {\n var i = mode.indexOf(channel) - (mode.substr(0, 2) === 'ok' ? 2 : 0);\n if (i > -1) {\n if (type$3(value) == 'string') {\n switch (value.charAt(0)) {\n case '+':\n src[i] += +value;\n break;\n case '-':\n src[i] += +value;\n break;\n case '*':\n src[i] *= +value.substr(1);\n break;\n case '/':\n src[i] /= +value.substr(1);\n break;\n default:\n src[i] = +value;\n }\n } else if (type$3(value) === 'number') {\n src[i] = value;\n } else {\n throw new Error(\"unsupported value for Color.set\");\n }\n var out = new Color$d(src, mode);\n if (mutate) {\n this._rgb = out._rgb;\n return this;\n }\n return out;\n }\n throw new Error((\"unknown channel \" + channel + \" in mode \" + mode));\n } else {\n return src;\n }\n };\n\n var Color$c = Color_1;\n\n var rgb = function (col1, col2, f) {\n var xyz0 = col1._rgb;\n var xyz1 = col2._rgb;\n return new Color$c(\n xyz0[0] + f * (xyz1[0]-xyz0[0]),\n xyz0[1] + f * (xyz1[1]-xyz0[1]),\n xyz0[2] + f * (xyz1[2]-xyz0[2]),\n 'rgb'\n )\n };\n\n // register interpolator\n interpolator$1.rgb = rgb;\n\n var Color$b = Color_1;\n var sqrt$2 = Math.sqrt;\n var pow$5 = Math.pow;\n\n var lrgb = function (col1, col2, f) {\n var ref = col1._rgb;\n var x1 = ref[0];\n var y1 = ref[1];\n var z1 = ref[2];\n var ref$1 = col2._rgb;\n var x2 = ref$1[0];\n var y2 = ref$1[1];\n var z2 = ref$1[2];\n return new Color$b(\n sqrt$2(pow$5(x1,2) * (1-f) + pow$5(x2,2) * f),\n sqrt$2(pow$5(y1,2) * (1-f) + pow$5(y2,2) * f),\n sqrt$2(pow$5(z1,2) * (1-f) + pow$5(z2,2) * f),\n 'rgb'\n )\n };\n\n // register interpolator\n interpolator$1.lrgb = lrgb;\n\n var Color$a = Color_1;\n\n var lab = function (col1, col2, f) {\n var xyz0 = col1.lab();\n var xyz1 = col2.lab();\n return new Color$a(\n xyz0[0] + f * (xyz1[0]-xyz0[0]),\n xyz0[1] + f * (xyz1[1]-xyz0[1]),\n xyz0[2] + f * (xyz1[2]-xyz0[2]),\n 'lab'\n )\n };\n\n // register interpolator\n interpolator$1.lab = lab;\n\n var Color$9 = Color_1;\n\n var _hsx = function (col1, col2, f, m) {\n var assign, assign$1;\n\n var xyz0, xyz1;\n if (m === 'hsl') {\n xyz0 = col1.hsl();\n xyz1 = col2.hsl();\n } else if (m === 'hsv') {\n xyz0 = col1.hsv();\n xyz1 = col2.hsv();\n } else if (m === 'hcg') {\n xyz0 = col1.hcg();\n xyz1 = col2.hcg();\n } else if (m === 'hsi') {\n xyz0 = col1.hsi();\n xyz1 = col2.hsi();\n } else if (m === 'lch' || m === 'hcl') {\n m = 'hcl';\n xyz0 = col1.hcl();\n xyz1 = col2.hcl();\n } else if (m === 'oklch') {\n xyz0 = col1.oklch().reverse();\n xyz1 = col2.oklch().reverse();\n }\n\n var hue0, hue1, sat0, sat1, lbv0, lbv1;\n if (m.substr(0, 1) === 'h' || m === 'oklch') {\n (assign = xyz0, hue0 = assign[0], sat0 = assign[1], lbv0 = assign[2]);\n (assign$1 = xyz1, hue1 = assign$1[0], sat1 = assign$1[1], lbv1 = assign$1[2]);\n }\n\n var sat, hue, lbv, dh;\n\n if (!isNaN(hue0) && !isNaN(hue1)) {\n // both colors have hue\n if (hue1 > hue0 && hue1 - hue0 > 180) {\n dh = hue1 - (hue0 + 360);\n } else if (hue1 < hue0 && hue0 - hue1 > 180) {\n dh = hue1 + 360 - hue0;\n } else {\n dh = hue1 - hue0;\n }\n hue = hue0 + f * dh;\n } else if (!isNaN(hue0)) {\n hue = hue0;\n if ((lbv1 == 1 || lbv1 == 0) && m != 'hsv') { sat = sat0; }\n } else if (!isNaN(hue1)) {\n hue = hue1;\n if ((lbv0 == 1 || lbv0 == 0) && m != 'hsv') { sat = sat1; }\n } else {\n hue = Number.NaN;\n }\n\n if (sat === undefined) { sat = sat0 + f * (sat1 - sat0); }\n lbv = lbv0 + f * (lbv1 - lbv0);\n return m === 'oklch' ? new Color$9([lbv, sat, hue], m) : new Color$9([hue, sat, lbv], m);\n };\n\n var interpolate_hsx$5 = _hsx;\n\n var lch = function (col1, col2, f) {\n \treturn interpolate_hsx$5(col1, col2, f, 'lch');\n };\n\n // register interpolator\n interpolator$1.lch = lch;\n interpolator$1.hcl = lch;\n\n var Color$8 = Color_1;\n\n var num = function (col1, col2, f) {\n var c1 = col1.num();\n var c2 = col2.num();\n return new Color$8(c1 + f * (c2-c1), 'num')\n };\n\n // register interpolator\n interpolator$1.num = num;\n\n var interpolate_hsx$4 = _hsx;\n\n var hcg = function (col1, col2, f) {\n \treturn interpolate_hsx$4(col1, col2, f, 'hcg');\n };\n\n // register interpolator\n interpolator$1.hcg = hcg;\n\n var interpolate_hsx$3 = _hsx;\n\n var hsi = function (col1, col2, f) {\n \treturn interpolate_hsx$3(col1, col2, f, 'hsi');\n };\n\n // register interpolator\n interpolator$1.hsi = hsi;\n\n var interpolate_hsx$2 = _hsx;\n\n var hsl = function (col1, col2, f) {\n \treturn interpolate_hsx$2(col1, col2, f, 'hsl');\n };\n\n // register interpolator\n interpolator$1.hsl = hsl;\n\n var interpolate_hsx$1 = _hsx;\n\n var hsv = function (col1, col2, f) {\n \treturn interpolate_hsx$1(col1, col2, f, 'hsv');\n };\n\n // register interpolator\n interpolator$1.hsv = hsv;\n\n var Color$7 = Color_1;\n\n var oklab = function (col1, col2, f) {\n var xyz0 = col1.oklab();\n var xyz1 = col2.oklab();\n return new Color$7(\n xyz0[0] + f * (xyz1[0] - xyz0[0]),\n xyz0[1] + f * (xyz1[1] - xyz0[1]),\n xyz0[2] + f * (xyz1[2] - xyz0[2]),\n 'oklab'\n );\n };\n\n // register interpolator\n interpolator$1.oklab = oklab;\n\n var interpolate_hsx = _hsx;\n\n var oklch = function (col1, col2, f) {\n return interpolate_hsx(col1, col2, f, 'oklch');\n };\n\n // register interpolator\n interpolator$1.oklch = oklch;\n\n var Color$6 = Color_1;\n var clip_rgb$1 = utils.clip_rgb;\n var pow$4 = Math.pow;\n var sqrt$1 = Math.sqrt;\n var PI$1 = Math.PI;\n var cos$2 = Math.cos;\n var sin$2 = Math.sin;\n var atan2$1 = Math.atan2;\n\n var average = function (colors, mode, weights) {\n if ( mode === void 0 ) mode='lrgb';\n if ( weights === void 0 ) weights=null;\n\n var l = colors.length;\n if (!weights) { weights = Array.from(new Array(l)).map(function () { return 1; }); }\n // normalize weights\n var k = l / weights.reduce(function(a, b) { return a + b; });\n weights.forEach(function (w,i) { weights[i] *= k; });\n // convert colors to Color objects\n colors = colors.map(function (c) { return new Color$6(c); });\n if (mode === 'lrgb') {\n return _average_lrgb(colors, weights)\n }\n var first = colors.shift();\n var xyz = first.get(mode);\n var cnt = [];\n var dx = 0;\n var dy = 0;\n // initial color\n for (var i=0; i<xyz.length; i++) {\n xyz[i] = (xyz[i] || 0) * weights[0];\n cnt.push(isNaN(xyz[i]) ? 0 : weights[0]);\n if (mode.charAt(i) === 'h' && !isNaN(xyz[i])) {\n var A = xyz[i] / 180 * PI$1;\n dx += cos$2(A) * weights[0];\n dy += sin$2(A) * weights[0];\n }\n }\n\n var alpha = first.alpha() * weights[0];\n colors.forEach(function (c,ci) {\n var xyz2 = c.get(mode);\n alpha += c.alpha() * weights[ci+1];\n for (var i=0; i<xyz.length; i++) {\n if (!isNaN(xyz2[i])) {\n cnt[i] += weights[ci+1];\n if (mode.charAt(i) === 'h') {\n var A = xyz2[i] / 180 * PI$1;\n dx += cos$2(A) * weights[ci+1];\n dy += sin$2(A) * weights[ci+1];\n } else {\n xyz[i] += xyz2[i] * weights[ci+1];\n }\n }\n }\n });\n\n for (var i$1=0; i$1<xyz.length; i$1++) {\n if (mode.charAt(i$1) === 'h') {\n var A$1 = atan2$1(dy / cnt[i$1], dx / cnt[i$1]) / PI$1 * 180;\n while (A$1 < 0) { A$1 += 360; }\n while (A$1 >= 360) { A$1 -= 360; }\n xyz[i$1] = A$1;\n } else {\n xyz[i$1] = xyz[i$1]/cnt[i$1];\n }\n }\n alpha /= l;\n return (new Color$6(xyz, mode)).alpha(alpha > 0.99999 ? 1 : alpha, true);\n };\n\n\n var _average_lrgb = function (colors, weights) {\n var l = colors.length;\n var xyz = [0,0,0,0];\n for (var i=0; i < colors.length; i++) {\n var col = colors[i];\n var f = weights[i] / l;\n var rgb = col._rgb;\n xyz[0] += pow$4(rgb[0],2) * f;\n xyz[1] += pow$4(rgb[1],2) * f;\n xyz[2] += pow$4(rgb[2],2) * f;\n xyz[3] += rgb[3] * f;\n }\n xyz[0] = sqrt$1(xyz[0]);\n xyz[1] = sqrt$1(xyz[1]);\n xyz[2] = sqrt$1(xyz[2]);\n if (xyz[3] > 0.9999999) { xyz[3] = 1; }\n return new Color$6(clip_rgb$1(xyz));\n };\n\n // minimal multi-purpose interface\n\n // @requires utils color analyze\n\n var chroma$4 = chroma_1;\n var type$2 = utils.type;\n\n var pow$3 = Math.pow;\n\n var scale$2 = function(colors) {\n\n // constructor\n var _mode = 'rgb';\n var _nacol = chroma$4('#ccc');\n var _spread = 0;\n // const _fixed = false;\n var _domain = [0, 1];\n var _pos = [];\n var _padding = [0,0];\n var _classes = false;\n var _colors = [];\n var _out = false;\n var _min = 0;\n var _max = 1;\n var _correctLightness = false;\n var _colorCache = {};\n var _useCache = true;\n var _gamma = 1;\n\n // private methods\n\n var setColors = function(colors) {\n colors = colors || ['#fff', '#000'];\n if (colors && type$2(colors) === 'string' && chroma$4.brewer &&\n chroma$4.brewer[colors.toLowerCase()]) {\n colors = chroma$4.brewer[colors.toLowerCase()];\n }\n if (type$2(colors) === 'array') {\n // handle single color\n if (colors.length === 1) {\n colors = [colors[0], colors[0]];\n }\n // make a copy of the colors\n colors = colors.slice(0);\n // convert to chroma classes\n for (var c=0; c<colors.length; c++) {\n colors[c] = chroma$4(colors[c]);\n }\n // auto-fill color position\n _pos.length = 0;\n for (var c$1=0; c$1<colors.length; c$1++) {\n _pos.push(c$1/(colors.length-1));\n }\n }\n resetCache();\n return _colors = colors;\n };\n\n var getClass = function(value) {\n if (_classes != null) {\n var n = _classes.length-1;\n var i = 0;\n while (i < n && value >= _classes[i]) {\n i++;\n }\n return i-1;\n }\n return 0;\n };\n\n var tMapLightness = function (t) { return t; };\n var tMapDomain = function (t) { return t; };\n\n // const classifyValue = function(value) {\n // let val = value;\n // if (_classes.length > 2) {\n // const n = _classes.length-1;\n // const i = getClass(value);\n // const minc = _classes[0] + ((_classes[1]-_classes[0]) * (0 + (_spread * 0.5))); // center of 1st class\n // const maxc = _classes[n-1] + ((_classes[n]-_classes[n-1]) * (1 - (_spread * 0.5))); // center of last class\n // val = _min + ((((_classes[i] + ((_classes[i+1] - _classes[i]) * 0.5)) - minc) / (maxc-minc)) * (_max - _min));\n // }\n // return val;\n // };\n\n var getColor = function(val, bypassMap) {\n var col, t;\n if (bypassMap == null) { bypassMap = false; }\n if (isNaN(val) || (val === null)) { return _nacol; }\n if (!bypassMap) {\n if (_classes && (_classes.length > 2)) {\n // find the class\n var c = getClass(val);\n t = c / (_classes.length-2);\n } else if (_max !== _min) {\n // just interpolate between min/max\n t = (val - _min) / (_max - _min);\n } else {\n t = 1;\n }\n } else {\n t = val;\n }\n\n // domain map\n t = tMapDomain(t);\n\n if (!bypassMap) {\n t = tMapLightness(t); // lightness correction\n }\n\n if (_gamma !== 1) { t = pow$3(t, _gamma); }\n\n t = _padding[0] + (t * (1 - _padding[0] - _padding[1]));\n\n t = Math.min(1, Math.max(0, t));\n\n var k = Math.floor(t * 10000);\n\n if (_useCache && _colorCache[k]) {\n col = _colorCache[k];\n } else {\n if (type$2(_colors) === 'array') {\n //for i in [0.._pos.length-1]\n for (var i=0; i<_pos.length; i++) {\n var p = _pos[i];\n if (t <= p) {\n col = _colors[i];\n break;\n }\n if ((t >= p) && (i === (_pos.length-1))) {\n col = _colors[i];\n break;\n }\n if (t > p && t < _pos[i+1]) {\n t = (t-p)/(_pos[i+1]-p);\n col = chroma$4.interpolate(_colors[i], _colors[i+1], t, _mode);\n break;\n }\n }\n } else if (type$2(_colors) === 'function') {\n col = _colors(t);\n }\n if (_useCache) { _colorCache[k] = col; }\n }\n return col;\n };\n\n var resetCache = function () { return _colorCache = {}; };\n\n setColors(colors);\n\n // public interface\n\n var f = function(v) {\n var c = chroma$4(getColor(v));\n if (_out && c[_out]) { return c[_out](); } else { return c; }\n };\n\n f.classes = function(classes) {\n if (classes != null) {\n if (type$2(classes) === 'array') {\n _classes = classes;\n _domain = [classes[0], classes[classes.length-1]];\n } else {\n var d = chroma$4.analyze(_domain);\n if (classes === 0) {\n _classes = [d.min, d.max];\n } else {\n _classes = chroma$4.limits(d, 'e', classes);\n }\n }\n return f;\n }\n return _classes;\n };\n\n\n f.domain = function(domain) {\n if (!arguments.length) {\n return _domain;\n }\n _min = domain[0];\n _max = domain[domain.length-1];\n _pos = [];\n var k = _colors.length;\n if ((domain.length === k) && (_min !== _max)) {\n // update positions\n for (var i = 0, list = Array.from(domain); i < list.length; i += 1) {\n var d = list[i];\n\n _pos.push((d-_min) / (_max-_min));\n }\n } else {\n for (var c=0; c<k; c++) {\n _pos.push(c/(k-1));\n }\n if (domain.length > 2) {\n // set domain map\n var tOut = domain.map(function (d,i) { return i/(domain.length-1); });\n var tBreaks = domain.map(function (d) { return (d - _min) / (_max - _min); });\n if (!tBreaks.every(function (val, i) { return tOut[i] === val; })) {\n tMapDomain = function (t) {\n if (t <= 0 || t >= 1) { return t; }\n var i = 0;\n while (t >= tBreaks[i+1]) { i++; }\n var f = (t - tBreaks[i]) / (tBreaks[i+1] - tBreaks[i]);\n var out = tOut[i] + f * (tOut[i+1] - tOut[i]);\n return out;\n };\n }\n\n }\n }\n _domain = [_min, _max];\n return f;\n };\n\n f.mode = function(_m) {\n if (!arguments.length) {\n return _mode;\n }\n _mode = _m;\n resetCache();\n return f;\n };\n\n f.range = function(colors, _pos) {\n setColors(colors);\n return f;\n };\n\n f.out = function(_o) {\n _out = _o;\n return f;\n };\n\n f.spread = function(val) {\n if (!arguments.length) {\n return _spread;\n }\n _spread = val;\n return f;\n };\n\n f.correctLightness = function(v) {\n if (v == null) { v = true; }\n _correctLightness = v;\n resetCache();\n if (_correctLightness) {\n tMapLightness = function(t) {\n var L0 = getColor(0, true).lab()[0];\n var L1 = getColor(1, true).lab()[0];\n var pol = L0 > L1;\n var L_actual = getColor(t, true).lab()[0];\n var L_ideal = L0 + ((L1 - L0) * t);\n var L_diff = L_actual - L_ideal;\n var t0 = 0;\n var t1 = 1;\n var max_iter = 20;\n while ((Math.abs(L_diff) > 1e-2) && (max_iter-- > 0)) {\n (function() {\n if (pol) { L_diff *= -1; }\n if (L_diff < 0) {\n t0 = t;\n t += (t1 - t) * 0.5;\n } else {\n t1 = t;\n t += (t0 - t) * 0.5;\n }\n L_actual = getColor(t, true).lab()[0];\n return L_diff = L_actual - L_ideal;\n })();\n }\n return t;\n };\n } else {\n tMapLightness = function (t) { return t; };\n }\n return f;\n };\n\n f.padding = function(p) {\n if (p != null) {\n if (type$2(p) === 'number') {\n p = [p,p];\n }\n _padding = p;\n return f;\n } else {\n return _padding;\n }\n };\n\n f.colors = function(numColors, out) {\n // If no arguments are given, return the original colors that were provided\n if (arguments.length < 2) { out = 'hex'; }\n var result = [];\n\n if (arguments.length === 0) {\n result = _colors.slice(0);\n\n } else if (numColors === 1) {\n result = [f(0.5)];\n\n } else if (numColors > 1) {\n var dm = _domain[0];\n var dd = _domain[1] - dm;\n result = __range__(0, numColors, false).map(function (i) { return f( dm + ((i/(numColors-1)) * dd) ); });\n\n } else { // returns all colors based on the defined classes\n colors = [];\n var samples = [];\n if (_classes && (_classes.length > 2)) {\n for (var i = 1, end = _classes.length, asc = 1 <= end; asc ? i < end : i > end; asc ? i++ : i--) {\n samples.push((_classes[i-1]+_classes[i])*0.5);\n }\n } else {\n samples = _domain;\n }\n result = samples.map(function (v) { return f(v); });\n }\n\n if (chroma$4[out]) {\n result = result.map(function (c) { return c[out](); });\n }\n return result;\n };\n\n f.cache = function(c) {\n if (c != null) {\n _useCache = c;\n return f;\n } else {\n return _useCache;\n }\n };\n\n f.gamma = function(g) {\n if (g != null) {\n _gamma = g;\n return f;\n } else {\n return _gamma;\n }\n };\n\n f.nodata = function(d) {\n if (d != null) {\n _nacol = chroma$4(d);\n return f;\n } else {\n return _nacol;\n }\n };\n\n return f;\n };\n\n function __range__(left, right, inclusive) {\n var range = [];\n var ascending = left < right;\n var end = !inclusive ? right : ascending ? right + 1 : right - 1;\n for (var i = left; ascending ? i < end : i > end; ascending ? i++ : i--) {\n range.push(i);\n }\n return range;\n }\n\n //\n // interpolates between a set of colors uzing a bezier spline\n //\n\n // @requires utils lab\n var Color$5 = Color_1;\n\n var scale$1 = scale$2;\n\n // nth row of the pascal triangle\n var binom_row = function(n) {\n var row = [1, 1];\n for (var i = 1; i < n; i++) {\n var newrow = [1];\n for (var j = 1; j <= row.length; j++) {\n newrow[j] = (row[j] || 0) + row[j - 1];\n }\n row = newrow;\n }\n return row;\n };\n\n var bezier = function(colors) {\n var assign, assign$1, assign$2;\n\n var I, lab0, lab1, lab2;\n colors = colors.map(function (c) { return new Color$5(c); });\n if (colors.length === 2) {\n // linear interpolation\n (assign = colors.map(function (c) { return c.lab(); }), lab0 = assign[0], lab1 = assign[1]);\n I = function(t) {\n var lab = ([0, 1, 2].map(function (i) { return lab0[i] + (t * (lab1[i] - lab0[i])); }));\n return new Color$5(lab, 'lab');\n };\n } else if (colors.length === 3) {\n // quadratic bezier interpolation\n (assign$1 = colors.map(function (c) { return c.lab(); }), lab0 = assign$1[0], lab1 = assign$1[1], lab2 = assign$1[2]);\n I = function(t) {\n var lab = ([0, 1, 2].map(function (i) { return ((1-t)*(1-t) * lab0[i]) + (2 * (1-t) * t * lab1[i]) + (t * t * lab2[i]); }));\n return new Color$5(lab, 'lab');\n };\n } else if (colors.length === 4) {\n // cubic bezier interpolation\n var lab3;\n (assign$2 = colors.map(function (c) { return c.lab(); }), lab0 = assign$2[0], lab1 = assign$2[1], lab2 = assign$2[2], lab3 = assign$2[3]);\n I = function(t) {\n var lab = ([0, 1, 2].map(function (i) { return ((1-t)*(1-t)*(1-t) * lab0[i]) + (3 * (1-t) * (1-t) * t * lab1[i]) + (3 * (1-t) * t * t * lab2[i]) + (t*t*t * lab3[i]); }));\n return new Color$5(lab, 'lab');\n };\n } else if (colors.length >= 5) {\n // general case (degree n bezier)\n var labs, row, n;\n labs = colors.map(function (c) { return c.lab(); });\n n = colors.length - 1;\n row = binom_row(n);\n I = function (t) {\n var u = 1 - t;\n var lab = ([0, 1, 2].map(function (i) { return labs.reduce(function (sum, el, j) { return (sum + row[j] * Math.pow( u, (n - j) ) * Math.pow( t, j ) * el[i]); }, 0); }));\n return new Color$5(lab, 'lab');\n };\n } else {\n throw new RangeError(\"No point in running bezier with only one color.\")\n }\n return I;\n };\n\n var bezier_1 = function (colors) {\n var f = bezier(colors);\n f.scale = function () { return scale$1(f); };\n return f;\n };\n\n /*\n * interpolates between a set of colors uzing a bezier spline\n * blend mode formulas taken from http://www.venture-ware.com/kevin/coding/lets-learn-math-photoshop-blend-modes/\n */\n\n var chroma$3 = chroma_1;\n\n var blend = function (bottom, top, mode) {\n if (!blend[mode]) {\n throw new Error('unknown blend mode ' + mode);\n }\n return blend[mode](bottom, top);\n };\n\n var blend_f = function (f) { return function (bottom,top) {\n var c0 = chroma$3(top).rgb();\n var c1 = chroma$3(bottom).rgb();\n return chroma$3.rgb(f(c0, c1));\n }; };\n\n var each = function (f) { return function (c0, c1) {\n var out = [];\n out[0] = f(c0[0], c1[0]);\n out[1] = f(c0[1], c1[1]);\n out[2] = f(c0[2], c1[2]);\n return out;\n }; };\n\n var normal = function (a) { return a; };\n var multiply = function (a,b) { return a * b / 255; };\n var darken = function (a,b) { return a > b ? b : a; };\n var lighten = function (a,b) { return a > b ? a : b; };\n var screen = function (a,b) { return 255 * (1 - (1-a/255) * (1-b/255)); };\n var overlay = function (a,b) { return b < 128 ? 2 * a * b / 255 : 255 * (1 - 2 * (1 - a / 255 ) * ( 1 - b / 255 )); };\n var burn = function (a,b) { return 255 * (1 - (1 - b / 255) / (a/255)); };\n var dodge = function (a,b) {\n if (a === 255) { return 255; }\n a = 255 * (b / 255) / (1 - a / 255);\n return a > 255 ? 255 : a\n };\n\n // # add = (a,b) ->\n // # if (a + b > 255) then 255 else a + b\n\n blend.normal = blend_f(each(normal));\n blend.multiply = blend_f(each(multiply));\n blend.screen = blend_f(each(screen));\n blend.overlay = blend_f(each(overlay));\n blend.darken = blend_f(each(darken));\n blend.lighten = blend_f(each(lighten));\n blend.dodge = blend_f(each(dodge));\n blend.burn = blend_f(each(burn));\n // blend.add = blend_f(each(add));\n\n var blend_1 = blend;\n\n // cubehelix interpolation\n // based on D.A. Green \"A colour scheme for the display of astronomical intensity images\"\n // http://astron-soc.in/bulletin/11June/289392011.pdf\n\n var type$1 = utils.type;\n var clip_rgb = utils.clip_rgb;\n var TWOPI = utils.TWOPI;\n var pow$2 = Math.pow;\n var sin$1 = Math.sin;\n var cos$1 = Math.cos;\n var chroma$2 = chroma_1;\n\n var cubehelix = function(start, rotations, hue, gamma, lightness) {\n if ( start === void 0 ) start=300;\n if ( rotations === void 0 ) rotations=-1.5;\n if ( hue === void 0 ) hue=1;\n if ( gamma === void 0 ) gamma=1;\n if ( lightness === void 0 ) lightness=[0,1];\n\n var dh = 0, dl;\n if (type$1(lightness) === 'array') {\n dl = lightness[1] - lightness[0];\n } else {\n dl = 0;\n lightness = [lightness, lightness];\n }\n\n var f = function(fract) {\n var a = TWOPI * (((start+120)/360) + (rotations * fract));\n var l = pow$2(lightness[0] + (dl * fract), gamma);\n var h = dh !== 0 ? hue[0] + (fract * dh) : hue;\n var amp = (h * l * (1-l)) / 2;\n var cos_a = cos$1(a);\n var sin_a = sin$1(a);\n var r = l + (amp * ((-0.14861 * cos_a) + (1.78277* sin_a)));\n var g = l + (amp * ((-0.29227 * cos_a) - (0.90649* sin_a)));\n var b = l + (amp * (+1.97294 * cos_a));\n return chroma$2(clip_rgb([r*255,g*255,b*255,1]));\n };\n\n f.start = function(s) {\n if ((s == null)) { return start; }\n start = s;\n return f;\n };\n\n f.rotations = function(r) {\n if ((r == null)) { return rotations; }\n rotations = r;\n return f;\n };\n\n f.gamma = function(g) {\n if ((g == null)) { return gamma; }\n gamma = g;\n return f;\n };\n\n f.hue = function(h) {\n if ((h == null)) { return hue; }\n hue = h;\n if (type$1(hue) === 'array') {\n dh = hue[1] - hue[0];\n if (dh === 0) { hue = hue[1]; }\n } else {\n dh = 0;\n }\n return f;\n };\n\n f.lightness = function(h) {\n if ((h == null)) { return lightness; }\n if (type$1(h) === 'array') {\n lightness = h;\n dl = h[1] - h[0];\n } else {\n lightness = [h,h];\n dl = 0;\n }\n return f;\n };\n\n f.scale = function () { return chroma$2.scale(f); };\n\n f.hue(hue);\n\n return f;\n };\n\n var Color$4 = Color_1;\n var digits = '0123456789abcdef';\n\n var floor$1 = Math.floor;\n var random = Math.random;\n\n var random_1 = function () {\n var code = '#';\n for (var i=0; i<6; i++) {\n code += digits.charAt(floor$1(random() * 16));\n }\n return new Color$4(code, 'hex');\n };\n\n var type = type$p;\n var log = Math.log;\n var pow$1 = Math.pow;\n var floor = Math.floor;\n var abs$1 = Math.abs;\n\n\n var analyze = function (data, key) {\n if ( key === void 0 ) key=null;\n\n var r = {\n min: Number.MAX_VALUE,\n max: Number.MAX_VALUE*-1,\n sum: 0,\n values: [],\n count: 0\n };\n if (type(data) === 'object') {\n data = Object.values(data);\n }\n data.forEach(function (val) {\n if (key && type(val) === 'object') { val = val[key]; }\n if (val !== undefined && val !== null && !isNaN(val)) {\n r.values.push(val);\n r.sum += val;\n if (val < r.min) { r.min = val; }\n if (val > r.max) { r.max = val; }\n r.count += 1;\n }\n });\n\n r.domain = [r.min, r.max];\n\n r.limits = function (mode, num) { return limits(r, mode, num); };\n\n return r;\n };\n\n\n var limits = function (data, mode, num) {\n if ( mode === void 0 ) mode='equal';\n if ( num === void 0 ) num=7;\n\n if (type(data) == 'array') {\n data = analyze(data);\n }\n var min = data.min;\n var max = data.max;\n var values = data.values.sort(function (a,b) { return a-b; });\n\n if (num === 1) { return [min,max]; }\n\n var limits = [];\n\n if (mode.substr(0,1) === 'c') { // continuous\n limits.push(min);\n limits.push(max);\n }\n\n if (mode.substr(0,1) === 'e') { // equal interval\n limits.push(min);\n for (var i=1; i<num; i++) {\n limits.push(min+((i/num)*(max-min)));\n }\n limits.push(max);\n }\n\n else if (mode.substr(0,1) === 'l') { // log scale\n if (min <= 0) {\n throw new Error('Logarithmic scales are only possible for values > 0');\n }\n var min_log = Math.LOG10E * log(min);\n var max_log = Math.LOG10E * log(max);\n limits.push(min);\n for (var i$1=1; i$1<num; i$1++) {\n limits.push(pow$1(10, min_log + ((i$1/num) * (max_log - min_log))));\n }\n limits.push(max);\n }\n\n else if (mode.substr(0,1) === 'q') { // quantile scale\n limits.push(min);\n for (var i$2=1; i$2<num; i$2++) {\n var p = ((values.length-1) * i$2)/num;\n var pb = floor(p);\n if (pb === p) {\n limits.push(values[pb]);\n } else { // p > pb\n var pr = p - pb;\n limits.push((values[pb]*(1-pr)) + (values[pb+1]*pr));\n }\n }\n limits.push(max);\n\n }\n\n else if (mode.substr(0,1) === 'k') { // k-means clustering\n /*\n implementation based on\n http://code.google.com/p/figue/source/browse/trunk/figue.js#336\n simplified for 1-d input values\n */\n var cluster;\n var n = values.length;\n var assignments = new Array(n);\n var clusterSizes = new Array(num);\n var repeat = true;\n var nb_iters = 0;\n var centroids = null;\n\n // get seed values\n centroids = [];\n centroids.push(min);\n for (var i$3=1; i$3<num; i$3++) {\n centroids.push(min + ((i$3/num) * (max-min)));\n }\n centroids.push(max);\n\n while (repeat) {\n // assignment step\n for (var j=0; j<num; j++) {\n clusterSizes[j] = 0;\n }\n for (var i$4=0; i$4<n; i$4++) {\n var value = values[i$4];\n var mindist = Number.MAX_VALUE;\n var best = (void 0);\n for (var j$1=0; j$1<num; j$1++) {\n var dist = abs$1(centroids[j$1]-value);\n if (dist < mindist) {\n mindist = dist;\n best = j$1;\n }\n clusterSizes[best]++;\n assignments[i$4] = best;\n }\n }\n\n // update centroids step\n var newCentroids = new Array(num);\n for (var j$2=0; j$2<num; j$2++) {\n newCentroids[j$2] = null;\n }\n for (var i$5=0; i$5<n; i$5++) {\n cluster = assignments[i$5];\n if (newCentroids[cluster] === null) {\n newCentroids[cluster] = values[i$5];\n } else {\n newCentroids[cluster] += values[i$5];\n }\n }\n for (var j$3=0; j$3<num; j$3++) {\n newCentroids[j$3] *= 1/clusterSizes[j$3];\n }\n\n // check convergence\n repeat = false;\n for (var j$4=0; j$4<num; j$4++) {\n if (newCentroids[j$4] !== centroids[j$4]) {\n repeat = true;\n break;\n }\n }\n\n centroids = newCentroids;\n nb_iters++;\n\n if (nb_iters > 200) {\n repeat = false;\n }\n }\n\n // finished k-means clustering\n // the next part is borrowed from gabrielflor.it\n var kClusters = {};\n for (var j$5=0; j$5<num; j$5++) {\n kClusters[j$5] = [];\n }\n for (var i$6=0; i$6<n; i$6++) {\n cluster = assignments[i$6];\n kClusters[cluster].push(values[i$6]);\n }\n var tmpKMeansBreaks = [];\n for (var j$6=0; j$6<num; j$6++) {\n tmpKMeansBreaks.push(kClusters[j$6][0]);\n tmpKMeansBreaks.push(kClusters[j$6][kClusters[j$6].length-1]);\n }\n tmpKMeansBreaks = tmpKMeansBreaks.sort(function (a,b){ return a-b; });\n limits.push(tmpKMeansBreaks[0]);\n for (var i$7=1; i$7 < tmpKMeansBreaks.length; i$7+= 2) {\n var v = tmpKMeansBreaks[i$7];\n if (!isNaN(v) && (limits.indexOf(v) === -1)) {\n limits.push(v);\n }\n }\n }\n return limits;\n };\n\n var analyze_1 = {analyze: analyze, limits: limits};\n\n var Color$3 = Color_1;\n\n\n var contrast = function (a, b) {\n // WCAG contrast ratio\n // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef\n a = new Color$3(a);\n b = new Color$3(b);\n var l1 = a.luminance();\n var l2 = b.luminance();\n return l1 > l2 ? (l1 + 0.05) / (l2 + 0.05) : (l2 + 0.05) / (l1 + 0.05);\n };\n\n var Color$2 = Color_1;\n var sqrt = Math.sqrt;\n var pow = Math.pow;\n var min = Math.min;\n var max = Math.max;\n var atan2 = Math.atan2;\n var abs = Math.abs;\n var cos = Math.cos;\n var sin = Math.sin;\n var exp = Math.exp;\n var PI = Math.PI;\n\n var deltaE = function(a, b, Kl, Kc, Kh) {\n if ( Kl === void 0 ) Kl=1;\n if ( Kc === void 0 ) Kc=1;\n if ( Kh === void 0 ) Kh=1;\n\n // Delta E (CIE 2000)\n // see http://www.brucelindbloom.com/index.html?Eqn_DeltaE_CIE2000.html\n var rad2deg = function(rad) {\n return 360 * rad / (2 * PI);\n };\n var deg2rad = function(deg) {\n return (2 * PI * deg) / 360;\n };\n a = new Color$2(a);\n b = new Color$2(b);\n var ref = Array.from(a.lab());\n var L1 = ref[0];\n var a1 = ref[1];\n var b1 = ref[2];\n var ref$1 = Array.from(b.lab());\n var L2 = ref$1[0];\n var a2 = ref$1[1];\n var b2 = ref$1[2];\n var avgL = (L1 + L2)/2;\n var C1 = sqrt(pow(a1, 2) + pow(b1, 2));\n var C2 = sqrt(pow(a2, 2) + pow(b2, 2));\n var avgC = (C1 + C2)/2;\n var G = 0.5*(1-sqrt(pow(avgC, 7)/(pow(avgC, 7) + pow(25, 7))));\n var a1p = a1*(1+G);\n var a2p = a2*(1+G);\n var C1p = sqrt(pow(a1p, 2) + pow(b1, 2));\n var C2p = sqrt(pow(a2p, 2) + pow(b2, 2));\n var avgCp = (C1p + C2p)/2;\n var arctan1 = rad2deg(atan2(b1, a1p));\n var arctan2 = rad2deg(atan2(b2, a2p));\n var h1p = arctan1 >= 0 ? arctan1 : arctan1 + 360;\n var h2p = arctan2 >= 0 ? arctan2 : arctan2 + 360;\n var avgHp = abs(h1p - h2p) > 180 ? (h1p + h2p + 360)/2 : (h1p + h2p)/2;\n var T = 1 - 0.17*cos(deg2rad(avgHp - 30)) + 0.24*cos(deg2rad(2*avgHp)) + 0.32*cos(deg2rad(3*avgHp + 6)) - 0.2*cos(deg2rad(4*avgHp - 63));\n var deltaHp = h2p - h1p;\n deltaHp = abs(deltaHp) <= 180 ? deltaHp : h2p <= h1p ? deltaHp + 360 : deltaHp - 360;\n deltaHp = 2*sqrt(C1p*C2p)*sin(deg2rad(deltaHp)/2);\n var deltaL = L2 - L1;\n var deltaCp = C2p - C1p; \n var sl = 1 + (0.015*pow(avgL - 50, 2))/sqrt(20 + pow(avgL - 50, 2));\n var sc = 1 + 0.045*avgCp;\n var sh = 1 + 0.015*avgCp*T;\n var deltaTheta = 30*exp(-pow((avgHp - 275)/25, 2));\n var Rc = 2*sqrt(pow(avgCp, 7)/(pow(avgCp, 7) + pow(25, 7)));\n var Rt = -Rc*sin(2*deg2rad(deltaTheta));\n var result = sqrt(pow(deltaL/(Kl*sl), 2) + pow(deltaCp/(Kc*sc), 2) + pow(deltaHp/(Kh*sh), 2) + Rt*(deltaCp/(Kc*sc))*(deltaHp/(Kh*sh)));\n return max(0, min(100, result));\n };\n\n var Color$1 = Color_1;\n\n // simple Euclidean distance\n var distance = function(a, b, mode) {\n if ( mode === void 0 ) mode='lab';\n\n // Delta E (CIE 1976)\n // see http://www.brucelindbloom.com/index.html?Equations.html\n a = new Color$1(a);\n b = new Color$1(b);\n var l1 = a.get(mode);\n var l2 = b.get(mode);\n var sum_sq = 0;\n for (var i in l1) {\n var d = (l1[i] || 0) - (l2[i] || 0);\n sum_sq += d*d;\n }\n return Math.sqrt(sum_sq);\n };\n\n var Color = Color_1;\n\n var valid = function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n try {\n new (Function.prototype.bind.apply( Color, [ null ].concat( args) ));\n return true;\n } catch (e) {\n return false;\n }\n };\n\n // some pre-defined color scales:\n var chroma$1 = chroma_1;\n\n var scale = scale$2;\n\n var scales = {\n \tcool: function cool() { return scale([chroma$1.hsl(180,1,.9), chroma$1.hsl(250,.7,.4)]) },\n \thot: function hot() { return scale(['#000','#f00','#ff0','#fff']).mode('rgb') }\n };\n\n /**\n ColorBrewer colors for chroma.js\n\n Copyright (c) 2002 Cynthia Brewer, Mark Harrower, and The\n Pennsylvania State University.\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\n you may not use this file except in compliance with the License.\n You may obtain a copy of the License at\n http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing, software distributed\n under the License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR\n CONDITIONS OF ANY KIND, either express or implied. See the License for the\n specific language governing permissions and limitations under the License.\n */\n\n var colorbrewer = {\n // sequential\n OrRd: ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#b30000', '#7f0000'],\n PuBu: ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#045a8d', '#023858'],\n BuPu: ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#810f7c', '#4d004b'],\n Oranges: ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#a63603', '#7f2704'],\n BuGn: ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#006d2c', '#00441b'],\n YlOrBr: ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#993404', '#662506'],\n YlGn: ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#006837', '#004529'],\n Reds: ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#a50f15', '#67000d'],\n RdPu: ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177', '#49006a'],\n Greens: ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#006d2c', '#00441b'],\n YlGnBu: ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#253494', '#081d58'],\n Purples: ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#54278f', '#3f007d'],\n GnBu: ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#0868ac', '#084081'],\n Greys: ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525', '#000000'],\n YlOrRd: ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#bd0026', '#800026'],\n PuRd: ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#980043', '#67001f'],\n Blues: ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#08519c', '#08306b'],\n PuBuGn: ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016c59', '#014636'],\n Viridis: ['#440154', '#482777', '#3f4a8a', '#31678e', '#26838f', '#1f9d8a', '#6cce5a', '#b6de2b', '#fee825'],\n\n // diverging\n\n Spectral: ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'],\n RdYlGn: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'],\n RdBu: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'],\n PiYG: ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'],\n PRGn: ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'],\n RdYlBu: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'],\n BrBG: ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'],\n RdGy: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'],\n PuOr: ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'],\n\n // qualitative\n\n Set2: ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494', '#b3b3b3'],\n Accent: ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17', '#666666'],\n Set1: ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf', '#999999'],\n Set3: ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f'],\n Dark2: ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d', '#666666'],\n Paired: ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99', '#b15928'],\n Pastel2: ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc', '#cccccc'],\n Pastel1: ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec', '#f2f2f2'],\n };\n\n // add lowercase aliases for case-insensitive matches\n for (var i = 0, list = Object.keys(colorbrewer); i < list.length; i += 1) {\n var key = list[i];\n\n colorbrewer[key.toLowerCase()] = colorbrewer[key];\n }\n\n var colorbrewer_1 = colorbrewer;\n\n var chroma = chroma_1;\n\n // feel free to comment out anything to rollup\n // a smaller chroma.js built\n\n // io --> convert colors\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n // operators --> modify existing Colors\n\n\n\n\n\n\n\n\n\n\n // interpolators\n\n\n\n\n\n\n\n\n\n\n\n\n // generators -- > create new colors\n chroma.average = average;\n chroma.bezier = bezier_1;\n chroma.blend = blend_1;\n chroma.cubehelix = cubehelix;\n chroma.mix = chroma.interpolate = mix$1;\n chroma.random = random_1;\n chroma.scale = scale$2;\n\n // other utility methods\n chroma.analyze = analyze_1.analyze;\n chroma.contrast = contrast;\n chroma.deltaE = deltaE;\n chroma.distance = distance;\n chroma.limits = analyze_1.limits;\n chroma.valid = valid;\n\n // scale\n chroma.scales = scales;\n\n // colors\n chroma.colors = w3cx11_1;\n chroma.brewer = colorbrewer_1;\n\n var chroma_js = chroma;\n\n return chroma_js;\n\n}));\n", "export default require(\"./node_modules/.pnpm/chroma-js@2.4.2/node_modules/chroma-js/chroma.js\");"],
"mappings": ";;;;;AAAA;AAAA;AAyDA,IAAC,UAAU,QAAQ,SAAS;AACxB,aAAO,YAAY,YAAY,OAAO,WAAW,cAAc,OAAO,UAAU,QAAQ,IACxF,OAAO,WAAW,cAAc,OAAO,MAAM,OAAO,OAAO,IAC1D,UAAS,OAAO,eAAe,cAAc,aAAa,UAAU,MAAM,OAAO,SAAS,QAAQ;AAAA,IACvG,GAAG,SAAO,WAAY;AAAE;AAEpB,UAAI,UAAU,SAAU,GAAG,MAAK,MAAK;AACjC,YAAK,SAAQ;AAAS,iBAAI;AAC1B,YAAK,SAAQ;AAAS,iBAAI;AAE1B,eAAO,IAAI,OAAM,OAAM,IAAI,OAAM,OAAM;AAAA,MAC3C;AAEA,UAAI,UAAU;AAEd,UAAI,aAAa,SAAU,MAAK;AAC5B,aAAI,WAAW;AACf,aAAI,aAAa,KAAI,MAAM,CAAC;AAC5B,iBAAS,KAAE,GAAG,MAAG,GAAG,MAAK;AACrB,cAAI,KAAI,GAAG;AACP,gBAAI,KAAI,MAAK,KAAK,KAAI,MAAK,KAAK;AAAE,mBAAI,WAAW;AAAA,YAAM;AACvD,iBAAI,MAAK,QAAQ,KAAI,KAAI,GAAG,GAAG;AAAA,UACnC,WAAW,OAAM,GAAG;AAChB,iBAAI,MAAK,QAAQ,KAAI,KAAI,GAAG,CAAC;AAAA,UACjC;AAAA,QACJ;AACA,eAAO;AAAA,MACX;AAGA,UAAI,cAAc,CAAC;AACnB,eAAS,MAAM,GAAG,SAAS,CAAC,WAAW,UAAU,UAAU,YAAY,SAAS,QAAQ,UAAU,aAAa,MAAM,GAAG,MAAM,OAAO,QAAQ,OAAO,GAAG;AACnJ,YAAI,OAAO,OAAO;AAElB,oBAAa,aAAa,OAAO,OAAQ,KAAK,YAAY;AAAA,MAC9D;AACA,UAAI,SAAS,SAAS,KAAK;AACvB,eAAO,YAAY,OAAO,UAAU,SAAS,KAAK,GAAG,MAAM;AAAA,MAC/D;AAEA,UAAI,SAAS;AAEb,UAAI,WAAW,SAAU,MAAM,UAAU;AACrC,YAAK,aAAa;AAAS,qBAAS;AAGpC,YAAI,KAAK,UAAU,GAAG;AAAE,iBAAO,MAAM,UAAU,MAAM,KAAK,IAAI;AAAA,QAAG;AAGpE,YAAI,OAAO,KAAK,EAAE,KAAK,YAAY,UAAU;AAC5C,iBAAO,SAAS,MAAM,EAAE,EACtB,OAAO,SAAU,GAAG;AAAE,mBAAO,KAAK,GAAG,OAAO;AAAA,UAAW,CAAC,EACxD,IAAI,SAAU,GAAG;AAAE,mBAAO,KAAK,GAAG;AAAA,UAAI,CAAC;AAAA,QAC1C;AAGG,eAAO,KAAK;AAAA,MAChB;AAEA,UAAI,SAAS;AAEb,UAAI,SAAS,SAAU,MAAM;AACzB,YAAI,KAAK,SAAS,GAAG;AAAE,iBAAO;AAAA,QAAM;AACpC,YAAI,IAAI,KAAK,SAAO;AACpB,YAAI,OAAO,KAAK,EAAE,KAAK,UAAU;AAAE,iBAAO,KAAK,GAAG,YAAY;AAAA,QAAG;AACjE,eAAO;AAAA,MACX;AAEA,UAAI,OAAO,KAAK;AAEhB,UAAI,QAAQ;AAAA,QACX,UAAU;AAAA,QACV,OAAO;AAAA,QACP,MAAM;AAAA,QACN,QAAQ;AAAA,QACR,MAAM;AAAA,QACN,IAAI;AAAA,QACJ,OAAO,OAAK;AAAA,QACZ,SAAS,OAAK;AAAA,QACd,SAAS,OAAO;AAAA,QAChB,SAAS,MAAM;AAAA,MAChB;AAEA,UAAI,UAAU;AAAA,QACb,QAAQ,CAAC;AAAA,QACT,YAAY,CAAC;AAAA,MACd;AAEA,UAAI,SAAS,MAAM;AACnB,UAAI,aAAa,MAAM;AACvB,UAAI,SAAS,MAAM;AACnB,UAAI,SAAS;AAEb,UAAI,UAAU,kBAAiB;AAC3B,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,KAAK;AACT,YAAI,OAAO,KAAK,EAAE,MAAM,YACpB,KAAK,GAAG,eACR,KAAK,GAAG,gBAAgB,KAAK,aAAa;AAE1C,iBAAO,KAAK;AAAA,QAChB;AAGA,YAAI,OAAO,OAAO,IAAI;AACtB,YAAI,aAAa;AAEjB,YAAI,CAAC,MAAM;AACP,uBAAa;AACb,cAAI,CAAC,OAAO,QAAQ;AAChB,mBAAO,aAAa,OAAO,WAAW,KAAK,SAAU,GAAE,GAAG;AAAE,qBAAO,EAAE,IAAI,EAAE;AAAA,YAAG,CAAC;AAC/E,mBAAO,SAAS;AAAA,UACpB;AAEA,mBAAS,KAAI,GAAG,QAAO,OAAO,YAAY,KAAI,MAAK,QAAQ,MAAK,GAAG;AAC/D,gBAAI,MAAM,MAAK;AAEf,mBAAO,IAAI,KAAK,MAAM,KAAK,IAAI;AAC/B,gBAAI,MAAM;AAAE;AAAA,YAAO;AAAA,UACvB;AAAA,QACJ;AAEA,YAAI,OAAO,OAAO,OAAO;AACrB,cAAI,OAAM,OAAO,OAAO,MAAM,MAAM,MAAM,aAAa,OAAO,KAAK,MAAM,GAAE,EAAE,CAAC;AAC9E,aAAG,OAAO,WAAW,IAAG;AAAA,QAC5B,OAAO;AACH,gBAAM,IAAI,MAAM,qBAAmB,IAAI;AAAA,QAC3C;AAGA,YAAI,GAAG,KAAK,WAAW,GAAG;AAAE,aAAG,KAAK,KAAK,CAAC;AAAA,QAAG;AAAA,MACjD;AAEA,cAAQ,UAAU,WAAW,oBAAqB;AAC9C,YAAI,OAAO,KAAK,GAAG,KAAK,YAAY;AAAE,iBAAO,KAAK,IAAI;AAAA,QAAG;AACzD,eAAQ,MAAO,KAAK,KAAK,KAAK,GAAG,IAAK;AAAA,MAC1C;AAEA,UAAI,UAAU;AAEd,UAAI,WAAW,WAAY;AAC1B,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,OAAO,CAAE,IAAK,EAAE,OAAQ,IAAI,CAAE;AAAA,MACnF;AAEA,eAAS,QAAQ;AACjB,eAAS,UAAU;AAEnB,UAAI,WAAW;AAEf,UAAI,WAAW,MAAM;AACrB,UAAI,QAAQ,KAAK;AAEjB,UAAI,aAAa,WAAY;AACzB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI;AACR,YAAI,IAAI;AACR,YAAI,IAAI;AACR,YAAI,IAAI,IAAI,MAAM,GAAE,MAAM,GAAE,CAAC,CAAC;AAC9B,YAAI,IAAI,IAAI,IAAI,IAAK,KAAE,KAAK;AAC5B,YAAI,IAAK,KAAE,IAAE,KAAK;AAClB,YAAI,IAAK,KAAE,IAAE,KAAK;AAClB,YAAI,IAAK,KAAE,IAAE,KAAK;AAClB,eAAO,CAAC,GAAE,GAAE,GAAE,CAAC;AAAA,MACnB;AAEA,UAAI,aAAa;AAEjB,UAAI,WAAW,MAAM;AAErB,UAAI,WAAW,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,SAAS,MAAM,MAAM;AAC5B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,QAAQ,KAAK,SAAS,IAAI,KAAK,KAAK;AACxC,YAAI,MAAM,GAAG;AAAE,iBAAO,CAAC,GAAE,GAAE,GAAE,KAAK;AAAA,QAAG;AACrC,eAAO;AAAA,UACH,KAAK,IAAI,IAAI,MAAO,KAAE,KAAM,KAAE;AAAA,UAC9B,KAAK,IAAI,IAAI,MAAO,KAAE,KAAM,KAAE;AAAA,UAC9B,KAAK,IAAI,IAAI,MAAO,KAAE,KAAM,KAAE;AAAA,UAC9B;AAAA,QACJ;AAAA,MACJ;AAEA,UAAI,aAAa;AAEjB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AACd,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AAEnB,UAAI,WAAW;AAEf,cAAQ,UAAU,OAAO,WAAW;AAChC,eAAO,SAAS,KAAK,IAAI;AAAA,MAC7B;AAEA,eAAS,OAAO,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,MAAM,CAAC,CAAE;AAAA,MACzF;AAEA,cAAQ,OAAO,OAAO;AAEtB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,iBAAO,SAAS,MAAM,MAAM;AAC5B,cAAI,OAAO,IAAI,MAAM,WAAW,KAAK,WAAW,GAAG;AAC/C,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,MAAM,SAAU,GAAG;AAAE,eAAO,KAAK,MAAM,IAAE,GAAG,IAAE;AAAA,MAAK;AAUvD,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,OAAO,SAAS,MAAM,MAAM;AAChC,YAAI,OAAO,OAAO,IAAI,KAAK;AAC3B,aAAK,KAAK,IAAI,KAAK,MAAM,CAAC;AAC1B,aAAK,KAAK,IAAI,KAAK,KAAG,GAAG,IAAI;AAC7B,aAAK,KAAK,IAAI,KAAK,KAAG,GAAG,IAAI;AAC7B,YAAI,SAAS,UAAW,KAAK,SAAS,KAAK,KAAK,KAAG,GAAI;AACnD,eAAK,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK;AACtC,iBAAO;AAAA,QACX,OAAO;AACH,eAAK,SAAS;AAAA,QAClB;AACA,eAAQ,OAAO,MAAO,KAAK,KAAK,GAAG,IAAK;AAAA,MAC5C;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AAUrB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,SAAS,MAAM,MAAM;AAC5B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AAEb,aAAK;AACL,aAAK;AACL,aAAK;AAEL,YAAI,OAAM,KAAK,IAAI,GAAG,GAAG,CAAC;AAC1B,YAAI,OAAM,KAAK,IAAI,GAAG,GAAG,CAAC;AAE1B,YAAI,IAAK,QAAM,QAAO;AACtB,YAAI,GAAG;AAEP,YAAI,SAAQ,MAAI;AACZ,cAAI;AACJ,cAAI,OAAO;AAAA,QACf,OAAO;AACH,cAAI,IAAI,MAAO,QAAM,QAAQ,QAAM,QAAQ,QAAM,QAAQ,KAAI,OAAM;AAAA,QACvE;AAEA,YAAI,KAAK,MAAK;AAAE,cAAK,KAAI,KAAM,QAAM;AAAA,QAAM,WAClC,KAAK,MAAK;AAAE,cAAI,IAAK,KAAI,KAAM,QAAM;AAAA,QAAM,WAC3C,KAAK,MAAK;AAAE,cAAI,IAAK,KAAI,KAAM,QAAM;AAAA,QAAM;AAEpD,aAAK;AACL,YAAI,IAAI,GAAG;AAAE,eAAK;AAAA,QAAK;AACvB,YAAI,KAAK,SAAO,KAAK,KAAK,OAAK,QAAW;AAAE,iBAAO,CAAC,GAAE,GAAE,GAAE,KAAK,EAAE;AAAA,QAAG;AACpE,eAAO,CAAC,GAAE,GAAE,CAAC;AAAA,MACjB;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,UAAU;AACd,UAAI,YAAY;AAChB,UAAI,UAAU,KAAK;AAUnB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,OAAO,SAAS,MAAM,MAAM;AAChC,YAAI,OAAO,OAAO,IAAI,KAAK;AAC3B,YAAI,KAAK,OAAO,GAAE,CAAC,KAAK,OAAO;AAC3B,iBAAO,QAAQ,UAAU,IAAI,GAAG,IAAI;AAAA,QACxC;AACA,aAAK,KAAK,QAAQ,KAAK,EAAE;AACzB,aAAK,KAAK,QAAQ,KAAK,EAAE;AACzB,aAAK,KAAK,QAAQ,KAAK,EAAE;AACzB,YAAI,SAAS,UAAW,KAAK,SAAS,KAAK,KAAK,KAAG,GAAI;AACnD,eAAK,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK;AACtC,iBAAO;AAAA,QACX;AACA,eAAQ,OAAO,MAAO,KAAK,MAAM,GAAE,SAAO,QAAM,IAAE,CAAC,EAAE,KAAK,GAAG,IAAK;AAAA,MACtE;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,UAAU,KAAK;AAEnB,UAAI,YAAY,WAAY;AACxB,YAAI;AAEJ,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AACzC,eAAO,SAAS,MAAM,KAAK;AAC3B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,GAAE,GAAE;AACR,YAAI,MAAM,GAAG;AACT,cAAI,IAAI,IAAI,IAAE;AAAA,QAClB,OAAO;AACH,cAAI,KAAK,CAAC,GAAE,GAAE,CAAC;AACf,cAAI,IAAI,CAAC,GAAE,GAAE,CAAC;AACd,cAAI,KAAK,IAAI,MAAM,IAAK,KAAE,KAAK,IAAE,IAAE,IAAE;AACrC,cAAI,KAAK,IAAI,IAAI;AACjB,cAAI,KAAK,IAAI;AACb,aAAG,KAAK,KAAK,IAAE;AACf,aAAG,KAAK;AACR,aAAG,KAAK,KAAK,IAAE;AACf,mBAAS,KAAE,GAAG,KAAE,GAAG,MAAK;AACpB,gBAAI,GAAG,MAAK,GAAG;AAAE,iBAAG,OAAM;AAAA,YAAG;AAC7B,gBAAI,GAAG,MAAK,GAAG;AAAE,iBAAG,OAAM;AAAA,YAAG;AAC7B,gBAAI,IAAI,GAAG,MAAK,GACZ;AAAE,gBAAE,MAAK,KAAM,MAAK,MAAM,IAAI,GAAG;AAAA,YAAI,WAChC,IAAI,GAAG,MAAK,GACjB;AAAE,gBAAE,MAAK;AAAA,YAAI,WACR,IAAI,GAAG,MAAK,GACjB;AAAE,gBAAE,MAAK,KAAM,MAAK,MAAQ,KAAI,IAAK,GAAG,OAAM;AAAA,YAAG,OAEjD;AAAE,gBAAE,MAAK;AAAA,YAAI;AAAA,UACrB;AACA,UAAC,SAAS,CAAC,QAAQ,EAAE,KAAG,GAAG,GAAE,QAAQ,EAAE,KAAG,GAAG,GAAE,QAAQ,EAAE,KAAG,GAAG,CAAC,GAAG,IAAI,OAAO,IAAI,IAAI,OAAO,IAAI,IAAI,OAAO;AAAA,QAChH;AACA,YAAI,KAAK,SAAS,GAAG;AAEjB,iBAAO,CAAC,GAAE,GAAE,GAAE,KAAK,EAAE;AAAA,QACzB;AACA,eAAO,CAAC,GAAE,GAAE,GAAE,CAAC;AAAA,MACnB;AAEA,UAAI,YAAY;AAEhB,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,UAAI,SAAS;AACb,UAAI,UAAU;AACd,UAAI,aAAa;AACjB,UAAI,cAAc;AAClB,UAAI,SAAS;AACb,UAAI,UAAU;AAEd,UAAI,UAAU,KAAK;AAEnB,UAAI,YAAY,SAAU,KAAK;AAC3B,cAAM,IAAI,YAAY,EAAE,KAAK;AAC7B,YAAI;AAEJ,YAAI,QAAQ,OAAO,OAAO;AACtB,cAAI;AACA,mBAAO,QAAQ,OAAO,MAAM,GAAG;AAAA,UACnC,SAAS,GAAP;AAAA,UAEF;AAAA,QACJ;AAGA,YAAK,IAAI,IAAI,MAAM,MAAM,GAAI;AACzB,cAAI,OAAM,EAAE,MAAM,GAAE,CAAC;AACrB,mBAAS,KAAE,GAAG,KAAE,GAAG,MAAK;AACpB,iBAAI,MAAK,CAAC,KAAI;AAAA,UAClB;AACA,eAAI,KAAK;AACT,iBAAO;AAAA,QACX;AAGA,YAAK,IAAI,IAAI,MAAM,OAAO,GAAI;AAC1B,cAAI,QAAQ,EAAE,MAAM,GAAE,CAAC;AACvB,mBAAS,OAAI,GAAG,OAAI,GAAG,QAAO;AAC1B,kBAAM,QAAO,CAAC,MAAM;AAAA,UACxB;AACA,iBAAO;AAAA,QACX;AAGA,YAAK,IAAI,IAAI,MAAM,UAAU,GAAI;AAC7B,cAAI,QAAQ,EAAE,MAAM,GAAE,CAAC;AACvB,mBAAS,MAAI,GAAG,MAAI,GAAG,OAAO;AAC1B,kBAAM,OAAO,QAAQ,MAAM,OAAO,IAAI;AAAA,UAC1C;AACA,gBAAM,KAAK;AACX,iBAAO;AAAA,QACX;AAGA,YAAK,IAAI,IAAI,MAAM,WAAW,GAAI;AAC9B,cAAI,QAAQ,EAAE,MAAM,GAAE,CAAC;AACvB,mBAAS,MAAI,GAAG,MAAI,GAAG,OAAO;AAC1B,kBAAM,OAAO,QAAQ,MAAM,OAAO,IAAI;AAAA,UAC1C;AACA,gBAAM,KAAK,CAAC,MAAM;AAClB,iBAAO;AAAA,QACX;AAGA,YAAK,IAAI,IAAI,MAAM,MAAM,GAAI;AACzB,cAAI,OAAM,EAAE,MAAM,GAAE,CAAC;AACrB,eAAI,MAAM;AACV,eAAI,MAAM;AACV,cAAI,QAAQ,QAAQ,IAAG;AACvB,gBAAM,KAAK;AACX,iBAAO;AAAA,QACX;AAGA,YAAK,IAAI,IAAI,MAAM,OAAO,GAAI;AAC1B,cAAI,QAAQ,EAAE,MAAM,GAAE,CAAC;AACvB,gBAAM,MAAM;AACZ,gBAAM,MAAM;AACZ,cAAI,QAAQ,QAAQ,KAAK;AACzB,gBAAM,KAAK,CAAC,EAAE;AACd,iBAAO;AAAA,QACX;AAAA,MACJ;AAEA,gBAAU,OAAO,SAAU,GAAG;AAC1B,eAAO,OAAO,KAAK,CAAC,KAChB,QAAQ,KAAK,CAAC,KACd,WAAW,KAAK,CAAC,KACjB,YAAY,KAAK,CAAC,KAClB,OAAO,KAAK,CAAC,KACb,QAAQ,KAAK,CAAC;AAAA,MACtB;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AACd,UAAI,SAAS,MAAM;AAEnB,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,cAAQ,UAAU,MAAM,SAAS,MAAM;AACnC,eAAO,QAAQ,KAAK,MAAM,IAAI;AAAA,MAClC;AAEA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM;AAErB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,SAAU,GAAG;AACf,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU,SAAS;AACxC,iBAAQ,QAAQ;AAAI,iBAAM,OAAQ,UAAW,MAAM;AAEnD,cAAI,CAAC,KAAK,UAAU,OAAO,CAAC,MAAM,YAAY,QAAQ,KAAK,CAAC,GAAG;AAC3D,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,UAAU;AACd,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,WAAW,MAAM;AAErB,cAAQ,OAAO,KAAK,WAAY;AAC5B,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,OAAM,SAAS,MAAM,MAAM;AAC/B,aAAI,MAAM;AACV,aAAI,MAAM;AACV,aAAI,MAAM;AACV,eAAO;AAAA,MACX;AAEA,eAAS,KAAK,WAAY;AACtB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,IAAI,CAAC,CAAE;AAAA,MACvF;AAEA,cAAQ,UAAU,KAAK,WAAW;AAC9B,YAAI,OAAM,KAAK;AACf,eAAO,CAAC,KAAI,KAAG,KAAK,KAAI,KAAG,KAAK,KAAI,KAAG,KAAK,KAAI,EAAE;AAAA,MACtD;AAEA,UAAI,WAAW,MAAM;AAErB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,OAAM,KAAK,IAAI,GAAG,GAAG,CAAC;AAC1B,YAAI,OAAM,KAAK,IAAI,GAAG,GAAG,CAAC;AAC1B,YAAI,QAAQ,OAAM;AAClB,YAAI,IAAI,QAAQ,MAAM;AACtB,YAAI,KAAK,OAAO,OAAM,SAAS;AAC/B,YAAI;AACJ,YAAI,UAAU,GAAG;AACb,cAAI,OAAO;AAAA,QACf,OAAO;AACH,cAAI,MAAM,MAAK;AAAE,gBAAK,KAAI,KAAK;AAAA,UAAO;AACtC,cAAI,MAAM,MAAK;AAAE,gBAAI,IAAG,KAAI,KAAK;AAAA,UAAO;AACxC,cAAI,MAAM,MAAK;AAAE,gBAAI,IAAG,KAAI,KAAK;AAAA,UAAO;AACxC,eAAK;AACL,cAAI,IAAI,GAAG;AAAE,iBAAK;AAAA,UAAK;AAAA,QAC3B;AACA,eAAO,CAAC,GAAG,GAAG,EAAE;AAAA,MACpB;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,UAAU,KAAK;AAUnB,UAAI,UAAU,WAAY;AACtB,YAAI,QAAQ,UAAU,UAAU,UAAU,UAAU;AAEpD,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AACzC,eAAO,SAAS,MAAM,KAAK;AAC3B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,KAAK,KAAK;AACd,YAAI,GAAE,GAAE;AACR,aAAK,KAAK;AACV,YAAI,KAAK,IAAI;AACb,YAAI,MAAM,GAAG;AACT,cAAI,IAAI,IAAI;AAAA,QAChB,OAAO;AACH,cAAI,MAAM,KAAK;AAAE,gBAAI;AAAA,UAAG;AACxB,cAAI,IAAI,KAAK;AAAE,iBAAK;AAAA,UAAK;AACzB,cAAI,IAAI,GAAG;AAAE,iBAAK;AAAA,UAAK;AACvB,eAAK;AACL,cAAI,KAAI,QAAQ,CAAC;AACjB,cAAI,IAAI,IAAI;AACZ,cAAI,IAAI,KAAM,KAAI;AAClB,cAAI,IAAI,IAAI,KAAM,KAAI;AACtB,cAAI,IAAI,IAAI,KAAK;AACjB,cAAI,IAAI,IAAI;AACZ,kBAAQ;AAAA,iBACC;AAAG,cAAC,SAAS,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,OAAO,IAAI,IAAI,OAAO,IAAI,IAAI,OAAO;AAAK;AAAA,iBACtE;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA,iBAC9E;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA,iBAC9E;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA,iBAC9E;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA,iBAC9E;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA;AAAA,QAE3F;AACA,eAAO,CAAC,GAAG,GAAG,GAAG,KAAK,SAAS,IAAI,KAAK,KAAK,CAAC;AAAA,MAClD;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,UAAI,UAAU;AAEd,cAAQ,UAAU,MAAM,WAAW;AAC/B,eAAO,QAAQ,KAAK,IAAI;AAAA,MAC5B;AAEA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM;AAErB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,iBAAO,SAAS,MAAM,KAAK;AAC3B,cAAI,OAAO,IAAI,MAAM,WAAW,KAAK,WAAW,GAAG;AAC/C,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,WAAW,MAAM;AACrB,UAAI,OAAO,MAAM;AACjB,UAAI,UAAU,KAAK;AAEnB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,MAAM,SAAS,MAAM,MAAM;AAC/B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,OAAO,KAAK,IAAI,KAAK;AACzB,YAAI,MAAM,QAAW;AAAE,cAAI;AAAA,QAAG;AAC9B,YAAI,SAAS,QAAQ;AACjB,iBAAO,IAAI,IAAI,SAAS;AAAA,QAC5B;AACA,YAAI,QAAQ,CAAC;AACb,YAAI,QAAQ,CAAC;AACb,YAAI,QAAQ,CAAC;AACb,YAAI,IAAI,KAAK,KAAK,KAAK,IAAI;AAC3B,YAAI,MAAM,WAAW,EAAE,SAAS,EAAE;AAClC,cAAM,IAAI,OAAO,IAAI,SAAS,CAAC;AAC/B,YAAI,MAAM,MAAM,QAAQ,IAAI,GAAG,EAAE,SAAS,EAAE;AAC5C,cAAM,IAAI,OAAO,IAAI,SAAS,CAAC;AAC/B,gBAAQ,KAAK,YAAY;AAAA,eAChB;AAAQ,mBAAQ,MAAM,MAAM;AAAA,eAC5B;AAAQ,mBAAQ,MAAM,MAAM;AAAA;AACxB,mBAAQ,MAAM;AAAA;AAAA,MAE/B;AAEA,UAAI,YAAY;AAEhB,UAAI,SAAS;AACb,UAAI,UAAU;AAEd,UAAI,YAAY,SAAU,KAAK;AAC3B,YAAI,IAAI,MAAM,MAAM,GAAG;AAEnB,cAAI,IAAI,WAAW,KAAK,IAAI,WAAW,GAAG;AACtC,kBAAM,IAAI,OAAO,CAAC;AAAA,UACtB;AAEA,cAAI,IAAI,WAAW,GAAG;AAClB,kBAAM,IAAI,MAAM,EAAE;AAClB,kBAAM,IAAI,KAAG,IAAI,KAAG,IAAI,KAAG,IAAI,KAAG,IAAI,KAAG,IAAI;AAAA,UACjD;AACA,cAAI,IAAI,SAAS,KAAK,EAAE;AACxB,cAAI,IAAI,KAAK;AACb,cAAI,IAAI,KAAK,IAAI;AACjB,cAAI,IAAI,IAAI;AACZ,iBAAO,CAAC,GAAE,GAAE,GAAE,CAAC;AAAA,QACnB;AAGA,YAAI,IAAI,MAAM,OAAO,GAAG;AACpB,cAAI,IAAI,WAAW,KAAK,IAAI,WAAW,GAAG;AAEtC,kBAAM,IAAI,OAAO,CAAC;AAAA,UACtB;AAEA,cAAI,IAAI,WAAW,GAAG;AAClB,kBAAM,IAAI,MAAM,EAAE;AAClB,kBAAM,IAAI,KAAG,IAAI,KAAG,IAAI,KAAG,IAAI,KAAG,IAAI,KAAG,IAAI,KAAG,IAAI,KAAG,IAAI;AAAA,UAC/D;AACA,cAAI,MAAM,SAAS,KAAK,EAAE;AAC1B,cAAI,MAAM,OAAO,KAAK;AACtB,cAAI,MAAM,OAAO,KAAK;AACtB,cAAI,MAAM,OAAO,IAAI;AACrB,cAAI,IAAI,KAAK,MAAO,OAAM,OAAQ,MAAO,GAAG,IAAI;AAChD,iBAAO,CAAC,KAAI,KAAI,KAAI,CAAC;AAAA,QACzB;AAMA,cAAM,IAAI,MAAO,wBAAwB,GAAI;AAAA,MACjD;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,SAAS,MAAM;AACnB,UAAI,UAAU;AAEd,UAAI,YAAY;AAEhB,cAAQ,UAAU,MAAM,SAAS,MAAM;AACnC,eAAO,UAAU,KAAK,MAAM,IAAI;AAAA,MACpC;AAEA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM;AACrB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,SAAU,GAAG;AACf,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU,SAAS;AACxC,iBAAQ,QAAQ;AAAI,iBAAM,OAAQ,UAAW,MAAM;AAEnD,cAAI,CAAC,KAAK,UAAU,OAAO,CAAC,MAAM,YAAY,CAAC,GAAE,GAAE,GAAE,GAAE,GAAE,GAAE,CAAC,EAAE,QAAQ,EAAE,MAAM,KAAK,GAAG;AAClF,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,WAAW,MAAM;AACrB,UAAI,UAAU,MAAM;AACpB,UAAI,QAAQ,KAAK;AACjB,UAAI,SAAS,KAAK;AAClB,UAAI,OAAO,KAAK;AAEhB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAMzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,aAAK;AACL,aAAK;AACL,aAAK;AACL,YAAI;AACJ,YAAI,OAAO,MAAM,GAAE,GAAE,CAAC;AACtB,YAAI,KAAK,KAAE,IAAE,KAAK;AAClB,YAAI,IAAI,KAAI,IAAI,IAAI,OAAK,KAAI;AAC7B,YAAI,MAAM,GAAG;AACT,cAAI;AAAA,QACR,OAAO;AACH,cAAM,KAAE,IAAI,KAAE,MAAM;AACpB,eAAK,OAAQ,KAAE,KAAI,KAAE,KAAM,KAAE,KAAI,KAAE,EAAE;AACrC,cAAI,KAAK,CAAC;AACV,cAAI,IAAI,GAAG;AACP,gBAAI,UAAU;AAAA,UAClB;AACA,eAAK;AAAA,QACT;AACA,eAAO,CAAC,IAAE,KAAI,GAAE,EAAC;AAAA,MACrB;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,QAAQ,MAAM;AAClB,UAAI,UAAU,MAAM;AACpB,UAAI,UAAU,MAAM;AACpB,UAAI,QAAQ,KAAK;AAOjB,UAAI,UAAU,WAAY;AACtB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAMzC,eAAO,SAAS,MAAM,KAAK;AAC3B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,KAAI,KAAK;AACb,YAAI,GAAE,GAAE;AAER,YAAI,MAAM,CAAC,GAAG;AAAE,cAAI;AAAA,QAAG;AACvB,YAAI,MAAM,CAAC,GAAG;AAAE,cAAI;AAAA,QAAG;AAEvB,YAAI,IAAI,KAAK;AAAE,eAAK;AAAA,QAAK;AACzB,YAAI,IAAI,GAAG;AAAE,eAAK;AAAA,QAAK;AACvB,aAAK;AACL,YAAI,IAAI,IAAE,GAAG;AACT,cAAK,KAAE,KAAG;AACV,cAAK,KAAE,IAAE,MAAM,UAAQ,CAAC,IAAE,MAAM,UAAQ,UAAQ,CAAC,KAAG;AACpD,cAAI,IAAK,KAAE;AAAA,QACf,WAAW,IAAI,IAAE,GAAG;AAChB,eAAK,IAAE;AACP,cAAK,KAAE,KAAG;AACV,cAAK,KAAE,IAAE,MAAM,UAAQ,CAAC,IAAE,MAAM,UAAQ,UAAQ,CAAC,KAAG;AACpD,cAAI,IAAK,KAAE;AAAA,QACf,OAAO;AACH,eAAK,IAAE;AACP,cAAK,KAAE,KAAG;AACV,cAAK,KAAE,IAAE,MAAM,UAAQ,CAAC,IAAE,MAAM,UAAQ,UAAQ,CAAC,KAAG;AACpD,cAAI,IAAK,KAAE;AAAA,QACf;AACA,YAAI,MAAM,KAAE,IAAE,CAAC;AACf,YAAI,MAAM,KAAE,IAAE,CAAC;AACf,YAAI,MAAM,KAAE,IAAE,CAAC;AACf,eAAO,CAAC,IAAE,KAAK,IAAE,KAAK,IAAE,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,CAAC;AAAA,MAC9D;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,UAAI,UAAU;AAEd,cAAQ,UAAU,MAAM,WAAW;AAC/B,eAAO,QAAQ,KAAK,IAAI;AAAA,MAC5B;AAEA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM;AAErB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,iBAAO,SAAS,MAAM,KAAK;AAC3B,cAAI,OAAO,IAAI,MAAM,WAAW,KAAK,WAAW,GAAG;AAC/C,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,UAAI,YAAY;AAEhB,cAAQ,UAAU,MAAM,WAAW;AAC/B,eAAO,UAAU,KAAK,IAAI;AAAA,MAC9B;AAEA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM;AAErB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,iBAAO,SAAS,MAAM,KAAK;AAC3B,cAAI,OAAO,IAAI,MAAM,WAAW,KAAK,WAAW,GAAG;AAC/C,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,WAAW,MAAM;AACrB,UAAI,QAAQ,KAAK;AACjB,UAAI,QAAQ,KAAK;AAQjB,UAAI,UAAU,WAAY;AACtB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,SAAS,MAAM,KAAK;AAC3B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,OAAO,MAAM,GAAG,GAAG,CAAC;AACxB,YAAI,OAAO,MAAM,GAAG,GAAG,CAAC;AACxB,YAAI,QAAQ,OAAO;AACnB,YAAI,GAAE,GAAE;AACR,YAAI,OAAO;AACX,YAAI,SAAS,GAAG;AACZ,cAAI,OAAO;AACX,cAAI;AAAA,QACR,OAAO;AACH,cAAI,QAAQ;AACZ,cAAI,MAAM,MAAM;AAAE,gBAAK,KAAI,KAAK;AAAA,UAAO;AACvC,cAAI,MAAM,MAAM;AAAE,gBAAI,IAAG,KAAI,KAAK;AAAA,UAAO;AACzC,cAAI,MAAM,MAAM;AAAE,gBAAI,IAAG,KAAI,KAAK;AAAA,UAAO;AACzC,eAAK;AACL,cAAI,IAAI,GAAG;AAAE,iBAAK;AAAA,UAAK;AAAA,QAC3B;AACA,eAAO,CAAC,GAAG,GAAG,CAAC;AAAA,MACnB;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,UAAU,KAAK;AAEnB,UAAI,UAAU,WAAY;AACtB,YAAI,QAAQ,UAAU,UAAU,UAAU,UAAU;AAEpD,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AACzC,eAAO,SAAS,MAAM,KAAK;AAC3B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,GAAE,GAAE;AACR,aAAK;AACL,YAAI,MAAM,GAAG;AACT,cAAI,IAAI,IAAI;AAAA,QAChB,OAAO;AACH,cAAI,MAAM,KAAK;AAAE,gBAAI;AAAA,UAAG;AACxB,cAAI,IAAI,KAAK;AAAE,iBAAK;AAAA,UAAK;AACzB,cAAI,IAAI,GAAG;AAAE,iBAAK;AAAA,UAAK;AACvB,eAAK;AAEL,cAAI,KAAI,QAAQ,CAAC;AACjB,cAAI,IAAI,IAAI;AACZ,cAAI,IAAI,IAAK,KAAI;AACjB,cAAI,IAAI,IAAK,KAAI,IAAI;AACrB,cAAI,IAAI,IAAK,KAAI,IAAK,KAAI;AAE1B,kBAAQ;AAAA,iBACC;AAAG,cAAC,SAAS,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,OAAO,IAAI,IAAI,OAAO,IAAI,IAAI,OAAO;AAAK;AAAA,iBACtE;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA,iBAC9E;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA,iBAC9E;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA,iBAC9E;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA,iBAC9E;AAAG,cAAC,WAAW,CAAC,GAAG,GAAG,CAAC,GAAG,IAAI,SAAS,IAAI,IAAI,SAAS,IAAI,IAAI,SAAS;AAAK;AAAA;AAAA,QAE3F;AACA,eAAO,CAAC,GAAE,GAAE,GAAE,KAAK,SAAS,IAAE,KAAK,KAAG,CAAC;AAAA,MAC3C;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,UAAI,UAAU;AAEd,cAAQ,UAAU,MAAM,WAAW;AAC/B,eAAO,QAAQ,KAAK,IAAI;AAAA,MAC5B;AAEA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM;AAErB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,iBAAO,SAAS,MAAM,KAAK;AAC3B,cAAI,OAAO,IAAI,MAAM,WAAW,KAAK,WAAW,GAAG;AAC/C,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,eAAe;AAAA,QAEf,IAAI;AAAA,QAGJ,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,QAEJ,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,QACJ,IAAI;AAAA,MACR;AAEA,UAAI,kBAAkB;AACtB,UAAI,WAAW,MAAM;AACrB,UAAI,QAAQ,KAAK;AAEjB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,QAAQ,QAAQ,GAAE,GAAE,CAAC;AACzB,YAAI,IAAI,MAAM;AACd,YAAI,IAAI,MAAM;AACd,YAAI,IAAI,MAAM;AACd,YAAI,IAAI,MAAM,IAAI;AAClB,eAAO,CAAC,IAAI,IAAI,IAAI,GAAG,MAAO,KAAI,IAAI,MAAO,KAAI,EAAE;AAAA,MACvD;AAEA,UAAI,UAAU,SAAU,GAAG;AACvB,YAAK,MAAK,QAAQ,SAAS;AAAE,iBAAO,IAAI;AAAA,QAAO;AAC/C,eAAO,MAAO,KAAI,SAAS,OAAO,GAAG;AAAA,MACzC;AAEA,UAAI,UAAU,SAAU,GAAG;AACvB,YAAI,IAAI,gBAAgB,IAAI;AAAE,iBAAO,MAAM,GAAG,IAAI,CAAC;AAAA,QAAG;AACtD,eAAO,IAAI,gBAAgB,KAAK,gBAAgB;AAAA,MACpD;AAEA,UAAI,UAAU,SAAU,GAAE,GAAE,GAAG;AAC3B,YAAI,QAAQ,CAAC;AACb,YAAI,QAAQ,CAAC;AACb,YAAI,QAAQ,CAAC;AACb,YAAI,IAAI,QAAS,aAAY,IAAI,YAAY,IAAI,YAAY,KAAK,gBAAgB,EAAE;AACpF,YAAI,IAAI,QAAS,aAAY,IAAI,YAAY,IAAI,WAAY,KAAK,gBAAgB,EAAE;AACpF,YAAI,IAAI,QAAS,aAAY,IAAI,WAAY,IAAI,YAAY,KAAK,gBAAgB,EAAE;AACpF,eAAO,CAAC,GAAE,GAAE,CAAC;AAAA,MACjB;AAEA,UAAI,YAAY;AAEhB,UAAI,kBAAkB;AACtB,UAAI,WAAW,MAAM;AACrB,UAAI,QAAQ,KAAK;AAOjB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,SAAS,MAAM,KAAK;AAC3B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,GAAE,GAAE,GAAG,GAAE,GAAE;AAEf,YAAK,KAAI,MAAM;AACf,YAAI,MAAM,CAAC,IAAI,IAAI,IAAI,IAAI;AAC3B,YAAI,MAAM,CAAC,IAAI,IAAI,IAAI,IAAI;AAE3B,YAAI,gBAAgB,KAAK,QAAQ,CAAC;AAClC,YAAI,gBAAgB,KAAK,QAAQ,CAAC;AAClC,YAAI,gBAAgB,KAAK,QAAQ,CAAC;AAElC,YAAI,QAAQ,YAAY,IAAI,YAAY,IAAI,YAAY,CAAC;AACzD,YAAI,QAAQ,YAAa,IAAI,YAAY,IAAI,WAAY,CAAC;AAC1D,aAAK,QAAQ,YAAY,IAAI,YAAY,IAAI,YAAY,CAAC;AAE1D,eAAO,CAAC,GAAE,GAAE,IAAG,KAAK,SAAS,IAAI,KAAK,KAAK,CAAC;AAAA,MAChD;AAEA,UAAI,UAAU,SAAU,GAAG;AACvB,eAAO,MAAO,MAAK,SAAU,QAAQ,IAAI,QAAQ,MAAM,GAAG,IAAI,GAAG,IAAI;AAAA,MACzE;AAEA,UAAI,UAAU,SAAU,GAAG;AACvB,eAAO,IAAI,gBAAgB,KAAK,IAAI,IAAI,IAAI,gBAAgB,KAAM,KAAI,gBAAgB;AAAA,MAC1F;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,UAAI,YAAY;AAEhB,cAAQ,UAAU,MAAM,WAAW;AAC/B,eAAO,UAAU,KAAK,IAAI;AAAA,MAC9B;AAEA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM;AAErB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,iBAAO,SAAS,MAAM,KAAK;AAC3B,cAAI,OAAO,IAAI,MAAM,WAAW,KAAK,WAAW,GAAG;AAC/C,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,WAAW,MAAM;AACrB,UAAI,UAAU,MAAM;AACpB,UAAI,SAAS,KAAK;AAClB,UAAI,UAAU,KAAK;AACnB,UAAI,UAAU,KAAK;AAEnB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,OAAO,IAAI,IAAI,IAAI,CAAC;AAC5B,YAAI,IAAK,SAAQ,GAAG,CAAC,IAAI,UAAU,OAAO;AAC1C,YAAI,QAAQ,IAAE,GAAK,MAAM,GAAG;AAAE,cAAI,OAAO;AAAA,QAAK;AAC9C,eAAO,CAAC,GAAG,GAAG,CAAC;AAAA,MACnB;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,UAAU;AACd,UAAI,YAAY;AAEhB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,QAAQ,QAAQ,GAAE,GAAE,CAAC;AACzB,YAAI,IAAI,MAAM;AACd,YAAI,IAAI,MAAM;AACd,YAAI,KAAK,MAAM;AACf,eAAO,UAAU,GAAE,GAAE,EAAE;AAAA,MAC3B;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,UAAU,MAAM;AACpB,UAAI,QAAQ,KAAK;AACjB,UAAI,QAAQ,KAAK;AAEjB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AASzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,MAAM,CAAC,GAAG;AAAE,cAAI;AAAA,QAAG;AACvB,YAAI,IAAI;AACR,eAAO,CAAC,GAAG,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;AAAA,MACzC;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,YAAY;AAChB,UAAI,UAAU;AAEd,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,SAAS,MAAM,KAAK;AAC3B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,MAAM,UAAW,GAAE,GAAE,CAAC;AAC1B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,KAAK,IAAI;AACb,YAAI,QAAQ,QAAS,GAAE,GAAE,EAAE;AAC3B,YAAI,IAAI,MAAM;AACd,YAAI,IAAI,MAAM;AACd,YAAI,IAAI,MAAM;AACd,eAAO,CAAC,GAAG,GAAG,GAAG,KAAK,SAAS,IAAI,KAAK,KAAK,CAAC;AAAA,MAClD;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,UAAU;AAEd,UAAI,UAAU,WAAY;AACtB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,MAAM,SAAS,MAAM,KAAK,EAAE,QAAQ;AACxC,eAAO,QAAQ,MAAM,QAAQ,GAAG;AAAA,MACpC;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,UAAI,UAAU;AAEd,cAAQ,UAAU,MAAM,WAAW;AAAE,eAAO,QAAQ,KAAK,IAAI;AAAA,MAAG;AAChE,cAAQ,UAAU,MAAM,WAAW;AAAE,eAAO,QAAQ,KAAK,IAAI,EAAE,QAAQ;AAAA,MAAG;AAE1E,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AACA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM;AACrB,cAAQ,OAAO,MAAM;AAErB,OAAC,OAAM,KAAK,EAAE,QAAQ,SAAU,GAAG;AAAE,eAAO,QAAQ,WAAW,KAAK;AAAA,UAChE,GAAG;AAAA,UACH,MAAM,WAAY;AACd,gBAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,mBAAQ;AAAQ,mBAAM,OAAQ,UAAW;AAEzC,mBAAO,SAAS,MAAM,CAAC;AACvB,gBAAI,OAAO,IAAI,MAAM,WAAW,KAAK,WAAW,GAAG;AAC/C,qBAAO;AAAA,YACX;AAAA,UACJ;AAAA,QACJ,CAAC;AAAA,MAAG,CAAC;AAQL,UAAI,WAAW;AAAA,QACX,WAAW;AAAA,QACX,cAAc;AAAA,QACd,MAAM;AAAA,QACN,YAAY;AAAA,QACZ,OAAO;AAAA,QACP,OAAO;AAAA,QACP,QAAQ;AAAA,QACR,OAAO;AAAA,QACP,gBAAgB;AAAA,QAChB,MAAM;AAAA,QACN,YAAY;AAAA,QACZ,OAAO;AAAA,QACP,WAAW;AAAA,QACX,WAAW;AAAA,QACX,YAAY;AAAA,QACZ,WAAW;AAAA,QACX,OAAO;AAAA,QACP,YAAY;AAAA,QACZ,gBAAgB;AAAA,QAChB,UAAU;AAAA,QACV,SAAS;AAAA,QACT,MAAM;AAAA,QACN,UAAU;AAAA,QACV,UAAU;AAAA,QACV,eAAe;AAAA,QACf,UAAU;AAAA,QACV,WAAW;AAAA,QACX,UAAU;AAAA,QACV,WAAW;AAAA,QACX,aAAa;AAAA,QACb,gBAAgB;AAAA,QAChB,YAAY;AAAA,QACZ,YAAY;AAAA,QACZ,SAAS;AAAA,QACT,YAAY;AAAA,QACZ,cAAc;AAAA,QACd,eAAe;AAAA,QACf,eAAe;AAAA,QACf,eAAe;AAAA,QACf,eAAe;AAAA,QACf,YAAY;AAAA,QACZ,UAAU;AAAA,QACV,aAAa;AAAA,QACb,SAAS;AAAA,QACT,SAAS;AAAA,QACT,YAAY;AAAA,QACZ,WAAW;AAAA,QACX,aAAa;AAAA,QACb,aAAa;AAAA,QACb,SAAS;AAAA,QACT,WAAW;AAAA,QACX,YAAY;AAAA,QACZ,MAAM;AAAA,QACN,WAAW;AAAA,QACX,MAAM;AAAA,QACN,OAAO;AAAA,QACP,aAAa;AAAA,QACb,MAAM;AAAA,QACN,UAAU;AAAA,QACV,SAAS;AAAA,QACT,WAAW;AAAA,QACX,QAAQ;AAAA,QACR,OAAO;AAAA,QACP,OAAO;AAAA,QACP,YAAY;AAAA,QACZ,UAAU;AAAA,QACV,eAAe;AAAA,QACf,WAAW;AAAA,QACX,cAAc;AAAA,QACd,WAAW;AAAA,QACX,YAAY;AAAA,QACZ,WAAW;AAAA,QACX,gBAAgB;AAAA,QAChB,sBAAsB;AAAA,QACtB,WAAW;AAAA,QACX,YAAY;AAAA,QACZ,WAAW;AAAA,QACX,WAAW;AAAA,QACX,aAAa;AAAA,QACb,eAAe;AAAA,QACf,cAAc;AAAA,QACd,gBAAgB;AAAA,QAChB,gBAAgB;AAAA,QAChB,gBAAgB;AAAA,QAChB,aAAa;AAAA,QACb,MAAM;AAAA,QACN,WAAW;AAAA,QACX,OAAO;AAAA,QACP,SAAS;AAAA,QACT,QAAQ;AAAA,QACR,SAAS;AAAA,QACT,SAAS;AAAA,QACT,kBAAkB;AAAA,QAClB,YAAY;AAAA,QACZ,cAAc;AAAA,QACd,cAAc;AAAA,QACd,gBAAgB;AAAA,QAChB,iBAAiB;AAAA,QACjB,mBAAmB;AAAA,QACnB,iBAAiB;AAAA,QACjB,iBAAiB;AAAA,QACjB,cAAc;AAAA,QACd,WAAW;AAAA,QACX,WAAW;AAAA,QACX,UAAU;AAAA,QACV,aAAa;AAAA,QACb,MAAM;AAAA,QACN,SAAS;AAAA,QACT,OAAO;AAAA,QACP,WAAW;AAAA,QACX,QAAQ;AAAA,QACR,WAAW;AAAA,QACX,QAAQ;AAAA,QACR,eAAe;AAAA,QACf,WAAW;AAAA,QACX,eAAe;AAAA,QACf,eAAe;AAAA,QACf,YAAY;AAAA,QACZ,WAAW;AAAA,QACX,MAAM;AAAA,QACN,MAAM;AAAA,QACN,MAAM;AAAA,QACN,YAAY;AAAA,QACZ,QAAQ;AAAA,QACR,SAAS;AAAA,QACT,SAAS;AAAA,QACT,eAAe;AAAA,QACf,KAAK;AAAA,QACL,WAAW;AAAA,QACX,WAAW;AAAA,QACX,aAAa;AAAA,QACb,QAAQ;AAAA,QACR,YAAY;AAAA,QACZ,UAAU;AAAA,QACV,UAAU;AAAA,QACV,QAAQ;AAAA,QACR,QAAQ;AAAA,QACR,SAAS;AAAA,QACT,WAAW;AAAA,QACX,WAAW;AAAA,QACX,WAAW;AAAA,QACX,MAAM;AAAA,QACN,aAAa;AAAA,QACb,WAAW;AAAA,QACX,KAAK;AAAA,QACL,MAAM;AAAA,QACN,SAAS;AAAA,QACT,QAAQ;AAAA,QACR,WAAW;AAAA,QACX,QAAQ;AAAA,QACR,OAAO;AAAA,QACP,OAAO;AAAA,QACP,YAAY;AAAA,QACZ,QAAQ;AAAA,QACR,aAAa;AAAA,MACjB;AAEA,UAAI,WAAW;AAEf,UAAI,UAAU;AACd,UAAI,UAAU;AACd,UAAI,SAAS,MAAM;AAEnB,UAAI,SAAS;AACb,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,cAAQ,UAAU,OAAO,WAAW;AAChC,YAAI,MAAM,QAAQ,KAAK,MAAM,KAAK;AAClC,iBAAS,KAAI,GAAG,QAAO,OAAO,KAAK,MAAM,GAAG,KAAI,MAAK,QAAQ,MAAK,GAAG;AACjE,cAAI,IAAI,MAAK;AAEb,cAAI,OAAO,OAAO,KAAK;AAAE,mBAAO,EAAE,YAAY;AAAA,UAAG;AAAA,QACrD;AACA,eAAO;AAAA,MACX;AAEA,cAAQ,OAAO,QAAQ,SAAU,OAAM;AACnC,gBAAO,MAAK,YAAY;AACxB,YAAI,OAAO,QAAO;AAAE,iBAAO,QAAQ,OAAO,MAAK;AAAA,QAAG;AAClD,cAAM,IAAI,MAAM,yBAAuB,KAAI;AAAA,MAC/C;AAEA,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,SAAU,GAAG;AACf,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU,SAAS;AACxC,iBAAQ,QAAQ;AAAI,iBAAM,OAAQ,UAAW,MAAM;AAEnD,cAAI,CAAC,KAAK,UAAU,OAAO,CAAC,MAAM,YAAY,OAAO,EAAE,YAAY,IAAI;AACnE,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,WAAW,MAAM;AAErB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,eAAQ,MAAK,MAAO,MAAK,KAAK;AAAA,MAClC;AAEA,UAAI,YAAY;AAEhB,UAAI,SAAS,MAAM;AAEnB,UAAI,UAAU,SAAU,MAAK;AACzB,YAAI,OAAO,IAAG,KAAK,YAAY,QAAO,KAAK,QAAO,UAAU;AACxD,cAAI,IAAI,QAAO;AACf,cAAI,IAAK,QAAO,IAAK;AACrB,cAAI,IAAI,OAAM;AACd,iBAAO,CAAC,GAAE,GAAE,GAAE,CAAC;AAAA,QACnB;AACA,cAAM,IAAI,MAAM,wBAAsB,IAAG;AAAA,MAC7C;AAEA,UAAI,YAAY;AAEhB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AACd,UAAI,SAAS,MAAM;AAEnB,UAAI,UAAU;AAEd,cAAQ,UAAU,MAAM,WAAW;AAC/B,eAAO,QAAQ,KAAK,IAAI;AAAA,MAC5B;AAEA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM;AAErB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,cAAI,KAAK,WAAW,KAAK,OAAO,KAAK,EAAE,MAAM,YAAY,KAAK,MAAM,KAAK,KAAK,MAAM,UAAU;AAC1F,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AACd,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,UAAU,KAAK;AAEnB,cAAQ,UAAU,MAAM,SAAS,MAAK;AAClC,YAAK,SAAQ;AAAS,iBAAI;AAE1B,YAAI,SAAQ,OAAO;AAAE,iBAAO,KAAK,KAAK,MAAM,GAAE,CAAC;AAAA,QAAG;AAClD,eAAO,KAAK,KAAK,MAAM,GAAE,CAAC,EAAE,IAAI,OAAO;AAAA,MAC3C;AAEA,cAAQ,UAAU,OAAO,SAAS,MAAK;AACnC,YAAK,SAAQ;AAAS,iBAAI;AAE1B,eAAO,KAAK,KAAK,MAAM,GAAE,CAAC,EAAE,IAAI,SAAU,GAAE,IAAG;AAC3C,iBAAO,KAAE,IAAK,SAAQ,QAAQ,IAAI,QAAQ,CAAC,IAAK;AAAA,QACpD,CAAC;AAAA,MACL;AAEA,eAAS,MAAM,WAAY;AACvB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,KAAK,CAAC,CAAE;AAAA,MACxF;AAEA,cAAQ,OAAO,MAAM,WAAY;AAC7B,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,OAAO,SAAS,MAAM,MAAM;AAChC,YAAI,KAAK,OAAO,QAAW;AAAE,eAAK,KAAK;AAAA,QAAG;AAC1C,eAAO;AAAA,MACX;AAEA,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,iBAAO,SAAS,MAAM,MAAM;AAC5B,cAAI,OAAO,IAAI,MAAM,WAAY,MAAK,WAAW,KAC7C,KAAK,WAAW,KAAK,OAAO,KAAK,EAAE,KAAK,YAAY,KAAK,MAAM,KAAK,KAAK,MAAM,IAAI;AACnF,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAOD,UAAI,QAAQ,KAAK;AAEjB,UAAI,oBAAoB,SAAU,QAAQ;AACtC,YAAI,OAAO,SAAS;AACpB,YAAI,GAAE,GAAE;AACR,YAAI,OAAO,IAAI;AACX,cAAI;AACJ,cAAI,OAAO,IAAI,IAAI,sBAAsB,sBAAuB,KAAI,OAAK,KAAK,qBAAqB,MAAM,CAAC;AAC1G,cAAI,OAAO,KAAK,IAAI,sBAAsB,qBAAsB,KAAI,OAAK,MAAM,qBAAqB,MAAM,CAAC;AAAA,QAC/G,OAAO;AACH,cAAI,qBAAqB,oBAAqB,KAAI,OAAK,MAAM,oBAAoB,MAAM,CAAC;AACxF,cAAI,oBAAoB,sBAAuB,KAAI,OAAK,MAAM,mBAAmB,MAAM,CAAC;AACxF,cAAI;AAAA,QACR;AACA,eAAO,CAAC,GAAE,GAAE,GAAE,CAAC;AAAA,MACnB;AAEA,UAAI,oBAAoB;AAOxB,UAAI,kBAAkB;AACtB,UAAI,WAAW,MAAM;AACrB,UAAI,QAAQ,KAAK;AAEjB,UAAI,oBAAoB,WAAY;AAChC,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,OAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,KAAI,IAAI,IAAI,KAAI;AACxB,YAAI,UAAU;AACd,YAAI,UAAU;AACd,YAAI,MAAM;AACV,YAAI;AACJ,eAAO,UAAU,UAAU,KAAK;AAC5B,iBAAQ,WAAU,WAAW;AAC7B,cAAI,QAAQ,gBAAgB,IAAI;AAChC,cAAK,MAAM,KAAK,MAAM,MAAQ,IAAI,GAAI;AAClC,sBAAU;AAAA,UACd,OAAO;AACH,sBAAU;AAAA,UACd;AAAA,QACJ;AACA,eAAO,MAAM,IAAI;AAAA,MACrB;AAEA,UAAI,oBAAoB;AAExB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,UAAI,kBAAkB;AAEtB,cAAQ,UAAU,OAClB,QAAQ,UAAU,SAClB,QAAQ,UAAU,cAAc,WAAW;AACvC,eAAO,gBAAgB,KAAK,IAAI;AAAA,MACpC;AAEA,eAAS,OACT,SAAS,SACT,SAAS,cAAc,WAAY;AAC/B,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,MAAM,CAAC,CAAE;AAAA,MACzF;AAEA,cAAQ,OAAO,OACf,QAAQ,OAAO,SACf,QAAQ,OAAO,cAAc;AAE7B,UAAI,WAAW,MAAM;AACrB,UAAI,OAAO,KAAK;AAChB,UAAI,QAAQ,KAAK;AACjB,UAAI,SAAS,KAAK;AAElB,UAAI,cAAc,WAAY;AAC1B,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAIzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,QAAQ,CAAC,SAAS,IAAI,GAAG,GAAG,SAAS,IAAI,GAAG,GAAG,SAAS,IAAI,GAAG,CAAC;AACpE,YAAI,KAAK,MAAM;AACf,YAAI,KAAK,MAAM;AACf,YAAI,KAAK,MAAM;AACf,YAAI,IAAI,KAAK,eAAe,KAAK,eAAe,KAAK,eAAe,EAAE;AACtE,YAAI,IAAI,KAAK,eAAe,KAAK,eAAe,KAAK,eAAe,EAAE;AACtE,YAAI,IAAI,KAAK,eAAe,KAAK,eAAe,KAAK,eAAe,EAAE;AAEtE,eAAO;AAAA,UACH,eAAe,IAAI,cAAc,IAAI,eAAe;AAAA,UACpD,eAAe,IAAI,cAAc,IAAI,eAAe;AAAA,UACpD,eAAe,IAAI,eAAe,IAAI,cAAc;AAAA,QACxD;AAAA,MACJ;AAEA,UAAI,cAAc;AAElB,wBAAkB,GAAG;AACjB,YAAI,OAAM,KAAK,IAAI,CAAC;AACpB,YAAI,OAAM,SAAS;AACf,iBAAO,IAAI;AAAA,QACf;AACA,eAAQ,QAAO,CAAC,KAAK,KAAK,MAAO,QAAM,SAAS,OAAO,GAAG;AAAA,MAC9D;AAEA,UAAI,WAAW,MAAM;AACrB,UAAI,QAAQ,KAAK;AACjB,UAAI,OAAO,KAAK;AAOhB,UAAI,cAAc,WAAY;AAC1B,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,SAAS,MAAM,KAAK;AAC3B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AAEb,YAAI,IAAI,MAAM,IAAI,eAAe,IAAI,eAAe,GAAG,CAAC;AACxD,YAAI,IAAI,MAAM,IAAI,eAAe,IAAI,eAAe,GAAG,CAAC;AACxD,YAAI,IAAI,MAAM,IAAI,eAAe,IAAI,cAAc,GAAG,CAAC;AAEvD,eAAO;AAAA,UACH,MAAM,SAAS,eAAgB,IAAI,eAAe,IAAI,eAAe,CAAC;AAAA,UACtE,MAAM,SAAS,gBAAgB,IAAI,eAAe,IAAI,eAAe,CAAC;AAAA,UACtE,MAAM,SAAS,gBAAgB,IAAI,eAAe,IAAI,cAAc,CAAC;AAAA,UACrE,KAAK,SAAS,IAAI,KAAK,KAAK;AAAA,QAChC;AAAA,MACJ;AAEA,UAAI,cAAc;AAElB,wBAAkB,GAAG;AACjB,YAAI,OAAM,KAAK,IAAI,CAAC;AACpB,YAAI,OAAM,UAAW;AACjB,iBAAQ,MAAK,CAAC,KAAK,KAAM,SAAQ,MAAM,MAAK,IAAI,GAAG,IAAI;AAAA,QAC3D;AACA,eAAO,IAAI;AAAA,MACf;AAEA,UAAI,WAAW,MAAM;AACrB,UAAI,SAAS,MAAM;AACnB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,UAAU;AAEd,UAAI,cAAc;AAElB,cAAQ,UAAU,QAAQ,WAAY;AAClC,eAAO,YAAY,KAAK,IAAI;AAAA,MAChC;AAEA,eAAS,QAAQ,WAAY;AACzB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,OAAO,CAAC,CAAE;AAAA,MAC1F;AAEA,cAAQ,OAAO,QAAQ;AAEvB,cAAQ,WAAW,KAAK;AAAA,QACpB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,iBAAO,SAAS,MAAM,OAAO;AAC7B,cAAI,OAAO,IAAI,MAAM,WAAW,KAAK,WAAW,GAAG;AAC/C,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,WAAW,MAAM;AACrB,UAAI,YAAY;AAChB,UAAI,UAAU;AAEd,UAAI,cAAc,WAAY;AAC1B,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI,MAAM,SAAS,MAAM,KAAK;AAC9B,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,QAAQ,UAAU,GAAG,GAAG,CAAC;AAC7B,YAAI,IAAI,MAAM;AACd,YAAI,IAAI,MAAM;AACd,YAAI,KAAK,MAAM;AACf,eAAO,QAAQ,GAAG,GAAG,EAAE;AAAA,MAC3B;AAEA,UAAI,cAAc;AAElB,UAAI,WAAW,MAAM;AACrB,UAAI,UAAU;AACd,UAAI,YAAY;AAEhB,UAAI,YAAY,WAAY;AACxB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,SAAS,MAAM,KAAK;AAC3B,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,IAAI,KAAK;AACb,YAAI,MAAM,QAAQ,GAAG,GAAG,CAAC;AACzB,YAAI,IAAI,IAAI;AACZ,YAAI,IAAI,IAAI;AACZ,YAAI,KAAK,IAAI;AACb,YAAI,QAAQ,UAAU,GAAG,GAAG,EAAE;AAC9B,YAAI,IAAI,MAAM;AACd,YAAI,IAAI,MAAM;AACd,YAAI,IAAI,MAAM;AACd,eAAO,CAAC,GAAG,GAAG,GAAG,KAAK,SAAS,IAAI,KAAK,KAAK,CAAC;AAAA,MAClD;AAEA,UAAI,cAAc;AAElB,UAAI,SAAS,MAAM;AACnB,UAAI,SAAS,MAAM;AACnB,UAAI,WAAW;AACf,UAAI,UAAU;AACd,UAAI,QAAQ;AAEZ,UAAI,YAAY;AAEhB,cAAQ,UAAU,QAAQ,WAAY;AAClC,eAAO,UAAU,KAAK,IAAI;AAAA,MAC9B;AAEA,eAAS,QAAQ,WAAY;AACzB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,eAAO,IAAK,UAAS,UAAU,KAAK,MAAO,SAAS,CAAE,IAAK,EAAE,OAAQ,MAAM,CAAC,OAAO,CAAC,CAAE;AAAA,MAC1F;AAEA,YAAM,OAAO,QAAQ;AAErB,YAAM,WAAW,KAAK;AAAA,QAClB,GAAG;AAAA,QACH,MAAM,WAAY;AACd,cAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,iBAAQ;AAAQ,iBAAM,OAAQ,UAAW;AAEzC,iBAAO,OAAO,MAAM,OAAO;AAC3B,cAAI,OAAO,IAAI,MAAM,WAAW,KAAK,WAAW,GAAG;AAC/C,mBAAO;AAAA,UACX;AAAA,QACJ;AAAA,MACJ,CAAC;AAED,UAAI,UAAU;AACd,UAAI,SAAS,MAAM;AAEnB,cAAQ,UAAU,QAAQ,SAAS,GAAG,QAAQ;AAC1C,YAAK,WAAW;AAAS,mBAAO;AAEhC,YAAI,MAAM,UAAa,OAAO,CAAC,MAAM,UAAU;AAC3C,cAAI,QAAQ;AACR,iBAAK,KAAK,KAAK;AACf,mBAAO;AAAA,UACX;AACA,iBAAO,IAAI,QAAQ,CAAC,KAAK,KAAK,IAAI,KAAK,KAAK,IAAI,KAAK,KAAK,IAAI,CAAC,GAAG,KAAK;AAAA,QAC3E;AACA,eAAO,KAAK,KAAK;AAAA,MACrB;AAEA,UAAI,UAAU;AAEd,cAAQ,UAAU,UAAU,WAAW;AACnC,eAAO,KAAK,KAAK,YAAY;AAAA,MACjC;AAEA,UAAI,UAAU;AACd,UAAI,kBAAkB;AAEtB,cAAQ,UAAU,SAAS,SAAS,QAAQ;AAC3C,YAAK,WAAW;AAAS,mBAAO;AAEhC,YAAI,KAAK;AACT,YAAI,OAAM,GAAG,IAAI;AACjB,aAAI,MAAM,gBAAgB,KAAK;AAC/B,eAAO,IAAI,QAAQ,MAAK,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;AAAA,MACtD;AAEA,cAAQ,UAAU,WAAW,SAAS,QAAQ;AAC7C,YAAK,WAAW;AAAS,mBAAO;AAEhC,eAAO,KAAK,OAAO,CAAC,MAAM;AAAA,MAC3B;AAEA,cAAQ,UAAU,SAAS,QAAQ,UAAU;AAC7C,cAAQ,UAAU,WAAW,QAAQ,UAAU;AAE/C,UAAI,UAAU;AAEd,cAAQ,UAAU,MAAM,SAAU,IAAI;AAClC,YAAI,MAAM,GAAG,MAAM,GAAG;AACtB,YAAI,OAAO,IAAI;AACf,YAAI,UAAU,IAAI;AAClB,YAAI,MAAM,KAAK,MAAM;AACrB,YAAI,SAAS;AACT,cAAI,KAAI,KAAK,QAAQ,OAAO,IAAK,MAAK,OAAO,GAAG,CAAC,MAAM,OAAO,IAAI;AAClE,cAAI,KAAI,IAAI;AAAE,mBAAO,IAAI;AAAA,UAAI;AAC7B,gBAAM,IAAI,MAAO,qBAAqB,UAAU,cAAc,IAAK;AAAA,QACvE,OAAO;AACH,iBAAO;AAAA,QACX;AAAA,MACJ;AAEA,UAAI,UAAU;AACd,UAAI,SAAS,MAAM;AACnB,UAAI,QAAQ,KAAK;AAEjB,UAAI,MAAM;AACV,UAAI,WAAW;AAEf,cAAQ,UAAU,YAAY,SAAS,KAAK;AACxC,YAAI,QAAQ,UAAa,OAAO,GAAG,MAAM,UAAU;AAC/C,cAAI,QAAQ,GAAG;AAEX,mBAAO,IAAI,QAAQ,CAAC,GAAE,GAAE,GAAE,KAAK,KAAK,EAAE,GAAG,KAAK;AAAA,UAClD;AACA,cAAI,QAAQ,GAAG;AAEX,mBAAO,IAAI,QAAQ,CAAC,KAAI,KAAI,KAAI,KAAK,KAAK,EAAE,GAAG,KAAK;AAAA,UACxD;AAEA,cAAI,UAAU,KAAK,UAAU;AAC7B,cAAI,OAAO;AACX,cAAI,WAAW;AAEf,cAAI,OAAO,SAAU,KAAK,MAAM;AAC5B,gBAAI,MAAM,IAAI,YAAY,MAAM,KAAK,IAAI;AACzC,gBAAI,KAAK,IAAI,UAAU;AACvB,gBAAI,KAAK,IAAI,MAAM,EAAE,IAAI,OAAO,CAAC,YAAY;AAEzC,qBAAO;AAAA,YACX;AACA,mBAAO,KAAK,MAAM,KAAK,KAAK,GAAG,IAAI,KAAK,KAAK,IAAI;AAAA,UACrD;AAEA,cAAI,OAAO,WAAU,MAAM,KAAK,IAAI,QAAQ,CAAC,GAAE,GAAE,CAAC,CAAC,GAAG,IAAI,IAAI,KAAK,MAAM,IAAI,QAAQ,CAAC,KAAI,KAAI,GAAG,CAAC,CAAC,GAAG,IAAI;AAC1G,iBAAO,IAAI,QAAQ,KAAI,OAAQ,CAAC,KAAK,KAAK,EAAE,CAAC,CAAC;AAAA,QAClD;AACA,eAAO,cAAc,MAAM,QAAS,KAAK,KAAM,MAAM,GAAE,CAAC,CAAC;AAAA,MAC7D;AAGA,UAAI,gBAAgB,SAAU,GAAE,GAAE,GAAG;AAGjC,YAAI,YAAY,CAAC;AACjB,YAAI,YAAY,CAAC;AACjB,YAAI,YAAY,CAAC;AACjB,eAAO,SAAS,IAAI,SAAS,IAAI,SAAS;AAAA,MAC9C;AAEA,UAAI,cAAc,SAAU,GAAG;AAC3B,aAAK;AACL,eAAO,KAAK,UAAU,IAAE,QAAQ,MAAO,KAAE,SAAO,OAAO,GAAG;AAAA,MAC9D;AAEA,UAAI,iBAAiB,CAAC;AAEtB,UAAI,UAAU;AACd,UAAI,SAAS,MAAM;AACnB,UAAI,eAAe;AAEnB,UAAI,QAAQ,SAAU,MAAM,MAAM,GAAG;AACjC,YAAK,MAAM;AAAS,cAAE;AACtB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU,SAAS;AACxC,eAAQ,QAAQ;AAAI,eAAM,OAAQ,UAAW,MAAM;AAEnD,YAAI,OAAO,KAAK,MAAM;AACtB,YAAI,CAAC,aAAa,SAAS,CAAC,KAAK,QAAQ;AAErC,iBAAO,OAAO,KAAK,YAAY,EAAE;AAAA,QACrC;AACA,YAAI,CAAC,aAAa,OAAO;AACrB,gBAAM,IAAI,MAAO,wBAAwB,OAAO,iBAAkB;AAAA,QACtE;AACA,YAAI,OAAO,IAAI,MAAM,UAAU;AAAE,iBAAO,IAAI,QAAQ,IAAI;AAAA,QAAG;AAC3D,YAAI,OAAO,IAAI,MAAM,UAAU;AAAE,iBAAO,IAAI,QAAQ,IAAI;AAAA,QAAG;AAC3D,eAAO,aAAa,MAAM,MAAM,MAAM,CAAC,EAClC,MAAM,KAAK,MAAM,IAAI,IAAK,MAAK,MAAM,IAAI,KAAK,MAAM,EAAE;AAAA,MAC/D;AAEA,UAAI,UAAU;AACd,UAAI,MAAM;AAEV,cAAQ,UAAU,MAClB,QAAQ,UAAU,cAAc,SAAS,MAAM,GAAG;AACjD,YAAK,MAAM;AAAS,cAAE;AACtB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU,SAAS;AACxC,eAAQ,QAAQ;AAAI,eAAM,OAAQ,UAAW,MAAM;AAEnD,eAAO,IAAI,MAAM,QAAQ,CAAE,MAAM,MAAM,CAAE,EAAE,OAAQ,IAAK,CAAC;AAAA,MAC1D;AAEA,UAAI,UAAU;AAEd,cAAQ,UAAU,cAAc,SAAS,QAAQ;AAChD,YAAK,WAAW;AAAS,mBAAO;AAEhC,YAAI,OAAM,KAAK;AACf,YAAI,IAAI,KAAI;AACZ,YAAI,QAAQ;AACX,eAAK,OAAO,CAAC,KAAI,KAAG,GAAG,KAAI,KAAG,GAAG,KAAI,KAAG,GAAG,CAAC;AAC5C,iBAAO;AAAA,QACR,OAAO;AACN,iBAAO,IAAI,QAAQ,CAAC,KAAI,KAAG,GAAG,KAAI,KAAG,GAAG,KAAI,KAAG,GAAG,CAAC,GAAG,KAAK;AAAA,QAC5D;AAAA,MACD;AAEA,UAAI,UAAU;AACd,UAAI,gBAAgB;AAEpB,cAAQ,UAAU,WAAW,SAAS,QAAQ;AAC7C,YAAK,WAAW;AAAS,mBAAO;AAEhC,YAAI,KAAK;AACT,YAAI,OAAM,GAAG,IAAI;AACjB,aAAI,MAAM,cAAc,KAAK;AAC7B,YAAI,KAAI,KAAK,GAAG;AAAE,eAAI,KAAK;AAAA,QAAG;AAC9B,eAAO,IAAI,QAAQ,MAAK,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;AAAA,MACtD;AAEA,cAAQ,UAAU,aAAa,SAAS,QAAQ;AAC/C,YAAK,WAAW;AAAS,mBAAO;AAEhC,eAAO,KAAK,SAAS,CAAC,MAAM;AAAA,MAC7B;AAEA,UAAI,UAAU;AACd,UAAI,SAAS,MAAM;AAEnB,cAAQ,UAAU,MAAM,SAAU,IAAI,OAAO,QAAQ;AACjD,YAAK,WAAW;AAAS,mBAAS;AAElC,YAAI,MAAM,GAAG,MAAM,GAAG;AACtB,YAAI,OAAO,IAAI;AACf,YAAI,UAAU,IAAI;AAClB,YAAI,MAAM,KAAK,MAAM;AACrB,YAAI,SAAS;AACT,cAAI,KAAI,KAAK,QAAQ,OAAO,IAAK,MAAK,OAAO,GAAG,CAAC,MAAM,OAAO,IAAI;AAClE,cAAI,KAAI,IAAI;AACR,gBAAI,OAAO,KAAK,KAAK,UAAU;AAC3B,sBAAQ,MAAM,OAAO,CAAC;AAAA,qBACb;AACD,sBAAI,OAAM,CAAC;AACX;AAAA,qBACC;AACD,sBAAI,OAAM,CAAC;AACX;AAAA,qBACC;AACD,sBAAI,OAAM,CAAC,MAAM,OAAO,CAAC;AACzB;AAAA,qBACC;AACD,sBAAI,OAAM,CAAC,MAAM,OAAO,CAAC;AACzB;AAAA;AAEA,sBAAI,MAAK,CAAC;AAAA;AAAA,YAEtB,WAAW,OAAO,KAAK,MAAM,UAAU;AACnC,kBAAI,MAAK;AAAA,YACb,OAAO;AACH,oBAAM,IAAI,MAAM,iCAAiC;AAAA,YACrD;AACA,gBAAI,MAAM,IAAI,QAAQ,KAAK,IAAI;AAC/B,gBAAI,QAAQ;AACR,mBAAK,OAAO,IAAI;AAChB,qBAAO;AAAA,YACX;AACA,mBAAO;AAAA,UACX;AACA,gBAAM,IAAI,MAAO,qBAAqB,UAAU,cAAc,IAAK;AAAA,QACvE,OAAO;AACH,iBAAO;AAAA,QACX;AAAA,MACJ;AAEA,UAAI,UAAU;AAEd,UAAI,MAAM,SAAU,MAAM,MAAM,GAAG;AAC/B,YAAI,OAAO,KAAK;AAChB,YAAI,OAAO,KAAK;AAChB,eAAO,IAAI,QACP,KAAK,KAAK,IAAK,MAAK,KAAG,KAAK,KAC5B,KAAK,KAAK,IAAK,MAAK,KAAG,KAAK,KAC5B,KAAK,KAAK,IAAK,MAAK,KAAG,KAAK,KAC5B,KACJ;AAAA,MACJ;AAGA,qBAAe,MAAM;AAErB,UAAI,UAAU;AACd,UAAI,SAAS,KAAK;AAClB,UAAI,QAAQ,KAAK;AAEjB,UAAI,OAAO,SAAU,MAAM,MAAM,GAAG;AAChC,YAAI,MAAM,KAAK;AACf,YAAI,KAAK,IAAI;AACb,YAAI,KAAK,IAAI;AACb,YAAI,KAAK,IAAI;AACb,YAAI,QAAQ,KAAK;AACjB,YAAI,KAAK,MAAM;AACf,YAAI,KAAK,MAAM;AACf,YAAI,KAAK,MAAM;AACf,eAAO,IAAI,QACP,OAAO,MAAM,IAAG,CAAC,IAAK,KAAE,KAAK,MAAM,IAAG,CAAC,IAAI,CAAC,GAC5C,OAAO,MAAM,IAAG,CAAC,IAAK,KAAE,KAAK,MAAM,IAAG,CAAC,IAAI,CAAC,GAC5C,OAAO,MAAM,IAAG,CAAC,IAAK,KAAE,KAAK,MAAM,IAAG,CAAC,IAAI,CAAC,GAC5C,KACJ;AAAA,MACJ;AAGA,qBAAe,OAAO;AAEtB,UAAI,UAAU;AAEd,UAAI,MAAM,SAAU,MAAM,MAAM,GAAG;AAC/B,YAAI,OAAO,KAAK,IAAI;AACpB,YAAI,OAAO,KAAK,IAAI;AACpB,eAAO,IAAI,QACP,KAAK,KAAK,IAAK,MAAK,KAAG,KAAK,KAC5B,KAAK,KAAK,IAAK,MAAK,KAAG,KAAK,KAC5B,KAAK,KAAK,IAAK,MAAK,KAAG,KAAK,KAC5B,KACJ;AAAA,MACJ;AAGA,qBAAe,MAAM;AAErB,UAAI,UAAU;AAEd,UAAI,OAAO,SAAU,MAAM,MAAM,GAAG,GAAG;AACnC,YAAI,QAAQ;AAEZ,YAAI,MAAM;AACV,YAAI,MAAM,OAAO;AACb,iBAAO,KAAK,IAAI;AAChB,iBAAO,KAAK,IAAI;AAAA,QACpB,WAAW,MAAM,OAAO;AACpB,iBAAO,KAAK,IAAI;AAChB,iBAAO,KAAK,IAAI;AAAA,QACpB,WAAW,MAAM,OAAO;AACpB,iBAAO,KAAK,IAAI;AAChB,iBAAO,KAAK,IAAI;AAAA,QACpB,WAAW,MAAM,OAAO;AACpB,iBAAO,KAAK,IAAI;AAChB,iBAAO,KAAK,IAAI;AAAA,QACpB,WAAW,MAAM,SAAS,MAAM,OAAO;AACnC,cAAI;AACJ,iBAAO,KAAK,IAAI;AAChB,iBAAO,KAAK,IAAI;AAAA,QACpB,WAAW,MAAM,SAAS;AACtB,iBAAO,KAAK,MAAM,EAAE,QAAQ;AAC5B,iBAAO,KAAK,MAAM,EAAE,QAAQ;AAAA,QAChC;AAEA,YAAI,MAAM,MAAM,MAAM,MAAM,MAAM;AAClC,YAAI,EAAE,OAAO,GAAG,CAAC,MAAM,OAAO,MAAM,SAAS;AACzC,UAAC,SAAS,MAAM,OAAO,OAAO,IAAI,OAAO,OAAO,IAAI,OAAO,OAAO;AAClE,UAAC,WAAW,MAAM,OAAO,SAAS,IAAI,OAAO,SAAS,IAAI,OAAO,SAAS;AAAA,QAC9E;AAEA,YAAI,KAAK,KAAK,KAAK;AAEnB,YAAI,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,IAAI,GAAG;AAE9B,cAAI,OAAO,QAAQ,OAAO,OAAO,KAAK;AAClC,iBAAK,OAAQ,QAAO;AAAA,UACxB,WAAW,OAAO,QAAQ,OAAO,OAAO,KAAK;AACzC,iBAAK,OAAO,MAAM;AAAA,UACtB,OAAO;AACH,iBAAK,OAAO;AAAA,UAChB;AACA,gBAAM,OAAO,IAAI;AAAA,QACrB,WAAW,CAAC,MAAM,IAAI,GAAG;AACrB,gBAAM;AACN,cAAK,SAAQ,KAAK,QAAQ,MAAM,KAAK,OAAO;AAAE,kBAAM;AAAA,UAAM;AAAA,QAC9D,WAAW,CAAC,MAAM,IAAI,GAAG;AACrB,gBAAM;AACN,cAAK,SAAQ,KAAK,QAAQ,MAAM,KAAK,OAAO;AAAE,kBAAM;AAAA,UAAM;AAAA,QAC9D,OAAO;AACH,gBAAM,OAAO;AAAA,QACjB;AAEA,YAAI,QAAQ,QAAW;AAAE,gBAAM,OAAO,IAAK,QAAO;AAAA,QAAO;AACzD,cAAM,OAAO,IAAK,QAAO;AACzB,eAAO,MAAM,UAAU,IAAI,QAAQ,CAAC,KAAK,KAAK,GAAG,GAAG,CAAC,IAAI,IAAI,QAAQ,CAAC,KAAK,KAAK,GAAG,GAAG,CAAC;AAAA,MAC3F;AAEA,UAAI,oBAAoB;AAExB,UAAI,MAAM,SAAU,MAAM,MAAM,GAAG;AAClC,eAAO,kBAAkB,MAAM,MAAM,GAAG,KAAK;AAAA,MAC9C;AAGA,qBAAe,MAAM;AACrB,qBAAe,MAAM;AAErB,UAAI,UAAU;AAEd,UAAI,MAAM,SAAU,MAAM,MAAM,GAAG;AAC/B,YAAI,KAAK,KAAK,IAAI;AAClB,YAAI,KAAK,KAAK,IAAI;AAClB,eAAO,IAAI,QAAQ,KAAK,IAAK,MAAG,KAAK,KAAK;AAAA,MAC9C;AAGA,qBAAe,MAAM;AAErB,UAAI,oBAAoB;AAExB,UAAI,MAAM,SAAU,MAAM,MAAM,GAAG;AAClC,eAAO,kBAAkB,MAAM,MAAM,GAAG,KAAK;AAAA,MAC9C;AAGA,qBAAe,MAAM;AAErB,UAAI,oBAAoB;AAExB,UAAI,MAAM,SAAU,MAAM,MAAM,GAAG;AAClC,eAAO,kBAAkB,MAAM,MAAM,GAAG,KAAK;AAAA,MAC9C;AAGA,qBAAe,MAAM;AAErB,UAAI,oBAAoB;AAExB,UAAI,MAAM,SAAU,MAAM,MAAM,GAAG;AAClC,eAAO,kBAAkB,MAAM,MAAM,GAAG,KAAK;AAAA,MAC9C;AAGA,qBAAe,MAAM;AAErB,UAAI,oBAAoB;AAExB,UAAI,MAAM,SAAU,MAAM,MAAM,GAAG;AAClC,eAAO,kBAAkB,MAAM,MAAM,GAAG,KAAK;AAAA,MAC9C;AAGA,qBAAe,MAAM;AAErB,UAAI,UAAU;AAEd,UAAI,QAAQ,SAAU,MAAM,MAAM,GAAG;AACjC,YAAI,OAAO,KAAK,MAAM;AACtB,YAAI,OAAO,KAAK,MAAM;AACtB,eAAO,IAAI,QACP,KAAK,KAAK,IAAK,MAAK,KAAK,KAAK,KAC9B,KAAK,KAAK,IAAK,MAAK,KAAK,KAAK,KAC9B,KAAK,KAAK,IAAK,MAAK,KAAK,KAAK,KAC9B,OACJ;AAAA,MACJ;AAGA,qBAAe,QAAQ;AAEvB,UAAI,kBAAkB;AAEtB,UAAI,QAAQ,SAAU,MAAM,MAAM,GAAG;AACjC,eAAO,gBAAgB,MAAM,MAAM,GAAG,OAAO;AAAA,MACjD;AAGA,qBAAe,QAAQ;AAEvB,UAAI,UAAU;AACd,UAAI,aAAa,MAAM;AACvB,UAAI,QAAQ,KAAK;AACjB,UAAI,SAAS,KAAK;AAClB,UAAI,OAAO,KAAK;AAChB,UAAI,QAAQ,KAAK;AACjB,UAAI,QAAQ,KAAK;AACjB,UAAI,UAAU,KAAK;AAEnB,UAAI,UAAU,SAAU,QAAQ,MAAM,SAAS;AAC3C,YAAK,SAAS;AAAS,iBAAK;AAC5B,YAAK,YAAY;AAAS,oBAAQ;AAElC,YAAI,IAAI,OAAO;AACf,YAAI,CAAC,SAAS;AAAE,oBAAU,MAAM,KAAK,IAAI,MAAM,CAAC,CAAC,EAAE,IAAI,WAAY;AAAE,mBAAO;AAAA,UAAG,CAAC;AAAA,QAAG;AAEnF,YAAI,IAAI,IAAI,QAAQ,OAAO,SAAS,GAAG,GAAG;AAAE,iBAAO,IAAI;AAAA,QAAG,CAAC;AAC3D,gBAAQ,QAAQ,SAAU,GAAE,IAAG;AAAE,kBAAQ,OAAM;AAAA,QAAG,CAAC;AAEnD,iBAAS,OAAO,IAAI,SAAU,GAAG;AAAE,iBAAO,IAAI,QAAQ,CAAC;AAAA,QAAG,CAAC;AAC3D,YAAI,SAAS,QAAQ;AACjB,iBAAO,cAAc,QAAQ,OAAO;AAAA,QACxC;AACA,YAAI,QAAQ,OAAO,MAAM;AACzB,YAAI,MAAM,MAAM,IAAI,IAAI;AACxB,YAAI,MAAM,CAAC;AACX,YAAI,KAAK;AACT,YAAI,KAAK;AAET,iBAAS,KAAE,GAAG,KAAE,IAAI,QAAQ,MAAK;AAC7B,cAAI,MAAM,KAAI,OAAM,KAAK,QAAQ;AACjC,cAAI,KAAK,MAAM,IAAI,GAAE,IAAI,IAAI,QAAQ,EAAE;AACvC,cAAI,KAAK,OAAO,EAAC,MAAM,OAAO,CAAC,MAAM,IAAI,GAAE,GAAG;AAC1C,gBAAI,IAAI,IAAI,MAAK,MAAM;AACvB,kBAAM,MAAM,CAAC,IAAI,QAAQ;AACzB,kBAAM,MAAM,CAAC,IAAI,QAAQ;AAAA,UAC7B;AAAA,QACJ;AAEA,YAAI,QAAQ,MAAM,MAAM,IAAI,QAAQ;AACpC,eAAO,QAAQ,SAAU,GAAE,IAAI;AAC3B,cAAI,OAAO,EAAE,IAAI,IAAI;AACrB,mBAAS,EAAE,MAAM,IAAI,QAAQ,KAAG;AAChC,mBAAS,KAAE,GAAG,KAAE,IAAI,QAAQ,MAAK;AAC7B,gBAAI,CAAC,MAAM,KAAK,GAAE,GAAG;AACjB,kBAAI,OAAM,QAAQ,KAAG;AACrB,kBAAI,KAAK,OAAO,EAAC,MAAM,KAAK;AACxB,oBAAI,KAAI,KAAK,MAAK,MAAM;AACxB,sBAAM,MAAM,EAAC,IAAI,QAAQ,KAAG;AAC5B,sBAAM,MAAM,EAAC,IAAI,QAAQ,KAAG;AAAA,cAChC,OAAO;AACH,oBAAI,OAAM,KAAK,MAAK,QAAQ,KAAG;AAAA,cACnC;AAAA,YACJ;AAAA,UACJ;AAAA,QACJ,CAAC;AAED,iBAAS,OAAI,GAAG,OAAI,IAAI,QAAQ,QAAO;AACnC,cAAI,KAAK,OAAO,IAAG,MAAM,KAAK;AAC1B,gBAAI,MAAM,QAAQ,KAAK,IAAI,OAAM,KAAK,IAAI,KAAI,IAAI,OAAO;AACzD,mBAAO,MAAM,GAAG;AAAE,qBAAO;AAAA,YAAK;AAC9B,mBAAO,OAAO,KAAK;AAAE,qBAAO;AAAA,YAAK;AACjC,gBAAI,QAAO;AAAA,UACf,OAAO;AACH,gBAAI,QAAO,IAAI,QAAK,IAAI;AAAA,UAC5B;AAAA,QACJ;AACA,iBAAS;AACT,eAAQ,IAAI,QAAQ,KAAK,IAAI,EAAG,MAAM,QAAQ,UAAU,IAAI,OAAO,IAAI;AAAA,MAC3E;AAGA,UAAI,gBAAgB,SAAU,QAAQ,SAAS;AAC3C,YAAI,IAAI,OAAO;AACf,YAAI,MAAM,CAAC,GAAE,GAAE,GAAE,CAAC;AAClB,iBAAS,KAAE,GAAG,KAAI,OAAO,QAAQ,MAAK;AAClC,cAAI,MAAM,OAAO;AACjB,cAAI,IAAI,QAAQ,MAAK;AACrB,cAAI,OAAM,IAAI;AACd,cAAI,MAAM,MAAM,KAAI,IAAG,CAAC,IAAI;AAC5B,cAAI,MAAM,MAAM,KAAI,IAAG,CAAC,IAAI;AAC5B,cAAI,MAAM,MAAM,KAAI,IAAG,CAAC,IAAI;AAC5B,cAAI,MAAM,KAAI,KAAK;AAAA,QACvB;AACA,YAAI,KAAK,OAAO,IAAI,EAAE;AACtB,YAAI,KAAK,OAAO,IAAI,EAAE;AACtB,YAAI,KAAK,OAAO,IAAI,EAAE;AACtB,YAAI,IAAI,KAAK,WAAW;AAAE,cAAI,KAAK;AAAA,QAAG;AACtC,eAAO,IAAI,QAAQ,WAAW,GAAG,CAAC;AAAA,MACtC;AAMA,UAAI,WAAW;AACf,UAAI,SAAS,MAAM;AAEnB,UAAI,QAAQ,KAAK;AAEjB,UAAI,UAAU,SAAS,QAAQ;AAG3B,YAAI,QAAQ;AACZ,YAAI,SAAS,SAAS,MAAM;AAC5B,YAAI,UAAU;AAEd,YAAI,UAAU,CAAC,GAAG,CAAC;AACnB,YAAI,OAAO,CAAC;AACZ,YAAI,WAAW,CAAC,GAAE,CAAC;AACnB,YAAI,WAAW;AACf,YAAI,UAAU,CAAC;AACf,YAAI,OAAO;AACX,YAAI,OAAO;AACX,YAAI,OAAO;AACX,YAAI,oBAAoB;AACxB,YAAI,cAAc,CAAC;AACnB,YAAI,YAAY;AAChB,YAAI,SAAS;AAIb,YAAI,YAAY,SAAS,SAAQ;AAC7B,oBAAS,WAAU,CAAC,QAAQ,MAAM;AAClC,cAAI,WAAU,OAAO,OAAM,MAAM,YAAY,SAAS,UAClD,SAAS,OAAO,QAAO,YAAY,IAAI;AACvC,sBAAS,SAAS,OAAO,QAAO,YAAY;AAAA,UAChD;AACA,cAAI,OAAO,OAAM,MAAM,SAAS;AAE5B,gBAAI,QAAO,WAAW,GAAG;AACrB,wBAAS,CAAC,QAAO,IAAI,QAAO,EAAE;AAAA,YAClC;AAEA,sBAAS,QAAO,MAAM,CAAC;AAEvB,qBAAS,IAAE,GAAG,IAAE,QAAO,QAAQ,KAAK;AAChC,sBAAO,KAAK,SAAS,QAAO,EAAE;AAAA,YAClC;AAEA,iBAAK,SAAS;AACd,qBAAS,MAAI,GAAG,MAAI,QAAO,QAAQ,OAAO;AACtC,mBAAK,KAAK,MAAK,SAAO,SAAO,EAAE;AAAA,YACnC;AAAA,UACJ;AACA,qBAAW;AACX,iBAAO,UAAU;AAAA,QACrB;AAEA,YAAI,WAAW,SAAS,OAAO;AAC3B,cAAI,YAAY,MAAM;AAClB,gBAAI,IAAI,SAAS,SAAO;AACxB,gBAAI,KAAI;AACR,mBAAO,KAAI,KAAK,SAAS,SAAS,KAAI;AAClC;AAAA,YACJ;AACA,mBAAO,KAAE;AAAA,UACb;AACA,iBAAO;AAAA,QACX;AAEA,YAAI,gBAAgB,SAAU,GAAG;AAAE,iBAAO;AAAA,QAAG;AAC7C,YAAI,aAAa,SAAU,GAAG;AAAE,iBAAO;AAAA,QAAG;AAc1C,YAAI,WAAW,SAAS,KAAK,WAAW;AACpC,cAAI,KAAK;AACT,cAAI,aAAa,MAAM;AAAE,wBAAY;AAAA,UAAO;AAC5C,cAAI,MAAM,GAAG,KAAM,QAAQ,MAAO;AAAE,mBAAO;AAAA,UAAQ;AACnD,cAAI,CAAC,WAAW;AACZ,gBAAI,YAAa,SAAS,SAAS,GAAI;AAEnC,kBAAI,IAAI,SAAS,GAAG;AACpB,kBAAI,IAAK,UAAS,SAAO;AAAA,YAC7B,WAAW,SAAS,MAAM;AAEtB,kBAAK,OAAM,QAAS,QAAO;AAAA,YAC/B,OAAO;AACH,kBAAI;AAAA,YACR;AAAA,UACJ,OAAO;AACH,gBAAI;AAAA,UACR;AAGA,cAAI,WAAW,CAAC;AAEhB,cAAI,CAAC,WAAW;AACZ,gBAAI,cAAc,CAAC;AAAA,UACvB;AAEA,cAAI,WAAW,GAAG;AAAE,gBAAI,MAAM,GAAG,MAAM;AAAA,UAAG;AAE1C,cAAI,SAAS,KAAM,IAAK,KAAI,SAAS,KAAK,SAAS;AAEnD,cAAI,KAAK,IAAI,GAAG,KAAK,IAAI,GAAG,CAAC,CAAC;AAE9B,cAAI,IAAI,KAAK,MAAM,IAAI,GAAK;AAE5B,cAAI,aAAa,YAAY,IAAI;AAC7B,kBAAM,YAAY;AAAA,UACtB,OAAO;AACH,gBAAI,OAAO,OAAO,MAAM,SAAS;AAE7B,uBAAS,KAAE,GAAG,KAAE,KAAK,QAAQ,MAAK;AAC9B,oBAAI,IAAI,KAAK;AACb,oBAAI,KAAK,GAAG;AACR,wBAAM,QAAQ;AACd;AAAA,gBACJ;AACA,oBAAK,KAAK,KAAO,OAAO,KAAK,SAAO,GAAK;AACrC,wBAAM,QAAQ;AACd;AAAA,gBACJ;AACA,oBAAI,IAAI,KAAK,IAAI,KAAK,KAAE,IAAI;AACxB,sBAAK,KAAE,KAAI,MAAK,KAAE,KAAG;AACrB,wBAAM,SAAS,YAAY,QAAQ,KAAI,QAAQ,KAAE,IAAI,GAAG,KAAK;AAC7D;AAAA,gBACJ;AAAA,cACJ;AAAA,YACJ,WAAW,OAAO,OAAO,MAAM,YAAY;AACvC,oBAAM,QAAQ,CAAC;AAAA,YACnB;AACA,gBAAI,WAAW;AAAE,0BAAY,KAAK;AAAA,YAAK;AAAA,UAC3C;AACA,iBAAO;AAAA,QACX;AAEA,YAAI,aAAa,WAAY;AAAE,iBAAO,cAAc,CAAC;AAAA,QAAG;AAExD,kBAAU,MAAM;AAIhB,YAAI,IAAI,SAAS,GAAG;AAChB,cAAI,IAAI,SAAS,SAAS,CAAC,CAAC;AAC5B,cAAI,QAAQ,EAAE,OAAO;AAAE,mBAAO,EAAE,MAAM;AAAA,UAAG,OAAO;AAAE,mBAAO;AAAA,UAAG;AAAA,QAChE;AAEA,UAAE,UAAU,SAAS,SAAS;AAC1B,cAAI,WAAW,MAAM;AACjB,gBAAI,OAAO,OAAO,MAAM,SAAS;AAC7B,yBAAW;AACX,wBAAU,CAAC,QAAQ,IAAI,QAAQ,QAAQ,SAAO,EAAE;AAAA,YACpD,OAAO;AACH,kBAAI,IAAI,SAAS,QAAQ,OAAO;AAChC,kBAAI,YAAY,GAAG;AACf,2BAAW,CAAC,EAAE,KAAK,EAAE,GAAG;AAAA,cAC5B,OAAO;AACH,2BAAW,SAAS,OAAO,GAAG,KAAK,OAAO;AAAA,cAC9C;AAAA,YACJ;AACA,mBAAO;AAAA,UACX;AACA,iBAAO;AAAA,QACX;AAGA,UAAE,SAAS,SAAS,QAAQ;AACxB,cAAI,CAAC,UAAU,QAAQ;AACnB,mBAAO;AAAA,UACX;AACA,iBAAO,OAAO;AACd,iBAAO,OAAO,OAAO,SAAO;AAC5B,iBAAO,CAAC;AACR,cAAI,IAAI,QAAQ;AAChB,cAAK,OAAO,WAAW,KAAO,SAAS,MAAO;AAE1C,qBAAS,KAAI,GAAG,QAAO,MAAM,KAAK,MAAM,GAAG,KAAI,MAAK,QAAQ,MAAK,GAAG;AAChE,kBAAI,IAAI,MAAK;AAEf,mBAAK,KAAM,KAAE,QAAS,QAAK,KAAK;AAAA,YAClC;AAAA,UACJ,OAAO;AACH,qBAAS,IAAE,GAAG,IAAE,GAAG,KAAK;AACpB,mBAAK,KAAK,IAAG,KAAE,EAAE;AAAA,YACrB;AACA,gBAAI,OAAO,SAAS,GAAG;AAEnB,kBAAI,OAAO,OAAO,IAAI,SAAU,IAAE,IAAG;AAAE,uBAAO,KAAG,QAAO,SAAO;AAAA,cAAI,CAAC;AACpE,kBAAI,UAAU,OAAO,IAAI,SAAU,IAAG;AAAE,uBAAQ,MAAI,QAAS,QAAO;AAAA,cAAO,CAAC;AAC5E,kBAAI,CAAC,QAAQ,MAAM,SAAU,KAAK,IAAG;AAAE,uBAAO,KAAK,QAAO;AAAA,cAAK,CAAC,GAAG;AAC/D,6BAAa,SAAU,GAAG;AACtB,sBAAI,KAAK,KAAK,KAAK,GAAG;AAAE,2BAAO;AAAA,kBAAG;AAClC,sBAAI,KAAI;AACR,yBAAO,KAAK,QAAQ,KAAE,IAAI;AAAE;AAAA,kBAAK;AACjC,sBAAI,KAAK,KAAI,QAAQ,OAAO,SAAQ,KAAE,KAAK,QAAQ;AACnD,sBAAI,MAAM,KAAK,MAAK,KAAK,MAAK,KAAE,KAAK,KAAK;AAC1C,yBAAO;AAAA,gBACX;AAAA,cACJ;AAAA,YAEJ;AAAA,UACJ;AACA,oBAAU,CAAC,MAAM,IAAI;AACrB,iBAAO;AAAA,QACX;AAEA,UAAE,OAAO,SAAS,IAAI;AAClB,cAAI,CAAC,UAAU,QAAQ;AACnB,mBAAO;AAAA,UACX;AACA,kBAAQ;AACR,qBAAW;AACX,iBAAO;AAAA,QACX;AAEA,UAAE,QAAQ,SAAS,SAAQ,OAAM;AAC7B,oBAAU,OAAM;AAChB,iBAAO;AAAA,QACX;AAEA,UAAE,MAAM,SAAS,IAAI;AACjB,iBAAO;AACP,iBAAO;AAAA,QACX;AAEA,UAAE,SAAS,SAAS,KAAK;AACrB,cAAI,CAAC,UAAU,QAAQ;AACnB,mBAAO;AAAA,UACX;AACA,oBAAU;AACV,iBAAO;AAAA,QACX;AAEA,UAAE,mBAAmB,SAAS,GAAG;AAC7B,cAAI,KAAK,MAAM;AAAE,gBAAI;AAAA,UAAM;AAC3B,8BAAoB;AACpB,qBAAW;AACX,cAAI,mBAAmB;AACnB,4BAAgB,SAAS,GAAG;AACxB,kBAAI,KAAK,SAAS,GAAG,IAAI,EAAE,IAAI,EAAE;AACjC,kBAAI,KAAK,SAAS,GAAG,IAAI,EAAE,IAAI,EAAE;AACjC,kBAAI,MAAM,KAAK;AACf,kBAAI,WAAW,SAAS,GAAG,IAAI,EAAE,IAAI,EAAE;AACvC,kBAAI,UAAU,KAAO,MAAK,MAAM;AAChC,kBAAI,SAAS,WAAW;AACxB,kBAAI,KAAK;AACT,kBAAI,KAAK;AACT,kBAAI,WAAW;AACf,qBAAQ,KAAK,IAAI,MAAM,IAAI,QAAU,aAAa,GAAI;AAClD,gBAAC,YAAW;AACR,sBAAI,KAAK;AAAE,8BAAU;AAAA,kBAAI;AACzB,sBAAI,SAAS,GAAG;AACZ,yBAAK;AACL,yBAAM,MAAK,KAAK;AAAA,kBACpB,OAAO;AACH,yBAAK;AACL,yBAAM,MAAK,KAAK;AAAA,kBACpB;AACA,6BAAW,SAAS,GAAG,IAAI,EAAE,IAAI,EAAE;AACnC,yBAAO,SAAS,WAAW;AAAA,gBAC/B,GAAG;AAAA,cACP;AACA,qBAAO;AAAA,YACX;AAAA,UACJ,OAAO;AACH,4BAAgB,SAAU,GAAG;AAAE,qBAAO;AAAA,YAAG;AAAA,UAC7C;AACA,iBAAO;AAAA,QACX;AAEA,UAAE,UAAU,SAAS,GAAG;AACpB,cAAI,KAAK,MAAM;AACX,gBAAI,OAAO,CAAC,MAAM,UAAU;AACxB,kBAAI,CAAC,GAAE,CAAC;AAAA,YACZ;AACA,uBAAW;AACX,mBAAO;AAAA,UACX,OAAO;AACH,mBAAO;AAAA,UACX;AAAA,QACJ;AAEA,UAAE,SAAS,SAAS,WAAW,KAAK;AAEhC,cAAI,UAAU,SAAS,GAAG;AAAE,kBAAM;AAAA,UAAO;AACzC,cAAI,SAAS,CAAC;AAEd,cAAI,UAAU,WAAW,GAAG;AACxB,qBAAS,QAAQ,MAAM,CAAC;AAAA,UAE5B,WAAW,cAAc,GAAG;AACxB,qBAAS,CAAC,EAAE,GAAG,CAAC;AAAA,UAEpB,WAAW,YAAY,GAAG;AACtB,gBAAI,KAAK,QAAQ;AACjB,gBAAI,KAAK,QAAQ,KAAK;AACtB,qBAAS,UAAU,GAAG,WAAW,KAAK,EAAE,IAAI,SAAU,IAAG;AAAE,qBAAO,EAAG,KAAO,KAAG,aAAU,KAAM,EAAI;AAAA,YAAG,CAAC;AAAA,UAE3G,OAAO;AACH,qBAAS,CAAC;AACV,gBAAI,UAAU,CAAC;AACf,gBAAI,YAAa,SAAS,SAAS,GAAI;AACnC,uBAAS,KAAI,GAAG,MAAM,SAAS,QAAQ,MAAM,KAAK,KAAK,MAAM,KAAI,MAAM,KAAI,KAAK,MAAM,OAAM,MAAK;AAC7F,wBAAQ,KAAM,UAAS,KAAE,KAAG,SAAS,OAAI,GAAG;AAAA,cAChD;AAAA,YACJ,OAAO;AACH,wBAAU;AAAA,YACd;AACA,qBAAS,QAAQ,IAAI,SAAU,GAAG;AAAE,qBAAO,EAAE,CAAC;AAAA,YAAG,CAAC;AAAA,UACtD;AAEA,cAAI,SAAS,MAAM;AACf,qBAAS,OAAO,IAAI,SAAU,GAAG;AAAE,qBAAO,EAAE,KAAK;AAAA,YAAG,CAAC;AAAA,UACzD;AACA,iBAAO;AAAA,QACX;AAEA,UAAE,QAAQ,SAAS,GAAG;AAClB,cAAI,KAAK,MAAM;AACX,wBAAY;AACZ,mBAAO;AAAA,UACX,OAAO;AACH,mBAAO;AAAA,UACX;AAAA,QACJ;AAEA,UAAE,QAAQ,SAAS,GAAG;AAClB,cAAI,KAAK,MAAM;AACX,qBAAS;AACT,mBAAO;AAAA,UACX,OAAO;AACH,mBAAO;AAAA,UACX;AAAA,QACJ;AAEA,UAAE,SAAS,SAAS,GAAG;AACnB,cAAI,KAAK,MAAM;AACX,qBAAS,SAAS,CAAC;AACnB,mBAAO;AAAA,UACX,OAAO;AACH,mBAAO;AAAA,UACX;AAAA,QACJ;AAEA,eAAO;AAAA,MACX;AAEA,yBAAmB,MAAM,OAAO,WAAW;AACzC,YAAI,QAAQ,CAAC;AACb,YAAI,YAAY,OAAO;AACvB,YAAI,MAAM,CAAC,YAAY,QAAQ,YAAY,QAAQ,IAAI,QAAQ;AAC/D,iBAAS,KAAI,MAAM,YAAY,KAAI,MAAM,KAAI,KAAK,YAAY,OAAM,MAAK;AACvE,gBAAM,KAAK,EAAC;AAAA,QACd;AACA,eAAO;AAAA,MACT;AAOA,UAAI,UAAU;AAEd,UAAI,UAAU;AAGd,UAAI,YAAY,SAAS,GAAG;AACxB,YAAI,MAAM,CAAC,GAAG,CAAC;AACf,iBAAS,KAAI,GAAG,KAAI,GAAG,MAAK;AACxB,cAAI,SAAS,CAAC,CAAC;AACf,mBAAS,IAAI,GAAG,KAAK,IAAI,QAAQ,KAAK;AAClC,mBAAO,KAAM,KAAI,MAAM,KAAK,IAAI,IAAI;AAAA,UACxC;AACA,gBAAM;AAAA,QACV;AACA,eAAO;AAAA,MACX;AAEA,UAAI,SAAS,SAAS,QAAQ;AAC1B,YAAI,QAAQ,UAAU;AAEtB,YAAI,GAAG,MAAM,MAAM;AACnB,iBAAS,OAAO,IAAI,SAAU,GAAG;AAAE,iBAAO,IAAI,QAAQ,CAAC;AAAA,QAAG,CAAC;AAC3D,YAAI,OAAO,WAAW,GAAG;AAErB,UAAC,SAAS,OAAO,IAAI,SAAU,GAAG;AAAE,mBAAO,EAAE,IAAI;AAAA,UAAG,CAAC,GAAG,OAAO,OAAO,IAAI,OAAO,OAAO;AACxF,cAAI,SAAS,GAAG;AACZ,gBAAI,OAAO,CAAC,GAAG,GAAG,CAAC,EAAE,IAAI,SAAU,IAAG;AAAE,qBAAO,KAAK,MAAM,IAAK,MAAK,MAAK,KAAK;AAAA,YAAM,CAAC;AACrF,mBAAO,IAAI,QAAQ,MAAK,KAAK;AAAA,UACjC;AAAA,QACJ,WAAW,OAAO,WAAW,GAAG;AAE5B,UAAC,WAAW,OAAO,IAAI,SAAU,GAAG;AAAE,mBAAO,EAAE,IAAI;AAAA,UAAG,CAAC,GAAG,OAAO,SAAS,IAAI,OAAO,SAAS,IAAI,OAAO,SAAS;AAClH,cAAI,SAAS,GAAG;AACZ,gBAAI,OAAO,CAAC,GAAG,GAAG,CAAC,EAAE,IAAI,SAAU,IAAG;AAAE,qBAAS,KAAE,KAAI,KAAE,KAAK,KAAK,MAAO,IAAK,KAAE,KAAK,IAAI,KAAK,MAAO,IAAI,IAAI,KAAK;AAAA,YAAK,CAAC;AACzH,mBAAO,IAAI,QAAQ,MAAK,KAAK;AAAA,UACjC;AAAA,QACJ,WAAW,OAAO,WAAW,GAAG;AAE5B,cAAI;AACJ,UAAC,WAAW,OAAO,IAAI,SAAU,GAAG;AAAE,mBAAO,EAAE,IAAI;AAAA,UAAG,CAAC,GAAG,OAAO,SAAS,IAAI,OAAO,SAAS,IAAI,OAAO,SAAS,IAAI,OAAO,SAAS;AACtI,cAAI,SAAS,GAAG;AACZ,gBAAI,OAAO,CAAC,GAAG,GAAG,CAAC,EAAE,IAAI,SAAU,IAAG;AAAE,qBAAS,KAAE,KAAI,KAAE,KAAI,KAAE,KAAK,KAAK,MAAO,IAAK,KAAE,KAAM,KAAE,KAAK,IAAI,KAAK,MAAO,IAAK,KAAE,KAAK,IAAI,IAAI,KAAK,MAAO,IAAE,IAAE,IAAI,KAAK;AAAA,YAAK,CAAC;AACvK,mBAAO,IAAI,QAAQ,MAAK,KAAK;AAAA,UACjC;AAAA,QACJ,WAAW,OAAO,UAAU,GAAG;AAE3B,cAAI,MAAM,KAAK;AACf,iBAAO,OAAO,IAAI,SAAU,GAAG;AAAE,mBAAO,EAAE,IAAI;AAAA,UAAG,CAAC;AAClD,cAAI,OAAO,SAAS;AACpB,gBAAM,UAAU,CAAC;AACjB,cAAI,SAAU,GAAG;AACb,gBAAI,IAAI,IAAI;AACZ,gBAAI,OAAO,CAAC,GAAG,GAAG,CAAC,EAAE,IAAI,SAAU,IAAG;AAAE,qBAAO,KAAK,OAAO,SAAU,KAAK,IAAI,GAAG;AAAE,uBAAQ,MAAM,IAAI,KAAK,KAAK,IAAK,GAAI,IAAI,CAAG,IAAI,KAAK,IAAK,GAAG,CAAE,IAAI,GAAG;AAAA,cAAK,GAAG,CAAC;AAAA,YAAG,CAAC;AACtK,mBAAO,IAAI,QAAQ,MAAK,KAAK;AAAA,UACjC;AAAA,QACJ,OAAO;AACH,gBAAM,IAAI,WAAW,iDAAiD;AAAA,QAC1E;AACA,eAAO;AAAA,MACX;AAEA,UAAI,WAAW,SAAU,QAAQ;AAC7B,YAAI,IAAI,OAAO,MAAM;AACrB,UAAE,QAAQ,WAAY;AAAE,iBAAO,QAAQ,CAAC;AAAA,QAAG;AAC3C,eAAO;AAAA,MACX;AAOA,UAAI,WAAW;AAEf,UAAI,QAAQ,SAAU,QAAQ,KAAK,MAAM;AACrC,YAAI,CAAC,MAAM,OAAO;AACd,gBAAM,IAAI,MAAM,wBAAwB,IAAI;AAAA,QAChD;AACA,eAAO,MAAM,MAAM,QAAQ,GAAG;AAAA,MAClC;AAEA,UAAI,UAAU,SAAU,GAAG;AAAE,eAAO,SAAU,QAAO,KAAK;AAClD,cAAI,KAAK,SAAS,GAAG,EAAE,IAAI;AAC3B,cAAI,KAAK,SAAS,MAAM,EAAE,IAAI;AAC9B,iBAAO,SAAS,IAAI,EAAE,IAAI,EAAE,CAAC;AAAA,QACjC;AAAA,MAAG;AAEP,UAAI,OAAO,SAAU,GAAG;AAAE,eAAO,SAAU,IAAI,IAAI;AAC3C,cAAI,MAAM,CAAC;AACX,cAAI,KAAK,EAAE,GAAG,IAAI,GAAG,EAAE;AACvB,cAAI,KAAK,EAAE,GAAG,IAAI,GAAG,EAAE;AACvB,cAAI,KAAK,EAAE,GAAG,IAAI,GAAG,EAAE;AACvB,iBAAO;AAAA,QACX;AAAA,MAAG;AAEP,UAAI,SAAS,SAAU,GAAG;AAAE,eAAO;AAAA,MAAG;AACtC,UAAI,WAAW,SAAU,GAAE,GAAG;AAAE,eAAO,IAAI,IAAI;AAAA,MAAK;AACpD,UAAI,SAAS,SAAU,GAAE,GAAG;AAAE,eAAO,IAAI,IAAI,IAAI;AAAA,MAAG;AACpD,UAAI,UAAU,SAAU,GAAE,GAAG;AAAE,eAAO,IAAI,IAAI,IAAI;AAAA,MAAG;AACrD,UAAI,SAAS,SAAU,GAAE,GAAG;AAAE,eAAO,MAAO,KAAK,KAAE,IAAE,OAAQ,KAAE,IAAE;AAAA,MAAO;AACxE,UAAI,UAAU,SAAU,GAAE,GAAG;AAAE,eAAO,IAAI,MAAM,IAAI,IAAI,IAAI,MAAM,MAAO,KAAI,IAAK,KAAI,IAAI,OAAU,KAAI,IAAI;AAAA,MAAQ;AACpH,UAAI,OAAO,SAAU,GAAE,GAAG;AAAE,eAAO,MAAO,KAAK,KAAI,IAAI,OAAQ,KAAE;AAAA,MAAO;AACxE,UAAI,QAAQ,SAAU,GAAE,GAAG;AACvB,YAAI,MAAM,KAAK;AAAE,iBAAO;AAAA,QAAK;AAC7B,YAAI,MAAO,KAAI,OAAQ,KAAI,IAAI;AAC/B,eAAO,IAAI,MAAM,MAAM;AAAA,MAC3B;AAKA,YAAM,SAAS,QAAQ,KAAK,MAAM,CAAC;AACnC,YAAM,WAAW,QAAQ,KAAK,QAAQ,CAAC;AACvC,YAAM,SAAS,QAAQ,KAAK,MAAM,CAAC;AACnC,YAAM,UAAU,QAAQ,KAAK,OAAO,CAAC;AACrC,YAAM,SAAS,QAAQ,KAAK,MAAM,CAAC;AACnC,YAAM,UAAU,QAAQ,KAAK,OAAO,CAAC;AACrC,YAAM,QAAQ,QAAQ,KAAK,KAAK,CAAC;AACjC,YAAM,OAAO,QAAQ,KAAK,IAAI,CAAC;AAG/B,UAAI,UAAU;AAMd,UAAI,SAAS,MAAM;AACnB,UAAI,WAAW,MAAM;AACrB,UAAI,QAAQ,MAAM;AAClB,UAAI,QAAQ,KAAK;AACjB,UAAI,QAAQ,KAAK;AACjB,UAAI,QAAQ,KAAK;AACjB,UAAI,WAAW;AAEf,UAAI,YAAY,SAAS,OAAO,WAAW,KAAK,OAAO,WAAW;AAC9D,YAAK,UAAU;AAAS,kBAAM;AAC9B,YAAK,cAAc;AAAS,sBAAU;AACtC,YAAK,QAAQ;AAAS,gBAAI;AAC1B,YAAK,UAAU;AAAS,kBAAM;AAC9B,YAAK,cAAc;AAAS,sBAAU,CAAC,GAAE,CAAC;AAE1C,YAAI,KAAK,GAAG;AACZ,YAAI,OAAO,SAAS,MAAM,SAAS;AAC/B,eAAK,UAAU,KAAK,UAAU;AAAA,QAClC,OAAO;AACH,eAAK;AACL,sBAAY,CAAC,WAAW,SAAS;AAAA,QACrC;AAEA,YAAI,IAAI,SAAS,OAAO;AACpB,cAAI,IAAI,QAAW,UAAM,OAAK,MAAQ,YAAY;AAClD,cAAI,IAAI,MAAM,UAAU,KAAM,KAAK,OAAQ,KAAK;AAChD,cAAI,IAAI,OAAO,IAAI,IAAI,KAAM,QAAQ,KAAM;AAC3C,cAAI,MAAO,IAAI,IAAK,KAAE,KAAM;AAC5B,cAAI,QAAQ,MAAM,CAAC;AACnB,cAAI,QAAQ,MAAM,CAAC;AACnB,cAAI,IAAI,IAAK,MAAQ,YAAW,QAAU,UAAS;AACnD,cAAI,IAAI,IAAK,MAAQ,YAAW,QAAU,UAAS;AACnD,cAAI,IAAI,IAAK,MAAO,WAAW;AAC/B,iBAAO,SAAS,SAAS,CAAC,IAAE,KAAI,IAAE,KAAI,IAAE,KAAI,CAAC,CAAC,CAAC;AAAA,QACnD;AAEA,UAAE,QAAQ,SAAS,GAAG;AAClB,cAAK,KAAK,MAAO;AAAE,mBAAO;AAAA,UAAO;AACjC,kBAAQ;AACR,iBAAO;AAAA,QACX;AAEA,UAAE,YAAY,SAAS,GAAG;AACtB,cAAK,KAAK,MAAO;AAAE,mBAAO;AAAA,UAAW;AACrC,sBAAY;AACZ,iBAAO;AAAA,QACX;AAEA,UAAE,QAAQ,SAAS,GAAG;AAClB,cAAK,KAAK,MAAO;AAAE,mBAAO;AAAA,UAAO;AACjC,kBAAQ;AACR,iBAAO;AAAA,QACX;AAEA,UAAE,MAAM,SAAS,GAAG;AAChB,cAAK,KAAK,MAAO;AAAE,mBAAO;AAAA,UAAK;AAC/B,gBAAM;AACN,cAAI,OAAO,GAAG,MAAM,SAAS;AACzB,iBAAK,IAAI,KAAK,IAAI;AAClB,gBAAI,OAAO,GAAG;AAAE,oBAAM,IAAI;AAAA,YAAI;AAAA,UAClC,OAAO;AACH,iBAAK;AAAA,UACT;AACA,iBAAO;AAAA,QACX;AAEA,UAAE,YAAY,SAAS,GAAG;AACtB,cAAK,KAAK,MAAO;AAAE,mBAAO;AAAA,UAAW;AACrC,cAAI,OAAO,CAAC,MAAM,SAAS;AACvB,wBAAY;AACZ,iBAAK,EAAE,KAAK,EAAE;AAAA,UAClB,OAAO;AACH,wBAAY,CAAC,GAAE,CAAC;AAChB,iBAAK;AAAA,UACT;AACA,iBAAO;AAAA,QACX;AAEA,UAAE,QAAQ,WAAY;AAAE,iBAAO,SAAS,MAAM,CAAC;AAAA,QAAG;AAElD,UAAE,IAAI,GAAG;AAET,eAAO;AAAA,MACX;AAEA,UAAI,UAAU;AACd,UAAI,SAAS;AAEb,UAAI,UAAU,KAAK;AACnB,UAAI,SAAS,KAAK;AAElB,UAAI,WAAW,WAAY;AACvB,YAAI,OAAO;AACX,iBAAS,KAAE,GAAG,KAAE,GAAG,MAAK;AACpB,kBAAQ,OAAO,OAAO,QAAQ,OAAO,IAAI,EAAE,CAAC;AAAA,QAChD;AACA,eAAO,IAAI,QAAQ,MAAM,KAAK;AAAA,MAClC;AAEA,UAAI,OAAO;AACX,UAAI,MAAM,KAAK;AACf,UAAI,QAAQ,KAAK;AACjB,UAAI,QAAQ,KAAK;AACjB,UAAI,QAAQ,KAAK;AAGjB,UAAI,UAAU,SAAU,MAAM,MAAK;AAC/B,YAAK,SAAQ;AAAS,iBAAI;AAE1B,YAAI,IAAI;AAAA,UACJ,KAAK,OAAO;AAAA,UACZ,KAAK,OAAO,YAAU;AAAA,UACtB,KAAK;AAAA,UACL,QAAQ,CAAC;AAAA,UACT,OAAO;AAAA,QACX;AACA,YAAI,KAAK,IAAI,MAAM,UAAU;AACzB,iBAAO,OAAO,OAAO,IAAI;AAAA,QAC7B;AACA,aAAK,QAAQ,SAAU,KAAK;AACxB,cAAI,QAAO,KAAK,GAAG,MAAM,UAAU;AAAE,kBAAM,IAAI;AAAA,UAAM;AACrD,cAAI,QAAQ,UAAa,QAAQ,QAAQ,CAAC,MAAM,GAAG,GAAG;AAClD,cAAE,OAAO,KAAK,GAAG;AACjB,cAAE,OAAO;AACT,gBAAI,MAAM,EAAE,KAAK;AAAE,gBAAE,MAAM;AAAA,YAAK;AAChC,gBAAI,MAAM,EAAE,KAAK;AAAE,gBAAE,MAAM;AAAA,YAAK;AAChC,cAAE,SAAS;AAAA,UACf;AAAA,QACJ,CAAC;AAED,UAAE,SAAS,CAAC,EAAE,KAAK,EAAE,GAAG;AAExB,UAAE,SAAS,SAAU,MAAM,MAAK;AAAE,iBAAO,OAAO,GAAG,MAAM,IAAG;AAAA,QAAG;AAE/D,eAAO;AAAA,MACX;AAGA,UAAI,SAAS,SAAU,MAAM,MAAM,MAAK;AACpC,YAAK,SAAS;AAAS,iBAAK;AAC5B,YAAK,SAAQ;AAAS,iBAAI;AAE1B,YAAI,KAAK,IAAI,KAAK,SAAS;AACvB,iBAAO,QAAQ,IAAI;AAAA,QACvB;AACA,YAAI,OAAM,KAAK;AACf,YAAI,OAAM,KAAK;AACf,YAAI,SAAS,KAAK,OAAO,KAAK,SAAU,GAAE,GAAG;AAAE,iBAAO,IAAE;AAAA,QAAG,CAAC;AAE5D,YAAI,SAAQ,GAAG;AAAE,iBAAO,CAAC,MAAI,IAAG;AAAA,QAAG;AAEnC,YAAI,UAAS,CAAC;AAEd,YAAI,KAAK,OAAO,GAAE,CAAC,MAAM,KAAK;AAC1B,kBAAO,KAAK,IAAG;AACf,kBAAO,KAAK,IAAG;AAAA,QACnB;AAEA,YAAI,KAAK,OAAO,GAAE,CAAC,MAAM,KAAK;AAC1B,kBAAO,KAAK,IAAG;AACf,mBAAS,KAAE,GAAG,KAAE,MAAK,MAAK;AACtB,oBAAO,KAAK,OAAM,KAAE,OAAM,QAAI,KAAK;AAAA,UACvC;AACA,kBAAO,KAAK,IAAG;AAAA,QACnB,WAES,KAAK,OAAO,GAAE,CAAC,MAAM,KAAK;AAC/B,cAAI,QAAO,GAAG;AACV,kBAAM,IAAI,MAAM,qDAAqD;AAAA,UACzE;AACA,cAAI,UAAU,KAAK,SAAS,IAAI,IAAG;AACnC,cAAI,UAAU,KAAK,SAAS,IAAI,IAAG;AACnC,kBAAO,KAAK,IAAG;AACf,mBAAS,OAAI,GAAG,OAAI,MAAK,QAAO;AAC5B,oBAAO,KAAK,MAAM,IAAI,UAAY,OAAI,OAAQ,WAAU,QAAS,CAAC;AAAA,UACtE;AACA,kBAAO,KAAK,IAAG;AAAA,QACnB,WAES,KAAK,OAAO,GAAE,CAAC,MAAM,KAAK;AAC/B,kBAAO,KAAK,IAAG;AACf,mBAAS,MAAI,GAAG,MAAI,MAAK,OAAO;AAC5B,gBAAI,IAAM,QAAO,SAAO,KAAK,MAAK;AAClC,gBAAI,KAAK,MAAM,CAAC;AAChB,gBAAI,OAAO,GAAG;AACV,sBAAO,KAAK,OAAO,GAAG;AAAA,YAC1B,OAAO;AACH,kBAAI,KAAK,IAAI;AACb,sBAAO,KAAM,OAAO,MAAK,KAAE,MAAQ,OAAO,KAAG,KAAG,EAAG;AAAA,YACvD;AAAA,UACJ;AACA,kBAAO,KAAK,IAAG;AAAA,QAEnB,WAES,KAAK,OAAO,GAAE,CAAC,MAAM,KAAK;AAM/B,cAAI;AACJ,cAAI,IAAI,OAAO;AACf,cAAI,cAAc,IAAI,MAAM,CAAC;AAC7B,cAAI,eAAe,IAAI,MAAM,IAAG;AAChC,cAAI,SAAS;AACb,cAAI,WAAW;AACf,cAAI,YAAY;AAGhB,sBAAY,CAAC;AACb,oBAAU,KAAK,IAAG;AAClB,mBAAS,MAAI,GAAG,MAAI,MAAK,OAAO;AAC5B,sBAAU,KAAK,OAAQ,MAAI,OAAQ,QAAI,KAAK;AAAA,UAChD;AACA,oBAAU,KAAK,IAAG;AAElB,iBAAO,QAAQ;AAEX,qBAAS,IAAE,GAAG,IAAE,MAAK,KAAK;AACtB,2BAAa,KAAK;AAAA,YACtB;AACA,qBAAS,MAAI,GAAG,MAAI,GAAG,OAAO;AAC1B,kBAAI,QAAQ,OAAO;AACnB,kBAAI,UAAU,OAAO;AACrB,kBAAI,OAAQ;AACZ,uBAAS,MAAI,GAAG,MAAI,MAAK,OAAO;AAC5B,oBAAI,OAAO,MAAM,UAAU,OAAK,KAAK;AACrC,oBAAI,OAAO,SAAS;AAChB,4BAAU;AACV,yBAAO;AAAA,gBACX;AACA,6BAAa;AACb,4BAAY,OAAO;AAAA,cACvB;AAAA,YACJ;AAGA,gBAAI,eAAe,IAAI,MAAM,IAAG;AAChC,qBAAS,MAAI,GAAG,MAAI,MAAK,OAAO;AAC5B,2BAAa,OAAO;AAAA,YACxB;AACA,qBAAS,MAAI,GAAG,MAAI,GAAG,OAAO;AAC1B,wBAAU,YAAY;AACtB,kBAAI,aAAa,aAAa,MAAM;AAChC,6BAAa,WAAW,OAAO;AAAA,cACnC,OAAO;AACH,6BAAa,YAAY,OAAO;AAAA,cACpC;AAAA,YACJ;AACA,qBAAS,MAAI,GAAG,MAAI,MAAK,OAAO;AAC5B,2BAAa,QAAQ,IAAE,aAAa;AAAA,YACxC;AAGA,qBAAS;AACT,qBAAS,MAAI,GAAG,MAAI,MAAK,OAAO;AAC5B,kBAAI,aAAa,SAAS,UAAU,MAAM;AACtC,yBAAS;AACT;AAAA,cACJ;AAAA,YACJ;AAEA,wBAAY;AACZ;AAEA,gBAAI,WAAW,KAAK;AAChB,uBAAS;AAAA,YACb;AAAA,UACJ;AAIA,cAAI,YAAY,CAAC;AACjB,mBAAS,MAAI,GAAG,MAAI,MAAK,OAAO;AAC5B,sBAAU,OAAO,CAAC;AAAA,UACtB;AACA,mBAAS,MAAI,GAAG,MAAI,GAAG,OAAO;AAC1B,sBAAU,YAAY;AACtB,sBAAU,SAAS,KAAK,OAAO,IAAI;AAAA,UACvC;AACA,cAAI,kBAAkB,CAAC;AACvB,mBAAS,MAAI,GAAG,MAAI,MAAK,OAAO;AAC5B,4BAAgB,KAAK,UAAU,KAAK,EAAE;AACtC,4BAAgB,KAAK,UAAU,KAAK,UAAU,KAAK,SAAO,EAAE;AAAA,UAChE;AACA,4BAAkB,gBAAgB,KAAK,SAAU,GAAE,GAAE;AAAE,mBAAO,IAAE;AAAA,UAAG,CAAC;AACpE,kBAAO,KAAK,gBAAgB,EAAE;AAC9B,mBAAS,MAAI,GAAG,MAAM,gBAAgB,QAAQ,OAAM,GAAG;AACnD,gBAAI,IAAI,gBAAgB;AACxB,gBAAI,CAAC,MAAM,CAAC,KAAM,QAAO,QAAQ,CAAC,MAAM,IAAK;AACzC,sBAAO,KAAK,CAAC;AAAA,YACjB;AAAA,UACJ;AAAA,QACJ;AACA,eAAO;AAAA,MACX;AAEA,UAAI,YAAY,EAAC,SAAkB,OAAc;AAEjD,UAAI,UAAU;AAGd,UAAI,WAAW,SAAU,GAAG,GAAG;AAG3B,YAAI,IAAI,QAAQ,CAAC;AACjB,YAAI,IAAI,QAAQ,CAAC;AACjB,YAAI,KAAK,EAAE,UAAU;AACrB,YAAI,KAAK,EAAE,UAAU;AACrB,eAAO,KAAK,KAAM,MAAK,QAAS,MAAK,QAAS,MAAK,QAAS,MAAK;AAAA,MACrE;AAEA,UAAI,UAAU;AACd,UAAI,OAAO,KAAK;AAChB,UAAI,MAAM,KAAK;AACf,UAAI,MAAM,KAAK;AACf,UAAI,MAAM,KAAK;AACf,UAAI,QAAQ,KAAK;AACjB,UAAI,MAAM,KAAK;AACf,UAAI,MAAM,KAAK;AACf,UAAI,MAAM,KAAK;AACf,UAAI,MAAM,KAAK;AACf,UAAI,KAAK,KAAK;AAEd,UAAI,SAAS,SAAS,GAAG,GAAG,IAAI,IAAI,IAAI;AACpC,YAAK,OAAO;AAAS,eAAG;AACxB,YAAK,OAAO;AAAS,eAAG;AACxB,YAAK,OAAO;AAAS,eAAG;AAIxB,YAAI,UAAU,SAAS,KAAK;AACxB,iBAAO,MAAM,MAAO,KAAI;AAAA,QAC5B;AACA,YAAI,UAAU,SAAS,KAAK;AACxB,iBAAQ,IAAI,KAAK,MAAO;AAAA,QAC5B;AACA,YAAI,IAAI,QAAQ,CAAC;AACjB,YAAI,IAAI,QAAQ,CAAC;AACjB,YAAI,MAAM,MAAM,KAAK,EAAE,IAAI,CAAC;AAC5B,YAAI,KAAK,IAAI;AACb,YAAI,KAAK,IAAI;AACb,YAAI,KAAK,IAAI;AACb,YAAI,QAAQ,MAAM,KAAK,EAAE,IAAI,CAAC;AAC9B,YAAI,KAAK,MAAM;AACf,YAAI,KAAK,MAAM;AACf,YAAI,KAAK,MAAM;AACf,YAAI,OAAQ,MAAK,MAAI;AACrB,YAAI,KAAK,KAAK,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;AACrC,YAAI,KAAK,KAAK,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;AACrC,YAAI,OAAQ,MAAK,MAAI;AACrB,YAAI,IAAI,MAAK,KAAE,KAAK,IAAI,MAAM,CAAC,IAAG,KAAI,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC,EAAE;AAC5D,YAAI,MAAM,KAAI,KAAE;AAChB,YAAI,MAAM,KAAI,KAAE;AAChB,YAAI,MAAM,KAAK,IAAI,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;AACvC,YAAI,MAAM,KAAK,IAAI,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC;AACvC,YAAI,QAAS,OAAM,OAAK;AACxB,YAAI,UAAU,QAAQ,MAAM,IAAI,GAAG,CAAC;AACpC,YAAI,UAAU,QAAQ,MAAM,IAAI,GAAG,CAAC;AACpC,YAAI,MAAM,WAAW,IAAI,UAAU,UAAU;AAC7C,YAAI,MAAM,WAAW,IAAI,UAAU,UAAU;AAC7C,YAAI,QAAQ,IAAI,MAAM,GAAG,IAAI,MAAO,OAAM,MAAM,OAAK,IAAK,OAAM,OAAK;AACrE,YAAI,IAAI,IAAI,OAAK,IAAI,QAAQ,QAAQ,EAAE,CAAC,IAAI,OAAK,IAAI,QAAQ,IAAE,KAAK,CAAC,IAAI,OAAK,IAAI,QAAQ,IAAE,QAAQ,CAAC,CAAC,IAAI,MAAI,IAAI,QAAQ,IAAE,QAAQ,EAAE,CAAC;AACvI,YAAI,UAAU,MAAM;AACpB,kBAAU,IAAI,OAAO,KAAK,MAAM,UAAU,OAAO,MAAM,UAAU,MAAM,UAAU;AACjF,kBAAU,IAAE,KAAK,MAAI,GAAG,IAAE,IAAI,QAAQ,OAAO,IAAE,CAAC;AAChD,YAAI,SAAS,KAAK;AAClB,YAAI,UAAU,MAAM;AACpB,YAAI,KAAK,IAAK,QAAM,IAAI,OAAO,IAAI,CAAC,IAAG,KAAK,KAAK,IAAI,OAAO,IAAI,CAAC,CAAC;AAClE,YAAI,KAAK,IAAI,QAAM;AACnB,YAAI,KAAK,IAAI,QAAM,QAAM;AACzB,YAAI,aAAa,KAAG,IAAI,CAAC,IAAK,SAAQ,OAAK,IAAI,CAAC,CAAC;AACjD,YAAI,KAAK,IAAE,KAAK,IAAI,OAAO,CAAC,IAAG,KAAI,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC,EAAE;AAC1D,YAAI,KAAK,CAAC,KAAG,IAAI,IAAE,QAAQ,UAAU,CAAC;AACtC,YAAI,SAAS,KAAK,IAAI,SAAQ,MAAG,KAAK,CAAC,IAAI,IAAI,UAAS,MAAG,KAAK,CAAC,IAAI,IAAI,UAAS,MAAG,KAAK,CAAC,IAAI,KAAI,WAAS,MAAG,OAAM,WAAS,MAAG,IAAI;AACrI,eAAO,IAAI,GAAG,IAAI,KAAK,MAAM,CAAC;AAAA,MAClC;AAEA,UAAI,UAAU;AAGd,UAAI,WAAW,SAAS,GAAG,GAAG,MAAM;AAChC,YAAK,SAAS;AAAS,iBAAK;AAI5B,YAAI,IAAI,QAAQ,CAAC;AACjB,YAAI,IAAI,QAAQ,CAAC;AACjB,YAAI,KAAK,EAAE,IAAI,IAAI;AACnB,YAAI,KAAK,EAAE,IAAI,IAAI;AACnB,YAAI,SAAS;AACb,iBAAS,MAAK,IAAI;AACd,cAAI,IAAK,IAAG,OAAM,KAAM,IAAG,OAAM;AACjC,oBAAU,IAAE;AAAA,QAChB;AACA,eAAO,KAAK,KAAK,MAAM;AAAA,MAC3B;AAEA,UAAI,QAAQ;AAEZ,UAAI,QAAQ,WAAY;AACpB,YAAI,OAAO,CAAC,GAAG,MAAM,UAAU;AAC/B,eAAQ;AAAQ,eAAM,OAAQ,UAAW;AAEzC,YAAI;AACA,cAAK,UAAS,UAAU,KAAK,MAAO,OAAO,CAAE,IAAK,EAAE,OAAQ,IAAI,CAAE;AAClE,iBAAO;AAAA,QACX,SAAS,GAAP;AACE,iBAAO;AAAA,QACX;AAAA,MACJ;AAGA,UAAI,WAAW;AAEf,UAAI,QAAQ;AAEZ,UAAI,SAAS;AAAA,QACZ,MAAM,gBAAgB;AAAE,iBAAO,MAAM,CAAC,SAAS,IAAI,KAAI,GAAE,GAAE,GAAG,SAAS,IAAI,KAAI,KAAG,GAAE,CAAC,CAAC;AAAA,QAAE;AAAA,QACxF,KAAK,eAAe;AAAE,iBAAO,MAAM,CAAC,QAAO,QAAO,QAAO,MAAM,CAAC,EAAE,KAAK,KAAK;AAAA,QAAE;AAAA,MAC/E;AAmBA,UAAI,cAAc;AAAA,QAEd,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,SAAS,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC3G,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,QAAQ,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC1G,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,QAAQ,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC1G,QAAQ,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC1G,SAAS,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC3G,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,OAAO,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACzG,QAAQ,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC1G,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,OAAO,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACzG,QAAQ,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC1G,SAAS,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAI3G,UAAU,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAClI,QAAQ,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAChI,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC9H,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC9H,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC9H,QAAQ,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAChI,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC9H,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC9H,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAI9H,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC7F,QAAQ,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC/F,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACxG,MAAM,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QACzI,OAAO,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC9F,QAAQ,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAC3I,SAAS,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,QAChG,SAAS,CAAC,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,SAAS;AAAA,MAC/G;AAGA,eAAS,IAAI,GAAG,OAAO,OAAO,KAAK,WAAW,GAAG,IAAI,KAAK,QAAQ,KAAK,GAAG;AACtE,YAAI,MAAM,KAAK;AAEf,oBAAY,IAAI,YAAY,KAAK,YAAY;AAAA,MACjD;AAEA,UAAI,gBAAgB;AAEpB,UAAI,SAAS;AAgDb,aAAO,UAAU;AACjB,aAAO,SAAS;AAChB,aAAO,QAAQ;AACf,aAAO,YAAY;AACnB,aAAO,MAAM,OAAO,cAAc;AAClC,aAAO,SAAS;AAChB,aAAO,QAAQ;AAGf,aAAO,UAAU,UAAU;AAC3B,aAAO,WAAW;AAClB,aAAO,SAAS;AAChB,aAAO,WAAW;AAClB,aAAO,SAAS,UAAU;AAC1B,aAAO,QAAQ;AAGf,aAAO,SAAS;AAGhB,aAAO,SAAS;AAChB,aAAO,SAAS;AAEhB,UAAI,YAAY;AAEhB,aAAO;AAAA,IAEX,CAAE;AAAA;AAAA;;;AC9/GF,IAAO,oBAAQ;",
"names": []
}