{"version":3,"file":"uspTilesSlider.js","mappings":"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SAAS,oDAAiB;AAC1B;AACA;AACA,KAAK;AACL;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA,KAAK;AACL;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA,KAAK;AACL;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA,KAAK;AACL;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA,KAAK;AACL;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA,KAAK;AACL;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA,KAAK;AACL;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA,KAAK;AACL;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,kEAAiB;AAC7C;AACA;AACA,sBAAsB,oDAAiB;AACvC,sBAAsB,oDAAiB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA,8CAA8C,kEAAiB;AAC/D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yEAAyE,EAAE,OAAO,EAAE,GAAG,oDAAY;AACnG;AACA;AACA,2BAA2B,kEAAiB;AAC5C;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,yBAAyB;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qEAAqE,EAAE,OAAO,EAAE,8BAA8B,EAAE,cAAc,EAAE;AAChI;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,qFAAqF,oBAAoB;AACzG;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN,aAAa,oDAAiB;AAC9B,aAAa,oDAAiB;AAC9B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,2BAA2B,oDAAiB;AAC5C;AACA;AACA,OAAO;AACP;;AAEA;AACA,qBAAqB,6DAAW;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,aAAa,oDAAiB;AAC9B,aAAa,oDAAiB;AAC9B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,2BAA2B,oDAAiB;AAC5C;AACA;AACA,OAAO;AACP;AACA,qBAAqB,6DAAW;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,oDAAa;AAC9B;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;;AAE2B;;;;;;;;;;;;;;;;;ACzXqC;;AAEhE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,MAAM;AACN;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,6DAAW;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,6DAAW;AAChC;AACA;AACA;AACA,qBAAqB,6DAAW;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAE+B;;;;;;;;;;;;;;;;;AC/SgD;;AAE/E,kCAAkC,iBAAiB;AACnD;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,uBAAuB;AAC7C;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU,oDAAQ;AAClB;AACA,WAAW;AACX;AACA,QAAQ,oDAAoB;AAC5B;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,kBAAkB,uBAAuB;AACzC;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV,+BAA+B,2BAA2B;AAC1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;;AAEiC;;;;;;;;;;;;;;;;;;;;;AC9L+B;AACJ;AACI;AAC8B;AAC/B;;AAE/D;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA,yDAAyD,sBAAsB;AAC/E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,uCAAuC;AACvD;AACA;AACA;AACA,qBAAqB,GAAG,KAAK,iBAAiB,GAAG,2BAA2B;AAC5E,QAAQ;AACR;AACA,qBAAqB,GAAG,KAAK,iBAAiB,IAAI,2BAA2B;AAC7E,QAAQ;AACR,gBAAgB,GAAG;AACnB;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,2BAA2B,OAAO,2BAA2B;;AAEzG;AACA;AACA,sBAAsB,GAAG,IAAI,GAAG,IAAI,GAAG;AACvC,kBAAkB,2CAA2C;AAC7D,gBAAgB,YAAY;AAC5B;AACA;;AAEA;AACA;AACA;AACA;AACA,qBAAqB,4DAAY;AACjC;AACA;AACA;AACA;AACA,uBAAuB,4DAAY;AACnC;AACA;AACA;AACA;AACA,2DAA2D,oDAAmB;AAC9E;AACA,uCAAuC,SAAS;AAChD;AACA,+CAA+C,SAAS;AACxD,OAAO;AACP,KAAK;AACL,IAAI,4EAA0B;AAC9B;AACA;AACA;AACA,KAAK;AACL;AACA,EAAE,0DAAU;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEkC;;;;;;;;;;;;;;;;;;;;AC/H8B;AACJ;AACI;AACkB;;AAElF;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,oDAAY;AAC1B;AACA,4CAA4C,YAAY;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,WAAW,KAAK,WAAW,KAAK,WAAW,eAAe,WAAW,eAAe,WAAW,aAAa,MAAM;AAC9J,uBAAuB,4DAAY;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,4DAAY;AACvC;AACA;AACA,0BAA0B,4DAAY;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2DAA2D,oDAAmB;AAC9E;AACA,uCAAuC,SAAS;AAChD;AACA,+CAA+C,SAAS;AACxD,OAAO;AACP,KAAK;AACL;AACA,EAAE,0DAAU;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEsC;;;;;;;;;;;;;;;;;;;;;ACvG0B;AACJ;AACI;AAC8B;AACZ;;AAElF;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,cAAc,MAAM;AACpB;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA,sBAAsB,oDAAY;AAClC;AACA;AACA,2DAA2D,OAAO;AAClE;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA,2BAA2B,MAAM,QAAQ,0CAA0C,IAAI,gCAAgC;AACvH,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,sCAAsC,gBAAgB,eAAe,gBAAgB,eAAe,gBAAgB;AACpH,0DAA0D,qDAAqD,cAAc,qDAAqD;AAClL;AACA,uCAAuC,gBAAgB,IAAI,cAAc,EAAE,YAAY;;AAEvF;AACA;AACA;AACA;AACA,qBAAqB,4DAAY;AACjC;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,4DAAY;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2DAA2D,oDAAmB;AAC9E;AACA,uCAAuC,SAAS;AAChD;AACA,+CAA+C,SAAS;AACxD,OAAO;AACP,KAAK;AACL,IAAI,4EAA0B;AAC9B;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,EAAE,0DAAU;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEqC;;;;;;;;;;;;;;;;;;ACjJuB;AACgB;;AAE5E;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,qBAAqB,oDAAa,wDAAwD,8BAA8B;AACxH;AACA;AACA;AACA,oBAAoB,oDAAa,wDAAwD,kCAAkC;AAC3H;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,cAAc,oDAAY;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,oDAAa;AACtC;AACA;AACA,uCAAuC,YAAY;AACnD,QAAQ;AACR;AACA;AACA,yBAAyB,oDAAa;AACtC;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,QAAQ;AACR;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,kCAAkC,eAAe,iCAAiC,mBAAmB,GAAG,MAAM,GAAG,MAAM,GAAG;AAC7J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,eAAe;AACjE,8DAA8D,eAAe;AAC7E;AACA;AACA,2DAA2D,sCAAsC,MAAM,iBAAiB,4CAA4C,mBAAmB;AACvL,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA,kDAAkD,OAAO,OAAO,OAAO,qBAAqB,0BAA0B,MAAM,2BAA2B;AACvJ;AACA;AACA;AACA,qDAAqD,QAAQ,cAAc,6CAA6C,eAAe,8CAA8C;AACrL,gEAAgE,QAAQ;AACxE;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,4CAA4C,SAAS;AACrD;AACA,4CAA4C,SAAS;AACrD,OAAO;AACP,KAAK;AACL;AACA;AACA,2DAA2D,SAAS;AACpE;AACA;AACA,EAAE,0DAAU;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEiC;;;;;;;;;;;;;;;;;;;;AC7K2B;AACI;AAC8B;AAC/B;;AAE/D;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,MAAM;AACN;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,4DAAY;AACnC;AACA,gDAAgD,GAAG,MAAM,GAAG;AAC5D;AACA;AACA;AACA,2DAA2D,oDAAmB;AAC9E;AACA,uCAAuC,SAAS;AAChD,KAAK;AACL,IAAI,4EAA0B;AAC9B;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,EAAE,0DAAU;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEiC;;;;;;;;;;;;;;;;;;;;;ACjE+B;AACJ;AACI;AAC8B;AACZ;;AAElF;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,qBAAqB,4DAAY;AACjC;AACA;AACA,oBAAoB,4DAAY;AAChC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,sBAAsB,oDAAY;AAClC,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,GAAG,MAAM,GAAG,mBAAmB,mBAAmB,eAAe,mBAAmB;AAC3H,uBAAuB,4DAAY;AACnC;AACA;AACA;AACA;AACA,2DAA2D,oDAAmB;AAC9E;AACA,uCAAuC,SAAS;AAChD;AACA,+CAA+C,SAAS;AACxD,OAAO;AACP,KAAK;AACL,IAAI,4EAA0B;AAC9B;AACA;AACA;AACA,KAAK;AACL;AACA,EAAE,0DAAU;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEiC;;;;;;;;;;;;;;;;;AC9GyC;;AAE1E;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,YAAY,oDAAG;AACf,KAAK;AACL;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,yBAAyB,oDAAG;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,oDAAG;AAC7B;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,QAAQ;AACR;AACA,wBAAwB,qBAAqB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,YAAY;AACZ;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,oDAAoB;AAC5B;AACA;AACA;AACA;AACA;AACA,YAAY,oDAAoB;AAChC;AACA;AACA,aAAa;AACb,WAAW;AACX,SAAS;AACT,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU,oDAAoB;AAC9B;AACA;AACA,WAAW;AACX;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAE+B;;;;;;;;;;;;;;;;AC5O/B;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,yCAAyC,0BAA0B,QAAQ,KAAK;AAChF,yFAAyF,aAAa;AACtG;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,qEAAqE,kCAAkC;AACvG;AACA;AACA;AACA,sBAAsB,qBAAqB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,6BAA6B,8BAA8B,UAAU,8BAA8B;AACnG;AACA;AACA,MAAM;AACN,0BAA0B,8BAA8B;AACxD;AACA,4BAA4B,8BAA8B;AAC1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAE2B;;;;;;;;;;;;;;;;;;AC1JqD;AACrB;;AAE3D;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA,mBAAmB,6DAAW;AAC9B,iBAAiB,6DAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,oDAAe,sBAAsB,yBAAyB,cAAc,KAAK,8BAA8B,KAAK;AACxJ;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,uIAAuI,mBAAmB;AAC1J;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uIAAuI,mBAAmB;AAC1J;AACA;AACA,kDAAkD,gBAAgB;AAClE;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEqC;;;;;;;;;;;;;;;;;AC5FyB;;AAE9D;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,6DAAS;AAC5B;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,6DAAS;AAC5B;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,+HAA+H,MAAM;AACrI;AACA;AACA;AACA;AACA,iBAAiB,KAAK,GAAG,SAAS,IAAI,QAAQ,EAAE,MAAM;AACtD,MAAM;AACN,iBAAiB,SAAS,IAAI,QAAQ,EAAE,MAAM;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,MAAM;AACN;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,qDAAqD,YAAY;AACjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,6DAAS;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,6DAAS;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;;AAE8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AC7ImB;AACE;AACI;AACA;AACA;AACF;AACF;AACR;AACY;AACZ;AACM;AACe;AACb;AACJ;AACK;AACT;AACgB;AACH;AACA;AACA;AACU;AACF;;;;;;;;;;;;;;;;;;ACrBgB;AACF;;AAE9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,mBAAmB,6DAAW;AAC9B,iBAAiB,6DAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,8CAA8C;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU,oDAAc,gBAAgB,yBAAyB,+BAA+B,oDAAc,gBAAgB,+BAA+B;AAC7J;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,oDAAa;AACxC;AACA;AACA,sBAAsB,wBAAwB;AAC9C;AACA;AACA,0DAA0D;AAC1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD;AACjD;AACA;AACA;AACA,MAAM;AACN;AACA,iDAAiD;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;;AAE+B;;;;;;;;;;;;;;;;ACpH/B;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,YAAY;AAC3C;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,kBAAkB,yBAAyB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0BAA0B;AAC9C;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA,kBAAkB,0BAA0B;AAC5C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEmC;;;;;;;;;;;;;;;;;;AC9L2B;AACA;;AAE9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,iBAAiB,6DAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,uBAAuB,oDAAG;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA,gBAAgB;;AAEhB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,oDAAG;AACrD;AACA;AACA;;AAEA;AACA;AACA;AACA,+BAA+B,oDAAG;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iCAAiC,2CAA2C;AAC5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C;AAC9C;AACA;AACA;AACA;AACA;AACA,4FAA4F;AAC5F,QAAQ,6EAA6E;AACrF,MAAM;AACN;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,oDAAG;AACjB;AACA;AACA;AACA;;AAEA;AACA;AACA,mCAAmC;AACnC;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc,oDAAG;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC;AACvC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,oDAAQ;AAC9B;AACA;AACA,aAAa,MAAM,aAAa;AAChC;;AAEA;AACA;AACA;AACA;AACA,sBAAsB,oDAAQ;AAC9B;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;;AAEiC;;;;;;;;;;;;;;;;;;AC1Y4D;AAChC;;AAE7D;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,4EAAyB;AACxD;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,aAAa,oDAAiB;AAC9B,aAAa,oDAAiB;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,aAAa,oDAAiB;AAC9B,aAAa,oDAAiB;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,MAAM;AACN,aAAa,oDAAiB;AAC9B,aAAa,oDAAiB;AAC9B;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,MAAM;AACN,aAAa,oDAAiB;AAC9B,aAAa,oDAAiB;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEiC;;;;;;;;;;;;;;;;;;;ACvM0C;AACkB;AAC+B;;AAE5H;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,IAAI;AAC1B,4BAA4B,IAAI;AAChC,wBAAwB,IAAI;AAC5B,uBAAuB,IAAI;AAC3B,qBAAqB,IAAI;AACzB,sBAAsB,IAAI;AAC1B,+BAA+B,IAAI;AACnC,mCAAmC,IAAI;AACvC,yBAAyB,IAAI;AAC7B,oBAAoB,IAAI;AACxB,0BAA0B,IAAI;AAC9B,wBAAwB,IAAI;AAC5B,kCAAkC,IAAI;AACtC;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,2BAA2B,0CAA0C;AACrE;AACA,gCAAgC,kBAAkB,GAAG,SAAS;AAC9D,6BAA6B,0CAA0C;AACvE;AACA,kCAAkC,kBAAkB,GAAG,SAAS,GAAG,SAAS;AAC5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,sCAAsC,kEAAiB;AACvD;AACA;AACA;AACA;AACA,kBAAkB,oDAAY;AAC9B;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,oDAAgB;AACrC;AACA,uEAAuE,6CAA6C;AACpH,SAAS;AACT;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iHAAiH,yBAAyB,EAAE,OAAO;AACnJ;AACA,OAAO;AACP;AACA;AACA,8BAA8B,oDAAY;AAC1C;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA,yCAAyC,yBAAyB;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA,mCAAmC,gBAAgB;AACnD;AACA,6CAA6C,yBAAyB;AACtE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wEAAwE,cAAc;AACtF,SAAS;AACT;AACA;AACA;AACA;AACA,+BAA+B,kEAAiB;AAChD;AACA,SAAS;AACT,+BAA+B,kEAAiB;AAChD;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,+BAA+B,kEAAiB;AAChD,oEAAoE,OAAO,WAAW,OAAO;AAC7F,mDAAmD,oBAAoB;AACvE,SAAS;AACT;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,oDAAiB;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,qBAAqB;AAC3C;AACA;AACA,UAAU;AACV;AACA,gCAAgC,sBAAsB,EAAE,yCAAyC,SAAS,mBAAmB,MAAM,qBAAqB;AACxJ;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,yCAAyC,oBAAoB,qCAAqC,kBAAkB;AACpH;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR,yCAAyC,4BAA4B;AACrE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iEAAiE,kEAAiB;AAClF;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,+BAA+B,4EAAyB;AACxD;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,oDAAc;AAC5B;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,SAAS,oDAAiB;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,qBAAqB,EAAE,YAAY;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,oDAAiB;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,SAAS,oDAAiB;AAC1B;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,MAAM;AACN;AACA,WAAW,oDAAiB;AAC5B;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,eAAe,oDAAiB;AAChC;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,WAAW,oDAAiB;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,WAAW,oDAAiB;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEiC;;;;;;;;;;;;;;;;;AC3c0B;;AAE3D;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,aAAa,uCAAuC;AACpD,MAAM;AACN,aAAa,yBAAyB;AACtC;AACA;AACA,aAAa,2BAA2B;AACxC,MAAM;AACN,aAAa,aAAa;AAC1B;AACA;AACA;AACA;AACA;AACA,mCAAmC,EAAE,IAAI,EAAE;AAC3C;AACA;AACA,6BAA6B,aAAa;AAC1C;AACA;AACA;AACA,8BAA8B,cAAc;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,qBAAqB,oDAAe;AACpC;AACA,uBAAuB,oDAAe;AACtC;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,iBAAiB;AACnD;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,iBAAiB;AAChE,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;;AAE+B;;;;;;;;;;;;;;;;;;;;AC3HiC;AAC0E;AAC7C;AAClB;;AAE3E;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,mBAAmB,6DAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,8CAA8C,OAAO;AACrD,8BAA8B,QAAQ;AACtC,MAAM;AACN,mDAAmD,OAAO;AAC1D,+BAA+B,QAAQ;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,0DAA0D,SAAS;AACnE;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,8BAA8B,SAAS;AACvC,MAAM;AACN,+BAA+B,SAAS;AACxC;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA,6CAA6C,oDAAa;AAC1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA,6DAA6D;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oDAAQ;AAC5B;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,8BAA8B,4EAAyB;AACvD;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,kEAAiB;AACjD;AACA,iBAAiB,oDAAa;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,yDAAyD,oDAAe;AACxE;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,oDAAe;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,SAAS,oDAAiB;AAC1B;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,MAAM;AACN;AACA,yDAAyD,oDAAe;AACxE;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA,kCAAkC,oDAAe;AACjD;AACA,8CAA8C,oDAAe;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,oDAAe;AAC9C;AACA,2CAA2C,oDAAe;AAC1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEgC;;;;;;;;;;;;;;;;;;AC7WgC;AACU;;AAE1E;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA,MAAM,SAAS,oDAAQ;AACvB,iDAAiD;AACjD;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,sBAAsB;AAC5C,QAAQ,oDAAe,qDAAqD,qBAAqB;AACjG;AACA,SAAS;AACT;AACA,MAAM;AACN,sBAAsB,sBAAsB;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0HAA0H,iBAAiB;AAC3I;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,uBAAuB,6DAAW;AAClC;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV,+BAA+B,2BAA2B;AAC1D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;;AAE4B;;;;;;;;;;;;;;;;;;ACpMoC;AACoC;;AAEpG;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,mBAAmB,6DAAW;AAC9B;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,gBAAgB,oDAAa;AAC7B,MAAM;AACN,gBAAgB,oDAAa;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,kDAAkD;AAClD;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,kDAAkD;AAC3F,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,SAAS;AACtC;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,yBAAyB;AACzE;AACA,OAAO;AACP,MAAM;AACN,iCAAiC,iBAAiB;AAClD;AACA;AACA,oDAAoD,yBAAyB,4BAA4B,WAAW,4CAA4C,WAAW;AAC3K;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA,2BAA2B,YAAY;AACvC;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,8CAA8C,QAAQ;AACtD;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,OAAO;AACP;AACA,IAAI,oDAAe;AACnB,qCAAqC,kDAAkD;AACvF,KAAK;AACL;AACA;AACA;AACA;AACA,sBAAsB,mBAAmB;AACzC;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,mBAAmB;AACzC;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,QAAQ;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+EAA+E,yBAAyB;AACxG;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,8BAA8B,qCAAqC;AACnE;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,MAAM;AACN;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,MAAM,oDAAc,+CAA+C,mBAAmB;AACtF;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAE8B;;;;;;;;;;;;;;;;;;AC5VgC;AACyD;;AAEvH;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,iBAAiB,6DAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mDAAmD,yBAAyB;AAC5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,kCAAkC;AAC3D;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,yBAAyB;AACtE;AACA,sDAAsD,sBAAsB;AAC5E;AACA;AACA;AACA;AACA;AACA,8BAA8B,oDAAc,sBAAsB,sBAAsB;AACxF,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kEAAkE,WAAW;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kDAAkD,oBAAoB;AACtE,kEAAkE,WAAW;AAC7E;AACA;AACA;AACA,uCAAuC,wBAAwB;AAC/D,MAAM;AACN,0CAA0C,wBAAwB;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,oDAAY;AACjC,qBAAqB,oDAAY;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yDAAyD,eAAe,MAAM,eAAe;AAC7F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,iBAAiB;AACvE,yDAAyD,eAAe,MAAM,eAAe;AAC7F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,oCAAoC;AAC9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yDAAyD,KAAK,MAAM,KAAK;AACzE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,yBAAyB;AACxE;AACA;AACA;AACA,4BAA4B,oDAAe,sBAAsB,+BAA+B;AAChG,UAAU;AACV;AACA;AACA;AACA,sDAAsD,sBAAsB;AAC5E;AACA;AACA;AACA;AACA;AACA,8BAA8B,oDAAc,sBAAsB,sBAAsB;AACxF,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,wBAAwB;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,oDAAa;AAC7B,gBAAgB,oDAAa;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yDAAyD,WAAW,MAAM,WAAW;AACrF;AACA,kEAAkE,WAAW;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,oDAAe,sBAAsB,+BAA+B;AAC9F,QAAQ;AACR;AACA;AACA,sDAAsD,sBAAsB;AAC5E;AACA;AACA;AACA;AACA;AACA,8BAA8B,oDAAc,sBAAsB,sBAAsB;AACxF,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,wBAAwB;AAChE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;;AAEN;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAE2B;;;;;;;;;;;;;;;;AC5rB3B;AACA;AACA;AACA;AACA,aAAa;AACb,sBAAsB;AACtB;;AAEkC;;;;;;;;;;;;;;;;;ACRqC;;AAEvE;AACA;AACA;AACA;AACA,sBAAsB,6CAAe,gBAAgB,gBAAgB;AACrE;AACA,oBAAoB,6CAAa;AACjC;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAE0C;;;;;;;;;;;;;;;;;ACpBiC;;AAE3E;AACA,4CAA4C,WAAW,KAAK,OAAO,EAAE,iCAAiC,OAAO,OAAO;AACpH,0BAA0B,6CAAmB;AAC7C,mDAAmD,iCAAiC;AACpF;AACA,eAAe,6CAAa;AAC5B;AACA;AACA;AACA;;AAE6B;;;;;;;;;;;;;;;;ACb7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,8BAA8B,qCAAqC,EAAE,OAAO;AAC5E;AACA,gCAAgC,qCAAqC;AACrE;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAE2B;;;;;;;;;;;;;;;;;ACzD4B;;AAEvD;AACA,sBAAsB,6CAAmB;AACzC;AACA;AACA;AACA;AACA;AACA;;AAE6B;;;;;;;;;;;;;;;;;ACX2B;;AAExD;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,MAAM,6CAAoB;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,OAAO;AACP,KAAK;AACL;AACA;;AAE2C;;;;;;;;;;;;;;;;;AC/C3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mEAAmE;AACnE;AACA;AACA,GAAG;AACH;AACA;AACA,UAAU;AACV,uBAAuB;AACvB,0BAA0B;AAC1B;AACA,aAAa;AACb;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,eAAe;AACf,uBAAuB;AACvB;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,qBAAqB;AACrB,kBAAkB;AAClB,WAAW;AACX;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH,uBAAuB;AACvB,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH,YAAY;AACZ,WAAW;AACX,YAAY;AACZ,iBAAiB;AACjB,mBAAmB;AACnB;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAE4C;;;;;;;;;;;;;;;;;;;ACjJ4B;AAC+R;;AAEvW;AACA;AACA,iBAAiB,sDAAS;AAC1B,mBAAmB,sDAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI,wBAAwB;AAC5B;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,qBAAqB;AAC3D;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gEAAgE,YAAY,GAAG,aAAa;AAC5F;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,+BAA+B,6CAAc;AAC7C,sBAAsB,6BAA6B;AACnD;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E,aAAa;AACvF;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2EAA2E,eAAe;AAC1F;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;;AAEA;AACA,2BAA2B,6CAAY,0CAA0C,6CAAY;AAC7F,6BAA6B,6CAAY,yCAAyC,6CAAY;AAC9F;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,iBAAiB,6CAAe,eAAe,yBAAyB;AACxE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,IAAI,6CAAc;AAClB,IAAI,6CAAc;AAClB;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH,kBAAkB,kBAAkB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,6CAAY,yCAAyC;;AAE1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAAgB,yBAAyB,6CAAgB;AACrG,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,gEAAgE,UAAU;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,kCAAkC;AACjE;AACA;AACA,4DAA4D,kCAAkC;AAC9F;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,oBAAoB,qBAAqB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,YAAY;AAClC;AACA;AACA;AACA,oBAAoB,8DAA8D;AAClF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,8BAA8B,aAAa;AAC3C,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,IAAI,6CAAc,kDAAkD,aAAa;AACjF,IAAI,6CAAc,iDAAiD,kEAAkE;AACrI;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,8BAA8B;AACjE;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,MAAM;AACN,kBAAkB,4CAA4C;AAC9D;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA,cAAc,yBAAyB;AACvC;AACA;AACA;AACA;AACA;;AAEA;AACA,uEAAuE,UAAU;AACjF;;AAEA;AACA;AACA;AACA;AACA;AACA,kBAAkB,mBAAmB;AACrC;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,kBAAkB,mBAAmB;AACrC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,WAAW,6CAAe,eAAe,kBAAkB,EAAE,SAAS,gBAAgB,SAAS;AAC/F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kEAAkE,WAAW;AAC7E,MAAM;AACN,kEAAkE,YAAY;AAC9E;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,6CAAc,kBAAkB,kBAAkB;AACpE;AACA;AACA;;AAEA;AACA,kBAAkB,6CAAc,kBAAkB,kBAAkB;AACpE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA,sEAAsE,yBAAyB;AAC/F;AACA;AACA,2CAA2C,iCAAiC;AAC5E;AACA;AACA,sDAAsD,iCAAiC;AACvF,QAAQ;AACR;AACA;AACA;AACA,0DAA0D,iCAAiC;AAC3F;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,uCAAuC,oCAAoC;AAC3E;AACA;AACA;AACA,IAAI;AACJ,oDAAoD,uDAAuD;AAC3G;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,kBAAkB,uBAAuB;AACzC;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,6BAA6B,kBAAkB;AAC/C;AACA;AACA,yDAAyD,kBAAkB;AAC3E;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,oBAAoB,0BAA0B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,6CAAY;AACrC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,MAAM;AACN;AACA;AACA,+CAA+C,EAAE,MAAM,EAAE,MAAM,EAAE;AACjE;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,+EAA+E,kFAAkF;;AAEjK;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,QAAQ,6CAAoB;AAC5B;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,mDAAmD,SAAS;AAC5D;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,kDAAkD,mDAAmD;AACrG;AACA,2BAA2B,KAAK;AAChC;AACA;AACA,yCAAyC,KAAK;AAC9C;AACA;AACA,wCAAwC,KAAK;AAC7C;AACA,wCAAwC,KAAK;AAC7C,MAAM;AACN,wCAAwC,KAAK;AAC7C;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,uBAAuB;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,mDAAmD,sDAAsD;;AAEzG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,MAAM;AACN;AACA,QAAQ,6CAAoB;AAC5B;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,gEAAgE,kBAAkB;AAClF;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAAe,cAAc,cAAc,4BAA4B,UAAU;AAC7H,QAAQ,6CAAQ;AAChB;AACA,SAAS;AACT,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA,0CAA0C,6CAAe,cAAc,cAAc,4BAA4B,UAAU;AAC3H,MAAM,6CAAQ;AACd;AACA,OAAO;AACP,MAAM;AACN;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,mBAAmB,6CAAe,eAAe,kBAAkB;AACnE;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,oBAAoB;AACxC,yCAAyC,6CAAa,6CAA6C,6CAAa;AAChH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,MAAM,6CAAW;AACjB;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,MAAM,6CAAW;AACjB;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,wBAAwB;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,6CAAW;AACf,IAAI;AACJ,IAAI,6CAAW;AACf;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,4CAA4C;AAChE;AACA;AACA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;AACA,YAAY;AACZ,QAAQ;AACR;AACA;AACA;AACA,IAAI;AACJ;AACA,oBAAoB,oBAAoB;AACxC;AACA;AACA;AACA;AACA,SAAS;AACT,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,MAAM;AACN;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,sDAAW,aAAa,sDAAS;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,sDAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,6CAAgB;AACzB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sFAAsF,sBAAsB;AAC5G;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,wBAAwB,6CAAG;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,mBAAmB,sDAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,uCAAuC;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,4BAA4B,6CAAG;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC;AACvC;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,uBAAuB,6CAAG;AAC1B;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,6CAAG;AAC1B,EAAE,6CAAQ;AACV;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA,kBAAkB,uBAAuB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oIAAoI;AACpI;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA,QAAQ;AACR;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,mBAAmB,sDAAW;AAC9B;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,mBAAmB,sDAAW;;AAE9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,8BAA8B,UAAU,8BAA8B;AACjG;AACA,IAAI;AACJ,wBAAwB,8BAA8B;AACtD;AACA,0BAA0B,8BAA8B;AACxD;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,EAAE,6CAAM;AACR;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,kBAAkB,mBAAmB;AACrC;AACA;AACA;AACA,MAAM;AACN;AACA,2CAA2C,MAAM;AACjD;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,MAAM;AACN;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,6CAAM;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,6CAAM;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,6CAAM;AACV;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wEAAwE,aAAa;AACrF;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,aAAa,6CAAM,GAAG;AACtB;AACA,qBAAqB,sDAAW;AAChC;AACA;AACA;AACA,0BAA0B,6CAAM,GAAG;AACnC;AACA,SAAS;AACT;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;;AAEL;AACA,yBAAyB,6CAAM,GAAG;;AAElC;AACA,oBAAoB,6CAAM,GAAG;AAC7B,4BAA4B,6CAAM,GAAG;AACrC,0BAA0B,6CAAM,GAAG;;AAEnC;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,mBAAmB,6CAAe,eAAe,kBAAkB;AACnE,4BAA4B,6CAAY;AACxC,WAAW,6CAAY;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,oBAAoB,6CAAe,eAAe,kBAAkB;AACpE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,oCAAoC,mBAAmB;AACvD;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,QAAQ;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,sCAAsC,mBAAmB;AACzD;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA,sCAAsC,QAAQ;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qCAAqC,EAAE,iBAAiB;AAC1F,+BAA+B,qCAAqC,EAAE,aAAa;AACnF;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,qCAAqC;AACtE;AACA,MAAM;AACN,oCAAoC,qCAAqC;AACzE;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,+DAA+D;AAChF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,6CAAe;AAC5B;AACA;AACA;AACA;AACA,kBAAkB,6CAAa;AAC/B;AACA,MAAM,6CAAe,SAAS,yBAAyB;AACvD;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,6CAAY;AACzD,mGAAmG,6CAAY;AAC/G,gBAAgB,6CAAY;AAC5B,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,MAAM,6CAAW;AACjB;AACA;AACA;AACA;AACA;AACA,IAAI,6CAAM;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH,CAAC;AACD;;AAEsC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACh1HkC;;AAExE;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gEAAgE;AAChE;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,sBAAsB;AACxC;AACA;AACA;AACA,sDAAsD,iBAAiB;AACvE;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA,cAAc;AACd;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,sDAAS;AAC1B,mBAAmB,sDAAW;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C;AAC5C;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC;AACxC;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB,iCAAiC;AACjC;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,sDAAS;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAE6e;;;;;;;;;;;;;;;;;;AC1U7e;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEqE;;;;;;;UCZrE;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA,eAAe,4BAA4B;WAC3C,eAAe;WACf,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA,8CAA8C;;;;;WCA9C;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;;;;;;;;;;ACNA;;AAE0D;AAExB;AAElC,IAAI/H,WAAW,GAAG7kB,CAAC,CAACE,MAAM,CAAC,CAACmjB,KAAK,CAAC,CAAC;AAEnCrjB,CAAC,CAACE,MAAM,CAAC,CAAC4J,EAAE,CAAC,aAAa,EAAEyiB,+CAAQ,CAAErhB,CAAC,IAAK;EACxC;EACA,IAAIA,CAAC,CAAC3J,IAAI,KAAK,MAAM,IAAIvB,CAAC,CAACE,MAAM,CAAC,CAACmjB,KAAK,CAAC,CAAC,KAAKwB,WAAW,EAAE;IACxD;IACAA,WAAW,GAAG7kB,CAAC,CAACE,MAAM,CAAC,CAACmjB,KAAK,CAAC,CAAC;IAC/B,IAAIrjB,CAAC,CAACE,MAAM,CAAC,CAACmjB,KAAK,CAAC,CAAC,GAAG,GAAG,EAAE;MACzB3C,mEAAe,CAAC4B,OAAO,CAAC,CAAC;IAC7B,CAAC,MAAM;MACH5B,mEAAe,CAAC4C,IAAI,CAAC,CAAC;IAC1B;EACJ;AACJ,CAAC,EAAE,GAAG,CAAC,CAAC,C","sources":["webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/checkout/adyenDropin.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/checkout/formErrors.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/checkout/membershipHelpers.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/checkout/orderSummary.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/checkout/paymentMethodHelpers.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/checkout/paymentScheduleUpdate.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/gtm/checkoutFlow.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/gtm/gtmCheckoutBuilder.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/gtm/gtmEcommBuilder.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/gtm/gtmParametersBuilder.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/membershipTilesSwiper.js","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/util.js","webpack://app_custom_basicfit/./node_modules/get-youtube-id/index.js","webpack://app_custom_basicfit/./node_modules/tingle.js/dist/tingle.min.js","webpack://app_custom_basicfit/./node_modules/swiper/modules/a11y.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/autoplay.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/controller.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/effect-cards.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/effect-coverflow.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/effect-creative.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/effect-cube.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/effect-fade.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/effect-flip.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/free-mode.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/grid.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/hash-navigation.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/history.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/index.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/keyboard.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/manipulation.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/mousewheel.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/navigation.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/pagination.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/parallax.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/scrollbar.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/thumbs.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/virtual.mjs","webpack://app_custom_basicfit/./node_modules/swiper/modules/zoom.mjs","webpack://app_custom_basicfit/./node_modules/swiper/shared/classes-to-selector.mjs","webpack://app_custom_basicfit/./node_modules/swiper/shared/create-element-if-not-defined.mjs","webpack://app_custom_basicfit/./node_modules/swiper/shared/create-shadow.mjs","webpack://app_custom_basicfit/./node_modules/swiper/shared/effect-init.mjs","webpack://app_custom_basicfit/./node_modules/swiper/shared/effect-target.mjs","webpack://app_custom_basicfit/./node_modules/swiper/shared/effect-virtual-transition-end.mjs","webpack://app_custom_basicfit/./node_modules/swiper/shared/ssr-window.esm.mjs","webpack://app_custom_basicfit/./node_modules/swiper/shared/swiper-core.mjs","webpack://app_custom_basicfit/./node_modules/swiper/shared/utils.mjs","webpack://app_custom_basicfit/./node_modules/swiper/swiper.mjs","webpack://app_custom_basicfit/webpack/bootstrap","webpack://app_custom_basicfit/webpack/runtime/compat get default export","webpack://app_custom_basicfit/webpack/runtime/define property getters","webpack://app_custom_basicfit/webpack/runtime/hasOwnProperty shorthand","webpack://app_custom_basicfit/webpack/runtime/make namespace object","webpack://app_custom_basicfit/./cartridges/app_custom_basicfit/cartridge/client/default/js/uspTilesSlider.js"],"sourcesContent":["/* eslint-disable */\nconst checkoutFlow = require('../gtm/checkoutFlow');\nconst formError = require('./formErrors');\n\nvar dropinConfig = null;\nvar dropin = null;\nvar adyenObj = null;\nvar brand = null;\n\nconst PAYMENT_PROVIDER = 'adyen';\n\nfunction createOrder(component, orderId, actions, data, peopleId) {\n    let url = $('#dropin-container').attr('data-placeorder');\n\n    if (!url || !orderId) {\n        window.location.href = $('#dropin-container').data('error');\n        return;\n    }\n\n    const params = {\n        orderid: orderId,\n        peopleid: peopleId,\n        brand,\n        adyenPaymentMethod: component.activePaymentMethod.displayName,\n        dropinSessionAmount: component.props.amount.value,\n    };\n\n    url += (url.indexOf('?') !== -1 ? '&' : '?')\n        + Object.keys(params).map((key) => `${key}=${encodeURIComponent(params[key])}`).join('&');\n\n    // Create an order on BE\n    $.ajax({\n        url,\n        type: 'POST',\n        success: (response) => {\n            if (response.error) {\n                const priceIssue = response && response.priceIssue !== undefined ? response.priceIssue : false;\n                dropin.closeActivePaymentMethod();\n\n                $.ajax({\n                    url: $('#dropin-container').attr('data-updatesession'),\n                    contentType: 'application/json',\n                    dataType: 'json',\n                    type: 'POST',\n                    data: JSON.stringify({ priceIssue }),\n                }).done(function(responseUpdateSession) {\n                    // Update people ID and order ID in the frontend\n                    $('input[name=orderId]').val(responseUpdateSession.adyenSessionData.orderId);\n                    $('input[name=peopleId]').val(responseUpdateSession.adyenSessionData.peopleId);\n\n                    // Reinitialize drop-in\n                    dropin.unmount();\n                    mountAdyenObj(reCrateAdyenConfig(responseUpdateSession.adyenSessionData));\n                });\n\n                renderFailedPayments('reload');\n                // Reload the page to make sure we see correct method selected in storefront\n                location.reload();\n                throw Error(response.errorMessage);\n            }\n\n            if (response.continueUrl && response.orderID && response.orderToken) {\n                const $checkoutDataContainer = $('.js-data-checkout-stage');\n                const gtmProductsNew = $checkoutDataContainer.data('gtm-membership-products');\n                const urlParams = {\n                    ID: response.orderID,\n                    token: response.orderToken,\n                };\n                let continueUrl = response.continueUrl;\n\n                continueUrl += (continueUrl.indexOf('?') !== -1 ? '&' : '?')\n                   + Object.keys(urlParams).map((key) => `${key}=${encodeURIComponent(urlParams[key])}`).join('&');\n\n                checkoutFlow.pushPaymentMethodSelectedEvent(component.activePaymentMethod.displayName);\n\n                if (gtmProductsNew) {\n                    const products = typeof gtmProductsNew === 'string' ? JSON.parse(gtmProductsNew) : gtmProductsNew;\n                    const paymentType = data && data.paymentMethod && data.paymentMethod.type;\n                    checkoutFlow.pushPaymentInfoEvent(products, paymentType, PAYMENT_PROVIDER);\n                }\n\n                $('#dropin-container').data('success', continueUrl);\n\n                if (actions && data) {\n                    actions.resolve(data);\n                }\n\n                sessionStorage.clear();\n            }\n        },\n        error: (error) => {\n            $('.js-payment-method').prop('disabled', false);\n            console.log('Error: ', error);\n            window.location.href = $('#dropin-container').data('error');\n        },\n    });\n}\n\nfunction check3DS2(state) {\n    // Verify payment details for 3ds2 case\n    var payload = state.data;\n    dropin.setStatus('loading');\n\n    $.ajax({\n        url: $('#dropin-container').attr('data-3ds2'),\n        contentType: 'application/json',\n        dataType: 'json',\n        type: 'POST',\n        data: JSON.stringify(payload),\n    }).done(function(response3ds2) {\n        if (response3ds2.error) {\n            // Reinitialize drop-in\n            dropin.closeActivePaymentMethod();\n\n            $.ajax({\n                url: $('#dropin-container').attr('data-updatesession'),\n                contentType: 'application/json',\n                dataType: 'json',\n                type: 'POST',\n                data: JSON.stringify({ orderId: $('input[name=orderId]').val() })\n            }).done(function(responseUpdateSession) {\n                var adyenSessionData = responseUpdateSession.adyenSessionData;\n                var orderId = adyenSessionData && adyenSessionData.orderId;\n                var peopleId = adyenSessionData && adyenSessionData.peopleId;\n\n                // Update people ID and order ID in the frontend\n                $('input[name=orderId]').val(orderId);\n                $('input[name=peopleId]').val(peopleId);\n\n                // Reinitialize drop-in\n                dropin.unmount();\n                mountAdyenObj(reCrateAdyenConfig(adyenSessionData));\n            });\n\n            $('.js-payment-method').prop('disabled', false);\n            renderFailedPayments(response3ds2.resultCode.toLowerCase());\n            throw Error(response3ds2.errorMessage);\n        }\n\n        if (response3ds2.authorised) {\n            dropin.setStatus('success');\n            window.location.href = $('#dropin-container').data('success');\n        } else if (response3ds2.action) {\n            dropin.handleAction(response3ds2.action);\n        } else {\n            window.location.href = $('#dropin-container').data('error');\n        }\n    }).fail(function (xhr, error) {\n        $('#creditErrorAlert').addClass('show');\n        $('#creditErrorAlert').text(error);\n\n        dropin.closeActivePaymentMethod();\n\n        $.ajax({\n            url: $('#dropin-container').attr('data-updatesession'),\n            contentType: 'application/json',\n            dataType: 'json',\n            type: 'POST',\n            data: JSON.stringify({orderId:$('input[name=orderId]').val()})\n        }).done(function(responseUpdateSession) {\n            // Update people ID and order ID in the frontend\n            $('input[name=orderId]').val(responseUpdateSession.adyenSessionData.orderId);\n            $('input[name=peopleId]').val(responseUpdateSession.adyenSessionData.peopleId);\n\n            // Reinitialize drop-in\n            dropin.unmount();\n            mountAdyenObj(reCrateAdyenConfig(responseUpdateSession.adyenSessionData));\n        });\n\n        renderFailedPayments('refused');\n        throw Error(error);\n    });\n}\n\nfunction renderFailedPayments(resultCode) {\n    $('#creditErrorAlert').removeClass('display-none');\n    $('#creditErrorAlert').addClass('show');\n    $('#creditErrorAlert').text(window.resources['checkout.error.' + resultCode]);\n}\n\nfunction reCrateAdyenConfig(failResponse) {\n    const data = {\n        config: {\n            countryCode: failResponse.countryCode,\n            locale: failResponse.locale,\n            environment: failResponse.environment,\n            clientKey: failResponse.clientKey,\n            session: {\n                id: failResponse.id,\n                sessionData: failResponse.sessionData,\n            },\n        },\n    };\n\n    return data;\n}\n\nasync function mountAdyenObj(data) {\n    var orderId = $('input[name=orderId]').val();\n    var peopleId = $('input[name=peopleId]').val();\n\n    if (dropin) {\n        dropin.unmount();\n    }\n\n    if (!data.error) {\n        dropinConfig = data.config;\n    }\n\n    if (!dropinConfig) {\n        console.error('Wrong Adyen drop-in config');\n        return;\n    }\n\n    dropinConfig.beforeSubmit = (data, component, actions) => {\n        orderId = $('input[name=orderId]').val();\n        $('#creditErrorAlert').text('');\n        $('#creditErrorAlert').removeClass('show');\n        $('#errorAlert').removeClass('show');\n\n        if (data.paymentMethod.type === 'paypal'\n            || data.paymentMethod.type === 'applepay'\n            || data.paymentMethod.type === 'bizum'\n            || data.paymentMethod.type === 'ideal'\n        ) {\n            const defer = $.Deferred();\n            const $accountHolder = $('#dwfrm_paymentDetails_accountHolder');\n            const $accountNumber = $('#dwfrm_paymentDetails_accountNumber');\n            const $sepaAgreement = $('#dwfrm_paymentDetails_agreeAutomaticSEPA');\n            const $termsAndConditions = $('#termsAndConditionsCheck');\n\n            const requiredName = !$accountHolder.length || $accountHolder.valid();\n            const requiredIban = !$accountNumber.length || $accountNumber.valid();\n            const requiredSepa = !$sepaAgreement.length || $sepaAgreement.valid();\n            const requiredTermsCon = !$termsAndConditions.length || $termsAndConditions.valid();\n\n            if (!requiredName || !requiredIban || !requiredSepa || !requiredTermsCon) {\n                defer.reject();\n            } else {\n                const $form = $('.js-payment-method-form');\n                $.ajax({\n                    url: $form.data('action'),\n                    method: 'POST',\n                    data: $form.serialize(),\n                    success(response) {\n                        if (response.error) {\n                            if (response.cartError) {\n                                window.location.href = response.redirectUrl;\n                                defer.reject();\n                            } else if (response.fieldErrors && response.fieldErrors.length > 0) {\n                                response.fieldErrors.forEach((error) => {\n                                    if (Object.keys(error).length) {\n                                        formError.loadFormErrors($form, error);\n                                    }\n                                });\n                            } else {\n                                // go to appropriate stage and display error message\n                                defer.reject(response);\n                            }\n                        } else {\n                            createOrder(component, orderId, actions, data, peopleId);\n                        }\n                    },\n                    error() {\n                        return;\n                    },\n                });\n            }\n        } else {\n            createOrder(component, orderId, actions, data, peopleId);\n        }\n    };\n\n    dropinConfig.onChange = (state) => {\n        try {\n            if (!state.isValid) {\n                $('.js-payment-method').prop('disabled', false);\n            }\n        } catch (error) {\n            console.error(error);\n            $('.js-payment-method').prop('disabled', false);\n        }\n    };\n\n    dropinConfig.onAdditionalDetails = (state, component) => {\n        check3DS2(state, component);\n    };\n\n    dropinConfig.onActionHandled = () => {\n        $('.js-payment-method').prop('disabled', true);\n    };\n\n    dropinConfig.onPaymentCompleted = () => {\n        $.ajax({\n            url: $('#dropin-container').attr('data-resetsession'),\n            contentType: 'application/json',\n            dataType: 'json',\n            type: 'POST',\n            data: JSON.stringify({ orderId }),\n        }).done(function(res) {\n            console.log('Session variables deleted');\n        }).then(function (stts, error) {\n            dropin.setStatus('success');\n            window.location.href = $('#dropin-container').data('success');\n            $('.js-payment-method').prop('disabled', false);\n        }).fail(function (stts, error) {\n            dropin.setStatus('success');\n            window.location.href = $('#dropin-container').data('success');\n            $('.js-payment-method').prop('disabled', false);\n        });\n    };\n\n    dropinConfig.onPaymentFailed = (result) => {\n        try {\n            renderFailedPayments(result.resultCode.toString().toLowerCase());\n\n            // Update order number in the session\n            $.ajax({\n                url: $('#dropin-container').attr('data-updatesession'),\n                contentType: 'application/json',\n                dataType: 'json',\n                type: 'POST',\n                data: JSON.stringify({ orderId }),\n            }).done(function(responseUpdateSession) {\n                // Update people ID and order ID in the frontend\n                $('input[name=orderId]').val(responseUpdateSession.adyenSessionData.orderId);\n                $('input[name=peopleId]').val(responseUpdateSession.adyenSessionData.peopleId);\n                orderId = $('input[name=orderId]').val();\n                peopleId = $('input[name=peopleId]').val();\n\n                // Reinitialize drop-in\n                dropin.unmount();\n                mountAdyenObj(reCrateAdyenConfig(responseUpdateSession.adyenSessionData));\n            });\n        } catch (error) {\n            console.error(error);\n        }\n\n        $('.js-payment-method').prop('disabled', false);\n    };\n\n    const paymentMethodsConfiguration = {\n        card: {\n            onBrand: function (state) {\n                brand = state.brand;\n            },\n            onError: function (state) {\n                console.error('onError: ', state);\n\n                try {\n                    renderFailedPayments('error');\n                    adyenDropin();\n                } catch (error) {\n                    console.error(error);\n                }\n\n                $('.js-payment-method').prop('disabled', false);\n            },\n            hasHolderName: true,\n            holderNameRequired: true,\n            name: window.resources['adyen.credit.card.label'],\n        },\n        paypal: {\n            onError: function (state, dropin) {\n                try {\n                    console.log('Error name for paypal: ' + state.name);\n                    // In case of resources missing or result code is a new code that we never handle before, we are doing this call in try and catch\n                    renderFailedPayments(state.name.toString().toLowerCase());\n\n                    // Update order number in the session\n                    $.ajax({\n                        url: $('#dropin-container').attr('data-updatesession'),\n                        contentType: 'application/json',\n                        dataType: 'json',\n                        type: 'POST',\n                        data: JSON.stringify({ orderId })\n                    }).done(function(responseUpdateSession) {\n                        // Update people ID and order ID in the frontend\n                        $('input[name=orderId]').val(responseUpdateSession.adyenSessionData.orderId);\n                        $('input[name=peopleId]').val(responseUpdateSession.adyenSessionData.peopleId);\n                        orderId = $('input[name=orderId]').val();\n                        peopleId = $('input[name=peopleId]').val();\n\n                        // Reinitialize drop-in\n                        dropin.unmount();\n                        mountAdyenObj(reCrateAdyenConfig(responseUpdateSession.adyenSessionData));\n                    });\n                } catch (error) {\n                    console.error(error);\n                }\n            },\n        },\n        applepay: {\n            buttonType: 'plain',\n            buttonColor: 'white-with-line',\n        },\n    };\n\n    try {\n        adyenObj = await AdyenWeb.AdyenCheckout(dropinConfig);\n        dropin = new AdyenWeb.Dropin(adyenObj, { paymentMethodsConfiguration }).mount('#dropin-container');\n    } catch (error) {\n        console.error('Error during Adyen drop-in initialization: ', error);\n        throw Error(error);\n    }\n}\n\nfunction adyenDropin() {\n    $.ajax({\n        url: $('#dropin-container').attr('data-url'),\n    }).done(function(response) {\n        mountAdyenObj(response);\n    }).fail(function (xhr, error) {\n        console.error('Failed to initialize Adyen drop-in');\n        throw Error(error);\n    });\n}\n\nmodule.exports = adyenDropin;\n","\n/**\n * Display error messages and highlight form fields with errors.\n * @param {string} parentSelector - the form which contains the fields\n * @param {Object} fieldErrors - the fields with errors\n */\nfunction loadFormErrors(parentSelector, fieldErrors) { // eslint-disable-line\n    // Display error messages and highlight form fields with errors.\n    $.each(fieldErrors, (attr) => {\n        $(`*[name=${attr}]`, parentSelector)\n            .addClass('is-invalid');\n\n        $(`*[name=${attr}]`, parentSelector).closest('.input-row')\n            .addClass('is-invalid')\n            .find('.invalid-feedback')\n            .html(fieldErrors[attr]);\n    });\n}\n\n/**\n * Clear the form errors.\n * @param {string} parentSelector - the parent form selector.\n */\nfunction clearPreviousErrors(parentSelector) {\n    $(parentSelector).find('.is-invalid').removeClass('is-invalid');\n    $(parentSelector).find('.invalid-feedback').html('');\n    $('.error-message').hide();\n}\n\nmodule.exports = {\n    loadFormErrors,\n    clearPreviousErrors,\n};\n","import { pushErrorEvent, pushSelectMembershipEvent } from './../gtm/checkoutFlow';\nimport { updateMiniCart } from './orderSummary';\nimport { dynamicCountdown } from '../util';\nimport { equalizeTiles } from '../membershipTilesSwiper';\nimport payementInitialize from './paymentScheduleUpdate';\n\n/**\n * Handle the USP's view more/view less button clicks on the membership checkout step 2\n */\nconst handleMembershipUSP = () => {\n    const $viewMore = $('.js-view-more-usp');\n    const $viewLess = $('.js-view-less-usp');\n    const $allUSP = $('.js-usp-list-all');\n\n    $viewMore.on('click', () => {\n        $viewMore.hide('fast');\n        $viewLess.show('fast');\n        $allUSP.show('fast');\n    });\n\n    $viewLess.on('click', () => {\n        $viewMore.show('fast');\n        $viewLess.hide('fast');\n        $allUSP.hide('fast');\n    });\n};\n\n/**\n * Updates membership step\n * @param {Object} data - Payload data from ajax call\n */\nconst updateMembershipBlock = data => {\n    const $membershipStep = $('.membership-step');\n    $membershipStep.empty().append(data.membershipsData);\n};\n\n/**\n * Resets membership tables\n * @param {HTMLElements} $membershipTables - List of membership tables\n */\nconst resetMembershipTables = $membershipTables => {\n    $membershipTables.each((i, table) => {\n        const $membershipTable = $(table);\n        $membershipTable.removeClass('highlighted');\n        $membershipTable.removeClass('selected');\n    });\n};\n\n/**\n * Resets membership duration wrapper\n * @param {HTMLElement} $membershipDuration - Membership duration wrapper\n * @param {string} name - Membership name\n */\nconst resetMembershipDurationWrapper = ($membershipDuration, name) => {\n    ['basic', 'comfort', 'premium', 'all-in', 'ultimate'].forEach(className => {\n        $membershipDuration.removeClass(className);\n    });\n    $membershipDuration.addClass(name);\n};\n\n/**\n * Resets membership duration radio buttons\n * @param {HTMLElements} $membershipDurations - List of membership duration radio buttons\n * @param {HTMLElement} $currentMembershipDuration - Current membership duration radio button that is being clicked\n */\nconst resetMembershipDurations = ($membershipDurations, $currentMembershipDuration) => {\n    $membershipDurations.each((i, duration) => {\n        const $membershipDuration = $(duration);\n        $membershipDuration.prop('checked', false);\n        $membershipDuration.removeClass('checked');\n    });\n    $currentMembershipDuration.prop('checked', true);\n    $currentMembershipDuration.addClass('checked');\n};\n\n/**\n * Handles click on the membership button\n * @param {Event} e - Click event\n */\nconst handleMembershipButtonClick = e => {\n    const $membershipButton = $(e.currentTarget);\n    const $membershipTables = $('.js-membership-block');\n    const $membershipStepWrapper = $membershipButton.closest('.js-step-02-content');\n    const $membershipTable = $membershipButton.closest('.js-membership-block');\n    const $membershipDurationWrapper = $membershipStepWrapper.find('.js-membership-duration-wrapper');\n    const $nextStepButton = $membershipStepWrapper.find('.js-next-step');\n    const membershipUrl = $membershipTable.attr('data-url');\n    const membershipName = $membershipTable.attr('data-name');\n    const $selectedMembershipDuration = $membershipDurationWrapper.find(`.js-membership-contract-length[data-membership-name=${membershipName}][type=radio].checked`);\n    const durationId = $selectedMembershipDuration.attr('data-pid');\n\n    resetMembershipTables($membershipTables);\n    resetMembershipDurationWrapper($membershipDurationWrapper, membershipName);\n    addMembershipPlanToCart(membershipUrl, durationId, null, false, true); // eslint-disable-line no-use-before-define\n    $membershipTable.addClass('highlighted');\n    $membershipTable.addClass('selected');\n    $nextStepButton.removeClass('display-none');\n};\n\n/**\n * Updates membership table HTML\n * @param {HTMLElement} $membershipTable - Membership table\n * @param {string} membershipTileHTML - Membership table html string\n */\nconst updateMembershipTable = ($membershipTable, membershipTileHTML) => {\n    const membershipTileContent = $(membershipTileHTML).html();\n\n    if ($membershipTable && membershipTileContent) {\n        $membershipTable.empty().append(membershipTileContent);\n        const $membershipButton = $membershipTable.find('.js-membership-btn-new');\n        $membershipButton.on('click', handleMembershipButtonClick);\n        handleMembershipUSP();\n    }\n};\n\n/**\n * Sends ajax call to add membership plan to cart\n * @param {string} url - Url to send ajax call to\n * @param {string} pid - Membership duration plan id\n * @param {?HTMLElement} $membershipTable - Membership table\n * @param {boolean} isUSPSectionExpanded - True if USP section needs to be expanded, False otherwise\n * @param {boolean} isMembershipButtonClick - True if the table membership button was clicked, False otherwise\n */\nfunction addMembershipPlanToCart(url, pid, $membershipTable, isUSPSectionExpanded, isMembershipButtonClick) {\n    $('.js-checkout-order-summary').css('pointer-events', 'none');\n\n    $.ajax({\n        url,\n        method: 'POST',\n        data: {\n            pid,\n            isUSPSectionExpanded,\n        },\n        success: ({\n            error,\n            errorMessage,\n            gtmProducts,\n            gtmProductsNew,\n            membershipTileHTML,\n        }) => {\n            if (error) {\n                pushErrorEvent('checkout', errorMessage || error.errorText);\n                return;\n            }\n\n            const $checkoutStage = $('.js-data-checkout-stage');\n\n            updateMembershipTable($membershipTable, membershipTileHTML);\n            equalizeTiles();\n            payementInitialize();\n            updateMiniCart();\n\n            if (gtmProducts) {\n                $checkoutStage.data('gtm-products', gtmProducts);\n            }\n\n            if (gtmProductsNew) {\n                $checkoutStage.data('gtm-membership-products', gtmProductsNew);\n\n                if (isMembershipButtonClick) {\n                    const products = typeof gtmProductsNew === 'string' ? JSON.parse(gtmProductsNew) : gtmProductsNew;\n                    pushSelectMembershipEvent(products);\n                }\n            }\n        },\n        error: ({\n            error,\n            errorMessage,\n        }) => {\n            $('.js-checkout-order-summary').css('pointer-events', 'auto');\n            pushErrorEvent('checkout', errorMessage || error.errorText);\n        },\n    });\n}\n\n/**\n * Binds click event to the membership selection buttons\n */\nfunction handleMembershipSelection() {\n    const $membershipButtons = $('.js-membership-btn-new');\n\n    $membershipButtons.each((i, button) => {\n        const $membershipButton = $(button);\n        $membershipButton.on('click', handleMembershipButtonClick);\n    });\n\n    dynamicCountdown();\n}\n\n/**\n * Binds click event to the membership duration radio buttons\n */\nconst handleMembershipDuration = () => {\n    const $membershipDurations = $('.js-membership-contract-length');\n\n    $membershipDurations.each((i, durationItem) => {\n        const $membershipDuration = $(durationItem);\n        const url = $membershipDuration.attr('data-url');\n        const pid = $membershipDuration.attr('data-pid');\n        const membershipName = $membershipDuration.attr('data-membership-name');\n        const $currentMembershipDurations = $(`.js-membership-contract-length[data-membership-name=${membershipName}]`);\n        const $membershipTable = $(`.js-membership-block.${membershipName}`);\n        const $allUSP = $('.js-usp-list-all');\n\n        $membershipDuration.on('change', () => {\n            const isUSPSectionExpanded = $allUSP.is(':visible');\n            resetMembershipDurations($currentMembershipDurations, $membershipDuration);\n            addMembershipPlanToCart(url, pid, $membershipTable, isUSPSectionExpanded, false);\n        });\n    });\n};\n\n/**\n * Handles redirect from the club details page to the checkout step 2\n */\nconst handleRedirectFromCDP = () => {\n    const $membershipTables = $('.js-membership-block');\n    const membershipTablesArray = $membershipTables.get();\n    const membershipTable = membershipTablesArray && membershipTablesArray.find(table => $(table).hasClass('selected'));\n\n    if (membershipTable) {\n        const $membershipTable = $(membershipTable);\n        const membershipUrl = $membershipTable.attr('data-url');\n        const membershipName = $membershipTable.attr('data-name');\n        const $membershipStepWrapper = $membershipTable.closest('.js-step-02-content');\n        const $membershipDurationWrapper = $membershipStepWrapper.find('.js-membership-duration-wrapper');\n        const $selectedMembershipDuration = $membershipDurationWrapper.find(`.js-membership-contract-length[data-membership-name=${membershipName}][type=radio].checked`);\n        const durationId = $selectedMembershipDuration.attr('data-pid');\n\n        addMembershipPlanToCart(membershipUrl, durationId, null, false, false);\n    }\n};\n\nconst getPreselectedMembershipInfo = () => {\n    const $selectedMembershipTable = $('.js-membership-block.selected.highlighted');\n    const membershipName = $selectedMembershipTable.attr('data-name');\n\n    if (!membershipName) {\n        return null;\n    }\n\n    const $selectedMembershipDuration = $(`.js-membership-contract-length[data-membership-name=${membershipName}][type=radio].checked`);\n    const name = membershipName.charAt(0).toUpperCase() + membershipName.slice(1).toLowerCase();\n    const duration = $selectedMembershipDuration.attr('data-duration');\n\n    return {\n        name,\n        duration,\n    };\n};\n\n/**\n * Handles counter in the checkout banner on step 2\n */\nconst countdown = () => {\n    const $counter = $('#top-counter');\n\n    if ($counter.length > 0) {\n        const $counterWrapper = $('#top-counter-wrapper');\n        const $daysValue = $('.js-top-counter-days');\n        const $hoursValue = $('.js-top-counter-hours');\n        const $minutesValue = $('.js-top-counter-minutes');\n        const date = $counter.attr('data-date');\n        const countDownDate = new Date(date).getTime();\n\n        const interval = setInterval(() => {\n            const now = new Date().getTime();\n            const distance = countDownDate - now;\n\n            const days = Math.floor(distance / (1000 * 60 * 60 * 24));\n            const hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));\n            const minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60));\n\n            $daysValue.text(days);\n            $hoursValue.text(hours);\n            $minutesValue.text(minutes);\n\n            if (distance < 0) {\n                clearInterval(interval);\n                $counterWrapper.addClass('d-none');\n            }\n        }, 1000);\n    }\n};\n\n/**\n * equalizes inline height of all elements with the same selector\n* @param {string} selector - can be any ccs class or id\n */\nconst equalizeElements = (selector) => {\n    const elements = $(selector);\n    if (elements.length === 0) return;\n\n    // Remove inline height\n    elements.css('min-height', '');\n\n    // Measure heights and find the maximum\n    let minHeight = 0;\n    elements.each((index, element) => {\n        const height = $(element).outerHeight();\n        if (height > minHeight) {\n            minHeight = height;\n        }\n    });\n\n    // Apply the maximum height to all elements\n    elements.css('min-height', `${minHeight}px`);\n};\n\nexport {\n    handleMembershipUSP,\n    updateMembershipBlock,\n    handleMembershipSelection,\n    handleMembershipDuration,\n    handleRedirectFromCDP,\n    getPreselectedMembershipInfo,\n    countdown,\n    equalizeElements,\n};\n","import { pushErrorEvent } from './../gtm/checkoutFlow';\nimport { updatePaymentScheduleOptions } from './paymentMethodHelpers';\nimport { scrollLock } from '../util';\n\nconst LAPTOP_MAX_WIDTH = 1025;\nconst LOW_ENTRY_BARRIER_MESSAGE_ID = 'low-entry-barrier-message';\n\n/**\n* Re-binds summary accordions\n*/\nfunction initSummaryAccordion() {\n    $('body').on('click', '.js-acc-head', (e) => {\n        $(e.target).toggleClass('content-open');\n    });\n}\n\n/**\n* Initializes checkout step 5 order summary accordions\n*/\nfunction initStep5SummaryAccordion() {\n    $('.js-payment-summary-new .js-acc-head').each(function bindClickEvent() {\n        $(this).off().on('click', () => {\n            $(this).toggleClass('content-open');\n        });\n    });\n}\n\n/**\n* Shows one of 3 order summaries based on the current checkout step\n* @param {number} step - Checkout step\n*/\nfunction showSummary(step) {\n    if (step === 3) {\n        $('.js-checkout-order-summary-step01').removeClass('visible');\n        $('.js-checkout-order-summary-step02').removeClass('visible');\n        $('.js-checkout-order-summary').addClass('visible');\n    } else if (step === 2) {\n        $('.js-checkout-order-summary').removeClass('visible');\n        $('.js-checkout-order-summary-step01').removeClass('visible');\n        $('.js-checkout-order-summary-step02').addClass('visible');\n    } else if (step === 1) {\n        $('.js-checkout-order-summary').removeClass('visible');\n        $('.js-checkout-order-summary-step02').removeClass('visible');\n        $('.js-checkout-order-summary-step01').addClass('visible');\n    }\n}\n\n/**\n* Opens/closes mobile order summary\n*/\nfunction toggleMobileSummary() {\n    $('body').on('click', '.summary-veil', () => {\n        // .menu-close\n        $('.checkout-order-summary-floating').removeClass('menu-open');\n        scrollLock('off');\n        $('.checkout-order-summary-floating .summary-body').slideToggle();\n        $('body').removeClass('no-scroll fixed');\n        $('.summary-veil').removeClass('active');\n    });\n\n    $('body').on('click', '.checkout-order-summary-floating .summary-header', () => {\n        $('body').toggleClass('no-scroll');\n        if ($('body').hasClass('no-scroll')) {\n            scrollLock('on');\n        } else {\n            scrollLock('off');\n        }\n        $('.summary-veil').toggleClass('active');\n        $('.checkout-order-summary-floating').toggleClass('menu-open');\n        $('.checkout-order-summary-floating .summary-body').slideToggle();\n    });\n}\n\n/**\n* Closes mobile order summary\n*/\nfunction closeMobileSummary() {\n    const $floatingSummary = $('.checkout-order-summary-floating');\n    const $floatingSummaryHeader = $('.checkout-order-summary-floating .summary-header');\n    if ($floatingSummary.hasClass('menu-open')) {\n        $floatingSummaryHeader.trigger('click');\n    }\n}\n\n/**\n* Hides floating order summary when inline is visible\n*/\nfunction mobileSummaryFloat() {\n    const $navWrapper = $('.main-navigation-wrapper');\n    const $orderSummary = $('.checkout-order-summary-floating');\n    let navWrapperHeight = 0;\n    let resizePending = false;\n\n    function updateNavWrapperHeight() {\n        if ($navWrapper.length) {\n            const newHeight = $navWrapper.outerHeight();\n            if (newHeight !== navWrapperHeight) {\n                navWrapperHeight = newHeight;\n            }\n        }\n    }\n\n    function handleScroll() {\n        if (!$navWrapper.length || !$orderSummary.length) return;\n\n        const navWrapperBottom = $navWrapper[0].getBoundingClientRect().bottom;\n\n        if (navWrapperBottom <= 0) {\n            $orderSummary.addClass('floating');\n        } else {\n            $orderSummary.removeClass('floating');\n        }\n    }\n\n    function handleResize() {\n        if (!resizePending) {\n            resizePending = true;\n            requestAnimationFrame(() => {\n                updateNavWrapperHeight();\n                resizePending = false;\n            });\n        }\n    }\n\n    updateNavWrapperHeight();\n    $(window).on('resize', handleResize);\n    $(window).on('scroll', handleScroll);\n}\n\n/**\n* Binds click event to toggle order summary\n*/\nconst bindOrderSummaryToggleTouchDevices = () => {\n    if ($(window).innerWidth() < LAPTOP_MAX_WIDTH) {\n        $('.checkout-navigation > .js-checkout-order-summary .js-order-summary-btn, .js-order-close-btn').on('click', () => {\n            $('.js-order-summary-btn').toggleClass('active');\n            $('.js-order-summary').toggleClass('show');\n        });\n    }\n};\n\n/**\n* Binds click event to open low entry barrier promotion pop-up\n*/\nconst bindOrderSummaryLowEntryBarrierPopup = () => {\n    $('body').on('click', '.js-low-entry-barrier-popup', () => {\n        const $lowEntryBarrierPlanMessage = $(`.js-plan-message[data-plan-message-id=\"${LOW_ENTRY_BARRIER_MESSAGE_ID}\"]`);\n        const $tooltip = $lowEntryBarrierPlanMessage.find('.js-tooltip-modal-icon');\n        if ($tooltip.length > 0) {\n            $tooltip.trigger('click');\n        }\n    });\n\n    // Since this item is clicked from other locations, it should close the MobileSummary when applicable\n    $('body').on('click', '.js-tooltip-modal-icon', () => {\n        closeMobileSummary();\n    });\n};\n\n/**\n* (Re)binds checkout step 5 click events to open low entry barrier promotion pop-up\n*/\nfunction initStep5bindOrderSummaryLowEntryBarrierPopup() {\n    const $lowEntryBarrierPlanMessage = $(`.checkout-order-summary-floating .js-plan-message[data-plan-message-id=\"${LOW_ENTRY_BARRIER_MESSAGE_ID}\"]`);\n    const $tooltip = $lowEntryBarrierPlanMessage.find('.js-tooltip-modal-icon');\n\n    const $injectedPopupLink = $('.js-payment-summary-new .js-low-entry-barrier-popup');\n    const $injectedTooltip = $(`.js-payment-summary-new .js-plan-message[data-plan-message-id=\"${LOW_ENTRY_BARRIER_MESSAGE_ID}\"] .js-tooltip-modal-icon`);\n\n    $injectedPopupLink.add($injectedTooltip).each(function bindClickEvent() {\n        $(this).off('click').on('click', () => {\n            if ($tooltip.length > 0) {\n                $tooltip.trigger('click');\n            }\n        });\n    });\n}\n\n/**\n* Toggles visibility of the one cent promotion content\n* @param {boolean} isOneCentPromotion - True if the one cent promotion is active, False otherwise\n*/\nconst toggleOneCentPromotionContent = isOneCentPromotion => {\n    const $oneCentPromotionContractDisclaimer = $('.js-one-cent-promotion-contract-disclaimer');\n    const $4Weeks = $('.js-per-4-weeks-asset');\n    const $oneCentPromotionAsset = $('.js-one-cent-promotion-asset');\n\n    if (isOneCentPromotion) {\n        $4Weeks.hide();\n        $oneCentPromotionAsset.show();\n        $oneCentPromotionContractDisclaimer.show();\n    } else {\n        $4Weeks.show();\n        $oneCentPromotionAsset.hide();\n        $oneCentPromotionContractDisclaimer.hide();\n    }\n};\n\n/**\n * Updates order summary\n */\nconst updateMiniCart = () => {\n    const url = $('.update-mini-cart').val();\n    const $orderSummary = $('.js-checkout-order-summary');\n    const $paymentSummaryNew = $('.js-payment-summary-new');\n    const isFirstCheckoutStep = $('.js-choose-step-tab[data-stage=\"HomeClub\"]').hasClass('active');\n\n    $.ajax({\n        url,\n        method: 'GET',\n        success: data => {\n            const {\n                error,\n                errorMessage,\n                miniCartHtml,\n                isOneCentPromotion,\n            } = data;\n\n            if (error) {\n                pushErrorEvent('checkout', errorMessage || error.errorText);\n                return;\n            }\n\n            $orderSummary.empty().append(miniCartHtml);\n            sessionStorage.setItem('miniCartTemplate', miniCartHtml);\n            $paymentSummaryNew.empty().append($orderSummary\n                .clone()\n                .removeClass('js-checkout-order-summary checkout-order-summary-floating')\n                .addClass('checkout-order-summary-static'));\n\n            initStep5SummaryAccordion();\n            initStep5bindOrderSummaryLowEntryBarrierPopup();\n            updatePaymentScheduleOptions(data);\n            toggleOneCentPromotionContent(isOneCentPromotion);\n\n            if (!isFirstCheckoutStep) {\n                bindOrderSummaryToggleTouchDevices();\n                showSummary(3);\n            }\n\n            $('.js-checkout-order-summary').css('pointer-events', 'auto');\n        },\n        error: () => {\n            $.spinner().stop();\n        },\n    });\n};\n\nexport {\n    initSummaryAccordion,\n    initStep5SummaryAccordion,\n    initStep5bindOrderSummaryLowEntryBarrierPopup,\n    showSummary,\n    toggleMobileSummary,\n    mobileSummaryFloat,\n    bindOrderSummaryToggleTouchDevices,\n    bindOrderSummaryLowEntryBarrierPopup,\n    updateMiniCart,\n};\n","import payementInitialize from './paymentScheduleUpdate'; // eslint-disable-line import/no-cycle\n\n/**\n * Toggles PayPal, ApplePay, Bizum, and iDeal buttons from the Adyen drop-in based on the validity of the Step 5 checkout input fields\n * @param {?HTMLElement} $paypalButton - PayPal button element\n * @param {?HTMLElement} $applepayButton - ApplePay button element\n * @param {?HTMLElement} $bizumButton - Bizum button element\n * @param {?HTMLElement} $idealButton - iDeal button element\n */\nconst toggleDropinButtons = ($paypalButton, $applepayButton, $bizumButton, $idealButton) => {\n    const $accountHolder = $('#dwfrm_paymentDetails_accountHolder');\n    const $accountNumber = $('#dwfrm_paymentDetails_accountNumber');\n    const $sepaAgreement = $('#dwfrm_paymentDetails_agreeAutomaticSEPA');\n    const $termsAndConditions = $('#termsAndConditionsCheck');\n\n    const isAccountHolderValid = !$accountHolder.length || $accountHolder.valid();\n    const isAccountNumberValid = !$accountNumber.length || $accountNumber.valid();\n    const isSepaAgreementValid = !$sepaAgreement.length || $sepaAgreement.valid();\n    const isTermsAndConditionsValid = !$termsAndConditions.length || $termsAndConditions.valid();\n\n    if (isAccountHolderValid && isAccountNumberValid && isSepaAgreementValid && isTermsAndConditionsValid) {\n        if ($paypalButton && $paypalButton.length > 0) {\n            $paypalButton.removeClass('paypal-button-disabled');\n        }\n        if ($applepayButton && $applepayButton.length > 0) {\n            $applepayButton.removeClass('applepay-button-disabled');\n        }\n        if ($bizumButton && $bizumButton.length > 0) {\n            $bizumButton.removeClass('bizum-button-disabled');\n        }\n        if ($idealButton && $idealButton.length > 0) {\n            $idealButton.removeClass('ideal-button-disabled');\n        }\n    } else {\n        if ($paypalButton && $paypalButton.length > 0) {\n            $paypalButton.addClass('paypal-button-disabled');\n        }\n        if ($applepayButton && $applepayButton.length > 0) {\n            $applepayButton.addClass('applepay-button-disabled');\n        }\n        if ($bizumButton && $bizumButton.length > 0) {\n            $bizumButton.addClass('bizum-button-disabled');\n        }\n        if ($idealButton && $idealButton.length > 0) {\n            $idealButton.addClass('ideal-button-disabled');\n        }\n    }\n};\n\n/**\n * Updates membership duration plan HTML wrapper with the given HTML string\n * @param {string} membershipDurationPlanHTML - HTML string\n */\nconst updateMembershipDuration = (membershipDurationPlanHTML) => {\n    if (!membershipDurationPlanHTML || typeof membershipDurationPlanHTML !== 'string') {\n        return;\n    }\n\n    const memberShipDurationPlan = $('.js-membershipDurationPlan');\n    const activeMemberShipDuration = memberShipDurationPlan.find('.js-first-part-checkboxes');\n    activeMemberShipDuration.replaceWith(membershipDurationPlanHTML);\n    payementInitialize();\n};\n\n/**\n * Updates payment schedule options on checkout step 5\n * @param {Object} data - Payload data\n */\nconst updatePaymentScheduleOptions = ({\n    isFlex,\n    isPromotionAvailable,\n    is13PeriodDiscount,\n    isLowEntryBarrierPromotion,\n    isFoundingMember,\n    subscriptionPrice,\n    discountedMonthlyPrice,\n    originalTotalPrice,\n    totalPrice,\n    promotionFlexLabel,\n    promotionLabel4Weeks,\n    promotionLabel52Weeks,\n    promotion13Label4Weeks,\n    promotion13Label52Weeks,\n    defaultDescription4Weeks,\n    lowEntryBarrierDescription4Weeks,\n    isStrikeThroughPrice,\n}) => {\n    const $4WeeksPaymentScheduleOption = $('.js-payment-schedule.fourWeeks');\n    const $52WeeksPaymentScheduleOption = $('.js-payment-schedule.52weeks');\n    const $4WeeksDescription = $4WeeksPaymentScheduleOption.find('.js-promotion-description');\n    const $4WeeksPrice = $4WeeksPaymentScheduleOption.find('.card__price');\n    const $52WeeksPrice = $52WeeksPaymentScheduleOption.find('.card__price');\n\n    $4WeeksDescription.html(isLowEntryBarrierPromotion ? lowEntryBarrierDescription4Weeks : defaultDescription4Weeks);\n\n    if (isPromotionAvailable || isFoundingMember) {\n        const $4WeeksDiscountedPrice = $4WeeksPaymentScheduleOption.find('.discounted-price');\n        const $52WeeksDiscountedPrice = $52WeeksPaymentScheduleOption.find('.discounted-price');\n        const $4WeeksStrikeThroughPrice = $4WeeksPaymentScheduleOption.find('.strike-through-price');\n        const $52WeeksStrikeThroughPrice = $52WeeksPaymentScheduleOption.find('.strike-through-price');\n        const $4WeeksPromotionLabel = $4WeeksPaymentScheduleOption.find('.sub-text');\n        const $52WeeksPromotionLabel = $52WeeksPaymentScheduleOption.find('.sub-text');\n        let label4Weeks;\n\n        if (isFlex) {\n            label4Weeks = promotionFlexLabel;\n        } else if (is13PeriodDiscount) {\n            label4Weeks = promotion13Label4Weeks;\n        } else {\n            label4Weeks = promotionLabel4Weeks;\n        }\n\n        if (discountedMonthlyPrice) {\n            if ($4WeeksDiscountedPrice.length > 0) {\n                $4WeeksDiscountedPrice.html(discountedMonthlyPrice);\n            } else {\n                $4WeeksPrice.html(discountedMonthlyPrice);\n            }\n        }\n        if (totalPrice) {\n            if ($52WeeksDiscountedPrice.length > 0) {\n                $52WeeksDiscountedPrice.html(totalPrice);\n            } else {\n                $52WeeksPrice.html(totalPrice);\n            }\n        }\n        if (isStrikeThroughPrice && subscriptionPrice) {\n            $4WeeksStrikeThroughPrice.html(subscriptionPrice);\n        }\n        if (isStrikeThroughPrice && originalTotalPrice) {\n            $52WeeksStrikeThroughPrice.html(originalTotalPrice);\n        }\n        if (label4Weeks) {\n            $4WeeksPromotionLabel.html(label4Weeks);\n        }\n        if (promotion13Label52Weeks || promotionLabel52Weeks) {\n            $52WeeksPromotionLabel.html(is13PeriodDiscount ? promotion13Label52Weeks : promotionLabel52Weeks);\n        }\n    } else {\n        if (subscriptionPrice) {\n            $4WeeksPrice.html(subscriptionPrice);\n        }\n        if (originalTotalPrice) {\n            $52WeeksPrice.html(originalTotalPrice);\n        }\n    }\n};\n\n/**\n * Toggles one cent promotion content on checkout step 5\n * @param {string} paymentInterval - Payment interval (fourWeeks, 52weeks)\n * @param {boolean} isOneCentPromotion - True if one cent promotion is available, False otherwise\n */\nconst toggleOneCentPromotionContent = (paymentInterval, isOneCentPromotion) => {\n    const is4Weeks = paymentInterval === 'fourWeeks';\n    const $4Weeks = $('.js-per-4-weeks-asset');\n    const $52Weeks = $('.js-per-52-weeks-asset');\n    const $oneCentPromotionAsset = $('.js-one-cent-promotion-asset');\n    const $oneCentPromotionDisclaimer = $('.js-one-cent-promotion-disclaimer');\n    const $oneCentPromotionMobileDisclaimer = $('.js-mobile-summary-block');\n\n    if (isOneCentPromotion) {\n        $4Weeks.hide();\n        $52Weeks.hide();\n        $oneCentPromotionAsset.show();\n    } else if (is4Weeks) {\n        $4Weeks.show();\n        $52Weeks.hide();\n        $oneCentPromotionAsset.hide();\n    } else {\n        $4Weeks.hide();\n        $52Weeks.show();\n        $oneCentPromotionAsset.hide();\n    }\n\n    if (isOneCentPromotion && is4Weeks) {\n        $oneCentPromotionDisclaimer.removeClass('display-none');\n        $oneCentPromotionMobileDisclaimer.show();\n    } else {\n        $oneCentPromotionDisclaimer.addClass('display-none');\n        $oneCentPromotionMobileDisclaimer.hide();\n    }\n};\n\nexport {\n    toggleDropinButtons,\n    updateMembershipDuration,\n    updatePaymentScheduleOptions,\n    toggleOneCentPromotionContent,\n};\n","import adyenDropin from './adyenDropin';\nimport { initStep5SummaryAccordion, initStep5bindOrderSummaryLowEntryBarrierPopup } from './orderSummary';\nimport { toggleOneCentPromotionContent } from './paymentMethodHelpers';\nimport { pushErrorEvent, pushSelectPaymentIntervalEvent } from './../gtm/checkoutFlow';\n\nlet ibanInputs = $('.js-acount-inputs.visually-hidden').detach();\nlet sepaCheckbox = $('.js-sepa-payment-checkbox.visually-hidden').detach();\n\nexport default function payementInitialize() {\n    $('.js-payment-schedule').on('click', e => {\n        const $target = $(e.currentTarget);\n        const $wrapper = $target.closest('[data-url]');\n        $wrapper.find('.js-payment-interval-error').addClass('visually-hidden');\n        const paymentInterval = $target.find('input').val();\n        const url = $wrapper.attr('data-url');\n        const endpointUrl = `${url}?paymentInterval=${paymentInterval}`;\n\n        $.ajax({\n            url: endpointUrl,\n            type: 'POST',\n            success: ({\n                isSepaYearPlanAllowed,\n                error,\n                errorMessage,\n                gtmProductsNew,\n                cart,\n                subscriptionBasePrice,\n                allRecurringCosts,\n                addOnsHtml,\n                extraYearlyPaymentPromo,\n                miniCartHtml,\n                isOneCentPromotion,\n                adyenSessionData,\n            }) => {\n                if (!isSepaYearPlanAllowed && paymentInterval === '52weeks' && $('.js-no-sepa-message').length) {\n                    ibanInputs = $('.js-acount-inputs').detach();\n                    sepaCheckbox = $('.js-sepa-payment-checkbox').detach();\n                    $('.js-skip-sepa').val(true);\n                    $('.js-no-sepa-message').removeClass('visually-hidden');\n                } else {\n                    $('.js-no-sepa-message').after(ibanInputs);\n                    $('.checkboxes').prepend(sepaCheckbox);\n                    $('.js-skip-sepa').val(false);\n                    $('.js-acount-inputs').removeClass('visually-hidden');\n                    $('.js-sepa-payment-checkbox').removeClass('visually-hidden');\n                    $('.js-no-sepa-message').addClass('visually-hidden');\n                }\n\n                if (error) {\n                    const message = errorMessage || error.errorText;\n                    const sanitizeMessage = message.includes('(') ? message.split('(')[0] : message;\n                    pushErrorEvent('checkout', sanitizeMessage);\n                    return;\n                }\n\n                if (gtmProductsNew) {\n                    const products = typeof gtmProductsNew === 'string' ? JSON.parse(gtmProductsNew) : gtmProductsNew;\n                    pushSelectPaymentIntervalEvent(products);\n                    $('.js-data-checkout-stage').data('gtm-membership-products', gtmProductsNew);\n                }\n\n                $wrapper.find('input[type=radio]').removeAttr('checked');\n                $target.find('input').attr('checked', 'checked');\n                $target.find('.js-price').html(cart.totals.subTotal);\n\n                $target.closest('.js-payment-schedule').find('.pre-promo-price').html(\n                    `<div class=\"pre-promo-price\">\n                        ${subscriptionBasePrice}\n                    </div>`\n                );\n\n                $target.closest('.js-payment-schedule').find('.js-sub-price').html(\n                    `<span class=\"js-sub-price\">${subscriptionBasePrice}</span>`\n                );\n\n                $target.closest('.js-payment-schedule').find('.js-price').html(\n                    `<span class=\"card__price\">\n                        <span>${allRecurringCosts}</span>\n                    </span>`\n                );\n\n                $target.find('.js-price').html(() => {\n                    $('.js-discounted-text-content').empty();\n\n                    if (paymentInterval === '52weeks') {\n                        $('#input-payment-schedule-52weeks').prop('checked', true);\n                        $('#input-payment-schedule-fourWeeks').prop('checked', false);\n                    } else {\n                        $('#input-payment-schedule-52weeks').prop('checked', false);\n                        $('#input-payment-schedule-fourWeeks').prop('checked', true);\n                    }\n\n                    if (addOnsHtml) {\n                        $('.js-checkout-navigation__addons-container').empty().append(addOnsHtml);\n                    }\n\n                    if (cart.isPlanAdjusted && cart.periodPromoDiscount.available) {\n                        $('.js-discounted-text-content').html(cart.periodPromoDiscountMsg);\n                    }\n\n                    if (cart.isFoundingMemberPromoTextInclude) {\n                        if (paymentInterval === '52weeks') {\n                            $('.js-founding-year').html(cart.foundingPromoMsg);\n                        } else {\n                            $('.js-founding-four-week').html(cart.foundingPromoMsg);\n                        }\n                    }\n\n                    if (cart.isPlanAdjusted && cart.periodPromoDiscount.available) {\n                        return cart.isStrikeThroughPrice\n                            ? `<span class=\"card__price\">\n                                    <span class=\"price-wrap\">\n                                        <span class=\"strike-through-price\">\n                                            ${subscriptionBasePrice}\n                                        </span>\n                                        <span class=\"discounted-price\">\n                                            ${allRecurringCosts}\n                                        </span>\n                                    </span>\n                                </span>`\n                            : `<span class=\"card__price\">\n                                    <span class=\"price-wrap\">\n                                        <span class=\"discounted-price\">\n                                            ${allRecurringCosts}\n                                        </span>\n                                    </span>\n                                </span>`;\n                    }\n\n                    return `<span class=\"card__price\">\n                                <span>${allRecurringCosts}</span>\n                            </span>`;\n                });\n\n                if (paymentInterval === '52weeks' && extraYearlyPaymentPromo.text) {\n                    $wrapper.find('.js-extra-promo-52weeks').removeClass('visually-hidden');\n                    $wrapper.find('.js-extra-promo-fourWeeks').addClass('visually-hidden');\n                    $wrapper.find('.js-extra-promo-52weeks').html(\n                        `<span class=\"old-price\">\n                            &euro;${extraYearlyPaymentPromo.stPrice}\n                        </span>\n                        <div class=\"subscription-promo\">\n                            ${extraYearlyPaymentPromo.percentage}${extraYearlyPaymentPromo.text}\n                        </div>`\n                    );\n\n                    if (paymentInterval === '52weeks' && extraYearlyPaymentPromo.text) {\n                        $wrapper.find('.js-extra-promo-52weeks').removeClass('visually-hidden');\n                        $wrapper.find('.js-extra-promo-fourWeeks').addClass('visually-hidden');\n                        $wrapper.find('.js-extra-promo-52weeks').html(\n                            `<span class=\"old-price\">\n                                &euro;${extraYearlyPaymentPromo.stPrice}\n                            </span>\n                            <div class=\"subscription-promo\">\n                                ${extraYearlyPaymentPromo.percentage}${extraYearlyPaymentPromo.text}\n                            </div>`\n                        );\n                    } else {\n                        $wrapper.find('.js-extra-promo-52weeks').addClass('visually-hidden');\n                        $wrapper.find('.js-extra-promo-fourWeeks').addClass('visually-hidden');\n                    }\n                }\n\n                if (adyenSessionData) {\n                    $('.js-order-id-input').val(adyenSessionData.orderId);\n                    $('.js-people-id-input').val(adyenSessionData.peopleId);\n                }\n\n                if (miniCartHtml) {\n                    const $paymentSummary = $('.js-payment-summary-new');\n                    const $checkoutOrderSummary = $('.js-checkout-order-summary');\n                    const $checkoutOrderSummaryStatic = $paymentSummary.find('.checkout-order-summary-static');\n                    $checkoutOrderSummary.empty().append(miniCartHtml);\n                    $checkoutOrderSummaryStatic.empty().append(miniCartHtml);\n                    initStep5SummaryAccordion();\n                    initStep5bindOrderSummaryLowEntryBarrierPopup();\n                    adyenDropin();\n                }\n\n                toggleOneCentPromotionContent(paymentInterval, isOneCentPromotion);\n            },\n            error: () => {\n                $wrapper.find('.js-payment-interval-error').removeClass('visually-hidden');\n            },\n        });\n    });\n}\n","import { formatName } from './../util';\n\nconst GtmParametersBuilder = require('./gtmParametersBuilder');\nconst GtmCheckoutBuilder = require('./gtmCheckoutBuilder');\nconst GtmEcommBuilder = require('./gtmEcommBuilder');\n\nfunction buildCheckoutOption(checkoutData) {\n    const ecommData = new GtmEcommBuilder()\n        .withCheckoutOption(checkoutData)\n        .build();\n\n    return new GtmParametersBuilder()\n        .withEvent('ecomCheckoutOption')\n        .withEcommerce(ecommData)\n        .build();\n}\n\nfunction buildCheckout(checkoutData) {\n    const ecommData = new GtmEcommBuilder()\n        .withCheckout(checkoutData)\n        .build();\n\n    return new GtmParametersBuilder()\n        .withEvent('ecomCheckout')\n        .withEcommerce(ecommData)\n        .build();\n}\n\nfunction buildPurchaseOption(checkoutData, user) {\n    const ecommData = new GtmEcommBuilder()\n        .withPurchaseOption(checkoutData)\n        .build();\n\n    return new GtmParametersBuilder()\n        .withEvent('ecomPurchase')\n        .withEcommerce(ecommData)\n        .withUser(user)\n        .build();\n}\n\n/**\n * @description Function for pushing GA4 event after clicking a CTA on second step of new checkout\n */\nfunction pushMembershipStepCTAEvent() {\n    window.dataLayer.push({ ecommerce: null });\n    window.dataLayer.push({\n        event: 'next_step',\n        type: 'membership checkout',\n        step_name: 'select membership',\n        step_index: 2,\n    });\n}\n\n/**\n * Handles view_details event\n * @param {string} membershipType - Membership type\n */\nconst pushMembershipViewDetailsEvent = membershipType => {\n    if (!membershipType) {\n        return;\n    }\n\n    const event = new GtmParametersBuilder()\n        .withEvent('view_details')\n        .withParameter('type', 'memberships')\n        .withParameter('membership', membershipType.toLowerCase())\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push(event);\n};\n\nfunction pushMembershipHideDetailsEvent(membershipType) {\n    if (!membershipType) {\n        return;\n    }\n\n    const event = new GtmParametersBuilder()\n        .withEvent('hide_details')\n        .withParameter('type', 'memberships')\n        .withParameter('membership', membershipType.toLowerCase())\n        .build();\n\n    window.dataLayer.push(event);\n}\n\nfunction pushPaymentMethodLoaded(products, option) {\n    if (!products) {\n        return;\n    }\n\n    const checkoutData = new GtmCheckoutBuilder()\n        .withActionField({ step: 4, option })\n        .withProducts(products.map(product => product))\n        .build();\n    const gtmParams = buildCheckout(checkoutData);\n\n    window.dataLayer.push(gtmParams);\n}\n\nfunction pushConfirmationPageLoaded(actionField, products, marketingID, user, userID) {\n    if (!products) {\n        return;\n    }\n\n    const checkoutData = new GtmCheckoutBuilder()\n        .withActionField(actionField)\n        .withProducts(products.map(product => formatName(product)))\n        .withMarketingID(marketingID)\n        .build();\n    const gtmParams = buildPurchaseOption(checkoutData, user);\n    // Idetify user for Tracedock\n    window.dataLayer.push({ userId: userID });\n    window.dataLayer.push(gtmParams);\n    localStorage.removeItem('selectedClub');\n    localStorage.removeItem('selectedMembershipType');\n    localStorage.removeItem('selectedMembershipDuration');\n    localStorage.removeItem('selectedAddOns');\n}\n\n/**\n * Handles purchase event\n * @param {?Object} data - Event data\n * @param {Object} userData - User data\n * @param {Object} actionData - Action data\n */\nconst pushPurchaseEvent = (data, userData, actionData) => {\n    if (!(data && data.items)) {\n        return;\n    }\n\n    const membership = data.items.find(item => item.item_category === 'subscription');\n\n    if (!membership) {\n        return;\n    }\n\n    const user = {\n        user_email: userData.user_email,\n        user_phone_number: userData.user_phone_number,\n        user_first_name: userData.user_first_name,\n        user_last_name: userData.user_last_name,\n        user_gender: userData.user_gender,\n        user_city: userData.user_city,\n        user_country: userData.user_country_code,\n        user_street: userData.user_street,\n        user_postal_code: userData.user_zip_code,\n        user_age_group: userData.user_age_group,\n        member_id: actionData.peopleId,\n    };\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    const ecommerce = {\n        transaction_id: actionData.id,\n        affiliation: actionData.affiliation,\n        order_amount: actionData.orderAmount,\n        value: actionData.value,\n        currency: data.currency,\n        payment_type: actionData.paymentType,\n        payment_provider: actionData.paymentProvider,\n        items: data.items,\n    };\n\n    const event = new GtmParametersBuilder()\n        .withEvent('purchase')\n        .withParameter('membership', membership.item_name)\n        .withParameter('membership_duration', membership.item_variant)\n        .withParameter('payment_interval', data.payment_interval)\n        .withParameter('user', user)\n        .withParameter('club', club)\n        .withParameter('ecommerce', ecommerce)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push({ ecommerce: null });\n    window.dataLayer.push(event);\n};\n\nfunction pushOriginalLocation(originalLocation) {\n    const event = new GtmParametersBuilder()\n        .withParameter('original_location', originalLocation)\n        .build();\n\n    window.dataLayer.push(event);\n}\n\nfunction pushPageView(data) {\n    if (!data) {\n        return;\n    }\n\n    const events = [\n        new GtmParametersBuilder()\n            .withParameter('page', null)\n            .build(),\n        new GtmParametersBuilder()\n            .withEvent('page_view')\n            .withPage(data)\n            .withTraffic(data)\n            .build(),\n    ];\n\n    events.forEach((event) => {\n        window.dataLayer.push(event);\n    });\n}\n\n/**\n * Handles begin_checkout event on entering step 4 of the checkout\n * @param {?Object} data - Event data\n */\nconst pushPersonalInformationEvent = data => {\n    if (!(data && data.items)) {\n        return;\n    }\n\n    const membership = data.items.find(item => item.item_category === 'subscription');\n\n    if (!membership) {\n        return;\n    }\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    const ecommerce = {\n        currency: data.currency,\n        items: data.items,\n    };\n\n    const event = new GtmParametersBuilder()\n        .withEvent('begin_checkout')\n        .withParameter('membership', membership.item_name)\n        .withParameter('membership_duration', membership.item_variant)\n        .withParameter('payment_interval', data.payment_interval)\n        .withParameter('club', club)\n        .withParameter('ecommerce', ecommerce)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push({ ecommerce: null });\n    window.dataLayer.push(event);\n};\n\n/**\n * Handles add_to_cart event\n * @param {?Object} data - Event data\n * @param {boolean} isOnlyAddonsAdded - True if only addons are added to cart, False otherwise\n * @param {boolean} isOnlyMembershipAdded - True if only membership and club are added to cart, False otherwise\n */\nconst pushAddToCartEvent = (data, isOnlyAddonsAdded, isOnlyMembershipAdded) => {\n    if (!(data && data.items)) {\n        return;\n    }\n\n    const membership = data.items.find((item) => item.item_category === 'subscription');\n\n    if (!membership) {\n        return;\n    }\n\n    let items = [];\n\n    if (isOnlyAddonsAdded) {\n        items = data.items.filter((item) => item.item_category === 'add-on');\n    } else if (isOnlyMembershipAdded) {\n        items = data.items.filter((item) => item.item_category !== 'add-on');\n    } else {\n        items = data.items;\n    }\n\n    if (items.length <= 0) {\n        return;\n    }\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    const ecommerce = {\n        currency: data.currency,\n        items,\n    };\n\n    const event = new GtmParametersBuilder()\n        .withEvent('add_to_cart')\n        .withParameter('membership', membership.item_name)\n        .withParameter('membership_duration', membership.item_variant)\n        .withParameter('payment_interval', data.payment_interval)\n        .withParameter('club', club)\n        .withParameter('ecommerce', ecommerce)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push({ ecommerce: null });\n    window.dataLayer.push(event);\n};\n\n/**\n * Handles remove_from_cart event\n * @param {?Object} data - Event data\n * @param {boolean} isOnlyAddonsRemoved - True if only addons are removed from cart, False otherwise\n * @param {boolean} isOnlyMembershipRemoved - True if only membership and club are removed from cart, False otherwise\n */\nconst pushRemoveFromCartEvent = (data, isOnlyAddonsRemoved, isOnlyMembershipRemoved) => {\n    if (!(data && data.items)) {\n        return;\n    }\n\n    const membership = data.items.find((item) => item.item_category === 'subscription');\n\n    if (!membership) {\n        return;\n    }\n\n    let items = [];\n\n    if (isOnlyAddonsRemoved) {\n        items = data.items.filter((item) => item.item_category === 'add-on');\n    } else if (isOnlyMembershipRemoved) {\n        items = data.items.filter((item) => item.item_category !== 'add-on');\n    } else {\n        items = data.items;\n    }\n\n    if (items.length <= 0) {\n        return;\n    }\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    const ecommerce = {\n        currency: data.currency,\n        items,\n    };\n\n    const event = new GtmParametersBuilder()\n        .withEvent('remove_from_cart')\n        .withParameter('membership', membership.item_name)\n        .withParameter('membership_duration', membership.item_variant)\n        .withParameter('payment_interval', data.payment_interval)\n        .withParameter('club', club)\n        .withParameter('ecommerce', ecommerce)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push({ ecommerce: null });\n    window.dataLayer.push(event);\n};\n\n/**\n * Handles add_shipping_info event on entering step 5 of the checkout\n * @param {?Object} data - Event data\n */\nconst pushPaymentMethodEvent = data => {\n    if (!(data && data.items)) {\n        return;\n    }\n\n    const membership = data.items.find(item => item.item_category === 'subscription');\n\n    if (!membership) {\n        return;\n    }\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    const ecommerce = {\n        currency: data.currency,\n        items: data.items,\n    };\n\n    const event = new GtmParametersBuilder()\n        .withEvent('add_shipping_info')\n        .withParameter('membership', membership.item_name)\n        .withParameter('membership_duration', membership.item_variant)\n        .withParameter('payment_interval', data.payment_interval)\n        .withParameter('club', club)\n        .withParameter('ecommerce', ecommerce)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push({ ecommerce: null });\n    window.dataLayer.push(event);\n};\n\n/**\n * Handles select_club event\n * @param {?Object} data - Event data\n * @param {string} type - List/club details (popup) type\n * @param {string} view - Map/list view\n * @param {number} position - Club's position in the list, applicable for the list view only\n */\nconst pushSelectClubEvent = (data, type, view, position) => {\n    if (!data) {\n        return;\n    }\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    if (position && view === 'list view') {\n        club.club_list_position = position.toString();\n    }\n\n    const event = new GtmParametersBuilder()\n        .withEvent('select_club')\n        .withParameter('type', type)\n        .withParameter('view_type', view)\n        .withParameter('club', club)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push(event);\n};\n\n/**\n * Handles error event\n * @param {string} errorType - Error type\n * @param {string} message - Error message\n */\nconst pushErrorEvent = (errorType, message) => {\n    const error = {\n        error_type: errorType,\n        error_message: message,\n    };\n\n    const events = [\n        new GtmParametersBuilder()\n            .withParameter('error', null)\n            .build(),\n        new GtmParametersBuilder()\n            .withEvent('error')\n            .withError(error)\n            .build(),\n    ];\n\n    window.dataLayer = window.dataLayer || [];\n\n    events.forEach(event => {\n        window.dataLayer.push(event);\n    });\n};\n\n/**\n * Handles select_filter / deselect_filter event\n * @param {string} type - Filter type\n * @param {boolean} isSelected - True if filter is selected, False otherwise\n */\nconst pushSelectFilterEvent = (type, isSelected) => {\n    const eventName = isSelected ? 'deselect_filter' : 'select_filter';\n    const event = new GtmParametersBuilder()\n        .withEvent(eventName)\n        .withParameter('type', type)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push(event);\n};\n\n/**\n * @description Function for handling view selection event\n * @param {string} viewTypeName - view type name\n */\nfunction pushViewTypeSelectEvent(viewTypeName) {\n    window.dataLayer = window.dataLayer || [];\n    const event = new GtmParametersBuilder()\n        .withEvent('change_view')\n        .withParameter('type', viewTypeName)\n        .build();\n\n    window.dataLayer.push(event);\n}\n\n/**\n * Handles payment_method_selected event\n * @param {string} option - Option\n */\nconst pushPaymentMethodSelectedEvent = option => {\n    if (!option) {\n        return;\n    }\n\n    const checkoutData = new GtmCheckoutBuilder()\n        .withActionField({ step: 4, option })\n        .build();\n    const gtmParams = buildCheckoutOption(checkoutData);\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push(gtmParams);\n};\n\n/**\n * Handles select_membership event\n * @param {?Object} data - Event data\n */\nconst pushSelectMembershipEvent = data => {\n    if (!(data && data.items)) {\n        return;\n    }\n\n    const membership = data.items.find(item => item.item_category === 'subscription');\n\n    if (!membership) {\n        return;\n    }\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    const event = new GtmParametersBuilder()\n        .withEvent('select_membership')\n        .withParameter('membership', membership.item_name)\n        .withParameter('payment_interval', data.payment_interval)\n        .withParameter('club', club)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push(event);\n};\n\n/**\n * Handles select_payment_interval event\n * @param {?Object} data - Event data\n */\nconst pushSelectPaymentIntervalEvent = data => {\n    if (!(data && data.items)) {\n        return;\n    }\n\n    const membership = data.items.find(item => item.item_category === 'subscription');\n\n    if (!membership) {\n        return;\n    }\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    const event = new GtmParametersBuilder()\n        .withEvent('select_payment_interval')\n        .withParameter('membership', membership.item_name)\n        .withParameter('membership_duration', membership.item_variant)\n        .withParameter('payment_interval', data.payment_interval)\n        .withParameter('club', club)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push(event);\n};\n\n/**\n * Handles add_payment_info event\n * @param {?Object} data - Event data\n * @param {string} paymentType - Payment type\n * @param {string} paymentProvider - Payment provider\n */\nconst pushPaymentInfoEvent = (data, paymentType, paymentProvider) => {\n    if (!(data && data.items)) {\n        return;\n    }\n\n    const membership = data.items.find(item => item.item_category === 'subscription');\n\n    if (!membership) {\n        return;\n    }\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    const ecommerce = {\n        currency: data.currency,\n        payment_type: paymentType,\n        payment_provider: paymentProvider,\n        items: data.items,\n    };\n\n    const event = new GtmParametersBuilder()\n        .withEvent('add_payment_info')\n        .withParameter('membership', membership.item_name)\n        .withParameter('membership_duration', membership.item_variant)\n        .withParameter('payment_interval', data.payment_interval)\n        .withParameter('club', club)\n        .withParameter('ecommerce', ecommerce)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push({ ecommerce: null });\n    window.dataLayer.push(event);\n};\n\n/**\n * Handles select_addon / deselect_addon event\n * @param {?Object} data - Event data\n * @param {string} addon - Add-on name\n * @param {boolean} isSelected - True if add-on is selected, False otherwise\n */\nconst pushSelectAddonEvent = (data, addon, isSelected) => {\n    if (!(data && data.items)) {\n        return;\n    }\n\n    const membership = data.items.find(item => item.item_category === 'subscription');\n\n    if (!membership) {\n        return;\n    }\n\n    const club = {\n        club_name: data.club_name,\n        club_id: data.club_id,\n        club_services: data.club_services,\n        club_founding_member: data.club_founding_member,\n    };\n\n    const eventName = isSelected ? 'select_addon' : 'deselect_addon';\n\n    const event = new GtmParametersBuilder()\n        .withEvent(eventName)\n        .withParameter('membership', membership.item_name)\n        .withParameter('membership_duration', membership.item_variant)\n        .withParameter('payment_interval', data.payment_interval)\n        .withParameter('addon', addon)\n        .withParameter('club', club)\n        .build();\n\n    window.dataLayer = window.dataLayer || [];\n    window.dataLayer.push(event);\n};\n\nexport {\n    pushPersonalInformationEvent,\n    pushPaymentMethodLoaded,\n    pushOriginalLocation,\n    pushPageView,\n    pushAddToCartEvent,\n    pushRemoveFromCartEvent,\n    pushPaymentMethodEvent,\n    pushConfirmationPageLoaded,\n    pushPurchaseEvent,\n    pushErrorEvent,\n    pushMembershipStepCTAEvent,\n    pushSelectFilterEvent,\n    pushViewTypeSelectEvent,\n    pushMembershipViewDetailsEvent,\n    pushMembershipHideDetailsEvent,\n    pushPaymentMethodSelectedEvent,\n    pushSelectMembershipEvent,\n    pushSelectClubEvent,\n    pushSelectPaymentIntervalEvent,\n    pushPaymentInfoEvent,\n    pushSelectAddonEvent,\n};\n","/* eslint-disable func-names */\n/* eslint-disable no-var */\n/* eslint-disable strict */\n\n'use strict';\n\nfunction GtmCheckoutBuilder() {\n    this.checkoutParameters = {};\n}\n\nGtmCheckoutBuilder.prototype.withActionField = function (value) {\n    this.checkoutParameters.actionField = value;\n    return this;\n};\n\nGtmCheckoutBuilder.prototype.withProducts = function (value) {\n    this.checkoutParameters.products = value;\n    return this;\n};\n\nGtmCheckoutBuilder.prototype.withMarketingID = function (value) {\n    this.checkoutParameters.marketingID = value;\n    return this;\n};\n\nGtmCheckoutBuilder.prototype.build = function () {\n    return this.checkoutParameters;\n};\n\nmodule.exports = GtmCheckoutBuilder;\n","/* eslint-disable func-names */\n/* eslint-disable no-var */\n/* eslint-disable strict */\n\n'use strict';\n\nfunction GtmEcommBuilder() {\n    this.ecommParameters = {};\n}\n\nGtmEcommBuilder.prototype.withCheckout = function (value) {\n    this.ecommParameters.checkout = value;\n    return this;\n};\n\nGtmEcommBuilder.prototype.withCheckoutOption = function (value) {\n    this.ecommParameters.checkout_option = value;\n    return this;\n};\n\nGtmEcommBuilder.prototype.withPurchaseOption = function (value) {\n    this.ecommParameters.purchase = value;\n    return this;\n};\n\nGtmEcommBuilder.prototype.withCurrencyCode = function (value) {\n    this.ecommParameters.currencyCode = value;\n    return this;\n};\n\nGtmEcommBuilder.prototype.withImpressions = function (value) {\n    this.ecommParameters.impressions = value;\n    return this;\n};\n\nGtmEcommBuilder.prototype.withProductClick = function (value, actionField) {\n    this.ecommParameters.click = { actionField, products: value };\n    return this;\n};\n\nGtmEcommBuilder.prototype.build = function () {\n    return this.ecommParameters;\n};\n\nmodule.exports = GtmEcommBuilder;\n","/* eslint-disable func-names */\n/* eslint-disable no-var */\n/* eslint-disable strict */\n\n'use strict';\n\nfunction GtmParametersBuilder() {\n    this.gtmParameters = {};\n}\n\nGtmParametersBuilder.prototype.withEvent = function (value) {\n    this.gtmParameters.event = value;\n    return this;\n};\n\nGtmParametersBuilder.prototype.withEventCategory = function (value) {\n    this.gtmParameters.eventCategory = value;\n    return this;\n};\n\nGtmParametersBuilder.prototype.withEventAction = function (value) {\n    this.gtmParameters.eventAction = value;\n    return this;\n};\n\nGtmParametersBuilder.prototype.withEventLabel = function (value) {\n    this.gtmParameters.eventLabel = value;\n    return this;\n};\n\nGtmParametersBuilder.prototype.withEcommerce = function (value) {\n    this.gtmParameters.ecommerce = value;\n    return this;\n};\n\nGtmParametersBuilder.prototype.withUser = function (value) {\n    this.gtmParameters.user = value;\n    return this;\n};\n\nGtmParametersBuilder.prototype.withParameter = function (name, value) {\n    this.gtmParameters[name] = value;\n    return this;\n};\n\nGtmParametersBuilder.prototype.withPage = function (data) {\n    const country = data.locale.split('_')[1].toUpperCase();\n    const language = data.locale.split('_')[0].toUpperCase();\n    this.gtmParameters.page = {\n        page_type: data.type,\n        page_country: country,\n        page_location: data.location,\n        page_title: data.title,\n        page_language: language,\n    };\n    return this;\n};\n\nGtmParametersBuilder.prototype.withTraffic = function (data) {\n    this.gtmParameters.traffictype = {\n        platform: 'web',\n        ip_address: data.ip,\n    };\n    return this;\n};\n\nGtmParametersBuilder.prototype.withError = function (value) {\n    this.gtmParameters.error = value;\n    return this;\n};\n\nGtmParametersBuilder.prototype.build = function () {\n    return this.gtmParameters;\n};\n\nmodule.exports = GtmParametersBuilder;\n","/* eslint-disable import/no-extraneous-dependencies */\n/* eslint-disable no-use-before-define */\n/* eslint-disable radix */\n\nimport Swiper from 'swiper';\nimport { Navigation, Pagination, A11y } from 'swiper/modules';\nimport { equalizeElements } from './checkout/membershipHelpers';\n\nconst swiperClass = '.js-m-swiper';\n\n// Swiper for the memberships in step 2 of the checkout on mobile\n// the membershipswiper in checkout step 2 is aparently reused with modifyOptionsForUspTilesSlider as well\nconst MembershipTiles = (() => {\n    let membershipSwiper;\n    function handleMembershipSwiper() {\n        if (!$(swiperClass).length > 0) {\n            // stop if no swipers or single slide swipers are on the page\n            return;\n        }\n\n        const slideNumber = $(swiperClass).find('.swiper-slide').length;\n\n        let options = {\n            // configure Swiper to use modules\n            modules: [Navigation, Pagination, A11y],\n            speed: 500,\n            loop: false,\n            spaceBetween: 8,\n            loopedSlides: slideNumber,\n            slidesPerView: 1,\n            initialSlide: 1,\n            centeredSlides: true,\n            pagination: {\n                el: '.swiper-pagination-top',\n                // el: '.js-m-swiper .swiper-pagination', << only single pagination now, so this one in checkout, and the other in USP tiles\n                type: 'bullets',\n                clickable: true,\n            },\n            navigation: {\n                nextEl: '.js-m-swiper .arrow-next',\n                prevEl: '.js-m-swiper .arrow-prev',\n            },\n            a11y: {\n                prevSlideMessage: `${window.resources['slider.prev.slide.label']}`,\n                nextSlideMessage: `${window.resources['slider.next.slide.label']}`,\n                firstSlideMessage: `${window.resources['slider.first.slide.label']}`,\n                lastSlideMessage: `${window.resources['slider.last.slide.label']}`,\n            },\n            on: {\n                slideChange() {\n                    if (typeof membershipSwiper !== 'undefined') {\n                        // eslint-disable-next-line no-use-before-define\n                        setSwipeText();\n                        // eslint-disable-next-line no-use-before-define\n                        slideChangePush();\n                    }\n                },\n            },\n        };\n\n        if ($('.js-usp-tile-swiper').length) {\n            options = modifyOptionsForUspTilesSlider(options);\n        }\n\n        //  if we already have one, lets wipe it\n        if (typeof membershipSwiper !== 'undefined') {\n            MembershipTiles.destroy();\n        }\n        if (typeof membershipSwiper === 'undefined' && slideNumber > 1) {\n            membershipSwiper = new Swiper(swiperClass, options);\n\n            // auto swipe to highlighted membership on start:\n            // eslint-disable-next-line func-names\n            $('.js-m-swiper .swiper-slide').each(function (e) {\n                if ($(this).hasClass('highlighted')) {\n                    membershipSwiper.slideTo(e);\n                }\n            });\n\n            // eslint-disable-next-line no-use-before-define\n            setSwipeText();\n        }\n    }\n\n    // Datalayer pushes (clicks or swipes + the membership they ended up on)\n    // clicks track both arrows and bullets\n    function slideChangePush() {\n        // eslint-disable-next-line func-names\n        const slideIdArray = $('.js-m-swiper .swiper-slide').map(function () {\n            return $(this).attr('data-name');\n        }).get();\n\n        const goToMembership = slideIdArray[membershipSwiper.activeIndex];\n        const startX = membershipSwiper.touches.startX;\n        const currentX = membershipSwiper.touches.currentX;\n        let eventType = 'click';\n        if (currentX !== startX) {\n            eventType = 'swipe';\n        }\n\n        window.dataLayer = window.dataLayer || [];\n        window.dataLayer.push({\n            event: 'navigation',\n            type: 'memberships',\n            navigation_method: eventType, // swipe or click\n            membership: goToMembership, // premium, comfort, all-in\n        });\n    }\n\n    // set text labels for left and right arrow in the swiper\n    function setSwipeText() {\n        //  fetch data-name from all tiles\n        // eslint-disable-next-line func-names\n        const slideIdArray = $('.js-m-swiper .swiper-slide').map(function () {\n            return $(this).attr('data-name');\n        }).get();\n\n        let PrevText = '';\n        let NextText = '';\n\n        if (membershipSwiper.activeIndex === 0) {\n            // we are in first position\n            NextText = slideIdArray[membershipSwiper.activeIndex + 1];\n        } else if (membershipSwiper.activeIndex === (slideIdArray.length - 1)) {\n            // we are in last position\n            PrevText = slideIdArray[membershipSwiper.activeIndex - 1];\n        } else {\n            PrevText = slideIdArray[membershipSwiper.activeIndex - 1];\n            NextText = slideIdArray[membershipSwiper.activeIndex + 1];\n        }\n        $('.js-m-swiper .arrow-prev').text(PrevText);\n        $('.js-m-swiper .arrow-next').text(NextText);\n    }\n\n    const destroyParams = {\n        cleanStyles: true,\n    };\n\n    function destroyMembershipSwiper() {\n        if (typeof membershipSwiper !== 'undefined') {\n            membershipSwiper.destroy(destroyParams);\n            membershipSwiper = undefined;\n        }\n    }\n\n    function modifyOptionsForUspTilesSlider(options) {\n        // the mebershipswiper in checkout step 2 is aparently reused with these settings\n        options.spaceBetween = 24;\n        options.initialSlide = 0;\n        options.pagination.el = '.js-m-swiper .swiper-pagination';\n\n        if ($(window).width() > 600 && $(window).width() < 901) { // tablet portrait\n            options.spaceBetween = 90;\n            options.slidesPerView = 2;\n        }\n\n        return options;\n    }\n\n    return {\n        init() {\n            handleMembershipSwiper();\n        },\n        destroy() {\n            destroyMembershipSwiper();\n        },\n    };\n})();\n\nconst equalizeTiles = () => {\n    // Equalize heights for headers\n    equalizeElements('.membership-block-header');\n\n    // Equalize heights for footers\n    equalizeElements('.membership-block-footer');\n};\n\nexport default MembershipTiles;\nexport { MembershipTiles, equalizeTiles };\n","/* eslint-disable import/no-extraneous-dependencies */\n\nimport tingle from 'tingle.js';\nimport getYouTubeID from 'get-youtube-id';\n\nexport const smallDesktopMin = 1025;\nexport const mobileViewMax = 767;\nexport const tabletViewMin = 901;\nexport const tabletViewMax = 1024;\n\nfunction processInclude(include) {\n    if (typeof include === 'function') {\n        include();\n    } else if (typeof include === 'object') {\n        Object.keys(include).forEach((key) => {\n            if (typeof include[key] === 'function') {\n                include[key]();\n            }\n        });\n    }\n}\n\n// Format name for ecommerce\nfunction formatName(product) {\n    if (product.category === 'subscription') {\n        product.name = `basic-fit ${product.name.toLowerCase()}`;\n    } else {\n        product.name = product.name.toLowerCase();\n    }\n    return product;\n}\n\nfunction getScreenSizeType() {\n    const { innerWidth } = window;\n\n    if (innerWidth <= mobileViewMax) {\n        return ['mobile-pt'];\n    } if (innerWidth > mobileViewMax && innerWidth <= 900) {\n        return ['mobile-ls', 'tablet-pt'];\n    } if (innerWidth > 900 && innerWidth <= tabletViewMax) {\n        return ['tablet-ls'];\n    } if (innerWidth > tabletViewMax) {\n        return ['desktop'];\n    }\n}\n\n// Better in terms of modularity than getScreenSizeType()\nfunction getScreenSize(mediaQuery) {\n    return window.matchMedia(mediaQuery).matches;\n}\n\n// Check if element is in viewport\n\nfunction isElementInViewport(element) {\n    const rect = document.querySelector(element).getBoundingClientRect();\n    const windowHeight = (window.innerHeight || document.documentElement.clientHeight);\n    const windowWidth = (window.innerWidth || document.documentElement.clientWidth);\n    const vertInView = (rect.top < windowHeight) && ((rect.top + rect.height) > 0);\n    const horInView = (rect.left < windowWidth) && ((rect.left + rect.width) > 0);\n\n    return (vertInView && horInView);\n}\n\nfunction isDOMElementInViewport(element) {\n    const bounding = element.getBoundingClientRect();\n    const windowHeight = (window.innerHeight || document.documentElement.clientHeight);\n    const windowWidth = (window.innerWidth || document.documentElement.clientWidth);\n    const vertInView = (bounding.top < windowHeight) && ((bounding.top + bounding.height) > 0);\n    const horInView = (bounding.left < windowWidth) && ((bounding.left + bounding.width) > 0);\n\n    return (vertInView && horInView);\n}\n\n/**\n* Prevents body scroll in a way that IOS accepts it as well\n* styles need to be written inline to work properly\n* the added class is for adressing nesting inheritance\n*/\n\nlet currentPageScrollPosition = 0;\n\nfunction scrollLock(onoff) {\n    const $body = document.querySelector('body');\n\n    if (onoff === 'on') {\n        currentPageScrollPosition = window.scrollY;\n        $body.classList.add('scroll-lock');\n        $body.style.overflow = 'hidden';\n        $body.style.position = 'fixed';\n        $body.style.top = `-${currentPageScrollPosition}px`;\n        $body.style.width = '100%';\n    } else if (onoff === 'off') {\n        $body.classList.remove('scroll-lock');\n        $body.style.removeProperty('overflow');\n        $body.style.removeProperty('position');\n        $body.style.removeProperty('top');\n        $body.style.removeProperty('width');\n        window.scrollTo(0, currentPageScrollPosition);\n    }\n}\n\n/**\n * Create an alert to display the error message\n * @param {Object} message - Error message to display\n */\nfunction createErrorNotification(message) {\n    const errorHtml = `<div class=\"alert alert-danger alert-dismissible valid-cart-error fade show\" role=\"alert\">\n        <button type=\"button\" class=\"close\" data-dismiss=\"alert\" aria-label=\"Close\">\n            <span aria-hidden=\"true\">&times;</span>\n        </button>\n        ${message}\n    </div>`;\n\n    $('.error-messaging').append(errorHtml);\n}\n\nfunction appendToUrl(url, params) {\n    let newUrl = url;\n\n    if (params) {\n        newUrl += (newUrl.indexOf('?') !== -1 ? '&' : '?') + Object.keys(params).map((key) => `${key}=${encodeURIComponent(params[key])}`).join('&');\n    }\n\n    return newUrl;\n}\n\nfunction openVideoInModal(videoUrl) {\n    const videoId = getYouTubeID(videoUrl);\n\n    const iframeVimeo = `<iframe width=\"100%\" height=\"400\" src=\"https://www.youtube.com/embed/${videoId}?rel=0&amp;showinfo=0&amp;controls=1&amp;autoplay=1\" frameborder=\"0\" allow=\"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture\" allowfullscreen></iframe>`;\n\n    const videoInModal = new tingle.modal({\n        cssClass: ['modal-wrapper', 'modal-wrapper--video'],\n        closeLabel: '',\n        onClose() {\n            this.destroy();\n        },\n    });\n\n    videoInModal.setContent(iframeVimeo);\n    videoInModal.open();\n}\n\nfunction scrollToAnchor(anchor, params = {}) {\n    const defaultOptions = {\n        headerElemHeight: params.headerElemHeight || 0,\n        extraMargin: params.extraMargin || 0,\n        duration: params.duration || 400,\n    };\n    const { headerElemHeight, extraMargin, duration } = defaultOptions;\n    const scrollPos = parseInt($(anchor).offset().top - headerElemHeight - extraMargin);\n\n    $('html, body').animate({\n        scrollTop: scrollPos,\n    }, duration);\n}\n\nfunction setEqualHeights(arrayItems, count) {\n    if (arrayItems !== undefined && arrayItems.length > 0) {\n        arrayItems.height('');\n\n        let maxH = 0;\n\n        if (count) {\n            const arrays = [];\n            while (arrayItems.length > 0) {\n                arrays.push(arrayItems.splice(0, count));\n            }\n\n            for (let i = 0; i < arrays.length; i += 1) {\n                const data = arrays[i];\n                maxH = 0;\n                for (let j = 0; j < data.length; j += 1) {\n                    const currentH = $(data[j]).outerHeight();\n                    if (currentH > maxH) {\n                        maxH = currentH;\n                    }\n                }\n\n                for (let k = 0; k < data.length; k += 1) {\n                    $(data[k]).css('height', maxH);\n                }\n            }\n        } else {\n            arrayItems.each(function () {\n                const currentH2 = $(this).outerHeight();\n                if (currentH2 > maxH) {\n                    maxH = currentH2;\n                }\n            });\n\n            arrayItems.css('height', maxH);\n        }\n    }\n}\n\nfunction fontSizeReduced() {\n    const pages = document.querySelectorAll('.page');\n    const titleContainer = document.querySelector('.js-text-col');\n    const fontReduceComponent = document.querySelectorAll('.js-font-component');\n\n    pages.forEach((page) => {\n        fontReduceComponent.forEach((component) => {\n            if (component.offsetWidth > page.offsetWidth || component.offsetWidth > titleContainer.offsetWidth) {\n                component.classList.add('font-smaller');\n            }\n        });\n    });\n}\n\nfunction checkForContent(elements) {\n    elements.forEach((item) => {\n        if (!item.hasChildNodes()) {\n            item.remove();\n        }\n    });\n}\n\n/**\n * Checks if the email value entered is correct format\n * @param {string} email - email string to check if valid\n * @returns {boolean} Whether email is valid\n */\nfunction validateEmail(email) {\n    const regex = /^[\\w.%+-]+@[\\w.-]+\\.[\\w]{2,6}$/;\n    return regex.test(email);\n}\n\nfunction calculateTitleHeight() {\n    const { innerWidth } = window;\n    const heroBannerTitle = document.querySelector('.js-main-title-hero-wrapper');\n    const heroBannerImg = document.querySelector('.js-hero-wrapper-content-img');\n\n    if (heroBannerImg) {\n        if (innerWidth < smallDesktopMin) {\n            heroBannerImg.style.marginTop = `${heroBannerTitle.offsetHeight + 30}px`;\n        }\n        heroBannerImg.style.display = 'block';\n        heroBannerImg.style.opacity = 1;\n    }\n}\n\nfunction openTabs(tabSelector, tabContentSelector) {\n    const tab = tabSelector;\n    const tabContent = tabContentSelector;\n\n    function removeActive() {\n        tab.forEach((element) => {\n            element.classList.remove('active');\n        });\n\n        tabContent.forEach((element) => {\n            element.style.display = 'none';\n        });\n    }\n\n    tab.forEach((element) => {\n        element.addEventListener('click', (e) => {\n            removeActive();\n\n            const current = e.currentTarget;\n            const currentID = e.currentTarget.getAttribute('data-id');\n            const tabContent = document.getElementById(currentID);\n\n            current.classList.add('active');\n            tabContent.style.display = 'block';\n        });\n    });\n}\n\n// requires to define two hidden input fields that contains text for buttons\nfunction readMoreButton(content, arrayItems, btnText, btnLessText, btnClassName, num, readLess) {\n    const readMoreBtn = document.createElement('button');\n\n    readMoreBtn.innerHTML = btnText.value;\n    readMoreBtn.classList.add(btnClassName);\n\n    // elements that needs to be hidden\n    arrayItems.forEach((item, index) => {\n        // from which element to show read more button\n        if (index > num) {\n            item.classList.add('hidden');\n\n            // where to append btn\n            content.appendChild(readMoreBtn);\n\n            // logic for read more/less button\n            readMoreBtn.addEventListener('click', function () {\n                if (!readLess) {\n                    item.classList.remove('hidden');\n                    this.style.display = 'none';\n                } else {\n                    item.classList.toggle('hidden');\n                }\n\n                // changing text of the button\n                if (item.classList.contains('hidden')) {\n                    this.innerHTML = btnText.value;\n                } else {\n                    this.innerHTML = btnLessText.value;\n                }\n            });\n        }\n    });\n}\n\nfunction imageResizeiOSFix() {\n    const $img = $('.js-hero-wrapper-content-img img');\n    if ($img) {\n        $img.addClass('resize-fix');\n    }\n}\n\nfunction backToTop(element) {\n    const $backToTop = element;\n\n    $(window).on('scroll', () => {\n        const $scrollPos = window.pageYOffset;\n\n        // 100 = one scroll\n        if ($scrollPos > 100) {\n            $backToTop.addClass('show');\n        } else {\n            $backToTop.removeClass('show');\n        }\n    });\n\n    $backToTop.on('click', (e) => {\n        e.preventDefault();\n\n        $('html, body').animate({\n            scrollTop: 0,\n        }, 500);\n    });\n}\n\nfunction customStickyPosition(stickyElement, elementOne, elementTwo, elementThree) {\n    const stickyEl = stickyElement;\n    let offSetOne = 0;\n    let offSetTwo = 0;\n    let offSetThree = 0;\n\n    if (elementOne) {\n        offSetOne += elementOne.offsetHeight;\n    }\n\n    if (elementTwo) {\n        offSetTwo += elementTwo.offsetHeight;\n    }\n\n    if (elementThree) {\n        offSetThree += elementThree.offsetHeight;\n    }\n\n    stickyEl.style.top = `${offSetOne + offSetTwo + offSetThree}px`;\n}\n\nfunction updateCountdown() {\n    // get minutes from each promotion\n    let timeLeftSeconds = parseFloat($(this).text(), 10) * 60;\n\n    const self = $(this);\n\n    const timer = setInterval(() => {\n        // get hours\n        let hours = Math.floor(timeLeftSeconds / 3600);\n        // get minutes\n        let minutes = Math.floor((timeLeftSeconds - hours * 3600) / 60);\n        // get seconds\n        let seconds = timeLeftSeconds - hours * 3600 - minutes * 60;\n\n        hours = hours < 10 ? `0${hours}` : hours;\n        minutes = minutes < 10 ? `0${minutes}` : minutes;\n        seconds = seconds < 10 ? `0${seconds}` : seconds;\n\n        const remainingTime = `${hours}:${minutes}:${seconds}`;\n\n        if (timeLeftSeconds <= 0) {\n            clearInterval(timer);\n        }\n\n        // when string concatenate pump text\n        if (remainingTime) {\n            // set remaining time to each label\n            self.text(remainingTime);\n            if (!$('.discount-label__promotion').hasClass('js-loaded')) {\n                $('.discount-label__promotion').addClass('js-loaded');\n                $.spinner().stop();\n            }\n        }\n\n        timeLeftSeconds -= 1;\n    }, 1000);\n}\n\nfunction dynamicCountdown() {\n    $('.js-promotion-text').each(updateCountdown);\n}\n\n/**\n * @description Should be done before slider init to remove slides so we can use different number of slider assets per locale, for non sliders it should alse be removed at the beginning.\n * @param {jQuery} $Selector - selector of element that has childred to hide\n * @param {string} parentToRemoveSelector - selector of parent element that should be removed.\n */\nfunction removeHiddenAssets($Selector, parentToRemoveSelector) {\n    if ($Selector.find('.js-remove-element')) {\n        $Selector.find('.js-remove-element').closest(parentToRemoveSelector).remove();\n    }\n}\n\nconst debounce = (func, wait, immediate = false) => {\n    let timeout;\n    return (...args) => {\n        const context = this;\n        const later = () => {\n            timeout = null;\n            if (!immediate) func.apply(context, args);\n        };\n        const callNow = immediate && !timeout;\n        clearTimeout(timeout);\n        timeout = setTimeout(later, wait);\n        if (callNow) func.apply(context, args);\n    };\n};\n\nexport {\n    processInclude,\n    getScreenSizeType,\n    isElementInViewport,\n    isDOMElementInViewport,\n    appendToUrl,\n    createErrorNotification,\n    getScreenSize,\n    openVideoInModal,\n    scrollToAnchor,\n    formatName,\n    setEqualHeights,\n    fontSizeReduced,\n    calculateTitleHeight,\n    validateEmail,\n    openTabs,\n    readMoreButton,\n    checkForContent,\n    backToTop,\n    imageResizeiOSFix,\n    customStickyPosition,\n    dynamicCountdown,\n    scrollLock,\n    removeHiddenAssets,\n    debounce,\n};\n","\n(function (root, factory) {\n  if (typeof exports === 'object') {\n    module.exports = factory();\n  } else if (typeof define === 'function' && define.amd) {\n    define(factory);\n  } else {\n    root.getYouTubeID = factory();\n  }\n}(this, function (exports) {\n\n  return function (url, opts) {\n    if (opts == undefined) {\n      opts = {fuzzy: true};\n    }\n\n    if (/youtu\\.?be/.test(url)) {\n\n      // Look first for known patterns\n      var i;\n      var patterns = [\n        /youtu\\.be\\/([^#\\&\\?]{11})/,  // youtu.be/<id>\n        /\\?v=([^#\\&\\?]{11})/,         // ?v=<id>\n        /\\&v=([^#\\&\\?]{11})/,         // &v=<id>\n        /embed\\/([^#\\&\\?]{11})/,      // embed/<id>\n        /\\/v\\/([^#\\&\\?]{11})/         // /v/<id>\n      ];\n\n      // If any pattern matches, return the ID\n      for (i = 0; i < patterns.length; ++i) {\n        if (patterns[i].test(url)) {\n          return patterns[i].exec(url)[1];\n        }\n      }\n\n      if (opts.fuzzy) {\n        // If that fails, break it apart by certain characters and look \n        // for the 11 character key\n        var tokens = url.split(/[\\/\\&\\?=#\\.\\s]/g);\n        for (i = 0; i < tokens.length; ++i) {\n          if (/^[^#\\&\\?]{11}$/.test(tokens[i])) {\n            return tokens[i];\n          }\n        }\n      }\n    }\n\n    return null;\n  };\n\n}));\n","!function(t,o){\"function\"==typeof define&&define.amd?define(o):\"object\"==typeof exports?module.exports=o():t.tingle=o()}(this,function(){var o=!1;function t(t){this.opts=function(){for(var t=1;t<arguments.length;t++)for(var o in arguments[t])arguments[t].hasOwnProperty(o)&&(arguments[0][o]=arguments[t][o]);return arguments[0]}({},{onClose:null,onOpen:null,beforeOpen:null,beforeClose:null,stickyFooter:!1,footer:!1,cssClass:[],closeLabel:\"Close\",closeMethods:[\"overlay\",\"button\",\"escape\"]},t),this.init()}function e(){this.modalBoxFooter&&(this.modalBoxFooter.style.width=this.modalBox.clientWidth+\"px\",this.modalBoxFooter.style.left=this.modalBox.offsetLeft+\"px\")}return t.prototype.init=function(){if(!this.modal)return function(){this.modal=document.createElement(\"div\"),this.modal.classList.add(\"tingle-modal\"),0!==this.opts.closeMethods.length&&-1!==this.opts.closeMethods.indexOf(\"overlay\")||this.modal.classList.add(\"tingle-modal--noOverlayClose\");this.modal.style.display=\"none\",this.opts.cssClass.forEach(function(t){\"string\"==typeof t&&this.modal.classList.add(t)},this),-1!==this.opts.closeMethods.indexOf(\"button\")&&(this.modalCloseBtn=document.createElement(\"button\"),this.modalCloseBtn.type=\"button\",this.modalCloseBtn.classList.add(\"tingle-modal__close\"),this.modalCloseBtnIcon=document.createElement(\"span\"),this.modalCloseBtnIcon.classList.add(\"tingle-modal__closeIcon\"),this.modalCloseBtnIcon.innerHTML='<svg viewBox=\"0 0 10 10\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M.3 9.7c.2.2.4.3.7.3.3 0 .5-.1.7-.3L5 6.4l3.3 3.3c.2.2.5.3.7.3.2 0 .5-.1.7-.3.4-.4.4-1 0-1.4L6.4 5l3.3-3.3c.4-.4.4-1 0-1.4-.4-.4-1-.4-1.4 0L5 3.6 1.7.3C1.3-.1.7-.1.3.3c-.4.4-.4 1 0 1.4L3.6 5 .3 8.3c-.4.4-.4 1 0 1.4z\" fill=\"#000\" fill-rule=\"nonzero\"/></svg>',this.modalCloseBtnLabel=document.createElement(\"span\"),this.modalCloseBtnLabel.classList.add(\"tingle-modal__closeLabel\"),this.modalCloseBtnLabel.innerHTML=this.opts.closeLabel,this.modalCloseBtn.appendChild(this.modalCloseBtnIcon),this.modalCloseBtn.appendChild(this.modalCloseBtnLabel));this.modalBox=document.createElement(\"div\"),this.modalBox.classList.add(\"tingle-modal-box\"),this.modalBoxContent=document.createElement(\"div\"),this.modalBoxContent.classList.add(\"tingle-modal-box__content\"),this.modalBox.appendChild(this.modalBoxContent),-1!==this.opts.closeMethods.indexOf(\"button\")&&this.modal.appendChild(this.modalCloseBtn);this.modal.appendChild(this.modalBox)}.call(this),function(){this._events={clickCloseBtn:this.close.bind(this),clickOverlay:function(t){var o=this.modal.offsetWidth-this.modal.clientWidth,e=t.clientX>=this.modal.offsetWidth-15,s=this.modal.scrollHeight!==this.modal.offsetHeight;if(\"MacIntel\"===navigator.platform&&0==o&&e&&s)return;-1!==this.opts.closeMethods.indexOf(\"overlay\")&&!function(t,o){for(;(t=t.parentElement)&&!t.classList.contains(o););return t}(t.target,\"tingle-modal\")&&t.clientX<this.modal.clientWidth&&this.close()}.bind(this),resize:this.checkOverflow.bind(this),keyboardNav:function(t){-1!==this.opts.closeMethods.indexOf(\"escape\")&&27===t.which&&this.isOpen()&&this.close()}.bind(this)},-1!==this.opts.closeMethods.indexOf(\"button\")&&this.modalCloseBtn.addEventListener(\"click\",this._events.clickCloseBtn);this.modal.addEventListener(\"mousedown\",this._events.clickOverlay),window.addEventListener(\"resize\",this._events.resize),document.addEventListener(\"keydown\",this._events.keyboardNav)}.call(this),document.body.appendChild(this.modal,document.body.firstChild),this.opts.footer&&this.addFooter(),this},t.prototype._busy=function(t){o=t},t.prototype._isBusy=function(){return o},t.prototype.destroy=function(){null!==this.modal&&(this.isOpen()&&this.close(!0),function(){-1!==this.opts.closeMethods.indexOf(\"button\")&&this.modalCloseBtn.removeEventListener(\"click\",this._events.clickCloseBtn);this.modal.removeEventListener(\"mousedown\",this._events.clickOverlay),window.removeEventListener(\"resize\",this._events.resize),document.removeEventListener(\"keydown\",this._events.keyboardNav)}.call(this),this.modal.parentNode.removeChild(this.modal),this.modal=null)},t.prototype.isOpen=function(){return!!this.modal.classList.contains(\"tingle-modal--visible\")},t.prototype.open=function(){if(!this._isBusy()){this._busy(!0);var t=this;return\"function\"==typeof t.opts.beforeOpen&&t.opts.beforeOpen(),this.modal.style.removeProperty?this.modal.style.removeProperty(\"display\"):this.modal.style.removeAttribute(\"display\"),this._scrollPosition=window.pageYOffset,document.body.classList.add(\"tingle-enabled\"),document.body.style.top=-this._scrollPosition+\"px\",this.setStickyFooter(this.opts.stickyFooter),this.modal.classList.add(\"tingle-modal--visible\"),\"function\"==typeof t.opts.onOpen&&t.opts.onOpen.call(t),t._busy(!1),this.checkOverflow(),this}},t.prototype.close=function(t){if(!this._isBusy()){if(this._busy(!0),!1,\"function\"==typeof this.opts.beforeClose)if(!this.opts.beforeClose.call(this))return void this._busy(!1);document.body.classList.remove(\"tingle-enabled\"),document.body.style.top=null,window.scrollTo({top:this._scrollPosition,behavior:\"instant\"}),this.modal.classList.remove(\"tingle-modal--visible\");var o=this;o.modal.style.display=\"none\",\"function\"==typeof o.opts.onClose&&o.opts.onClose.call(this),o._busy(!1)}},t.prototype.setContent=function(t){return\"string\"==typeof t?this.modalBoxContent.innerHTML=t:(this.modalBoxContent.innerHTML=\"\",this.modalBoxContent.appendChild(t)),this.isOpen()&&this.checkOverflow(),this},t.prototype.getContent=function(){return this.modalBoxContent},t.prototype.addFooter=function(){return function(){this.modalBoxFooter=document.createElement(\"div\"),this.modalBoxFooter.classList.add(\"tingle-modal-box__footer\"),this.modalBox.appendChild(this.modalBoxFooter)}.call(this),this},t.prototype.setFooterContent=function(t){return this.modalBoxFooter.innerHTML=t,this},t.prototype.getFooterContent=function(){return this.modalBoxFooter},t.prototype.setStickyFooter=function(t){return this.isOverflow()||(t=!1),t?this.modalBox.contains(this.modalBoxFooter)&&(this.modalBox.removeChild(this.modalBoxFooter),this.modal.appendChild(this.modalBoxFooter),this.modalBoxFooter.classList.add(\"tingle-modal-box__footer--sticky\"),e.call(this),this.modalBoxContent.style[\"padding-bottom\"]=this.modalBoxFooter.clientHeight+20+\"px\"):this.modalBoxFooter&&(this.modalBox.contains(this.modalBoxFooter)||(this.modal.removeChild(this.modalBoxFooter),this.modalBox.appendChild(this.modalBoxFooter),this.modalBoxFooter.style.width=\"auto\",this.modalBoxFooter.style.left=\"\",this.modalBoxContent.style[\"padding-bottom\"]=\"\",this.modalBoxFooter.classList.remove(\"tingle-modal-box__footer--sticky\"))),this},t.prototype.addFooterBtn=function(t,o,e){var s=document.createElement(\"button\");return s.innerHTML=t,s.addEventListener(\"click\",e),\"string\"==typeof o&&o.length&&o.split(\" \").forEach(function(t){s.classList.add(t)}),this.modalBoxFooter.appendChild(s),s},t.prototype.resize=function(){console.warn(\"Resize is deprecated and will be removed in version 1.0\")},t.prototype.isOverflow=function(){return window.innerHeight<=this.modalBox.clientHeight},t.prototype.checkOverflow=function(){this.modal.classList.contains(\"tingle-modal--visible\")&&(this.isOverflow()?this.modal.classList.add(\"tingle-modal--overflow\"):this.modal.classList.remove(\"tingle-modal--overflow\"),!this.isOverflow()&&this.opts.stickyFooter?this.setStickyFooter(!1):this.isOverflow()&&this.opts.stickyFooter&&(e.call(this),this.setStickyFooter(!0)))},{modal:t}});","import { g as getDocument } from '../shared/ssr-window.esm.mjs';\nimport { c as classesToSelector } from '../shared/classes-to-selector.mjs';\nimport { c as createElement, h as elementIndex, m as makeElementsArray } from '../shared/utils.mjs';\n\nfunction A11y(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    a11y: {\n      enabled: true,\n      notificationClass: 'swiper-notification',\n      prevSlideMessage: 'Previous slide',\n      nextSlideMessage: 'Next slide',\n      firstSlideMessage: 'This is the first slide',\n      lastSlideMessage: 'This is the last slide',\n      paginationBulletMessage: 'Go to slide {{index}}',\n      slideLabelMessage: '{{index}} / {{slidesLength}}',\n      containerMessage: null,\n      containerRoleDescriptionMessage: null,\n      containerRole: null,\n      itemRoleDescriptionMessage: null,\n      slideRole: 'group',\n      id: null,\n      scrollOnFocus: true\n    }\n  });\n  swiper.a11y = {\n    clicked: false\n  };\n  let liveRegion = null;\n  let preventFocusHandler;\n  let focusTargetSlideEl;\n  let visibilityChangedTimestamp = new Date().getTime();\n  function notify(message) {\n    const notification = liveRegion;\n    if (notification.length === 0) return;\n    notification.innerHTML = '';\n    notification.innerHTML = message;\n  }\n  function getRandomNumber(size) {\n    if (size === void 0) {\n      size = 16;\n    }\n    const randomChar = () => Math.round(16 * Math.random()).toString(16);\n    return 'x'.repeat(size).replace(/x/g, randomChar);\n  }\n  function makeElFocusable(el) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('tabIndex', '0');\n    });\n  }\n  function makeElNotFocusable(el) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('tabIndex', '-1');\n    });\n  }\n  function addElRole(el, role) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('role', role);\n    });\n  }\n  function addElRoleDescription(el, description) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('aria-roledescription', description);\n    });\n  }\n  function addElControls(el, controls) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('aria-controls', controls);\n    });\n  }\n  function addElLabel(el, label) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('aria-label', label);\n    });\n  }\n  function addElId(el, id) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('id', id);\n    });\n  }\n  function addElLive(el, live) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('aria-live', live);\n    });\n  }\n  function disableEl(el) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('aria-disabled', true);\n    });\n  }\n  function enableEl(el) {\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.setAttribute('aria-disabled', false);\n    });\n  }\n  function onEnterOrSpaceKey(e) {\n    if (e.keyCode !== 13 && e.keyCode !== 32) return;\n    const params = swiper.params.a11y;\n    const targetEl = e.target;\n    if (swiper.pagination && swiper.pagination.el && (targetEl === swiper.pagination.el || swiper.pagination.el.contains(e.target))) {\n      if (!e.target.matches(classesToSelector(swiper.params.pagination.bulletClass))) return;\n    }\n    if (swiper.navigation && swiper.navigation.prevEl && swiper.navigation.nextEl) {\n      const prevEls = makeElementsArray(swiper.navigation.prevEl);\n      const nextEls = makeElementsArray(swiper.navigation.nextEl);\n      if (nextEls.includes(targetEl)) {\n        if (!(swiper.isEnd && !swiper.params.loop)) {\n          swiper.slideNext();\n        }\n        if (swiper.isEnd) {\n          notify(params.lastSlideMessage);\n        } else {\n          notify(params.nextSlideMessage);\n        }\n      }\n      if (prevEls.includes(targetEl)) {\n        if (!(swiper.isBeginning && !swiper.params.loop)) {\n          swiper.slidePrev();\n        }\n        if (swiper.isBeginning) {\n          notify(params.firstSlideMessage);\n        } else {\n          notify(params.prevSlideMessage);\n        }\n      }\n    }\n    if (swiper.pagination && targetEl.matches(classesToSelector(swiper.params.pagination.bulletClass))) {\n      targetEl.click();\n    }\n  }\n  function updateNavigation() {\n    if (swiper.params.loop || swiper.params.rewind || !swiper.navigation) return;\n    const {\n      nextEl,\n      prevEl\n    } = swiper.navigation;\n    if (prevEl) {\n      if (swiper.isBeginning) {\n        disableEl(prevEl);\n        makeElNotFocusable(prevEl);\n      } else {\n        enableEl(prevEl);\n        makeElFocusable(prevEl);\n      }\n    }\n    if (nextEl) {\n      if (swiper.isEnd) {\n        disableEl(nextEl);\n        makeElNotFocusable(nextEl);\n      } else {\n        enableEl(nextEl);\n        makeElFocusable(nextEl);\n      }\n    }\n  }\n  function hasPagination() {\n    return swiper.pagination && swiper.pagination.bullets && swiper.pagination.bullets.length;\n  }\n  function hasClickablePagination() {\n    return hasPagination() && swiper.params.pagination.clickable;\n  }\n  function updatePagination() {\n    const params = swiper.params.a11y;\n    if (!hasPagination()) return;\n    swiper.pagination.bullets.forEach(bulletEl => {\n      if (swiper.params.pagination.clickable) {\n        makeElFocusable(bulletEl);\n        if (!swiper.params.pagination.renderBullet) {\n          addElRole(bulletEl, 'button');\n          addElLabel(bulletEl, params.paginationBulletMessage.replace(/\\{\\{index\\}\\}/, elementIndex(bulletEl) + 1));\n        }\n      }\n      if (bulletEl.matches(classesToSelector(swiper.params.pagination.bulletActiveClass))) {\n        bulletEl.setAttribute('aria-current', 'true');\n      } else {\n        bulletEl.removeAttribute('aria-current');\n      }\n    });\n  }\n  const initNavEl = (el, wrapperId, message) => {\n    makeElFocusable(el);\n    if (el.tagName !== 'BUTTON') {\n      addElRole(el, 'button');\n      el.addEventListener('keydown', onEnterOrSpaceKey);\n    }\n    addElLabel(el, message);\n    addElControls(el, wrapperId);\n  };\n  const handlePointerDown = e => {\n    if (focusTargetSlideEl && focusTargetSlideEl !== e.target && !focusTargetSlideEl.contains(e.target)) {\n      preventFocusHandler = true;\n    }\n    swiper.a11y.clicked = true;\n  };\n  const handlePointerUp = () => {\n    preventFocusHandler = false;\n    requestAnimationFrame(() => {\n      requestAnimationFrame(() => {\n        if (!swiper.destroyed) {\n          swiper.a11y.clicked = false;\n        }\n      });\n    });\n  };\n  const onVisibilityChange = e => {\n    visibilityChangedTimestamp = new Date().getTime();\n  };\n  const handleFocus = e => {\n    if (swiper.a11y.clicked || !swiper.params.a11y.scrollOnFocus) return;\n    if (new Date().getTime() - visibilityChangedTimestamp < 100) return;\n    const slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);\n    if (!slideEl || !swiper.slides.includes(slideEl)) return;\n    focusTargetSlideEl = slideEl;\n    const isActive = swiper.slides.indexOf(slideEl) === swiper.activeIndex;\n    const isVisible = swiper.params.watchSlidesProgress && swiper.visibleSlides && swiper.visibleSlides.includes(slideEl);\n    if (isActive || isVisible) return;\n    if (e.sourceCapabilities && e.sourceCapabilities.firesTouchEvents) return;\n    if (swiper.isHorizontal()) {\n      swiper.el.scrollLeft = 0;\n    } else {\n      swiper.el.scrollTop = 0;\n    }\n    requestAnimationFrame(() => {\n      if (preventFocusHandler) return;\n      if (swiper.params.loop) {\n        swiper.slideToLoop(parseInt(slideEl.getAttribute('data-swiper-slide-index')), 0);\n      } else {\n        swiper.slideTo(swiper.slides.indexOf(slideEl), 0);\n      }\n      preventFocusHandler = false;\n    });\n  };\n  const initSlides = () => {\n    const params = swiper.params.a11y;\n    if (params.itemRoleDescriptionMessage) {\n      addElRoleDescription(swiper.slides, params.itemRoleDescriptionMessage);\n    }\n    if (params.slideRole) {\n      addElRole(swiper.slides, params.slideRole);\n    }\n    const slidesLength = swiper.slides.length;\n    if (params.slideLabelMessage) {\n      swiper.slides.forEach((slideEl, index) => {\n        const slideIndex = swiper.params.loop ? parseInt(slideEl.getAttribute('data-swiper-slide-index'), 10) : index;\n        const ariaLabelMessage = params.slideLabelMessage.replace(/\\{\\{index\\}\\}/, slideIndex + 1).replace(/\\{\\{slidesLength\\}\\}/, slidesLength);\n        addElLabel(slideEl, ariaLabelMessage);\n      });\n    }\n  };\n  const init = () => {\n    const params = swiper.params.a11y;\n    swiper.el.append(liveRegion);\n\n    // Container\n    const containerEl = swiper.el;\n    if (params.containerRoleDescriptionMessage) {\n      addElRoleDescription(containerEl, params.containerRoleDescriptionMessage);\n    }\n    if (params.containerMessage) {\n      addElLabel(containerEl, params.containerMessage);\n    }\n    if (params.containerRole) {\n      addElRole(containerEl, params.containerRole);\n    }\n\n    // Wrapper\n    const wrapperEl = swiper.wrapperEl;\n    const wrapperId = params.id || wrapperEl.getAttribute('id') || `swiper-wrapper-${getRandomNumber(16)}`;\n    const live = swiper.params.autoplay && swiper.params.autoplay.enabled ? 'off' : 'polite';\n    addElId(wrapperEl, wrapperId);\n    addElLive(wrapperEl, live);\n\n    // Slide\n    initSlides();\n\n    // Navigation\n    let {\n      nextEl,\n      prevEl\n    } = swiper.navigation ? swiper.navigation : {};\n    nextEl = makeElementsArray(nextEl);\n    prevEl = makeElementsArray(prevEl);\n    if (nextEl) {\n      nextEl.forEach(el => initNavEl(el, wrapperId, params.nextSlideMessage));\n    }\n    if (prevEl) {\n      prevEl.forEach(el => initNavEl(el, wrapperId, params.prevSlideMessage));\n    }\n\n    // Pagination\n    if (hasClickablePagination()) {\n      const paginationEl = makeElementsArray(swiper.pagination.el);\n      paginationEl.forEach(el => {\n        el.addEventListener('keydown', onEnterOrSpaceKey);\n      });\n    }\n\n    // Tab focus\n    const document = getDocument();\n    document.addEventListener('visibilitychange', onVisibilityChange);\n    swiper.el.addEventListener('focus', handleFocus, true);\n    swiper.el.addEventListener('focus', handleFocus, true);\n    swiper.el.addEventListener('pointerdown', handlePointerDown, true);\n    swiper.el.addEventListener('pointerup', handlePointerUp, true);\n  };\n  function destroy() {\n    if (liveRegion) liveRegion.remove();\n    let {\n      nextEl,\n      prevEl\n    } = swiper.navigation ? swiper.navigation : {};\n    nextEl = makeElementsArray(nextEl);\n    prevEl = makeElementsArray(prevEl);\n    if (nextEl) {\n      nextEl.forEach(el => el.removeEventListener('keydown', onEnterOrSpaceKey));\n    }\n    if (prevEl) {\n      prevEl.forEach(el => el.removeEventListener('keydown', onEnterOrSpaceKey));\n    }\n\n    // Pagination\n    if (hasClickablePagination()) {\n      const paginationEl = makeElementsArray(swiper.pagination.el);\n      paginationEl.forEach(el => {\n        el.removeEventListener('keydown', onEnterOrSpaceKey);\n      });\n    }\n    const document = getDocument();\n    document.removeEventListener('visibilitychange', onVisibilityChange);\n    // Tab focus\n    if (swiper.el && typeof swiper.el !== 'string') {\n      swiper.el.removeEventListener('focus', handleFocus, true);\n      swiper.el.removeEventListener('pointerdown', handlePointerDown, true);\n      swiper.el.removeEventListener('pointerup', handlePointerUp, true);\n    }\n  }\n  on('beforeInit', () => {\n    liveRegion = createElement('span', swiper.params.a11y.notificationClass);\n    liveRegion.setAttribute('aria-live', 'assertive');\n    liveRegion.setAttribute('aria-atomic', 'true');\n  });\n  on('afterInit', () => {\n    if (!swiper.params.a11y.enabled) return;\n    init();\n  });\n  on('slidesLengthChange snapGridLengthChange slidesGridLengthChange', () => {\n    if (!swiper.params.a11y.enabled) return;\n    initSlides();\n  });\n  on('fromEdge toEdge afterInit lock unlock', () => {\n    if (!swiper.params.a11y.enabled) return;\n    updateNavigation();\n  });\n  on('paginationUpdate', () => {\n    if (!swiper.params.a11y.enabled) return;\n    updatePagination();\n  });\n  on('destroy', () => {\n    if (!swiper.params.a11y.enabled) return;\n    destroy();\n  });\n}\n\nexport { A11y as default };\n","import { g as getDocument } from '../shared/ssr-window.esm.mjs';\n\n/* eslint no-underscore-dangle: \"off\" */\n/* eslint no-use-before-define: \"off\" */\nfunction Autoplay(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on,\n    emit,\n    params\n  } = _ref;\n  swiper.autoplay = {\n    running: false,\n    paused: false,\n    timeLeft: 0\n  };\n  extendParams({\n    autoplay: {\n      enabled: false,\n      delay: 3000,\n      waitForTransition: true,\n      disableOnInteraction: false,\n      stopOnLastSlide: false,\n      reverseDirection: false,\n      pauseOnMouseEnter: false\n    }\n  });\n  let timeout;\n  let raf;\n  let autoplayDelayTotal = params && params.autoplay ? params.autoplay.delay : 3000;\n  let autoplayDelayCurrent = params && params.autoplay ? params.autoplay.delay : 3000;\n  let autoplayTimeLeft;\n  let autoplayStartTime = new Date().getTime();\n  let wasPaused;\n  let isTouched;\n  let pausedByTouch;\n  let touchStartTimeout;\n  let slideChanged;\n  let pausedByInteraction;\n  let pausedByPointerEnter;\n  function onTransitionEnd(e) {\n    if (!swiper || swiper.destroyed || !swiper.wrapperEl) return;\n    if (e.target !== swiper.wrapperEl) return;\n    swiper.wrapperEl.removeEventListener('transitionend', onTransitionEnd);\n    if (pausedByPointerEnter || e.detail && e.detail.bySwiperTouchMove) {\n      return;\n    }\n    resume();\n  }\n  const calcTimeLeft = () => {\n    if (swiper.destroyed || !swiper.autoplay.running) return;\n    if (swiper.autoplay.paused) {\n      wasPaused = true;\n    } else if (wasPaused) {\n      autoplayDelayCurrent = autoplayTimeLeft;\n      wasPaused = false;\n    }\n    const timeLeft = swiper.autoplay.paused ? autoplayTimeLeft : autoplayStartTime + autoplayDelayCurrent - new Date().getTime();\n    swiper.autoplay.timeLeft = timeLeft;\n    emit('autoplayTimeLeft', timeLeft, timeLeft / autoplayDelayTotal);\n    raf = requestAnimationFrame(() => {\n      calcTimeLeft();\n    });\n  };\n  const getSlideDelay = () => {\n    let activeSlideEl;\n    if (swiper.virtual && swiper.params.virtual.enabled) {\n      activeSlideEl = swiper.slides.find(slideEl => slideEl.classList.contains('swiper-slide-active'));\n    } else {\n      activeSlideEl = swiper.slides[swiper.activeIndex];\n    }\n    if (!activeSlideEl) return undefined;\n    const currentSlideDelay = parseInt(activeSlideEl.getAttribute('data-swiper-autoplay'), 10);\n    return currentSlideDelay;\n  };\n  const run = delayForce => {\n    if (swiper.destroyed || !swiper.autoplay.running) return;\n    cancelAnimationFrame(raf);\n    calcTimeLeft();\n    let delay = typeof delayForce === 'undefined' ? swiper.params.autoplay.delay : delayForce;\n    autoplayDelayTotal = swiper.params.autoplay.delay;\n    autoplayDelayCurrent = swiper.params.autoplay.delay;\n    const currentSlideDelay = getSlideDelay();\n    if (!Number.isNaN(currentSlideDelay) && currentSlideDelay > 0 && typeof delayForce === 'undefined') {\n      delay = currentSlideDelay;\n      autoplayDelayTotal = currentSlideDelay;\n      autoplayDelayCurrent = currentSlideDelay;\n    }\n    autoplayTimeLeft = delay;\n    const speed = swiper.params.speed;\n    const proceed = () => {\n      if (!swiper || swiper.destroyed) return;\n      if (swiper.params.autoplay.reverseDirection) {\n        if (!swiper.isBeginning || swiper.params.loop || swiper.params.rewind) {\n          swiper.slidePrev(speed, true, true);\n          emit('autoplay');\n        } else if (!swiper.params.autoplay.stopOnLastSlide) {\n          swiper.slideTo(swiper.slides.length - 1, speed, true, true);\n          emit('autoplay');\n        }\n      } else {\n        if (!swiper.isEnd || swiper.params.loop || swiper.params.rewind) {\n          swiper.slideNext(speed, true, true);\n          emit('autoplay');\n        } else if (!swiper.params.autoplay.stopOnLastSlide) {\n          swiper.slideTo(0, speed, true, true);\n          emit('autoplay');\n        }\n      }\n      if (swiper.params.cssMode) {\n        autoplayStartTime = new Date().getTime();\n        requestAnimationFrame(() => {\n          run();\n        });\n      }\n    };\n    if (delay > 0) {\n      clearTimeout(timeout);\n      timeout = setTimeout(() => {\n        proceed();\n      }, delay);\n    } else {\n      requestAnimationFrame(() => {\n        proceed();\n      });\n    }\n\n    // eslint-disable-next-line\n    return delay;\n  };\n  const start = () => {\n    autoplayStartTime = new Date().getTime();\n    swiper.autoplay.running = true;\n    run();\n    emit('autoplayStart');\n  };\n  const stop = () => {\n    swiper.autoplay.running = false;\n    clearTimeout(timeout);\n    cancelAnimationFrame(raf);\n    emit('autoplayStop');\n  };\n  const pause = (internal, reset) => {\n    if (swiper.destroyed || !swiper.autoplay.running) return;\n    clearTimeout(timeout);\n    if (!internal) {\n      pausedByInteraction = true;\n    }\n    const proceed = () => {\n      emit('autoplayPause');\n      if (swiper.params.autoplay.waitForTransition) {\n        swiper.wrapperEl.addEventListener('transitionend', onTransitionEnd);\n      } else {\n        resume();\n      }\n    };\n    swiper.autoplay.paused = true;\n    if (reset) {\n      if (slideChanged) {\n        autoplayTimeLeft = swiper.params.autoplay.delay;\n      }\n      slideChanged = false;\n      proceed();\n      return;\n    }\n    const delay = autoplayTimeLeft || swiper.params.autoplay.delay;\n    autoplayTimeLeft = delay - (new Date().getTime() - autoplayStartTime);\n    if (swiper.isEnd && autoplayTimeLeft < 0 && !swiper.params.loop) return;\n    if (autoplayTimeLeft < 0) autoplayTimeLeft = 0;\n    proceed();\n  };\n  const resume = () => {\n    if (swiper.isEnd && autoplayTimeLeft < 0 && !swiper.params.loop || swiper.destroyed || !swiper.autoplay.running) return;\n    autoplayStartTime = new Date().getTime();\n    if (pausedByInteraction) {\n      pausedByInteraction = false;\n      run(autoplayTimeLeft);\n    } else {\n      run();\n    }\n    swiper.autoplay.paused = false;\n    emit('autoplayResume');\n  };\n  const onVisibilityChange = () => {\n    if (swiper.destroyed || !swiper.autoplay.running) return;\n    const document = getDocument();\n    if (document.visibilityState === 'hidden') {\n      pausedByInteraction = true;\n      pause(true);\n    }\n    if (document.visibilityState === 'visible') {\n      resume();\n    }\n  };\n  const onPointerEnter = e => {\n    if (e.pointerType !== 'mouse') return;\n    pausedByInteraction = true;\n    pausedByPointerEnter = true;\n    if (swiper.animating || swiper.autoplay.paused) return;\n    pause(true);\n  };\n  const onPointerLeave = e => {\n    if (e.pointerType !== 'mouse') return;\n    pausedByPointerEnter = false;\n    if (swiper.autoplay.paused) {\n      resume();\n    }\n  };\n  const attachMouseEvents = () => {\n    if (swiper.params.autoplay.pauseOnMouseEnter) {\n      swiper.el.addEventListener('pointerenter', onPointerEnter);\n      swiper.el.addEventListener('pointerleave', onPointerLeave);\n    }\n  };\n  const detachMouseEvents = () => {\n    if (swiper.el && typeof swiper.el !== 'string') {\n      swiper.el.removeEventListener('pointerenter', onPointerEnter);\n      swiper.el.removeEventListener('pointerleave', onPointerLeave);\n    }\n  };\n  const attachDocumentEvents = () => {\n    const document = getDocument();\n    document.addEventListener('visibilitychange', onVisibilityChange);\n  };\n  const detachDocumentEvents = () => {\n    const document = getDocument();\n    document.removeEventListener('visibilitychange', onVisibilityChange);\n  };\n  on('init', () => {\n    if (swiper.params.autoplay.enabled) {\n      attachMouseEvents();\n      attachDocumentEvents();\n      start();\n    }\n  });\n  on('destroy', () => {\n    detachMouseEvents();\n    detachDocumentEvents();\n    if (swiper.autoplay.running) {\n      stop();\n    }\n  });\n  on('_freeModeStaticRelease', () => {\n    if (pausedByTouch || pausedByInteraction) {\n      resume();\n    }\n  });\n  on('_freeModeNoMomentumRelease', () => {\n    if (!swiper.params.autoplay.disableOnInteraction) {\n      pause(true, true);\n    } else {\n      stop();\n    }\n  });\n  on('beforeTransitionStart', (_s, speed, internal) => {\n    if (swiper.destroyed || !swiper.autoplay.running) return;\n    if (internal || !swiper.params.autoplay.disableOnInteraction) {\n      pause(true, true);\n    } else {\n      stop();\n    }\n  });\n  on('sliderFirstMove', () => {\n    if (swiper.destroyed || !swiper.autoplay.running) return;\n    if (swiper.params.autoplay.disableOnInteraction) {\n      stop();\n      return;\n    }\n    isTouched = true;\n    pausedByTouch = false;\n    pausedByInteraction = false;\n    touchStartTimeout = setTimeout(() => {\n      pausedByInteraction = true;\n      pausedByTouch = true;\n      pause(true);\n    }, 200);\n  });\n  on('touchEnd', () => {\n    if (swiper.destroyed || !swiper.autoplay.running || !isTouched) return;\n    clearTimeout(touchStartTimeout);\n    clearTimeout(timeout);\n    if (swiper.params.autoplay.disableOnInteraction) {\n      pausedByTouch = false;\n      isTouched = false;\n      return;\n    }\n    if (pausedByTouch && swiper.params.cssMode) resume();\n    pausedByTouch = false;\n    isTouched = false;\n  });\n  on('slideChange', () => {\n    if (swiper.destroyed || !swiper.autoplay.running) return;\n    slideChanged = true;\n  });\n  Object.assign(swiper.autoplay, {\n    start,\n    stop,\n    pause,\n    resume\n  });\n}\n\nexport { Autoplay as default };\n","import { n as nextTick, k as elementTransitionEnd } from '../shared/utils.mjs';\n\n/* eslint no-bitwise: [\"error\", { \"allow\": [\">>\"] }] */\nfunction Controller(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    controller: {\n      control: undefined,\n      inverse: false,\n      by: 'slide' // or 'container'\n    }\n  });\n\n  swiper.controller = {\n    control: undefined\n  };\n  function LinearSpline(x, y) {\n    const binarySearch = function search() {\n      let maxIndex;\n      let minIndex;\n      let guess;\n      return (array, val) => {\n        minIndex = -1;\n        maxIndex = array.length;\n        while (maxIndex - minIndex > 1) {\n          guess = maxIndex + minIndex >> 1;\n          if (array[guess] <= val) {\n            minIndex = guess;\n          } else {\n            maxIndex = guess;\n          }\n        }\n        return maxIndex;\n      };\n    }();\n    this.x = x;\n    this.y = y;\n    this.lastIndex = x.length - 1;\n    // Given an x value (x2), return the expected y2 value:\n    // (x1,y1) is the known point before given value,\n    // (x3,y3) is the known point after given value.\n    let i1;\n    let i3;\n    this.interpolate = function interpolate(x2) {\n      if (!x2) return 0;\n\n      // Get the indexes of x1 and x3 (the array indexes before and after given x2):\n      i3 = binarySearch(this.x, x2);\n      i1 = i3 - 1;\n\n      // We have our indexes i1 & i3, so we can calculate already:\n      // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1\n      return (x2 - this.x[i1]) * (this.y[i3] - this.y[i1]) / (this.x[i3] - this.x[i1]) + this.y[i1];\n    };\n    return this;\n  }\n  function getInterpolateFunction(c) {\n    swiper.controller.spline = swiper.params.loop ? new LinearSpline(swiper.slidesGrid, c.slidesGrid) : new LinearSpline(swiper.snapGrid, c.snapGrid);\n  }\n  function setTranslate(_t, byController) {\n    const controlled = swiper.controller.control;\n    let multiplier;\n    let controlledTranslate;\n    const Swiper = swiper.constructor;\n    function setControlledTranslate(c) {\n      if (c.destroyed) return;\n\n      // this will create an Interpolate function based on the snapGrids\n      // x is the Grid of the scrolled scroller and y will be the controlled scroller\n      // it makes sense to create this only once and recall it for the interpolation\n      // the function does a lot of value caching for performance\n      const translate = swiper.rtlTranslate ? -swiper.translate : swiper.translate;\n      if (swiper.params.controller.by === 'slide') {\n        getInterpolateFunction(c);\n        // i am not sure why the values have to be multiplicated this way, tried to invert the snapGrid\n        // but it did not work out\n        controlledTranslate = -swiper.controller.spline.interpolate(-translate);\n      }\n      if (!controlledTranslate || swiper.params.controller.by === 'container') {\n        multiplier = (c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());\n        if (Number.isNaN(multiplier) || !Number.isFinite(multiplier)) {\n          multiplier = 1;\n        }\n        controlledTranslate = (translate - swiper.minTranslate()) * multiplier + c.minTranslate();\n      }\n      if (swiper.params.controller.inverse) {\n        controlledTranslate = c.maxTranslate() - controlledTranslate;\n      }\n      c.updateProgress(controlledTranslate);\n      c.setTranslate(controlledTranslate, swiper);\n      c.updateActiveIndex();\n      c.updateSlidesClasses();\n    }\n    if (Array.isArray(controlled)) {\n      for (let i = 0; i < controlled.length; i += 1) {\n        if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n          setControlledTranslate(controlled[i]);\n        }\n      }\n    } else if (controlled instanceof Swiper && byController !== controlled) {\n      setControlledTranslate(controlled);\n    }\n  }\n  function setTransition(duration, byController) {\n    const Swiper = swiper.constructor;\n    const controlled = swiper.controller.control;\n    let i;\n    function setControlledTransition(c) {\n      if (c.destroyed) return;\n      c.setTransition(duration, swiper);\n      if (duration !== 0) {\n        c.transitionStart();\n        if (c.params.autoHeight) {\n          nextTick(() => {\n            c.updateAutoHeight();\n          });\n        }\n        elementTransitionEnd(c.wrapperEl, () => {\n          if (!controlled) return;\n          c.transitionEnd();\n        });\n      }\n    }\n    if (Array.isArray(controlled)) {\n      for (i = 0; i < controlled.length; i += 1) {\n        if (controlled[i] !== byController && controlled[i] instanceof Swiper) {\n          setControlledTransition(controlled[i]);\n        }\n      }\n    } else if (controlled instanceof Swiper && byController !== controlled) {\n      setControlledTransition(controlled);\n    }\n  }\n  function removeSpline() {\n    if (!swiper.controller.control) return;\n    if (swiper.controller.spline) {\n      swiper.controller.spline = undefined;\n      delete swiper.controller.spline;\n    }\n  }\n  on('beforeInit', () => {\n    if (typeof window !== 'undefined' && (\n    // eslint-disable-line\n    typeof swiper.params.controller.control === 'string' || swiper.params.controller.control instanceof HTMLElement)) {\n      const controlElements = typeof swiper.params.controller.control === 'string' ? [...document.querySelectorAll(swiper.params.controller.control)] : [swiper.params.controller.control];\n      controlElements.forEach(controlElement => {\n        if (!swiper.controller.control) swiper.controller.control = [];\n        if (controlElement && controlElement.swiper) {\n          swiper.controller.control.push(controlElement.swiper);\n        } else if (controlElement) {\n          const eventName = `${swiper.params.eventsPrefix}init`;\n          const onControllerSwiper = e => {\n            swiper.controller.control.push(e.detail[0]);\n            swiper.update();\n            controlElement.removeEventListener(eventName, onControllerSwiper);\n          };\n          controlElement.addEventListener(eventName, onControllerSwiper);\n        }\n      });\n      return;\n    }\n    swiper.controller.control = swiper.params.controller.control;\n  });\n  on('update', () => {\n    removeSpline();\n  });\n  on('resize', () => {\n    removeSpline();\n  });\n  on('observerUpdate', () => {\n    removeSpline();\n  });\n  on('setTranslate', (_s, translate, byController) => {\n    if (!swiper.controller.control || swiper.controller.control.destroyed) return;\n    swiper.controller.setTranslate(translate, byController);\n  });\n  on('setTransition', (_s, duration, byController) => {\n    if (!swiper.controller.control || swiper.controller.control.destroyed) return;\n    swiper.controller.setTransition(duration, byController);\n  });\n  Object.assign(swiper.controller, {\n    setTranslate,\n    setTransition\n  });\n}\n\nexport { Controller as default };\n","import { c as createShadow } from '../shared/create-shadow.mjs';\nimport { e as effectInit } from '../shared/effect-init.mjs';\nimport { e as effectTarget } from '../shared/effect-target.mjs';\nimport { e as effectVirtualTransitionEnd } from '../shared/effect-virtual-transition-end.mjs';\nimport { g as getSlideTransformEl } from '../shared/utils.mjs';\n\nfunction EffectCards(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    cardsEffect: {\n      slideShadows: true,\n      rotate: true,\n      perSlideRotate: 2,\n      perSlideOffset: 8\n    }\n  });\n  const setTranslate = () => {\n    const {\n      slides,\n      activeIndex,\n      rtlTranslate: rtl\n    } = swiper;\n    const params = swiper.params.cardsEffect;\n    const {\n      startTranslate,\n      isTouched\n    } = swiper.touchEventsData;\n    const currentTranslate = rtl ? -swiper.translate : swiper.translate;\n    for (let i = 0; i < slides.length; i += 1) {\n      const slideEl = slides[i];\n      const slideProgress = slideEl.progress;\n      const progress = Math.min(Math.max(slideProgress, -4), 4);\n      let offset = slideEl.swiperSlideOffset;\n      if (swiper.params.centeredSlides && !swiper.params.cssMode) {\n        swiper.wrapperEl.style.transform = `translateX(${swiper.minTranslate()}px)`;\n      }\n      if (swiper.params.centeredSlides && swiper.params.cssMode) {\n        offset -= slides[0].swiperSlideOffset;\n      }\n      let tX = swiper.params.cssMode ? -offset - swiper.translate : -offset;\n      let tY = 0;\n      const tZ = -100 * Math.abs(progress);\n      let scale = 1;\n      let rotate = -params.perSlideRotate * progress;\n      let tXAdd = params.perSlideOffset - Math.abs(progress) * 0.75;\n      const slideIndex = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.from + i : i;\n      const isSwipeToNext = (slideIndex === activeIndex || slideIndex === activeIndex - 1) && progress > 0 && progress < 1 && (isTouched || swiper.params.cssMode) && currentTranslate < startTranslate;\n      const isSwipeToPrev = (slideIndex === activeIndex || slideIndex === activeIndex + 1) && progress < 0 && progress > -1 && (isTouched || swiper.params.cssMode) && currentTranslate > startTranslate;\n      if (isSwipeToNext || isSwipeToPrev) {\n        const subProgress = (1 - Math.abs((Math.abs(progress) - 0.5) / 0.5)) ** 0.5;\n        rotate += -28 * progress * subProgress;\n        scale += -0.5 * subProgress;\n        tXAdd += 96 * subProgress;\n        tY = `${-25 * subProgress * Math.abs(progress)}%`;\n      }\n      if (progress < 0) {\n        // next\n        tX = `calc(${tX}px ${rtl ? '-' : '+'} (${tXAdd * Math.abs(progress)}%))`;\n      } else if (progress > 0) {\n        // prev\n        tX = `calc(${tX}px ${rtl ? '-' : '+'} (-${tXAdd * Math.abs(progress)}%))`;\n      } else {\n        tX = `${tX}px`;\n      }\n      if (!swiper.isHorizontal()) {\n        const prevY = tY;\n        tY = tX;\n        tX = prevY;\n      }\n      const scaleString = progress < 0 ? `${1 + (1 - scale) * progress}` : `${1 - (1 - scale) * progress}`;\n\n      /* eslint-disable */\n      const transform = `\n        translate3d(${tX}, ${tY}, ${tZ}px)\n        rotateZ(${params.rotate ? rtl ? -rotate : rotate : 0}deg)\n        scale(${scaleString})\n      `;\n      /* eslint-enable */\n\n      if (params.slideShadows) {\n        // Set shadows\n        let shadowEl = slideEl.querySelector('.swiper-slide-shadow');\n        if (!shadowEl) {\n          shadowEl = createShadow('cards', slideEl);\n        }\n        if (shadowEl) shadowEl.style.opacity = Math.min(Math.max((Math.abs(progress) - 0.5) / 0.5, 0), 1);\n      }\n      slideEl.style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n      const targetEl = effectTarget(params, slideEl);\n      targetEl.style.transform = transform;\n    }\n  };\n  const setTransition = duration => {\n    const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n    transformElements.forEach(el => {\n      el.style.transitionDuration = `${duration}ms`;\n      el.querySelectorAll('.swiper-slide-shadow').forEach(shadowEl => {\n        shadowEl.style.transitionDuration = `${duration}ms`;\n      });\n    });\n    effectVirtualTransitionEnd({\n      swiper,\n      duration,\n      transformElements\n    });\n  };\n  effectInit({\n    effect: 'cards',\n    swiper,\n    on,\n    setTranslate,\n    setTransition,\n    perspective: () => true,\n    overwriteParams: () => ({\n      _loopSwapReset: false,\n      watchSlidesProgress: true,\n      loopAdditionalSlides: 3,\n      centeredSlides: true,\n      virtualTranslate: !swiper.params.cssMode\n    })\n  });\n}\n\nexport { EffectCards as default };\n","import { c as createShadow } from '../shared/create-shadow.mjs';\nimport { e as effectInit } from '../shared/effect-init.mjs';\nimport { e as effectTarget } from '../shared/effect-target.mjs';\nimport { g as getSlideTransformEl, o as getRotateFix } from '../shared/utils.mjs';\n\nfunction EffectCoverflow(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    coverflowEffect: {\n      rotate: 50,\n      stretch: 0,\n      depth: 100,\n      scale: 1,\n      modifier: 1,\n      slideShadows: true\n    }\n  });\n  const setTranslate = () => {\n    const {\n      width: swiperWidth,\n      height: swiperHeight,\n      slides,\n      slidesSizesGrid\n    } = swiper;\n    const params = swiper.params.coverflowEffect;\n    const isHorizontal = swiper.isHorizontal();\n    const transform = swiper.translate;\n    const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;\n    const rotate = isHorizontal ? params.rotate : -params.rotate;\n    const translate = params.depth;\n    const r = getRotateFix(swiper);\n    // Each slide offset from center\n    for (let i = 0, length = slides.length; i < length; i += 1) {\n      const slideEl = slides[i];\n      const slideSize = slidesSizesGrid[i];\n      const slideOffset = slideEl.swiperSlideOffset;\n      const centerOffset = (center - slideOffset - slideSize / 2) / slideSize;\n      const offsetMultiplier = typeof params.modifier === 'function' ? params.modifier(centerOffset) : centerOffset * params.modifier;\n      let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;\n      let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier;\n      // var rotateZ = 0\n      let translateZ = -translate * Math.abs(offsetMultiplier);\n      let stretch = params.stretch;\n      // Allow percentage to make a relative stretch for responsive sliders\n      if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {\n        stretch = parseFloat(params.stretch) / 100 * slideSize;\n      }\n      let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;\n      let translateX = isHorizontal ? stretch * offsetMultiplier : 0;\n      let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier);\n\n      // Fix for ultra small values\n      if (Math.abs(translateX) < 0.001) translateX = 0;\n      if (Math.abs(translateY) < 0.001) translateY = 0;\n      if (Math.abs(translateZ) < 0.001) translateZ = 0;\n      if (Math.abs(rotateY) < 0.001) rotateY = 0;\n      if (Math.abs(rotateX) < 0.001) rotateX = 0;\n      if (Math.abs(scale) < 0.001) scale = 0;\n      const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px)  rotateX(${r(rotateX)}deg) rotateY(${r(rotateY)}deg) scale(${scale})`;\n      const targetEl = effectTarget(params, slideEl);\n      targetEl.style.transform = slideTransform;\n      slideEl.style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;\n      if (params.slideShadows) {\n        // Set shadows\n        let shadowBeforeEl = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-left') : slideEl.querySelector('.swiper-slide-shadow-top');\n        let shadowAfterEl = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-right') : slideEl.querySelector('.swiper-slide-shadow-bottom');\n        if (!shadowBeforeEl) {\n          shadowBeforeEl = createShadow('coverflow', slideEl, isHorizontal ? 'left' : 'top');\n        }\n        if (!shadowAfterEl) {\n          shadowAfterEl = createShadow('coverflow', slideEl, isHorizontal ? 'right' : 'bottom');\n        }\n        if (shadowBeforeEl) shadowBeforeEl.style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;\n        if (shadowAfterEl) shadowAfterEl.style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;\n      }\n    }\n  };\n  const setTransition = duration => {\n    const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n    transformElements.forEach(el => {\n      el.style.transitionDuration = `${duration}ms`;\n      el.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(shadowEl => {\n        shadowEl.style.transitionDuration = `${duration}ms`;\n      });\n    });\n  };\n  effectInit({\n    effect: 'coverflow',\n    swiper,\n    on,\n    setTranslate,\n    setTransition,\n    perspective: () => true,\n    overwriteParams: () => ({\n      watchSlidesProgress: true\n    })\n  });\n}\n\nexport { EffectCoverflow as default };\n","import { c as createShadow } from '../shared/create-shadow.mjs';\nimport { e as effectInit } from '../shared/effect-init.mjs';\nimport { e as effectTarget } from '../shared/effect-target.mjs';\nimport { e as effectVirtualTransitionEnd } from '../shared/effect-virtual-transition-end.mjs';\nimport { g as getSlideTransformEl, o as getRotateFix } from '../shared/utils.mjs';\n\nfunction EffectCreative(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    creativeEffect: {\n      limitProgress: 1,\n      shadowPerProgress: false,\n      progressMultiplier: 1,\n      perspective: true,\n      prev: {\n        translate: [0, 0, 0],\n        rotate: [0, 0, 0],\n        opacity: 1,\n        scale: 1\n      },\n      next: {\n        translate: [0, 0, 0],\n        rotate: [0, 0, 0],\n        opacity: 1,\n        scale: 1\n      }\n    }\n  });\n  const getTranslateValue = value => {\n    if (typeof value === 'string') return value;\n    return `${value}px`;\n  };\n  const setTranslate = () => {\n    const {\n      slides,\n      wrapperEl,\n      slidesSizesGrid\n    } = swiper;\n    const params = swiper.params.creativeEffect;\n    const {\n      progressMultiplier: multiplier\n    } = params;\n    const isCenteredSlides = swiper.params.centeredSlides;\n    const rotateFix = getRotateFix(swiper);\n    if (isCenteredSlides) {\n      const margin = slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore || 0;\n      wrapperEl.style.transform = `translateX(calc(50% - ${margin}px))`;\n    }\n    for (let i = 0; i < slides.length; i += 1) {\n      const slideEl = slides[i];\n      const slideProgress = slideEl.progress;\n      const progress = Math.min(Math.max(slideEl.progress, -params.limitProgress), params.limitProgress);\n      let originalProgress = progress;\n      if (!isCenteredSlides) {\n        originalProgress = Math.min(Math.max(slideEl.originalProgress, -params.limitProgress), params.limitProgress);\n      }\n      const offset = slideEl.swiperSlideOffset;\n      const t = [swiper.params.cssMode ? -offset - swiper.translate : -offset, 0, 0];\n      const r = [0, 0, 0];\n      let custom = false;\n      if (!swiper.isHorizontal()) {\n        t[1] = t[0];\n        t[0] = 0;\n      }\n      let data = {\n        translate: [0, 0, 0],\n        rotate: [0, 0, 0],\n        scale: 1,\n        opacity: 1\n      };\n      if (progress < 0) {\n        data = params.next;\n        custom = true;\n      } else if (progress > 0) {\n        data = params.prev;\n        custom = true;\n      }\n      // set translate\n      t.forEach((value, index) => {\n        t[index] = `calc(${value}px + (${getTranslateValue(data.translate[index])} * ${Math.abs(progress * multiplier)}))`;\n      });\n      // set rotates\n      r.forEach((value, index) => {\n        let val = data.rotate[index] * Math.abs(progress * multiplier);\n        r[index] = val;\n      });\n      slideEl.style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;\n      const translateString = t.join(', ');\n      const rotateString = `rotateX(${rotateFix(r[0])}deg) rotateY(${rotateFix(r[1])}deg) rotateZ(${rotateFix(r[2])}deg)`;\n      const scaleString = originalProgress < 0 ? `scale(${1 + (1 - data.scale) * originalProgress * multiplier})` : `scale(${1 - (1 - data.scale) * originalProgress * multiplier})`;\n      const opacityString = originalProgress < 0 ? 1 + (1 - data.opacity) * originalProgress * multiplier : 1 - (1 - data.opacity) * originalProgress * multiplier;\n      const transform = `translate3d(${translateString}) ${rotateString} ${scaleString}`;\n\n      // Set shadows\n      if (custom && data.shadow || !custom) {\n        let shadowEl = slideEl.querySelector('.swiper-slide-shadow');\n        if (!shadowEl && data.shadow) {\n          shadowEl = createShadow('creative', slideEl);\n        }\n        if (shadowEl) {\n          const shadowOpacity = params.shadowPerProgress ? progress * (1 / params.limitProgress) : progress;\n          shadowEl.style.opacity = Math.min(Math.max(Math.abs(shadowOpacity), 0), 1);\n        }\n      }\n      const targetEl = effectTarget(params, slideEl);\n      targetEl.style.transform = transform;\n      targetEl.style.opacity = opacityString;\n      if (data.origin) {\n        targetEl.style.transformOrigin = data.origin;\n      }\n    }\n  };\n  const setTransition = duration => {\n    const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n    transformElements.forEach(el => {\n      el.style.transitionDuration = `${duration}ms`;\n      el.querySelectorAll('.swiper-slide-shadow').forEach(shadowEl => {\n        shadowEl.style.transitionDuration = `${duration}ms`;\n      });\n    });\n    effectVirtualTransitionEnd({\n      swiper,\n      duration,\n      transformElements,\n      allSlides: true\n    });\n  };\n  effectInit({\n    effect: 'creative',\n    swiper,\n    on,\n    setTranslate,\n    setTransition,\n    perspective: () => swiper.params.creativeEffect.perspective,\n    overwriteParams: () => ({\n      watchSlidesProgress: true,\n      virtualTranslate: !swiper.params.cssMode\n    })\n  });\n}\n\nexport { EffectCreative as default };\n","import { e as effectInit } from '../shared/effect-init.mjs';\nimport { c as createElement, o as getRotateFix } from '../shared/utils.mjs';\n\nfunction EffectCube(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    cubeEffect: {\n      slideShadows: true,\n      shadow: true,\n      shadowOffset: 20,\n      shadowScale: 0.94\n    }\n  });\n  const createSlideShadows = (slideEl, progress, isHorizontal) => {\n    let shadowBefore = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-left') : slideEl.querySelector('.swiper-slide-shadow-top');\n    let shadowAfter = isHorizontal ? slideEl.querySelector('.swiper-slide-shadow-right') : slideEl.querySelector('.swiper-slide-shadow-bottom');\n    if (!shadowBefore) {\n      shadowBefore = createElement('div', `swiper-slide-shadow-cube swiper-slide-shadow-${isHorizontal ? 'left' : 'top'}`.split(' '));\n      slideEl.append(shadowBefore);\n    }\n    if (!shadowAfter) {\n      shadowAfter = createElement('div', `swiper-slide-shadow-cube swiper-slide-shadow-${isHorizontal ? 'right' : 'bottom'}`.split(' '));\n      slideEl.append(shadowAfter);\n    }\n    if (shadowBefore) shadowBefore.style.opacity = Math.max(-progress, 0);\n    if (shadowAfter) shadowAfter.style.opacity = Math.max(progress, 0);\n  };\n  const recreateShadows = () => {\n    // create new ones\n    const isHorizontal = swiper.isHorizontal();\n    swiper.slides.forEach(slideEl => {\n      const progress = Math.max(Math.min(slideEl.progress, 1), -1);\n      createSlideShadows(slideEl, progress, isHorizontal);\n    });\n  };\n  const setTranslate = () => {\n    const {\n      el,\n      wrapperEl,\n      slides,\n      width: swiperWidth,\n      height: swiperHeight,\n      rtlTranslate: rtl,\n      size: swiperSize,\n      browser\n    } = swiper;\n    const r = getRotateFix(swiper);\n    const params = swiper.params.cubeEffect;\n    const isHorizontal = swiper.isHorizontal();\n    const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n    let wrapperRotate = 0;\n    let cubeShadowEl;\n    if (params.shadow) {\n      if (isHorizontal) {\n        cubeShadowEl = swiper.wrapperEl.querySelector('.swiper-cube-shadow');\n        if (!cubeShadowEl) {\n          cubeShadowEl = createElement('div', 'swiper-cube-shadow');\n          swiper.wrapperEl.append(cubeShadowEl);\n        }\n        cubeShadowEl.style.height = `${swiperWidth}px`;\n      } else {\n        cubeShadowEl = el.querySelector('.swiper-cube-shadow');\n        if (!cubeShadowEl) {\n          cubeShadowEl = createElement('div', 'swiper-cube-shadow');\n          el.append(cubeShadowEl);\n        }\n      }\n    }\n    for (let i = 0; i < slides.length; i += 1) {\n      const slideEl = slides[i];\n      let slideIndex = i;\n      if (isVirtual) {\n        slideIndex = parseInt(slideEl.getAttribute('data-swiper-slide-index'), 10);\n      }\n      let slideAngle = slideIndex * 90;\n      let round = Math.floor(slideAngle / 360);\n      if (rtl) {\n        slideAngle = -slideAngle;\n        round = Math.floor(-slideAngle / 360);\n      }\n      const progress = Math.max(Math.min(slideEl.progress, 1), -1);\n      let tx = 0;\n      let ty = 0;\n      let tz = 0;\n      if (slideIndex % 4 === 0) {\n        tx = -round * 4 * swiperSize;\n        tz = 0;\n      } else if ((slideIndex - 1) % 4 === 0) {\n        tx = 0;\n        tz = -round * 4 * swiperSize;\n      } else if ((slideIndex - 2) % 4 === 0) {\n        tx = swiperSize + round * 4 * swiperSize;\n        tz = swiperSize;\n      } else if ((slideIndex - 3) % 4 === 0) {\n        tx = -swiperSize;\n        tz = 3 * swiperSize + swiperSize * 4 * round;\n      }\n      if (rtl) {\n        tx = -tx;\n      }\n      if (!isHorizontal) {\n        ty = tx;\n        tx = 0;\n      }\n      const transform = `rotateX(${r(isHorizontal ? 0 : -slideAngle)}deg) rotateY(${r(isHorizontal ? slideAngle : 0)}deg) translate3d(${tx}px, ${ty}px, ${tz}px)`;\n      if (progress <= 1 && progress > -1) {\n        wrapperRotate = slideIndex * 90 + progress * 90;\n        if (rtl) wrapperRotate = -slideIndex * 90 - progress * 90;\n      }\n      slideEl.style.transform = transform;\n      if (params.slideShadows) {\n        createSlideShadows(slideEl, progress, isHorizontal);\n      }\n    }\n    wrapperEl.style.transformOrigin = `50% 50% -${swiperSize / 2}px`;\n    wrapperEl.style['-webkit-transform-origin'] = `50% 50% -${swiperSize / 2}px`;\n    if (params.shadow) {\n      if (isHorizontal) {\n        cubeShadowEl.style.transform = `translate3d(0px, ${swiperWidth / 2 + params.shadowOffset}px, ${-swiperWidth / 2}px) rotateX(89.99deg) rotateZ(0deg) scale(${params.shadowScale})`;\n      } else {\n        const shadowAngle = Math.abs(wrapperRotate) - Math.floor(Math.abs(wrapperRotate) / 90) * 90;\n        const multiplier = 1.5 - (Math.sin(shadowAngle * 2 * Math.PI / 360) / 2 + Math.cos(shadowAngle * 2 * Math.PI / 360) / 2);\n        const scale1 = params.shadowScale;\n        const scale2 = params.shadowScale / multiplier;\n        const offset = params.shadowOffset;\n        cubeShadowEl.style.transform = `scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${swiperHeight / 2 + offset}px, ${-swiperHeight / 2 / scale2}px) rotateX(-89.99deg)`;\n      }\n    }\n    const zFactor = (browser.isSafari || browser.isWebView) && browser.needPerspectiveFix ? -swiperSize / 2 : 0;\n    wrapperEl.style.transform = `translate3d(0px,0,${zFactor}px) rotateX(${r(swiper.isHorizontal() ? 0 : wrapperRotate)}deg) rotateY(${r(swiper.isHorizontal() ? -wrapperRotate : 0)}deg)`;\n    wrapperEl.style.setProperty('--swiper-cube-translate-z', `${zFactor}px`);\n  };\n  const setTransition = duration => {\n    const {\n      el,\n      slides\n    } = swiper;\n    slides.forEach(slideEl => {\n      slideEl.style.transitionDuration = `${duration}ms`;\n      slideEl.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(subEl => {\n        subEl.style.transitionDuration = `${duration}ms`;\n      });\n    });\n    if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) {\n      const shadowEl = el.querySelector('.swiper-cube-shadow');\n      if (shadowEl) shadowEl.style.transitionDuration = `${duration}ms`;\n    }\n  };\n  effectInit({\n    effect: 'cube',\n    swiper,\n    on,\n    setTranslate,\n    setTransition,\n    recreateShadows,\n    getEffectParams: () => swiper.params.cubeEffect,\n    perspective: () => true,\n    overwriteParams: () => ({\n      slidesPerView: 1,\n      slidesPerGroup: 1,\n      watchSlidesProgress: true,\n      resistanceRatio: 0,\n      spaceBetween: 0,\n      centeredSlides: false,\n      virtualTranslate: true\n    })\n  });\n}\n\nexport { EffectCube as default };\n","import { e as effectInit } from '../shared/effect-init.mjs';\nimport { e as effectTarget } from '../shared/effect-target.mjs';\nimport { e as effectVirtualTransitionEnd } from '../shared/effect-virtual-transition-end.mjs';\nimport { g as getSlideTransformEl } from '../shared/utils.mjs';\n\nfunction EffectFade(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    fadeEffect: {\n      crossFade: false\n    }\n  });\n  const setTranslate = () => {\n    const {\n      slides\n    } = swiper;\n    const params = swiper.params.fadeEffect;\n    for (let i = 0; i < slides.length; i += 1) {\n      const slideEl = swiper.slides[i];\n      const offset = slideEl.swiperSlideOffset;\n      let tx = -offset;\n      if (!swiper.params.virtualTranslate) tx -= swiper.translate;\n      let ty = 0;\n      if (!swiper.isHorizontal()) {\n        ty = tx;\n        tx = 0;\n      }\n      const slideOpacity = swiper.params.fadeEffect.crossFade ? Math.max(1 - Math.abs(slideEl.progress), 0) : 1 + Math.min(Math.max(slideEl.progress, -1), 0);\n      const targetEl = effectTarget(params, slideEl);\n      targetEl.style.opacity = slideOpacity;\n      targetEl.style.transform = `translate3d(${tx}px, ${ty}px, 0px)`;\n    }\n  };\n  const setTransition = duration => {\n    const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n    transformElements.forEach(el => {\n      el.style.transitionDuration = `${duration}ms`;\n    });\n    effectVirtualTransitionEnd({\n      swiper,\n      duration,\n      transformElements,\n      allSlides: true\n    });\n  };\n  effectInit({\n    effect: 'fade',\n    swiper,\n    on,\n    setTranslate,\n    setTransition,\n    overwriteParams: () => ({\n      slidesPerView: 1,\n      slidesPerGroup: 1,\n      watchSlidesProgress: true,\n      spaceBetween: 0,\n      virtualTranslate: !swiper.params.cssMode\n    })\n  });\n}\n\nexport { EffectFade as default };\n","import { c as createShadow } from '../shared/create-shadow.mjs';\nimport { e as effectInit } from '../shared/effect-init.mjs';\nimport { e as effectTarget } from '../shared/effect-target.mjs';\nimport { e as effectVirtualTransitionEnd } from '../shared/effect-virtual-transition-end.mjs';\nimport { g as getSlideTransformEl, o as getRotateFix } from '../shared/utils.mjs';\n\nfunction EffectFlip(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    flipEffect: {\n      slideShadows: true,\n      limitRotation: true\n    }\n  });\n  const createSlideShadows = (slideEl, progress) => {\n    let shadowBefore = swiper.isHorizontal() ? slideEl.querySelector('.swiper-slide-shadow-left') : slideEl.querySelector('.swiper-slide-shadow-top');\n    let shadowAfter = swiper.isHorizontal() ? slideEl.querySelector('.swiper-slide-shadow-right') : slideEl.querySelector('.swiper-slide-shadow-bottom');\n    if (!shadowBefore) {\n      shadowBefore = createShadow('flip', slideEl, swiper.isHorizontal() ? 'left' : 'top');\n    }\n    if (!shadowAfter) {\n      shadowAfter = createShadow('flip', slideEl, swiper.isHorizontal() ? 'right' : 'bottom');\n    }\n    if (shadowBefore) shadowBefore.style.opacity = Math.max(-progress, 0);\n    if (shadowAfter) shadowAfter.style.opacity = Math.max(progress, 0);\n  };\n  const recreateShadows = () => {\n    // Set shadows\n    swiper.params.flipEffect;\n    swiper.slides.forEach(slideEl => {\n      let progress = slideEl.progress;\n      if (swiper.params.flipEffect.limitRotation) {\n        progress = Math.max(Math.min(slideEl.progress, 1), -1);\n      }\n      createSlideShadows(slideEl, progress);\n    });\n  };\n  const setTranslate = () => {\n    const {\n      slides,\n      rtlTranslate: rtl\n    } = swiper;\n    const params = swiper.params.flipEffect;\n    const rotateFix = getRotateFix(swiper);\n    for (let i = 0; i < slides.length; i += 1) {\n      const slideEl = slides[i];\n      let progress = slideEl.progress;\n      if (swiper.params.flipEffect.limitRotation) {\n        progress = Math.max(Math.min(slideEl.progress, 1), -1);\n      }\n      const offset = slideEl.swiperSlideOffset;\n      const rotate = -180 * progress;\n      let rotateY = rotate;\n      let rotateX = 0;\n      let tx = swiper.params.cssMode ? -offset - swiper.translate : -offset;\n      let ty = 0;\n      if (!swiper.isHorizontal()) {\n        ty = tx;\n        tx = 0;\n        rotateX = -rotateY;\n        rotateY = 0;\n      } else if (rtl) {\n        rotateY = -rotateY;\n      }\n      slideEl.style.zIndex = -Math.abs(Math.round(progress)) + slides.length;\n      if (params.slideShadows) {\n        createSlideShadows(slideEl, progress);\n      }\n      const transform = `translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateFix(rotateX)}deg) rotateY(${rotateFix(rotateY)}deg)`;\n      const targetEl = effectTarget(params, slideEl);\n      targetEl.style.transform = transform;\n    }\n  };\n  const setTransition = duration => {\n    const transformElements = swiper.slides.map(slideEl => getSlideTransformEl(slideEl));\n    transformElements.forEach(el => {\n      el.style.transitionDuration = `${duration}ms`;\n      el.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(shadowEl => {\n        shadowEl.style.transitionDuration = `${duration}ms`;\n      });\n    });\n    effectVirtualTransitionEnd({\n      swiper,\n      duration,\n      transformElements\n    });\n  };\n  effectInit({\n    effect: 'flip',\n    swiper,\n    on,\n    setTranslate,\n    setTransition,\n    recreateShadows,\n    getEffectParams: () => swiper.params.flipEffect,\n    perspective: () => true,\n    overwriteParams: () => ({\n      slidesPerView: 1,\n      slidesPerGroup: 1,\n      watchSlidesProgress: true,\n      spaceBetween: 0,\n      virtualTranslate: !swiper.params.cssMode\n    })\n  });\n}\n\nexport { EffectFlip as default };\n","import { d as now, k as elementTransitionEnd } from '../shared/utils.mjs';\n\nfunction freeMode(_ref) {\n  let {\n    swiper,\n    extendParams,\n    emit,\n    once\n  } = _ref;\n  extendParams({\n    freeMode: {\n      enabled: false,\n      momentum: true,\n      momentumRatio: 1,\n      momentumBounce: true,\n      momentumBounceRatio: 1,\n      momentumVelocityRatio: 1,\n      sticky: false,\n      minimumVelocity: 0.02\n    }\n  });\n  function onTouchStart() {\n    if (swiper.params.cssMode) return;\n    const translate = swiper.getTranslate();\n    swiper.setTranslate(translate);\n    swiper.setTransition(0);\n    swiper.touchEventsData.velocities.length = 0;\n    swiper.freeMode.onTouchEnd({\n      currentPos: swiper.rtl ? swiper.translate : -swiper.translate\n    });\n  }\n  function onTouchMove() {\n    if (swiper.params.cssMode) return;\n    const {\n      touchEventsData: data,\n      touches\n    } = swiper;\n    // Velocity\n    if (data.velocities.length === 0) {\n      data.velocities.push({\n        position: touches[swiper.isHorizontal() ? 'startX' : 'startY'],\n        time: data.touchStartTime\n      });\n    }\n    data.velocities.push({\n      position: touches[swiper.isHorizontal() ? 'currentX' : 'currentY'],\n      time: now()\n    });\n  }\n  function onTouchEnd(_ref2) {\n    let {\n      currentPos\n    } = _ref2;\n    if (swiper.params.cssMode) return;\n    const {\n      params,\n      wrapperEl,\n      rtlTranslate: rtl,\n      snapGrid,\n      touchEventsData: data\n    } = swiper;\n    // Time diff\n    const touchEndTime = now();\n    const timeDiff = touchEndTime - data.touchStartTime;\n    if (currentPos < -swiper.minTranslate()) {\n      swiper.slideTo(swiper.activeIndex);\n      return;\n    }\n    if (currentPos > -swiper.maxTranslate()) {\n      if (swiper.slides.length < snapGrid.length) {\n        swiper.slideTo(snapGrid.length - 1);\n      } else {\n        swiper.slideTo(swiper.slides.length - 1);\n      }\n      return;\n    }\n    if (params.freeMode.momentum) {\n      if (data.velocities.length > 1) {\n        const lastMoveEvent = data.velocities.pop();\n        const velocityEvent = data.velocities.pop();\n        const distance = lastMoveEvent.position - velocityEvent.position;\n        const time = lastMoveEvent.time - velocityEvent.time;\n        swiper.velocity = distance / time;\n        swiper.velocity /= 2;\n        if (Math.abs(swiper.velocity) < params.freeMode.minimumVelocity) {\n          swiper.velocity = 0;\n        }\n        // this implies that the user stopped moving a finger then released.\n        // There would be no events with distance zero, so the last event is stale.\n        if (time > 150 || now() - lastMoveEvent.time > 300) {\n          swiper.velocity = 0;\n        }\n      } else {\n        swiper.velocity = 0;\n      }\n      swiper.velocity *= params.freeMode.momentumVelocityRatio;\n      data.velocities.length = 0;\n      let momentumDuration = 1000 * params.freeMode.momentumRatio;\n      const momentumDistance = swiper.velocity * momentumDuration;\n      let newPosition = swiper.translate + momentumDistance;\n      if (rtl) newPosition = -newPosition;\n      let doBounce = false;\n      let afterBouncePosition;\n      const bounceAmount = Math.abs(swiper.velocity) * 20 * params.freeMode.momentumBounceRatio;\n      let needsLoopFix;\n      if (newPosition < swiper.maxTranslate()) {\n        if (params.freeMode.momentumBounce) {\n          if (newPosition + swiper.maxTranslate() < -bounceAmount) {\n            newPosition = swiper.maxTranslate() - bounceAmount;\n          }\n          afterBouncePosition = swiper.maxTranslate();\n          doBounce = true;\n          data.allowMomentumBounce = true;\n        } else {\n          newPosition = swiper.maxTranslate();\n        }\n        if (params.loop && params.centeredSlides) needsLoopFix = true;\n      } else if (newPosition > swiper.minTranslate()) {\n        if (params.freeMode.momentumBounce) {\n          if (newPosition - swiper.minTranslate() > bounceAmount) {\n            newPosition = swiper.minTranslate() + bounceAmount;\n          }\n          afterBouncePosition = swiper.minTranslate();\n          doBounce = true;\n          data.allowMomentumBounce = true;\n        } else {\n          newPosition = swiper.minTranslate();\n        }\n        if (params.loop && params.centeredSlides) needsLoopFix = true;\n      } else if (params.freeMode.sticky) {\n        let nextSlide;\n        for (let j = 0; j < snapGrid.length; j += 1) {\n          if (snapGrid[j] > -newPosition) {\n            nextSlide = j;\n            break;\n          }\n        }\n        if (Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition) || swiper.swipeDirection === 'next') {\n          newPosition = snapGrid[nextSlide];\n        } else {\n          newPosition = snapGrid[nextSlide - 1];\n        }\n        newPosition = -newPosition;\n      }\n      if (needsLoopFix) {\n        once('transitionEnd', () => {\n          swiper.loopFix();\n        });\n      }\n      // Fix duration\n      if (swiper.velocity !== 0) {\n        if (rtl) {\n          momentumDuration = Math.abs((-newPosition - swiper.translate) / swiper.velocity);\n        } else {\n          momentumDuration = Math.abs((newPosition - swiper.translate) / swiper.velocity);\n        }\n        if (params.freeMode.sticky) {\n          // If freeMode.sticky is active and the user ends a swipe with a slow-velocity\n          // event, then durations can be 20+ seconds to slide one (or zero!) slides.\n          // It's easy to see this when simulating touch with mouse events. To fix this,\n          // limit single-slide swipes to the default slide duration. This also has the\n          // nice side effect of matching slide speed if the user stopped moving before\n          // lifting finger or mouse vs. moving slowly before lifting the finger/mouse.\n          // For faster swipes, also apply limits (albeit higher ones).\n          const moveDistance = Math.abs((rtl ? -newPosition : newPosition) - swiper.translate);\n          const currentSlideSize = swiper.slidesSizesGrid[swiper.activeIndex];\n          if (moveDistance < currentSlideSize) {\n            momentumDuration = params.speed;\n          } else if (moveDistance < 2 * currentSlideSize) {\n            momentumDuration = params.speed * 1.5;\n          } else {\n            momentumDuration = params.speed * 2.5;\n          }\n        }\n      } else if (params.freeMode.sticky) {\n        swiper.slideToClosest();\n        return;\n      }\n      if (params.freeMode.momentumBounce && doBounce) {\n        swiper.updateProgress(afterBouncePosition);\n        swiper.setTransition(momentumDuration);\n        swiper.setTranslate(newPosition);\n        swiper.transitionStart(true, swiper.swipeDirection);\n        swiper.animating = true;\n        elementTransitionEnd(wrapperEl, () => {\n          if (!swiper || swiper.destroyed || !data.allowMomentumBounce) return;\n          emit('momentumBounce');\n          swiper.setTransition(params.speed);\n          setTimeout(() => {\n            swiper.setTranslate(afterBouncePosition);\n            elementTransitionEnd(wrapperEl, () => {\n              if (!swiper || swiper.destroyed) return;\n              swiper.transitionEnd();\n            });\n          }, 0);\n        });\n      } else if (swiper.velocity) {\n        emit('_freeModeNoMomentumRelease');\n        swiper.updateProgress(newPosition);\n        swiper.setTransition(momentumDuration);\n        swiper.setTranslate(newPosition);\n        swiper.transitionStart(true, swiper.swipeDirection);\n        if (!swiper.animating) {\n          swiper.animating = true;\n          elementTransitionEnd(wrapperEl, () => {\n            if (!swiper || swiper.destroyed) return;\n            swiper.transitionEnd();\n          });\n        }\n      } else {\n        swiper.updateProgress(newPosition);\n      }\n      swiper.updateActiveIndex();\n      swiper.updateSlidesClasses();\n    } else if (params.freeMode.sticky) {\n      swiper.slideToClosest();\n      return;\n    } else if (params.freeMode) {\n      emit('_freeModeNoMomentumRelease');\n    }\n    if (!params.freeMode.momentum || timeDiff >= params.longSwipesMs) {\n      emit('_freeModeStaticRelease');\n      swiper.updateProgress();\n      swiper.updateActiveIndex();\n      swiper.updateSlidesClasses();\n    }\n  }\n  Object.assign(swiper, {\n    freeMode: {\n      onTouchStart,\n      onTouchMove,\n      onTouchEnd\n    }\n  });\n}\n\nexport { freeMode as default };\n","function Grid(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    grid: {\n      rows: 1,\n      fill: 'column'\n    }\n  });\n  let slidesNumberEvenToRows;\n  let slidesPerRow;\n  let numFullColumns;\n  let wasMultiRow;\n  const getSpaceBetween = () => {\n    let spaceBetween = swiper.params.spaceBetween;\n    if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n      spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiper.size;\n    } else if (typeof spaceBetween === 'string') {\n      spaceBetween = parseFloat(spaceBetween);\n    }\n    return spaceBetween;\n  };\n  const initSlides = slides => {\n    const {\n      slidesPerView\n    } = swiper.params;\n    const {\n      rows,\n      fill\n    } = swiper.params.grid;\n    const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : slides.length;\n    numFullColumns = Math.floor(slidesLength / rows);\n    if (Math.floor(slidesLength / rows) === slidesLength / rows) {\n      slidesNumberEvenToRows = slidesLength;\n    } else {\n      slidesNumberEvenToRows = Math.ceil(slidesLength / rows) * rows;\n    }\n    if (slidesPerView !== 'auto' && fill === 'row') {\n      slidesNumberEvenToRows = Math.max(slidesNumberEvenToRows, slidesPerView * rows);\n    }\n    slidesPerRow = slidesNumberEvenToRows / rows;\n  };\n  const unsetSlides = () => {\n    if (swiper.slides) {\n      swiper.slides.forEach(slide => {\n        if (slide.swiperSlideGridSet) {\n          slide.style.height = '';\n          slide.style[swiper.getDirectionLabel('margin-top')] = '';\n        }\n      });\n    }\n  };\n  const updateSlide = (i, slide, slides) => {\n    const {\n      slidesPerGroup\n    } = swiper.params;\n    const spaceBetween = getSpaceBetween();\n    const {\n      rows,\n      fill\n    } = swiper.params.grid;\n    const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : slides.length;\n    // Set slides order\n    let newSlideOrderIndex;\n    let column;\n    let row;\n    if (fill === 'row' && slidesPerGroup > 1) {\n      const groupIndex = Math.floor(i / (slidesPerGroup * rows));\n      const slideIndexInGroup = i - rows * slidesPerGroup * groupIndex;\n      const columnsInGroup = groupIndex === 0 ? slidesPerGroup : Math.min(Math.ceil((slidesLength - groupIndex * rows * slidesPerGroup) / rows), slidesPerGroup);\n      row = Math.floor(slideIndexInGroup / columnsInGroup);\n      column = slideIndexInGroup - row * columnsInGroup + groupIndex * slidesPerGroup;\n      newSlideOrderIndex = column + row * slidesNumberEvenToRows / rows;\n      slide.style.order = newSlideOrderIndex;\n    } else if (fill === 'column') {\n      column = Math.floor(i / rows);\n      row = i - column * rows;\n      if (column > numFullColumns || column === numFullColumns && row === rows - 1) {\n        row += 1;\n        if (row >= rows) {\n          row = 0;\n          column += 1;\n        }\n      }\n    } else {\n      row = Math.floor(i / slidesPerRow);\n      column = i - row * slidesPerRow;\n    }\n    slide.row = row;\n    slide.column = column;\n    slide.style.height = `calc((100% - ${(rows - 1) * spaceBetween}px) / ${rows})`;\n    slide.style[swiper.getDirectionLabel('margin-top')] = row !== 0 ? spaceBetween && `${spaceBetween}px` : '';\n    slide.swiperSlideGridSet = true;\n  };\n  const updateWrapperSize = (slideSize, snapGrid) => {\n    const {\n      centeredSlides,\n      roundLengths\n    } = swiper.params;\n    const spaceBetween = getSpaceBetween();\n    const {\n      rows\n    } = swiper.params.grid;\n    swiper.virtualSize = (slideSize + spaceBetween) * slidesNumberEvenToRows;\n    swiper.virtualSize = Math.ceil(swiper.virtualSize / rows) - spaceBetween;\n    if (!swiper.params.cssMode) {\n      swiper.wrapperEl.style[swiper.getDirectionLabel('width')] = `${swiper.virtualSize + spaceBetween}px`;\n    }\n    if (centeredSlides) {\n      const newSlidesGrid = [];\n      for (let i = 0; i < snapGrid.length; i += 1) {\n        let slidesGridItem = snapGrid[i];\n        if (roundLengths) slidesGridItem = Math.floor(slidesGridItem);\n        if (snapGrid[i] < swiper.virtualSize + snapGrid[0]) newSlidesGrid.push(slidesGridItem);\n      }\n      snapGrid.splice(0, snapGrid.length);\n      snapGrid.push(...newSlidesGrid);\n    }\n  };\n  const onInit = () => {\n    wasMultiRow = swiper.params.grid && swiper.params.grid.rows > 1;\n  };\n  const onUpdate = () => {\n    const {\n      params,\n      el\n    } = swiper;\n    const isMultiRow = params.grid && params.grid.rows > 1;\n    if (wasMultiRow && !isMultiRow) {\n      el.classList.remove(`${params.containerModifierClass}grid`, `${params.containerModifierClass}grid-column`);\n      numFullColumns = 1;\n      swiper.emitContainerClasses();\n    } else if (!wasMultiRow && isMultiRow) {\n      el.classList.add(`${params.containerModifierClass}grid`);\n      if (params.grid.fill === 'column') {\n        el.classList.add(`${params.containerModifierClass}grid-column`);\n      }\n      swiper.emitContainerClasses();\n    }\n    wasMultiRow = isMultiRow;\n  };\n  on('init', onInit);\n  on('update', onUpdate);\n  swiper.grid = {\n    initSlides,\n    unsetSlides,\n    updateSlide,\n    updateWrapperSize\n  };\n}\n\nexport { Grid as default };\n","import { g as getDocument, a as getWindow } from '../shared/ssr-window.esm.mjs';\nimport { e as elementChildren } from '../shared/utils.mjs';\n\nfunction HashNavigation(_ref) {\n  let {\n    swiper,\n    extendParams,\n    emit,\n    on\n  } = _ref;\n  let initialized = false;\n  const document = getDocument();\n  const window = getWindow();\n  extendParams({\n    hashNavigation: {\n      enabled: false,\n      replaceState: false,\n      watchState: false,\n      getSlideIndex(_s, hash) {\n        if (swiper.virtual && swiper.params.virtual.enabled) {\n          const slideWithHash = swiper.slides.find(slideEl => slideEl.getAttribute('data-hash') === hash);\n          if (!slideWithHash) return 0;\n          const index = parseInt(slideWithHash.getAttribute('data-swiper-slide-index'), 10);\n          return index;\n        }\n        return swiper.getSlideIndex(elementChildren(swiper.slidesEl, `.${swiper.params.slideClass}[data-hash=\"${hash}\"], swiper-slide[data-hash=\"${hash}\"]`)[0]);\n      }\n    }\n  });\n  const onHashChange = () => {\n    emit('hashChange');\n    const newHash = document.location.hash.replace('#', '');\n    const activeSlideEl = swiper.virtual && swiper.params.virtual.enabled ? swiper.slidesEl.querySelector(`[data-swiper-slide-index=\"${swiper.activeIndex}\"]`) : swiper.slides[swiper.activeIndex];\n    const activeSlideHash = activeSlideEl ? activeSlideEl.getAttribute('data-hash') : '';\n    if (newHash !== activeSlideHash) {\n      const newIndex = swiper.params.hashNavigation.getSlideIndex(swiper, newHash);\n      if (typeof newIndex === 'undefined' || Number.isNaN(newIndex)) return;\n      swiper.slideTo(newIndex);\n    }\n  };\n  const setHash = () => {\n    if (!initialized || !swiper.params.hashNavigation.enabled) return;\n    const activeSlideEl = swiper.virtual && swiper.params.virtual.enabled ? swiper.slidesEl.querySelector(`[data-swiper-slide-index=\"${swiper.activeIndex}\"]`) : swiper.slides[swiper.activeIndex];\n    const activeSlideHash = activeSlideEl ? activeSlideEl.getAttribute('data-hash') || activeSlideEl.getAttribute('data-history') : '';\n    if (swiper.params.hashNavigation.replaceState && window.history && window.history.replaceState) {\n      window.history.replaceState(null, null, `#${activeSlideHash}` || '');\n      emit('hashSet');\n    } else {\n      document.location.hash = activeSlideHash || '';\n      emit('hashSet');\n    }\n  };\n  const init = () => {\n    if (!swiper.params.hashNavigation.enabled || swiper.params.history && swiper.params.history.enabled) return;\n    initialized = true;\n    const hash = document.location.hash.replace('#', '');\n    if (hash) {\n      const speed = 0;\n      const index = swiper.params.hashNavigation.getSlideIndex(swiper, hash);\n      swiper.slideTo(index || 0, speed, swiper.params.runCallbacksOnInit, true);\n    }\n    if (swiper.params.hashNavigation.watchState) {\n      window.addEventListener('hashchange', onHashChange);\n    }\n  };\n  const destroy = () => {\n    if (swiper.params.hashNavigation.watchState) {\n      window.removeEventListener('hashchange', onHashChange);\n    }\n  };\n  on('init', () => {\n    if (swiper.params.hashNavigation.enabled) {\n      init();\n    }\n  });\n  on('destroy', () => {\n    if (swiper.params.hashNavigation.enabled) {\n      destroy();\n    }\n  });\n  on('transitionEnd _freeModeNoMomentumRelease', () => {\n    if (initialized) {\n      setHash();\n    }\n  });\n  on('slideChange', () => {\n    if (initialized && swiper.params.cssMode) {\n      setHash();\n    }\n  });\n}\n\nexport { HashNavigation as default };\n","import { a as getWindow } from '../shared/ssr-window.esm.mjs';\n\nfunction History(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    history: {\n      enabled: false,\n      root: '',\n      replaceState: false,\n      key: 'slides',\n      keepQuery: false\n    }\n  });\n  let initialized = false;\n  let paths = {};\n  const slugify = text => {\n    return text.toString().replace(/\\s+/g, '-').replace(/[^\\w-]+/g, '').replace(/--+/g, '-').replace(/^-+/, '').replace(/-+$/, '');\n  };\n  const getPathValues = urlOverride => {\n    const window = getWindow();\n    let location;\n    if (urlOverride) {\n      location = new URL(urlOverride);\n    } else {\n      location = window.location;\n    }\n    const pathArray = location.pathname.slice(1).split('/').filter(part => part !== '');\n    const total = pathArray.length;\n    const key = pathArray[total - 2];\n    const value = pathArray[total - 1];\n    return {\n      key,\n      value\n    };\n  };\n  const setHistory = (key, index) => {\n    const window = getWindow();\n    if (!initialized || !swiper.params.history.enabled) return;\n    let location;\n    if (swiper.params.url) {\n      location = new URL(swiper.params.url);\n    } else {\n      location = window.location;\n    }\n    const slide = swiper.virtual && swiper.params.virtual.enabled ? swiper.slidesEl.querySelector(`[data-swiper-slide-index=\"${index}\"]`) : swiper.slides[index];\n    let value = slugify(slide.getAttribute('data-history'));\n    if (swiper.params.history.root.length > 0) {\n      let root = swiper.params.history.root;\n      if (root[root.length - 1] === '/') root = root.slice(0, root.length - 1);\n      value = `${root}/${key ? `${key}/` : ''}${value}`;\n    } else if (!location.pathname.includes(key)) {\n      value = `${key ? `${key}/` : ''}${value}`;\n    }\n    if (swiper.params.history.keepQuery) {\n      value += location.search;\n    }\n    const currentState = window.history.state;\n    if (currentState && currentState.value === value) {\n      return;\n    }\n    if (swiper.params.history.replaceState) {\n      window.history.replaceState({\n        value\n      }, null, value);\n    } else {\n      window.history.pushState({\n        value\n      }, null, value);\n    }\n  };\n  const scrollToSlide = (speed, value, runCallbacks) => {\n    if (value) {\n      for (let i = 0, length = swiper.slides.length; i < length; i += 1) {\n        const slide = swiper.slides[i];\n        const slideHistory = slugify(slide.getAttribute('data-history'));\n        if (slideHistory === value) {\n          const index = swiper.getSlideIndex(slide);\n          swiper.slideTo(index, speed, runCallbacks);\n        }\n      }\n    } else {\n      swiper.slideTo(0, speed, runCallbacks);\n    }\n  };\n  const setHistoryPopState = () => {\n    paths = getPathValues(swiper.params.url);\n    scrollToSlide(swiper.params.speed, paths.value, false);\n  };\n  const init = () => {\n    const window = getWindow();\n    if (!swiper.params.history) return;\n    if (!window.history || !window.history.pushState) {\n      swiper.params.history.enabled = false;\n      swiper.params.hashNavigation.enabled = true;\n      return;\n    }\n    initialized = true;\n    paths = getPathValues(swiper.params.url);\n    if (!paths.key && !paths.value) {\n      if (!swiper.params.history.replaceState) {\n        window.addEventListener('popstate', setHistoryPopState);\n      }\n      return;\n    }\n    scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit);\n    if (!swiper.params.history.replaceState) {\n      window.addEventListener('popstate', setHistoryPopState);\n    }\n  };\n  const destroy = () => {\n    const window = getWindow();\n    if (!swiper.params.history.replaceState) {\n      window.removeEventListener('popstate', setHistoryPopState);\n    }\n  };\n  on('init', () => {\n    if (swiper.params.history.enabled) {\n      init();\n    }\n  });\n  on('destroy', () => {\n    if (swiper.params.history.enabled) {\n      destroy();\n    }\n  });\n  on('transitionEnd _freeModeNoMomentumRelease', () => {\n    if (initialized) {\n      setHistory(swiper.params.history.key, swiper.activeIndex);\n    }\n  });\n  on('slideChange', () => {\n    if (initialized && swiper.params.cssMode) {\n      setHistory(swiper.params.history.key, swiper.activeIndex);\n    }\n  });\n}\n\nexport { History as default };\n","export {default as Virtual} from './virtual.mjs';\nexport {default as Keyboard} from './keyboard.mjs';\nexport {default as Mousewheel} from './mousewheel.mjs';\nexport {default as Navigation} from './navigation.mjs';\nexport {default as Pagination} from './pagination.mjs';\nexport {default as Scrollbar} from './scrollbar.mjs';\nexport {default as Parallax} from './parallax.mjs';\nexport {default as Zoom} from './zoom.mjs';\nexport {default as Controller} from './controller.mjs';\nexport {default as A11y} from './a11y.mjs';\nexport {default as History} from './history.mjs';\nexport {default as HashNavigation} from './hash-navigation.mjs';\nexport {default as Autoplay} from './autoplay.mjs';\nexport {default as Thumbs} from './thumbs.mjs';\nexport {default as FreeMode} from './free-mode.mjs';\nexport {default as Grid} from './grid.mjs';\nexport {default as Manipulation} from './manipulation.mjs';\nexport {default as EffectFade} from './effect-fade.mjs';\nexport {default as EffectCube} from './effect-cube.mjs';\nexport {default as EffectFlip} from './effect-flip.mjs';\nexport {default as EffectCoverflow} from './effect-coverflow.mjs';\nexport {default as EffectCreative} from './effect-creative.mjs';\nexport {default as EffectCards} from './effect-cards.mjs';","import { g as getDocument, a as getWindow } from '../shared/ssr-window.esm.mjs';\nimport { a as elementParents, b as elementOffset } from '../shared/utils.mjs';\n\n/* eslint-disable consistent-return */\nfunction Keyboard(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on,\n    emit\n  } = _ref;\n  const document = getDocument();\n  const window = getWindow();\n  swiper.keyboard = {\n    enabled: false\n  };\n  extendParams({\n    keyboard: {\n      enabled: false,\n      onlyInViewport: true,\n      pageUpDown: true\n    }\n  });\n  function handle(event) {\n    if (!swiper.enabled) return;\n    const {\n      rtlTranslate: rtl\n    } = swiper;\n    let e = event;\n    if (e.originalEvent) e = e.originalEvent; // jquery fix\n    const kc = e.keyCode || e.charCode;\n    const pageUpDown = swiper.params.keyboard.pageUpDown;\n    const isPageUp = pageUpDown && kc === 33;\n    const isPageDown = pageUpDown && kc === 34;\n    const isArrowLeft = kc === 37;\n    const isArrowRight = kc === 39;\n    const isArrowUp = kc === 38;\n    const isArrowDown = kc === 40;\n    // Directions locks\n    if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {\n      return false;\n    }\n    if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {\n      return false;\n    }\n    if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {\n      return undefined;\n    }\n    if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {\n      return undefined;\n    }\n    if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {\n      let inView = false;\n      // Check that swiper should be inside of visible area of window\n      if (elementParents(swiper.el, `.${swiper.params.slideClass}, swiper-slide`).length > 0 && elementParents(swiper.el, `.${swiper.params.slideActiveClass}`).length === 0) {\n        return undefined;\n      }\n      const el = swiper.el;\n      const swiperWidth = el.clientWidth;\n      const swiperHeight = el.clientHeight;\n      const windowWidth = window.innerWidth;\n      const windowHeight = window.innerHeight;\n      const swiperOffset = elementOffset(el);\n      if (rtl) swiperOffset.left -= el.scrollLeft;\n      const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];\n      for (let i = 0; i < swiperCoord.length; i += 1) {\n        const point = swiperCoord[i];\n        if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {\n          if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line\n          inView = true;\n        }\n      }\n      if (!inView) return undefined;\n    }\n    if (swiper.isHorizontal()) {\n      if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {\n        if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n      }\n      if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();\n      if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();\n    } else {\n      if (isPageUp || isPageDown || isArrowUp || isArrowDown) {\n        if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n      }\n      if (isPageDown || isArrowDown) swiper.slideNext();\n      if (isPageUp || isArrowUp) swiper.slidePrev();\n    }\n    emit('keyPress', kc);\n    return undefined;\n  }\n  function enable() {\n    if (swiper.keyboard.enabled) return;\n    document.addEventListener('keydown', handle);\n    swiper.keyboard.enabled = true;\n  }\n  function disable() {\n    if (!swiper.keyboard.enabled) return;\n    document.removeEventListener('keydown', handle);\n    swiper.keyboard.enabled = false;\n  }\n  on('init', () => {\n    if (swiper.params.keyboard.enabled) {\n      enable();\n    }\n  });\n  on('destroy', () => {\n    if (swiper.keyboard.enabled) {\n      disable();\n    }\n  });\n  Object.assign(swiper.keyboard, {\n    enable,\n    disable\n  });\n}\n\nexport { Keyboard as default };\n","function appendSlide(slides) {\n  const swiper = this;\n  const {\n    params,\n    slidesEl\n  } = swiper;\n  if (params.loop) {\n    swiper.loopDestroy();\n  }\n  const appendElement = slideEl => {\n    if (typeof slideEl === 'string') {\n      const tempDOM = document.createElement('div');\n      tempDOM.innerHTML = slideEl;\n      slidesEl.append(tempDOM.children[0]);\n      tempDOM.innerHTML = '';\n    } else {\n      slidesEl.append(slideEl);\n    }\n  };\n  if (typeof slides === 'object' && 'length' in slides) {\n    for (let i = 0; i < slides.length; i += 1) {\n      if (slides[i]) appendElement(slides[i]);\n    }\n  } else {\n    appendElement(slides);\n  }\n  swiper.recalcSlides();\n  if (params.loop) {\n    swiper.loopCreate();\n  }\n  if (!params.observer || swiper.isElement) {\n    swiper.update();\n  }\n}\n\nfunction prependSlide(slides) {\n  const swiper = this;\n  const {\n    params,\n    activeIndex,\n    slidesEl\n  } = swiper;\n  if (params.loop) {\n    swiper.loopDestroy();\n  }\n  let newActiveIndex = activeIndex + 1;\n  const prependElement = slideEl => {\n    if (typeof slideEl === 'string') {\n      const tempDOM = document.createElement('div');\n      tempDOM.innerHTML = slideEl;\n      slidesEl.prepend(tempDOM.children[0]);\n      tempDOM.innerHTML = '';\n    } else {\n      slidesEl.prepend(slideEl);\n    }\n  };\n  if (typeof slides === 'object' && 'length' in slides) {\n    for (let i = 0; i < slides.length; i += 1) {\n      if (slides[i]) prependElement(slides[i]);\n    }\n    newActiveIndex = activeIndex + slides.length;\n  } else {\n    prependElement(slides);\n  }\n  swiper.recalcSlides();\n  if (params.loop) {\n    swiper.loopCreate();\n  }\n  if (!params.observer || swiper.isElement) {\n    swiper.update();\n  }\n  swiper.slideTo(newActiveIndex, 0, false);\n}\n\nfunction addSlide(index, slides) {\n  const swiper = this;\n  const {\n    params,\n    activeIndex,\n    slidesEl\n  } = swiper;\n  let activeIndexBuffer = activeIndex;\n  if (params.loop) {\n    activeIndexBuffer -= swiper.loopedSlides;\n    swiper.loopDestroy();\n    swiper.recalcSlides();\n  }\n  const baseLength = swiper.slides.length;\n  if (index <= 0) {\n    swiper.prependSlide(slides);\n    return;\n  }\n  if (index >= baseLength) {\n    swiper.appendSlide(slides);\n    return;\n  }\n  let newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + 1 : activeIndexBuffer;\n  const slidesBuffer = [];\n  for (let i = baseLength - 1; i >= index; i -= 1) {\n    const currentSlide = swiper.slides[i];\n    currentSlide.remove();\n    slidesBuffer.unshift(currentSlide);\n  }\n  if (typeof slides === 'object' && 'length' in slides) {\n    for (let i = 0; i < slides.length; i += 1) {\n      if (slides[i]) slidesEl.append(slides[i]);\n    }\n    newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + slides.length : activeIndexBuffer;\n  } else {\n    slidesEl.append(slides);\n  }\n  for (let i = 0; i < slidesBuffer.length; i += 1) {\n    slidesEl.append(slidesBuffer[i]);\n  }\n  swiper.recalcSlides();\n  if (params.loop) {\n    swiper.loopCreate();\n  }\n  if (!params.observer || swiper.isElement) {\n    swiper.update();\n  }\n  if (params.loop) {\n    swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n  } else {\n    swiper.slideTo(newActiveIndex, 0, false);\n  }\n}\n\nfunction removeSlide(slidesIndexes) {\n  const swiper = this;\n  const {\n    params,\n    activeIndex\n  } = swiper;\n  let activeIndexBuffer = activeIndex;\n  if (params.loop) {\n    activeIndexBuffer -= swiper.loopedSlides;\n    swiper.loopDestroy();\n  }\n  let newActiveIndex = activeIndexBuffer;\n  let indexToRemove;\n  if (typeof slidesIndexes === 'object' && 'length' in slidesIndexes) {\n    for (let i = 0; i < slidesIndexes.length; i += 1) {\n      indexToRemove = slidesIndexes[i];\n      if (swiper.slides[indexToRemove]) swiper.slides[indexToRemove].remove();\n      if (indexToRemove < newActiveIndex) newActiveIndex -= 1;\n    }\n    newActiveIndex = Math.max(newActiveIndex, 0);\n  } else {\n    indexToRemove = slidesIndexes;\n    if (swiper.slides[indexToRemove]) swiper.slides[indexToRemove].remove();\n    if (indexToRemove < newActiveIndex) newActiveIndex -= 1;\n    newActiveIndex = Math.max(newActiveIndex, 0);\n  }\n  swiper.recalcSlides();\n  if (params.loop) {\n    swiper.loopCreate();\n  }\n  if (!params.observer || swiper.isElement) {\n    swiper.update();\n  }\n  if (params.loop) {\n    swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);\n  } else {\n    swiper.slideTo(newActiveIndex, 0, false);\n  }\n}\n\nfunction removeAllSlides() {\n  const swiper = this;\n  const slidesIndexes = [];\n  for (let i = 0; i < swiper.slides.length; i += 1) {\n    slidesIndexes.push(i);\n  }\n  swiper.removeSlide(slidesIndexes);\n}\n\nfunction Manipulation(_ref) {\n  let {\n    swiper\n  } = _ref;\n  Object.assign(swiper, {\n    appendSlide: appendSlide.bind(swiper),\n    prependSlide: prependSlide.bind(swiper),\n    addSlide: addSlide.bind(swiper),\n    removeSlide: removeSlide.bind(swiper),\n    removeAllSlides: removeAllSlides.bind(swiper)\n  });\n}\n\nexport { Manipulation as default };\n","import { a as getWindow } from '../shared/ssr-window.esm.mjs';\nimport { n as nextTick, d as now } from '../shared/utils.mjs';\n\n/* eslint-disable consistent-return */\nfunction Mousewheel(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on,\n    emit\n  } = _ref;\n  const window = getWindow();\n  extendParams({\n    mousewheel: {\n      enabled: false,\n      releaseOnEdges: false,\n      invert: false,\n      forceToAxis: false,\n      sensitivity: 1,\n      eventsTarget: 'container',\n      thresholdDelta: null,\n      thresholdTime: null,\n      noMousewheelClass: 'swiper-no-mousewheel'\n    }\n  });\n  swiper.mousewheel = {\n    enabled: false\n  };\n  let timeout;\n  let lastScrollTime = now();\n  let lastEventBeforeSnap;\n  const recentWheelEvents = [];\n  function normalize(e) {\n    // Reasonable defaults\n    const PIXEL_STEP = 10;\n    const LINE_HEIGHT = 40;\n    const PAGE_HEIGHT = 800;\n    let sX = 0;\n    let sY = 0; // spinX, spinY\n    let pX = 0;\n    let pY = 0; // pixelX, pixelY\n\n    // Legacy\n    if ('detail' in e) {\n      sY = e.detail;\n    }\n    if ('wheelDelta' in e) {\n      sY = -e.wheelDelta / 120;\n    }\n    if ('wheelDeltaY' in e) {\n      sY = -e.wheelDeltaY / 120;\n    }\n    if ('wheelDeltaX' in e) {\n      sX = -e.wheelDeltaX / 120;\n    }\n\n    // side scrolling on FF with DOMMouseScroll\n    if ('axis' in e && e.axis === e.HORIZONTAL_AXIS) {\n      sX = sY;\n      sY = 0;\n    }\n    pX = sX * PIXEL_STEP;\n    pY = sY * PIXEL_STEP;\n    if ('deltaY' in e) {\n      pY = e.deltaY;\n    }\n    if ('deltaX' in e) {\n      pX = e.deltaX;\n    }\n    if (e.shiftKey && !pX) {\n      // if user scrolls with shift he wants horizontal scroll\n      pX = pY;\n      pY = 0;\n    }\n    if ((pX || pY) && e.deltaMode) {\n      if (e.deltaMode === 1) {\n        // delta in LINE units\n        pX *= LINE_HEIGHT;\n        pY *= LINE_HEIGHT;\n      } else {\n        // delta in PAGE units\n        pX *= PAGE_HEIGHT;\n        pY *= PAGE_HEIGHT;\n      }\n    }\n\n    // Fall-back if spin cannot be determined\n    if (pX && !sX) {\n      sX = pX < 1 ? -1 : 1;\n    }\n    if (pY && !sY) {\n      sY = pY < 1 ? -1 : 1;\n    }\n    return {\n      spinX: sX,\n      spinY: sY,\n      pixelX: pX,\n      pixelY: pY\n    };\n  }\n  function handleMouseEnter() {\n    if (!swiper.enabled) return;\n    swiper.mouseEntered = true;\n  }\n  function handleMouseLeave() {\n    if (!swiper.enabled) return;\n    swiper.mouseEntered = false;\n  }\n  function animateSlider(newEvent) {\n    if (swiper.params.mousewheel.thresholdDelta && newEvent.delta < swiper.params.mousewheel.thresholdDelta) {\n      // Prevent if delta of wheel scroll delta is below configured threshold\n      return false;\n    }\n    if (swiper.params.mousewheel.thresholdTime && now() - lastScrollTime < swiper.params.mousewheel.thresholdTime) {\n      // Prevent if time between scrolls is below configured threshold\n      return false;\n    }\n\n    // If the movement is NOT big enough and\n    // if the last time the user scrolled was too close to the current one (avoid continuously triggering the slider):\n    //   Don't go any further (avoid insignificant scroll movement).\n    if (newEvent.delta >= 6 && now() - lastScrollTime < 60) {\n      // Return false as a default\n      return true;\n    }\n    // If user is scrolling towards the end:\n    //   If the slider hasn't hit the latest slide or\n    //   if the slider is a loop and\n    //   if the slider isn't moving right now:\n    //     Go to next slide and\n    //     emit a scroll event.\n    // Else (the user is scrolling towards the beginning) and\n    // if the slider hasn't hit the first slide or\n    // if the slider is a loop and\n    // if the slider isn't moving right now:\n    //   Go to prev slide and\n    //   emit a scroll event.\n    if (newEvent.direction < 0) {\n      if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) {\n        swiper.slideNext();\n        emit('scroll', newEvent.raw);\n      }\n    } else if ((!swiper.isBeginning || swiper.params.loop) && !swiper.animating) {\n      swiper.slidePrev();\n      emit('scroll', newEvent.raw);\n    }\n    // If you got here is because an animation has been triggered so store the current time\n    lastScrollTime = new window.Date().getTime();\n    // Return false as a default\n    return false;\n  }\n  function releaseScroll(newEvent) {\n    const params = swiper.params.mousewheel;\n    if (newEvent.direction < 0) {\n      if (swiper.isEnd && !swiper.params.loop && params.releaseOnEdges) {\n        // Return true to animate scroll on edges\n        return true;\n      }\n    } else if (swiper.isBeginning && !swiper.params.loop && params.releaseOnEdges) {\n      // Return true to animate scroll on edges\n      return true;\n    }\n    return false;\n  }\n  function handle(event) {\n    let e = event;\n    let disableParentSwiper = true;\n    if (!swiper.enabled) return;\n\n    // Ignore event if the target or its parents have the swiper-no-mousewheel class\n    if (event.target.closest(`.${swiper.params.mousewheel.noMousewheelClass}`)) return;\n    const params = swiper.params.mousewheel;\n    if (swiper.params.cssMode) {\n      e.preventDefault();\n    }\n    let targetEl = swiper.el;\n    if (swiper.params.mousewheel.eventsTarget !== 'container') {\n      targetEl = document.querySelector(swiper.params.mousewheel.eventsTarget);\n    }\n    const targetElContainsTarget = targetEl && targetEl.contains(e.target);\n    if (!swiper.mouseEntered && !targetElContainsTarget && !params.releaseOnEdges) return true;\n    if (e.originalEvent) e = e.originalEvent; // jquery fix\n    let delta = 0;\n    const rtlFactor = swiper.rtlTranslate ? -1 : 1;\n    const data = normalize(e);\n    if (params.forceToAxis) {\n      if (swiper.isHorizontal()) {\n        if (Math.abs(data.pixelX) > Math.abs(data.pixelY)) delta = -data.pixelX * rtlFactor;else return true;\n      } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) delta = -data.pixelY;else return true;\n    } else {\n      delta = Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor : -data.pixelY;\n    }\n    if (delta === 0) return true;\n    if (params.invert) delta = -delta;\n\n    // Get the scroll positions\n    let positions = swiper.getTranslate() + delta * params.sensitivity;\n    if (positions >= swiper.minTranslate()) positions = swiper.minTranslate();\n    if (positions <= swiper.maxTranslate()) positions = swiper.maxTranslate();\n\n    // When loop is true:\n    //     the disableParentSwiper will be true.\n    // When loop is false:\n    //     if the scroll positions is not on edge,\n    //     then the disableParentSwiper will be true.\n    //     if the scroll on edge positions,\n    //     then the disableParentSwiper will be false.\n    disableParentSwiper = swiper.params.loop ? true : !(positions === swiper.minTranslate() || positions === swiper.maxTranslate());\n    if (disableParentSwiper && swiper.params.nested) e.stopPropagation();\n    if (!swiper.params.freeMode || !swiper.params.freeMode.enabled) {\n      // Register the new event in a variable which stores the relevant data\n      const newEvent = {\n        time: now(),\n        delta: Math.abs(delta),\n        direction: Math.sign(delta),\n        raw: event\n      };\n\n      // Keep the most recent events\n      if (recentWheelEvents.length >= 2) {\n        recentWheelEvents.shift(); // only store the last N events\n      }\n\n      const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;\n      recentWheelEvents.push(newEvent);\n\n      // If there is at least one previous recorded event:\n      //   If direction has changed or\n      //   if the scroll is quicker than the previous one:\n      //     Animate the slider.\n      // Else (this is the first time the wheel is moved):\n      //     Animate the slider.\n      if (prevEvent) {\n        if (newEvent.direction !== prevEvent.direction || newEvent.delta > prevEvent.delta || newEvent.time > prevEvent.time + 150) {\n          animateSlider(newEvent);\n        }\n      } else {\n        animateSlider(newEvent);\n      }\n\n      // If it's time to release the scroll:\n      //   Return now so you don't hit the preventDefault.\n      if (releaseScroll(newEvent)) {\n        return true;\n      }\n    } else {\n      // Freemode or scrollContainer:\n\n      // If we recently snapped after a momentum scroll, then ignore wheel events\n      // to give time for the deceleration to finish. Stop ignoring after 500 msecs\n      // or if it's a new scroll (larger delta or inverse sign as last event before\n      // an end-of-momentum snap).\n      const newEvent = {\n        time: now(),\n        delta: Math.abs(delta),\n        direction: Math.sign(delta)\n      };\n      const ignoreWheelEvents = lastEventBeforeSnap && newEvent.time < lastEventBeforeSnap.time + 500 && newEvent.delta <= lastEventBeforeSnap.delta && newEvent.direction === lastEventBeforeSnap.direction;\n      if (!ignoreWheelEvents) {\n        lastEventBeforeSnap = undefined;\n        let position = swiper.getTranslate() + delta * params.sensitivity;\n        const wasBeginning = swiper.isBeginning;\n        const wasEnd = swiper.isEnd;\n        if (position >= swiper.minTranslate()) position = swiper.minTranslate();\n        if (position <= swiper.maxTranslate()) position = swiper.maxTranslate();\n        swiper.setTransition(0);\n        swiper.setTranslate(position);\n        swiper.updateProgress();\n        swiper.updateActiveIndex();\n        swiper.updateSlidesClasses();\n        if (!wasBeginning && swiper.isBeginning || !wasEnd && swiper.isEnd) {\n          swiper.updateSlidesClasses();\n        }\n        if (swiper.params.loop) {\n          swiper.loopFix({\n            direction: newEvent.direction < 0 ? 'next' : 'prev',\n            byMousewheel: true\n          });\n        }\n        if (swiper.params.freeMode.sticky) {\n          // When wheel scrolling starts with sticky (aka snap) enabled, then detect\n          // the end of a momentum scroll by storing recent (N=15?) wheel events.\n          // 1. do all N events have decreasing or same (absolute value) delta?\n          // 2. did all N events arrive in the last M (M=500?) msecs?\n          // 3. does the earliest event have an (absolute value) delta that's\n          //    at least P (P=1?) larger than the most recent event's delta?\n          // 4. does the latest event have a delta that's smaller than Q (Q=6?) pixels?\n          // If 1-4 are \"yes\" then we're near the end of a momentum scroll deceleration.\n          // Snap immediately and ignore remaining wheel events in this scroll.\n          // See comment above for \"remaining wheel events in this scroll\" determination.\n          // If 1-4 aren't satisfied, then wait to snap until 500ms after the last event.\n          clearTimeout(timeout);\n          timeout = undefined;\n          if (recentWheelEvents.length >= 15) {\n            recentWheelEvents.shift(); // only store the last N events\n          }\n\n          const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;\n          const firstEvent = recentWheelEvents[0];\n          recentWheelEvents.push(newEvent);\n          if (prevEvent && (newEvent.delta > prevEvent.delta || newEvent.direction !== prevEvent.direction)) {\n            // Increasing or reverse-sign delta means the user started scrolling again. Clear the wheel event log.\n            recentWheelEvents.splice(0);\n          } else if (recentWheelEvents.length >= 15 && newEvent.time - firstEvent.time < 500 && firstEvent.delta - newEvent.delta >= 1 && newEvent.delta <= 6) {\n            // We're at the end of the deceleration of a momentum scroll, so there's no need\n            // to wait for more events. Snap ASAP on the next tick.\n            // Also, because there's some remaining momentum we'll bias the snap in the\n            // direction of the ongoing scroll because it's better UX for the scroll to snap\n            // in the same direction as the scroll instead of reversing to snap.  Therefore,\n            // if it's already scrolled more than 20% in the current direction, keep going.\n            const snapToThreshold = delta > 0 ? 0.8 : 0.2;\n            lastEventBeforeSnap = newEvent;\n            recentWheelEvents.splice(0);\n            timeout = nextTick(() => {\n              if (swiper.destroyed || !swiper.params) return;\n              swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n            }, 0); // no delay; move on next tick\n          }\n\n          if (!timeout) {\n            // if we get here, then we haven't detected the end of a momentum scroll, so\n            // we'll consider a scroll \"complete\" when there haven't been any wheel events\n            // for 500ms.\n            timeout = nextTick(() => {\n              if (swiper.destroyed || !swiper.params) return;\n              const snapToThreshold = 0.5;\n              lastEventBeforeSnap = newEvent;\n              recentWheelEvents.splice(0);\n              swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);\n            }, 500);\n          }\n        }\n\n        // Emit event\n        if (!ignoreWheelEvents) emit('scroll', e);\n\n        // Stop autoplay\n        if (swiper.params.autoplay && swiper.params.autoplay.disableOnInteraction) swiper.autoplay.stop();\n        // Return page scroll on edge positions\n        if (params.releaseOnEdges && (position === swiper.minTranslate() || position === swiper.maxTranslate())) {\n          return true;\n        }\n      }\n    }\n    if (e.preventDefault) e.preventDefault();else e.returnValue = false;\n    return false;\n  }\n  function events(method) {\n    let targetEl = swiper.el;\n    if (swiper.params.mousewheel.eventsTarget !== 'container') {\n      targetEl = document.querySelector(swiper.params.mousewheel.eventsTarget);\n    }\n    targetEl[method]('mouseenter', handleMouseEnter);\n    targetEl[method]('mouseleave', handleMouseLeave);\n    targetEl[method]('wheel', handle);\n  }\n  function enable() {\n    if (swiper.params.cssMode) {\n      swiper.wrapperEl.removeEventListener('wheel', handle);\n      return true;\n    }\n    if (swiper.mousewheel.enabled) return false;\n    events('addEventListener');\n    swiper.mousewheel.enabled = true;\n    return true;\n  }\n  function disable() {\n    if (swiper.params.cssMode) {\n      swiper.wrapperEl.addEventListener(event, handle);\n      return true;\n    }\n    if (!swiper.mousewheel.enabled) return false;\n    events('removeEventListener');\n    swiper.mousewheel.enabled = false;\n    return true;\n  }\n  on('init', () => {\n    if (!swiper.params.mousewheel.enabled && swiper.params.cssMode) {\n      disable();\n    }\n    if (swiper.params.mousewheel.enabled) enable();\n  });\n  on('destroy', () => {\n    if (swiper.params.cssMode) {\n      enable();\n    }\n    if (swiper.mousewheel.enabled) disable();\n  });\n  Object.assign(swiper.mousewheel, {\n    enable,\n    disable\n  });\n}\n\nexport { Mousewheel as default };\n","import { c as createElementIfNotDefined } from '../shared/create-element-if-not-defined.mjs';\nimport { m as makeElementsArray } from '../shared/utils.mjs';\n\nfunction Navigation(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on,\n    emit\n  } = _ref;\n  extendParams({\n    navigation: {\n      nextEl: null,\n      prevEl: null,\n      hideOnClick: false,\n      disabledClass: 'swiper-button-disabled',\n      hiddenClass: 'swiper-button-hidden',\n      lockClass: 'swiper-button-lock',\n      navigationDisabledClass: 'swiper-navigation-disabled'\n    }\n  });\n  swiper.navigation = {\n    nextEl: null,\n    prevEl: null\n  };\n  function getEl(el) {\n    let res;\n    if (el && typeof el === 'string' && swiper.isElement) {\n      res = swiper.el.querySelector(el) || swiper.hostEl.querySelector(el);\n      if (res) return res;\n    }\n    if (el) {\n      if (typeof el === 'string') res = [...document.querySelectorAll(el)];\n      if (swiper.params.uniqueNavElements && typeof el === 'string' && res && res.length > 1 && swiper.el.querySelectorAll(el).length === 1) {\n        res = swiper.el.querySelector(el);\n      } else if (res && res.length === 1) {\n        res = res[0];\n      }\n    }\n    if (el && !res) return el;\n    // if (Array.isArray(res) && res.length === 1) res = res[0];\n    return res;\n  }\n  function toggleEl(el, disabled) {\n    const params = swiper.params.navigation;\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      if (subEl) {\n        subEl.classList[disabled ? 'add' : 'remove'](...params.disabledClass.split(' '));\n        if (subEl.tagName === 'BUTTON') subEl.disabled = disabled;\n        if (swiper.params.watchOverflow && swiper.enabled) {\n          subEl.classList[swiper.isLocked ? 'add' : 'remove'](params.lockClass);\n        }\n      }\n    });\n  }\n  function update() {\n    // Update Navigation Buttons\n    const {\n      nextEl,\n      prevEl\n    } = swiper.navigation;\n    if (swiper.params.loop) {\n      toggleEl(prevEl, false);\n      toggleEl(nextEl, false);\n      return;\n    }\n    toggleEl(prevEl, swiper.isBeginning && !swiper.params.rewind);\n    toggleEl(nextEl, swiper.isEnd && !swiper.params.rewind);\n  }\n  function onPrevClick(e) {\n    e.preventDefault();\n    if (swiper.isBeginning && !swiper.params.loop && !swiper.params.rewind) return;\n    swiper.slidePrev();\n    emit('navigationPrev');\n  }\n  function onNextClick(e) {\n    e.preventDefault();\n    if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return;\n    swiper.slideNext();\n    emit('navigationNext');\n  }\n  function init() {\n    const params = swiper.params.navigation;\n    swiper.params.navigation = createElementIfNotDefined(swiper, swiper.originalParams.navigation, swiper.params.navigation, {\n      nextEl: 'swiper-button-next',\n      prevEl: 'swiper-button-prev'\n    });\n    if (!(params.nextEl || params.prevEl)) return;\n    let nextEl = getEl(params.nextEl);\n    let prevEl = getEl(params.prevEl);\n    Object.assign(swiper.navigation, {\n      nextEl,\n      prevEl\n    });\n    nextEl = makeElementsArray(nextEl);\n    prevEl = makeElementsArray(prevEl);\n    const initButton = (el, dir) => {\n      if (el) {\n        el.addEventListener('click', dir === 'next' ? onNextClick : onPrevClick);\n      }\n      if (!swiper.enabled && el) {\n        el.classList.add(...params.lockClass.split(' '));\n      }\n    };\n    nextEl.forEach(el => initButton(el, 'next'));\n    prevEl.forEach(el => initButton(el, 'prev'));\n  }\n  function destroy() {\n    let {\n      nextEl,\n      prevEl\n    } = swiper.navigation;\n    nextEl = makeElementsArray(nextEl);\n    prevEl = makeElementsArray(prevEl);\n    const destroyButton = (el, dir) => {\n      el.removeEventListener('click', dir === 'next' ? onNextClick : onPrevClick);\n      el.classList.remove(...swiper.params.navigation.disabledClass.split(' '));\n    };\n    nextEl.forEach(el => destroyButton(el, 'next'));\n    prevEl.forEach(el => destroyButton(el, 'prev'));\n  }\n  on('init', () => {\n    if (swiper.params.navigation.enabled === false) {\n      // eslint-disable-next-line\n      disable();\n    } else {\n      init();\n      update();\n    }\n  });\n  on('toEdge fromEdge lock unlock', () => {\n    update();\n  });\n  on('destroy', () => {\n    destroy();\n  });\n  on('enable disable', () => {\n    let {\n      nextEl,\n      prevEl\n    } = swiper.navigation;\n    nextEl = makeElementsArray(nextEl);\n    prevEl = makeElementsArray(prevEl);\n    if (swiper.enabled) {\n      update();\n      return;\n    }\n    [...nextEl, ...prevEl].filter(el => !!el).forEach(el => el.classList.add(swiper.params.navigation.lockClass));\n  });\n  on('click', (_s, e) => {\n    let {\n      nextEl,\n      prevEl\n    } = swiper.navigation;\n    nextEl = makeElementsArray(nextEl);\n    prevEl = makeElementsArray(prevEl);\n    const targetEl = e.target;\n    let targetIsButton = prevEl.includes(targetEl) || nextEl.includes(targetEl);\n    if (swiper.isElement && !targetIsButton) {\n      const path = e.path || e.composedPath && e.composedPath();\n      if (path) {\n        targetIsButton = path.find(pathEl => nextEl.includes(pathEl) || prevEl.includes(pathEl));\n      }\n    }\n    if (swiper.params.navigation.hideOnClick && !targetIsButton) {\n      if (swiper.pagination && swiper.params.pagination && swiper.params.pagination.clickable && (swiper.pagination.el === targetEl || swiper.pagination.el.contains(targetEl))) return;\n      let isHidden;\n      if (nextEl.length) {\n        isHidden = nextEl[0].classList.contains(swiper.params.navigation.hiddenClass);\n      } else if (prevEl.length) {\n        isHidden = prevEl[0].classList.contains(swiper.params.navigation.hiddenClass);\n      }\n      if (isHidden === true) {\n        emit('navigationShow');\n      } else {\n        emit('navigationHide');\n      }\n      [...nextEl, ...prevEl].filter(el => !!el).forEach(el => el.classList.toggle(swiper.params.navigation.hiddenClass));\n    }\n  });\n  const enable = () => {\n    swiper.el.classList.remove(...swiper.params.navigation.navigationDisabledClass.split(' '));\n    init();\n    update();\n  };\n  const disable = () => {\n    swiper.el.classList.add(...swiper.params.navigation.navigationDisabledClass.split(' '));\n    destroy();\n  };\n  Object.assign(swiper.navigation, {\n    enable,\n    disable,\n    update,\n    init,\n    destroy\n  });\n}\n\nexport { Navigation as default };\n","import { c as classesToSelector } from '../shared/classes-to-selector.mjs';\nimport { c as createElementIfNotDefined } from '../shared/create-element-if-not-defined.mjs';\nimport { m as makeElementsArray, f as elementOuterSize, h as elementIndex, a as elementParents } from '../shared/utils.mjs';\n\nfunction Pagination(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on,\n    emit\n  } = _ref;\n  const pfx = 'swiper-pagination';\n  extendParams({\n    pagination: {\n      el: null,\n      bulletElement: 'span',\n      clickable: false,\n      hideOnClick: false,\n      renderBullet: null,\n      renderProgressbar: null,\n      renderFraction: null,\n      renderCustom: null,\n      progressbarOpposite: false,\n      type: 'bullets',\n      // 'bullets' or 'progressbar' or 'fraction' or 'custom'\n      dynamicBullets: false,\n      dynamicMainBullets: 1,\n      formatFractionCurrent: number => number,\n      formatFractionTotal: number => number,\n      bulletClass: `${pfx}-bullet`,\n      bulletActiveClass: `${pfx}-bullet-active`,\n      modifierClass: `${pfx}-`,\n      currentClass: `${pfx}-current`,\n      totalClass: `${pfx}-total`,\n      hiddenClass: `${pfx}-hidden`,\n      progressbarFillClass: `${pfx}-progressbar-fill`,\n      progressbarOppositeClass: `${pfx}-progressbar-opposite`,\n      clickableClass: `${pfx}-clickable`,\n      lockClass: `${pfx}-lock`,\n      horizontalClass: `${pfx}-horizontal`,\n      verticalClass: `${pfx}-vertical`,\n      paginationDisabledClass: `${pfx}-disabled`\n    }\n  });\n  swiper.pagination = {\n    el: null,\n    bullets: []\n  };\n  let bulletSize;\n  let dynamicBulletIndex = 0;\n  function isPaginationDisabled() {\n    return !swiper.params.pagination.el || !swiper.pagination.el || Array.isArray(swiper.pagination.el) && swiper.pagination.el.length === 0;\n  }\n  function setSideBullets(bulletEl, position) {\n    const {\n      bulletActiveClass\n    } = swiper.params.pagination;\n    if (!bulletEl) return;\n    bulletEl = bulletEl[`${position === 'prev' ? 'previous' : 'next'}ElementSibling`];\n    if (bulletEl) {\n      bulletEl.classList.add(`${bulletActiveClass}-${position}`);\n      bulletEl = bulletEl[`${position === 'prev' ? 'previous' : 'next'}ElementSibling`];\n      if (bulletEl) {\n        bulletEl.classList.add(`${bulletActiveClass}-${position}-${position}`);\n      }\n    }\n  }\n  function getMoveDirection(prevIndex, nextIndex, length) {\n    prevIndex = prevIndex % length;\n    nextIndex = nextIndex % length;\n    if (nextIndex === prevIndex + 1) {\n      return 'next';\n    } else if (nextIndex === prevIndex - 1) {\n      return 'previous';\n    }\n    return;\n  }\n  function onBulletClick(e) {\n    const bulletEl = e.target.closest(classesToSelector(swiper.params.pagination.bulletClass));\n    if (!bulletEl) {\n      return;\n    }\n    e.preventDefault();\n    const index = elementIndex(bulletEl) * swiper.params.slidesPerGroup;\n    if (swiper.params.loop) {\n      if (swiper.realIndex === index) return;\n      const moveDirection = getMoveDirection(swiper.realIndex, index, swiper.slides.length);\n      if (moveDirection === 'next') {\n        swiper.slideNext();\n      } else if (moveDirection === 'previous') {\n        swiper.slidePrev();\n      } else {\n        swiper.slideToLoop(index);\n      }\n    } else {\n      swiper.slideTo(index);\n    }\n  }\n  function update() {\n    // Render || Update Pagination bullets/items\n    const rtl = swiper.rtl;\n    const params = swiper.params.pagination;\n    if (isPaginationDisabled()) return;\n    let el = swiper.pagination.el;\n    el = makeElementsArray(el);\n    // Current/Total\n    let current;\n    let previousIndex;\n    const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;\n    const total = swiper.params.loop ? Math.ceil(slidesLength / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n    if (swiper.params.loop) {\n      previousIndex = swiper.previousRealIndex || 0;\n      current = swiper.params.slidesPerGroup > 1 ? Math.floor(swiper.realIndex / swiper.params.slidesPerGroup) : swiper.realIndex;\n    } else if (typeof swiper.snapIndex !== 'undefined') {\n      current = swiper.snapIndex;\n      previousIndex = swiper.previousSnapIndex;\n    } else {\n      previousIndex = swiper.previousIndex || 0;\n      current = swiper.activeIndex || 0;\n    }\n    // Types\n    if (params.type === 'bullets' && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) {\n      const bullets = swiper.pagination.bullets;\n      let firstIndex;\n      let lastIndex;\n      let midIndex;\n      if (params.dynamicBullets) {\n        bulletSize = elementOuterSize(bullets[0], swiper.isHorizontal() ? 'width' : 'height', true);\n        el.forEach(subEl => {\n          subEl.style[swiper.isHorizontal() ? 'width' : 'height'] = `${bulletSize * (params.dynamicMainBullets + 4)}px`;\n        });\n        if (params.dynamicMainBullets > 1 && previousIndex !== undefined) {\n          dynamicBulletIndex += current - (previousIndex || 0);\n          if (dynamicBulletIndex > params.dynamicMainBullets - 1) {\n            dynamicBulletIndex = params.dynamicMainBullets - 1;\n          } else if (dynamicBulletIndex < 0) {\n            dynamicBulletIndex = 0;\n          }\n        }\n        firstIndex = Math.max(current - dynamicBulletIndex, 0);\n        lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1);\n        midIndex = (lastIndex + firstIndex) / 2;\n      }\n      bullets.forEach(bulletEl => {\n        const classesToRemove = [...['', '-next', '-next-next', '-prev', '-prev-prev', '-main'].map(suffix => `${params.bulletActiveClass}${suffix}`)].map(s => typeof s === 'string' && s.includes(' ') ? s.split(' ') : s).flat();\n        bulletEl.classList.remove(...classesToRemove);\n      });\n      if (el.length > 1) {\n        bullets.forEach(bullet => {\n          const bulletIndex = elementIndex(bullet);\n          if (bulletIndex === current) {\n            bullet.classList.add(...params.bulletActiveClass.split(' '));\n          } else if (swiper.isElement) {\n            bullet.setAttribute('part', 'bullet');\n          }\n          if (params.dynamicBullets) {\n            if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {\n              bullet.classList.add(...`${params.bulletActiveClass}-main`.split(' '));\n            }\n            if (bulletIndex === firstIndex) {\n              setSideBullets(bullet, 'prev');\n            }\n            if (bulletIndex === lastIndex) {\n              setSideBullets(bullet, 'next');\n            }\n          }\n        });\n      } else {\n        const bullet = bullets[current];\n        if (bullet) {\n          bullet.classList.add(...params.bulletActiveClass.split(' '));\n        }\n        if (swiper.isElement) {\n          bullets.forEach((bulletEl, bulletIndex) => {\n            bulletEl.setAttribute('part', bulletIndex === current ? 'bullet-active' : 'bullet');\n          });\n        }\n        if (params.dynamicBullets) {\n          const firstDisplayedBullet = bullets[firstIndex];\n          const lastDisplayedBullet = bullets[lastIndex];\n          for (let i = firstIndex; i <= lastIndex; i += 1) {\n            if (bullets[i]) {\n              bullets[i].classList.add(...`${params.bulletActiveClass}-main`.split(' '));\n            }\n          }\n          setSideBullets(firstDisplayedBullet, 'prev');\n          setSideBullets(lastDisplayedBullet, 'next');\n        }\n      }\n      if (params.dynamicBullets) {\n        const dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);\n        const bulletsOffset = (bulletSize * dynamicBulletsLength - bulletSize) / 2 - midIndex * bulletSize;\n        const offsetProp = rtl ? 'right' : 'left';\n        bullets.forEach(bullet => {\n          bullet.style[swiper.isHorizontal() ? offsetProp : 'top'] = `${bulletsOffset}px`;\n        });\n      }\n    }\n    el.forEach((subEl, subElIndex) => {\n      if (params.type === 'fraction') {\n        subEl.querySelectorAll(classesToSelector(params.currentClass)).forEach(fractionEl => {\n          fractionEl.textContent = params.formatFractionCurrent(current + 1);\n        });\n        subEl.querySelectorAll(classesToSelector(params.totalClass)).forEach(totalEl => {\n          totalEl.textContent = params.formatFractionTotal(total);\n        });\n      }\n      if (params.type === 'progressbar') {\n        let progressbarDirection;\n        if (params.progressbarOpposite) {\n          progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';\n        } else {\n          progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';\n        }\n        const scale = (current + 1) / total;\n        let scaleX = 1;\n        let scaleY = 1;\n        if (progressbarDirection === 'horizontal') {\n          scaleX = scale;\n        } else {\n          scaleY = scale;\n        }\n        subEl.querySelectorAll(classesToSelector(params.progressbarFillClass)).forEach(progressEl => {\n          progressEl.style.transform = `translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`;\n          progressEl.style.transitionDuration = `${swiper.params.speed}ms`;\n        });\n      }\n      if (params.type === 'custom' && params.renderCustom) {\n        subEl.innerHTML = params.renderCustom(swiper, current + 1, total);\n        if (subElIndex === 0) emit('paginationRender', subEl);\n      } else {\n        if (subElIndex === 0) emit('paginationRender', subEl);\n        emit('paginationUpdate', subEl);\n      }\n      if (swiper.params.watchOverflow && swiper.enabled) {\n        subEl.classList[swiper.isLocked ? 'add' : 'remove'](params.lockClass);\n      }\n    });\n  }\n  function render() {\n    // Render Container\n    const params = swiper.params.pagination;\n    if (isPaginationDisabled()) return;\n    const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.grid && swiper.params.grid.rows > 1 ? swiper.slides.length / Math.ceil(swiper.params.grid.rows) : swiper.slides.length;\n    let el = swiper.pagination.el;\n    el = makeElementsArray(el);\n    let paginationHTML = '';\n    if (params.type === 'bullets') {\n      let numberOfBullets = swiper.params.loop ? Math.ceil(slidesLength / swiper.params.slidesPerGroup) : swiper.snapGrid.length;\n      if (swiper.params.freeMode && swiper.params.freeMode.enabled && numberOfBullets > slidesLength) {\n        numberOfBullets = slidesLength;\n      }\n      for (let i = 0; i < numberOfBullets; i += 1) {\n        if (params.renderBullet) {\n          paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);\n        } else {\n          // prettier-ignore\n          paginationHTML += `<${params.bulletElement} ${swiper.isElement ? 'part=\"bullet\"' : ''} class=\"${params.bulletClass}\"></${params.bulletElement}>`;\n        }\n      }\n    }\n    if (params.type === 'fraction') {\n      if (params.renderFraction) {\n        paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);\n      } else {\n        paginationHTML = `<span class=\"${params.currentClass}\"></span>` + ' / ' + `<span class=\"${params.totalClass}\"></span>`;\n      }\n    }\n    if (params.type === 'progressbar') {\n      if (params.renderProgressbar) {\n        paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);\n      } else {\n        paginationHTML = `<span class=\"${params.progressbarFillClass}\"></span>`;\n      }\n    }\n    swiper.pagination.bullets = [];\n    el.forEach(subEl => {\n      if (params.type !== 'custom') {\n        subEl.innerHTML = paginationHTML || '';\n      }\n      if (params.type === 'bullets') {\n        swiper.pagination.bullets.push(...subEl.querySelectorAll(classesToSelector(params.bulletClass)));\n      }\n    });\n    if (params.type !== 'custom') {\n      emit('paginationRender', el[0]);\n    }\n  }\n  function init() {\n    swiper.params.pagination = createElementIfNotDefined(swiper, swiper.originalParams.pagination, swiper.params.pagination, {\n      el: 'swiper-pagination'\n    });\n    const params = swiper.params.pagination;\n    if (!params.el) return;\n    let el;\n    if (typeof params.el === 'string' && swiper.isElement) {\n      el = swiper.el.querySelector(params.el);\n    }\n    if (!el && typeof params.el === 'string') {\n      el = [...document.querySelectorAll(params.el)];\n    }\n    if (!el) {\n      el = params.el;\n    }\n    if (!el || el.length === 0) return;\n    if (swiper.params.uniqueNavElements && typeof params.el === 'string' && Array.isArray(el) && el.length > 1) {\n      el = [...swiper.el.querySelectorAll(params.el)];\n      // check if it belongs to another nested Swiper\n      if (el.length > 1) {\n        el = el.find(subEl => {\n          if (elementParents(subEl, '.swiper')[0] !== swiper.el) return false;\n          return true;\n        });\n      }\n    }\n    if (Array.isArray(el) && el.length === 1) el = el[0];\n    Object.assign(swiper.pagination, {\n      el\n    });\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      if (params.type === 'bullets' && params.clickable) {\n        subEl.classList.add(...(params.clickableClass || '').split(' '));\n      }\n      subEl.classList.add(params.modifierClass + params.type);\n      subEl.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n      if (params.type === 'bullets' && params.dynamicBullets) {\n        subEl.classList.add(`${params.modifierClass}${params.type}-dynamic`);\n        dynamicBulletIndex = 0;\n        if (params.dynamicMainBullets < 1) {\n          params.dynamicMainBullets = 1;\n        }\n      }\n      if (params.type === 'progressbar' && params.progressbarOpposite) {\n        subEl.classList.add(params.progressbarOppositeClass);\n      }\n      if (params.clickable) {\n        subEl.addEventListener('click', onBulletClick);\n      }\n      if (!swiper.enabled) {\n        subEl.classList.add(params.lockClass);\n      }\n    });\n  }\n  function destroy() {\n    const params = swiper.params.pagination;\n    if (isPaginationDisabled()) return;\n    let el = swiper.pagination.el;\n    if (el) {\n      el = makeElementsArray(el);\n      el.forEach(subEl => {\n        subEl.classList.remove(params.hiddenClass);\n        subEl.classList.remove(params.modifierClass + params.type);\n        subEl.classList.remove(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n        if (params.clickable) {\n          subEl.classList.remove(...(params.clickableClass || '').split(' '));\n          subEl.removeEventListener('click', onBulletClick);\n        }\n      });\n    }\n    if (swiper.pagination.bullets) swiper.pagination.bullets.forEach(subEl => subEl.classList.remove(...params.bulletActiveClass.split(' ')));\n  }\n  on('changeDirection', () => {\n    if (!swiper.pagination || !swiper.pagination.el) return;\n    const params = swiper.params.pagination;\n    let {\n      el\n    } = swiper.pagination;\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.classList.remove(params.horizontalClass, params.verticalClass);\n      subEl.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n    });\n  });\n  on('init', () => {\n    if (swiper.params.pagination.enabled === false) {\n      // eslint-disable-next-line\n      disable();\n    } else {\n      init();\n      render();\n      update();\n    }\n  });\n  on('activeIndexChange', () => {\n    if (typeof swiper.snapIndex === 'undefined') {\n      update();\n    }\n  });\n  on('snapIndexChange', () => {\n    update();\n  });\n  on('snapGridLengthChange', () => {\n    render();\n    update();\n  });\n  on('destroy', () => {\n    destroy();\n  });\n  on('enable disable', () => {\n    let {\n      el\n    } = swiper.pagination;\n    if (el) {\n      el = makeElementsArray(el);\n      el.forEach(subEl => subEl.classList[swiper.enabled ? 'remove' : 'add'](swiper.params.pagination.lockClass));\n    }\n  });\n  on('lock unlock', () => {\n    update();\n  });\n  on('click', (_s, e) => {\n    const targetEl = e.target;\n    const el = makeElementsArray(swiper.pagination.el);\n    if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && el && el.length > 0 && !targetEl.classList.contains(swiper.params.pagination.bulletClass)) {\n      if (swiper.navigation && (swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl || swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) return;\n      const isHidden = el[0].classList.contains(swiper.params.pagination.hiddenClass);\n      if (isHidden === true) {\n        emit('paginationShow');\n      } else {\n        emit('paginationHide');\n      }\n      el.forEach(subEl => subEl.classList.toggle(swiper.params.pagination.hiddenClass));\n    }\n  });\n  const enable = () => {\n    swiper.el.classList.remove(swiper.params.pagination.paginationDisabledClass);\n    let {\n      el\n    } = swiper.pagination;\n    if (el) {\n      el = makeElementsArray(el);\n      el.forEach(subEl => subEl.classList.remove(swiper.params.pagination.paginationDisabledClass));\n    }\n    init();\n    render();\n    update();\n  };\n  const disable = () => {\n    swiper.el.classList.add(swiper.params.pagination.paginationDisabledClass);\n    let {\n      el\n    } = swiper.pagination;\n    if (el) {\n      el = makeElementsArray(el);\n      el.forEach(subEl => subEl.classList.add(swiper.params.pagination.paginationDisabledClass));\n    }\n    destroy();\n  };\n  Object.assign(swiper.pagination, {\n    enable,\n    disable,\n    render,\n    update,\n    init,\n    destroy\n  });\n}\n\nexport { Pagination as default };\n","import { e as elementChildren } from '../shared/utils.mjs';\n\nfunction Parallax(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    parallax: {\n      enabled: false\n    }\n  });\n  const elementsSelector = '[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]';\n  const setTransform = (el, progress) => {\n    const {\n      rtl\n    } = swiper;\n    const rtlFactor = rtl ? -1 : 1;\n    const p = el.getAttribute('data-swiper-parallax') || '0';\n    let x = el.getAttribute('data-swiper-parallax-x');\n    let y = el.getAttribute('data-swiper-parallax-y');\n    const scale = el.getAttribute('data-swiper-parallax-scale');\n    const opacity = el.getAttribute('data-swiper-parallax-opacity');\n    const rotate = el.getAttribute('data-swiper-parallax-rotate');\n    if (x || y) {\n      x = x || '0';\n      y = y || '0';\n    } else if (swiper.isHorizontal()) {\n      x = p;\n      y = '0';\n    } else {\n      y = p;\n      x = '0';\n    }\n    if (x.indexOf('%') >= 0) {\n      x = `${parseInt(x, 10) * progress * rtlFactor}%`;\n    } else {\n      x = `${x * progress * rtlFactor}px`;\n    }\n    if (y.indexOf('%') >= 0) {\n      y = `${parseInt(y, 10) * progress}%`;\n    } else {\n      y = `${y * progress}px`;\n    }\n    if (typeof opacity !== 'undefined' && opacity !== null) {\n      const currentOpacity = opacity - (opacity - 1) * (1 - Math.abs(progress));\n      el.style.opacity = currentOpacity;\n    }\n    let transform = `translate3d(${x}, ${y}, 0px)`;\n    if (typeof scale !== 'undefined' && scale !== null) {\n      const currentScale = scale - (scale - 1) * (1 - Math.abs(progress));\n      transform += ` scale(${currentScale})`;\n    }\n    if (rotate && typeof rotate !== 'undefined' && rotate !== null) {\n      const currentRotate = rotate * progress * -1;\n      transform += ` rotate(${currentRotate}deg)`;\n    }\n    el.style.transform = transform;\n  };\n  const setTranslate = () => {\n    const {\n      el,\n      slides,\n      progress,\n      snapGrid,\n      isElement\n    } = swiper;\n    const elements = elementChildren(el, elementsSelector);\n    if (swiper.isElement) {\n      elements.push(...elementChildren(swiper.hostEl, elementsSelector));\n    }\n    elements.forEach(subEl => {\n      setTransform(subEl, progress);\n    });\n    slides.forEach((slideEl, slideIndex) => {\n      let slideProgress = slideEl.progress;\n      if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== 'auto') {\n        slideProgress += Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1);\n      }\n      slideProgress = Math.min(Math.max(slideProgress, -1), 1);\n      slideEl.querySelectorAll(`${elementsSelector}, [data-swiper-parallax-rotate]`).forEach(subEl => {\n        setTransform(subEl, slideProgress);\n      });\n    });\n  };\n  const setTransition = function (duration) {\n    if (duration === void 0) {\n      duration = swiper.params.speed;\n    }\n    const {\n      el,\n      hostEl\n    } = swiper;\n    const elements = [...el.querySelectorAll(elementsSelector)];\n    if (swiper.isElement) {\n      elements.push(...hostEl.querySelectorAll(elementsSelector));\n    }\n    elements.forEach(parallaxEl => {\n      let parallaxDuration = parseInt(parallaxEl.getAttribute('data-swiper-parallax-duration'), 10) || duration;\n      if (duration === 0) parallaxDuration = 0;\n      parallaxEl.style.transitionDuration = `${parallaxDuration}ms`;\n    });\n  };\n  on('beforeInit', () => {\n    if (!swiper.params.parallax.enabled) return;\n    swiper.params.watchSlidesProgress = true;\n    swiper.originalParams.watchSlidesProgress = true;\n  });\n  on('init', () => {\n    if (!swiper.params.parallax.enabled) return;\n    setTranslate();\n  });\n  on('setTranslate', () => {\n    if (!swiper.params.parallax.enabled) return;\n    setTranslate();\n  });\n  on('setTransition', (_swiper, duration) => {\n    if (!swiper.params.parallax.enabled) return;\n    setTransition(duration);\n  });\n}\n\nexport { Parallax as default };\n","import { g as getDocument } from '../shared/ssr-window.esm.mjs';\nimport { m as makeElementsArray, i as classesToTokens, c as createElement, n as nextTick, b as elementOffset } from '../shared/utils.mjs';\nimport { c as createElementIfNotDefined } from '../shared/create-element-if-not-defined.mjs';\nimport { c as classesToSelector } from '../shared/classes-to-selector.mjs';\n\nfunction Scrollbar(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on,\n    emit\n  } = _ref;\n  const document = getDocument();\n  let isTouched = false;\n  let timeout = null;\n  let dragTimeout = null;\n  let dragStartPos;\n  let dragSize;\n  let trackSize;\n  let divider;\n  extendParams({\n    scrollbar: {\n      el: null,\n      dragSize: 'auto',\n      hide: false,\n      draggable: false,\n      snapOnRelease: true,\n      lockClass: 'swiper-scrollbar-lock',\n      dragClass: 'swiper-scrollbar-drag',\n      scrollbarDisabledClass: 'swiper-scrollbar-disabled',\n      horizontalClass: `swiper-scrollbar-horizontal`,\n      verticalClass: `swiper-scrollbar-vertical`\n    }\n  });\n  swiper.scrollbar = {\n    el: null,\n    dragEl: null\n  };\n  function setTranslate() {\n    if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n    const {\n      scrollbar,\n      rtlTranslate: rtl\n    } = swiper;\n    const {\n      dragEl,\n      el\n    } = scrollbar;\n    const params = swiper.params.scrollbar;\n    const progress = swiper.params.loop ? swiper.progressLoop : swiper.progress;\n    let newSize = dragSize;\n    let newPos = (trackSize - dragSize) * progress;\n    if (rtl) {\n      newPos = -newPos;\n      if (newPos > 0) {\n        newSize = dragSize - newPos;\n        newPos = 0;\n      } else if (-newPos + dragSize > trackSize) {\n        newSize = trackSize + newPos;\n      }\n    } else if (newPos < 0) {\n      newSize = dragSize + newPos;\n      newPos = 0;\n    } else if (newPos + dragSize > trackSize) {\n      newSize = trackSize - newPos;\n    }\n    if (swiper.isHorizontal()) {\n      dragEl.style.transform = `translate3d(${newPos}px, 0, 0)`;\n      dragEl.style.width = `${newSize}px`;\n    } else {\n      dragEl.style.transform = `translate3d(0px, ${newPos}px, 0)`;\n      dragEl.style.height = `${newSize}px`;\n    }\n    if (params.hide) {\n      clearTimeout(timeout);\n      el.style.opacity = 1;\n      timeout = setTimeout(() => {\n        el.style.opacity = 0;\n        el.style.transitionDuration = '400ms';\n      }, 1000);\n    }\n  }\n  function setTransition(duration) {\n    if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n    swiper.scrollbar.dragEl.style.transitionDuration = `${duration}ms`;\n  }\n  function updateSize() {\n    if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n    const {\n      scrollbar\n    } = swiper;\n    const {\n      dragEl,\n      el\n    } = scrollbar;\n    dragEl.style.width = '';\n    dragEl.style.height = '';\n    trackSize = swiper.isHorizontal() ? el.offsetWidth : el.offsetHeight;\n    divider = swiper.size / (swiper.virtualSize + swiper.params.slidesOffsetBefore - (swiper.params.centeredSlides ? swiper.snapGrid[0] : 0));\n    if (swiper.params.scrollbar.dragSize === 'auto') {\n      dragSize = trackSize * divider;\n    } else {\n      dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);\n    }\n    if (swiper.isHorizontal()) {\n      dragEl.style.width = `${dragSize}px`;\n    } else {\n      dragEl.style.height = `${dragSize}px`;\n    }\n    if (divider >= 1) {\n      el.style.display = 'none';\n    } else {\n      el.style.display = '';\n    }\n    if (swiper.params.scrollbar.hide) {\n      el.style.opacity = 0;\n    }\n    if (swiper.params.watchOverflow && swiper.enabled) {\n      scrollbar.el.classList[swiper.isLocked ? 'add' : 'remove'](swiper.params.scrollbar.lockClass);\n    }\n  }\n  function getPointerPosition(e) {\n    return swiper.isHorizontal() ? e.clientX : e.clientY;\n  }\n  function setDragPosition(e) {\n    const {\n      scrollbar,\n      rtlTranslate: rtl\n    } = swiper;\n    const {\n      el\n    } = scrollbar;\n    let positionRatio;\n    positionRatio = (getPointerPosition(e) - elementOffset(el)[swiper.isHorizontal() ? 'left' : 'top'] - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);\n    positionRatio = Math.max(Math.min(positionRatio, 1), 0);\n    if (rtl) {\n      positionRatio = 1 - positionRatio;\n    }\n    const position = swiper.minTranslate() + (swiper.maxTranslate() - swiper.minTranslate()) * positionRatio;\n    swiper.updateProgress(position);\n    swiper.setTranslate(position);\n    swiper.updateActiveIndex();\n    swiper.updateSlidesClasses();\n  }\n  function onDragStart(e) {\n    const params = swiper.params.scrollbar;\n    const {\n      scrollbar,\n      wrapperEl\n    } = swiper;\n    const {\n      el,\n      dragEl\n    } = scrollbar;\n    isTouched = true;\n    dragStartPos = e.target === dragEl ? getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left' : 'top'] : null;\n    e.preventDefault();\n    e.stopPropagation();\n    wrapperEl.style.transitionDuration = '100ms';\n    dragEl.style.transitionDuration = '100ms';\n    setDragPosition(e);\n    clearTimeout(dragTimeout);\n    el.style.transitionDuration = '0ms';\n    if (params.hide) {\n      el.style.opacity = 1;\n    }\n    if (swiper.params.cssMode) {\n      swiper.wrapperEl.style['scroll-snap-type'] = 'none';\n    }\n    emit('scrollbarDragStart', e);\n  }\n  function onDragMove(e) {\n    const {\n      scrollbar,\n      wrapperEl\n    } = swiper;\n    const {\n      el,\n      dragEl\n    } = scrollbar;\n    if (!isTouched) return;\n    if (e.preventDefault && e.cancelable) e.preventDefault();else e.returnValue = false;\n    setDragPosition(e);\n    wrapperEl.style.transitionDuration = '0ms';\n    el.style.transitionDuration = '0ms';\n    dragEl.style.transitionDuration = '0ms';\n    emit('scrollbarDragMove', e);\n  }\n  function onDragEnd(e) {\n    const params = swiper.params.scrollbar;\n    const {\n      scrollbar,\n      wrapperEl\n    } = swiper;\n    const {\n      el\n    } = scrollbar;\n    if (!isTouched) return;\n    isTouched = false;\n    if (swiper.params.cssMode) {\n      swiper.wrapperEl.style['scroll-snap-type'] = '';\n      wrapperEl.style.transitionDuration = '';\n    }\n    if (params.hide) {\n      clearTimeout(dragTimeout);\n      dragTimeout = nextTick(() => {\n        el.style.opacity = 0;\n        el.style.transitionDuration = '400ms';\n      }, 1000);\n    }\n    emit('scrollbarDragEnd', e);\n    if (params.snapOnRelease) {\n      swiper.slideToClosest();\n    }\n  }\n  function events(method) {\n    const {\n      scrollbar,\n      params\n    } = swiper;\n    const el = scrollbar.el;\n    if (!el) return;\n    const target = el;\n    const activeListener = params.passiveListeners ? {\n      passive: false,\n      capture: false\n    } : false;\n    const passiveListener = params.passiveListeners ? {\n      passive: true,\n      capture: false\n    } : false;\n    if (!target) return;\n    const eventMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n    target[eventMethod]('pointerdown', onDragStart, activeListener);\n    document[eventMethod]('pointermove', onDragMove, activeListener);\n    document[eventMethod]('pointerup', onDragEnd, passiveListener);\n  }\n  function enableDraggable() {\n    if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n    events('on');\n  }\n  function disableDraggable() {\n    if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;\n    events('off');\n  }\n  function init() {\n    const {\n      scrollbar,\n      el: swiperEl\n    } = swiper;\n    swiper.params.scrollbar = createElementIfNotDefined(swiper, swiper.originalParams.scrollbar, swiper.params.scrollbar, {\n      el: 'swiper-scrollbar'\n    });\n    const params = swiper.params.scrollbar;\n    if (!params.el) return;\n    let el;\n    if (typeof params.el === 'string' && swiper.isElement) {\n      el = swiper.el.querySelector(params.el);\n    }\n    if (!el && typeof params.el === 'string') {\n      el = document.querySelectorAll(params.el);\n      if (!el.length) return;\n    } else if (!el) {\n      el = params.el;\n    }\n    if (swiper.params.uniqueNavElements && typeof params.el === 'string' && el.length > 1 && swiperEl.querySelectorAll(params.el).length === 1) {\n      el = swiperEl.querySelector(params.el);\n    }\n    if (el.length > 0) el = el[0];\n    el.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n    let dragEl;\n    if (el) {\n      dragEl = el.querySelector(classesToSelector(swiper.params.scrollbar.dragClass));\n      if (!dragEl) {\n        dragEl = createElement('div', swiper.params.scrollbar.dragClass);\n        el.append(dragEl);\n      }\n    }\n    Object.assign(scrollbar, {\n      el,\n      dragEl\n    });\n    if (params.draggable) {\n      enableDraggable();\n    }\n    if (el) {\n      el.classList[swiper.enabled ? 'remove' : 'add'](...classesToTokens(swiper.params.scrollbar.lockClass));\n    }\n  }\n  function destroy() {\n    const params = swiper.params.scrollbar;\n    const el = swiper.scrollbar.el;\n    if (el) {\n      el.classList.remove(...classesToTokens(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass));\n    }\n    disableDraggable();\n  }\n  on('changeDirection', () => {\n    if (!swiper.scrollbar || !swiper.scrollbar.el) return;\n    const params = swiper.params.scrollbar;\n    let {\n      el\n    } = swiper.scrollbar;\n    el = makeElementsArray(el);\n    el.forEach(subEl => {\n      subEl.classList.remove(params.horizontalClass, params.verticalClass);\n      subEl.classList.add(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);\n    });\n  });\n  on('init', () => {\n    if (swiper.params.scrollbar.enabled === false) {\n      // eslint-disable-next-line\n      disable();\n    } else {\n      init();\n      updateSize();\n      setTranslate();\n    }\n  });\n  on('update resize observerUpdate lock unlock changeDirection', () => {\n    updateSize();\n  });\n  on('setTranslate', () => {\n    setTranslate();\n  });\n  on('setTransition', (_s, duration) => {\n    setTransition(duration);\n  });\n  on('enable disable', () => {\n    const {\n      el\n    } = swiper.scrollbar;\n    if (el) {\n      el.classList[swiper.enabled ? 'remove' : 'add'](...classesToTokens(swiper.params.scrollbar.lockClass));\n    }\n  });\n  on('destroy', () => {\n    destroy();\n  });\n  const enable = () => {\n    swiper.el.classList.remove(...classesToTokens(swiper.params.scrollbar.scrollbarDisabledClass));\n    if (swiper.scrollbar.el) {\n      swiper.scrollbar.el.classList.remove(...classesToTokens(swiper.params.scrollbar.scrollbarDisabledClass));\n    }\n    init();\n    updateSize();\n    setTranslate();\n  };\n  const disable = () => {\n    swiper.el.classList.add(...classesToTokens(swiper.params.scrollbar.scrollbarDisabledClass));\n    if (swiper.scrollbar.el) {\n      swiper.scrollbar.el.classList.add(...classesToTokens(swiper.params.scrollbar.scrollbarDisabledClass));\n    }\n    destroy();\n  };\n  Object.assign(swiper.scrollbar, {\n    enable,\n    disable,\n    updateSize,\n    setTranslate,\n    init,\n    destroy\n  });\n}\n\nexport { Scrollbar as default };\n","import { g as getDocument } from '../shared/ssr-window.esm.mjs';\nimport { l as isObject, e as elementChildren } from '../shared/utils.mjs';\n\nfunction Thumb(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on\n  } = _ref;\n  extendParams({\n    thumbs: {\n      swiper: null,\n      multipleActiveThumbs: true,\n      autoScrollOffset: 0,\n      slideThumbActiveClass: 'swiper-slide-thumb-active',\n      thumbsContainerClass: 'swiper-thumbs'\n    }\n  });\n  let initialized = false;\n  let swiperCreated = false;\n  swiper.thumbs = {\n    swiper: null\n  };\n  function onThumbClick() {\n    const thumbsSwiper = swiper.thumbs.swiper;\n    if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n    const clickedIndex = thumbsSwiper.clickedIndex;\n    const clickedSlide = thumbsSwiper.clickedSlide;\n    if (clickedSlide && clickedSlide.classList.contains(swiper.params.thumbs.slideThumbActiveClass)) return;\n    if (typeof clickedIndex === 'undefined' || clickedIndex === null) return;\n    let slideToIndex;\n    if (thumbsSwiper.params.loop) {\n      slideToIndex = parseInt(thumbsSwiper.clickedSlide.getAttribute('data-swiper-slide-index'), 10);\n    } else {\n      slideToIndex = clickedIndex;\n    }\n    if (swiper.params.loop) {\n      swiper.slideToLoop(slideToIndex);\n    } else {\n      swiper.slideTo(slideToIndex);\n    }\n  }\n  function init() {\n    const {\n      thumbs: thumbsParams\n    } = swiper.params;\n    if (initialized) return false;\n    initialized = true;\n    const SwiperClass = swiper.constructor;\n    if (thumbsParams.swiper instanceof SwiperClass) {\n      if (thumbsParams.swiper.destroyed) {\n        initialized = false;\n        return false;\n      }\n      swiper.thumbs.swiper = thumbsParams.swiper;\n      Object.assign(swiper.thumbs.swiper.originalParams, {\n        watchSlidesProgress: true,\n        slideToClickedSlide: false\n      });\n      Object.assign(swiper.thumbs.swiper.params, {\n        watchSlidesProgress: true,\n        slideToClickedSlide: false\n      });\n      swiper.thumbs.swiper.update();\n    } else if (isObject(thumbsParams.swiper)) {\n      const thumbsSwiperParams = Object.assign({}, thumbsParams.swiper);\n      Object.assign(thumbsSwiperParams, {\n        watchSlidesProgress: true,\n        slideToClickedSlide: false\n      });\n      swiper.thumbs.swiper = new SwiperClass(thumbsSwiperParams);\n      swiperCreated = true;\n    }\n    swiper.thumbs.swiper.el.classList.add(swiper.params.thumbs.thumbsContainerClass);\n    swiper.thumbs.swiper.on('tap', onThumbClick);\n    return true;\n  }\n  function update(initial) {\n    const thumbsSwiper = swiper.thumbs.swiper;\n    if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n    const slidesPerView = thumbsSwiper.params.slidesPerView === 'auto' ? thumbsSwiper.slidesPerViewDynamic() : thumbsSwiper.params.slidesPerView;\n\n    // Activate thumbs\n    let thumbsToActivate = 1;\n    const thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;\n    if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) {\n      thumbsToActivate = swiper.params.slidesPerView;\n    }\n    if (!swiper.params.thumbs.multipleActiveThumbs) {\n      thumbsToActivate = 1;\n    }\n    thumbsToActivate = Math.floor(thumbsToActivate);\n    thumbsSwiper.slides.forEach(slideEl => slideEl.classList.remove(thumbActiveClass));\n    if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual && thumbsSwiper.params.virtual.enabled) {\n      for (let i = 0; i < thumbsToActivate; i += 1) {\n        elementChildren(thumbsSwiper.slidesEl, `[data-swiper-slide-index=\"${swiper.realIndex + i}\"]`).forEach(slideEl => {\n          slideEl.classList.add(thumbActiveClass);\n        });\n      }\n    } else {\n      for (let i = 0; i < thumbsToActivate; i += 1) {\n        if (thumbsSwiper.slides[swiper.realIndex + i]) {\n          thumbsSwiper.slides[swiper.realIndex + i].classList.add(thumbActiveClass);\n        }\n      }\n    }\n    const autoScrollOffset = swiper.params.thumbs.autoScrollOffset;\n    const useOffset = autoScrollOffset && !thumbsSwiper.params.loop;\n    if (swiper.realIndex !== thumbsSwiper.realIndex || useOffset) {\n      const currentThumbsIndex = thumbsSwiper.activeIndex;\n      let newThumbsIndex;\n      let direction;\n      if (thumbsSwiper.params.loop) {\n        const newThumbsSlide = thumbsSwiper.slides.find(slideEl => slideEl.getAttribute('data-swiper-slide-index') === `${swiper.realIndex}`);\n        newThumbsIndex = thumbsSwiper.slides.indexOf(newThumbsSlide);\n        direction = swiper.activeIndex > swiper.previousIndex ? 'next' : 'prev';\n      } else {\n        newThumbsIndex = swiper.realIndex;\n        direction = newThumbsIndex > swiper.previousIndex ? 'next' : 'prev';\n      }\n      if (useOffset) {\n        newThumbsIndex += direction === 'next' ? autoScrollOffset : -1 * autoScrollOffset;\n      }\n      if (thumbsSwiper.visibleSlidesIndexes && thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0) {\n        if (thumbsSwiper.params.centeredSlides) {\n          if (newThumbsIndex > currentThumbsIndex) {\n            newThumbsIndex = newThumbsIndex - Math.floor(slidesPerView / 2) + 1;\n          } else {\n            newThumbsIndex = newThumbsIndex + Math.floor(slidesPerView / 2) - 1;\n          }\n        } else if (newThumbsIndex > currentThumbsIndex && thumbsSwiper.params.slidesPerGroup === 1) ;\n        thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);\n      }\n    }\n  }\n  on('beforeInit', () => {\n    const {\n      thumbs\n    } = swiper.params;\n    if (!thumbs || !thumbs.swiper) return;\n    if (typeof thumbs.swiper === 'string' || thumbs.swiper instanceof HTMLElement) {\n      const document = getDocument();\n      const getThumbsElementAndInit = () => {\n        const thumbsElement = typeof thumbs.swiper === 'string' ? document.querySelector(thumbs.swiper) : thumbs.swiper;\n        if (thumbsElement && thumbsElement.swiper) {\n          thumbs.swiper = thumbsElement.swiper;\n          init();\n          update(true);\n        } else if (thumbsElement) {\n          const eventName = `${swiper.params.eventsPrefix}init`;\n          const onThumbsSwiper = e => {\n            thumbs.swiper = e.detail[0];\n            thumbsElement.removeEventListener(eventName, onThumbsSwiper);\n            init();\n            update(true);\n            thumbs.swiper.update();\n            swiper.update();\n          };\n          thumbsElement.addEventListener(eventName, onThumbsSwiper);\n        }\n        return thumbsElement;\n      };\n      const watchForThumbsToAppear = () => {\n        if (swiper.destroyed) return;\n        const thumbsElement = getThumbsElementAndInit();\n        if (!thumbsElement) {\n          requestAnimationFrame(watchForThumbsToAppear);\n        }\n      };\n      requestAnimationFrame(watchForThumbsToAppear);\n    } else {\n      init();\n      update(true);\n    }\n  });\n  on('slideChange update resize observerUpdate', () => {\n    update();\n  });\n  on('setTransition', (_s, duration) => {\n    const thumbsSwiper = swiper.thumbs.swiper;\n    if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n    thumbsSwiper.setTransition(duration);\n  });\n  on('beforeDestroy', () => {\n    const thumbsSwiper = swiper.thumbs.swiper;\n    if (!thumbsSwiper || thumbsSwiper.destroyed) return;\n    if (swiperCreated) {\n      thumbsSwiper.destroy();\n    }\n  });\n  Object.assign(swiper.thumbs, {\n    init,\n    update\n  });\n}\n\nexport { Thumb as default };\n","import { g as getDocument } from '../shared/ssr-window.esm.mjs';\nimport { s as setCSSProperty, e as elementChildren, c as createElement } from '../shared/utils.mjs';\n\nfunction Virtual(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on,\n    emit\n  } = _ref;\n  extendParams({\n    virtual: {\n      enabled: false,\n      slides: [],\n      cache: true,\n      renderSlide: null,\n      renderExternal: null,\n      renderExternalUpdate: true,\n      addSlidesBefore: 0,\n      addSlidesAfter: 0\n    }\n  });\n  let cssModeTimeout;\n  const document = getDocument();\n  swiper.virtual = {\n    cache: {},\n    from: undefined,\n    to: undefined,\n    slides: [],\n    offset: 0,\n    slidesGrid: []\n  };\n  const tempDOM = document.createElement('div');\n  function renderSlide(slide, index) {\n    const params = swiper.params.virtual;\n    if (params.cache && swiper.virtual.cache[index]) {\n      return swiper.virtual.cache[index];\n    }\n    // eslint-disable-next-line\n    let slideEl;\n    if (params.renderSlide) {\n      slideEl = params.renderSlide.call(swiper, slide, index);\n      if (typeof slideEl === 'string') {\n        tempDOM.innerHTML = slideEl;\n        slideEl = tempDOM.children[0];\n      }\n    } else if (swiper.isElement) {\n      slideEl = createElement('swiper-slide');\n    } else {\n      slideEl = createElement('div', swiper.params.slideClass);\n    }\n    slideEl.setAttribute('data-swiper-slide-index', index);\n    if (!params.renderSlide) {\n      slideEl.innerHTML = slide;\n    }\n    if (params.cache) {\n      swiper.virtual.cache[index] = slideEl;\n    }\n    return slideEl;\n  }\n  function update(force, beforeInit, forceActiveIndex) {\n    const {\n      slidesPerView,\n      slidesPerGroup,\n      centeredSlides,\n      loop: isLoop,\n      initialSlide\n    } = swiper.params;\n    if (beforeInit && !isLoop && initialSlide > 0) {\n      return;\n    }\n    const {\n      addSlidesBefore,\n      addSlidesAfter\n    } = swiper.params.virtual;\n    const {\n      from: previousFrom,\n      to: previousTo,\n      slides,\n      slidesGrid: previousSlidesGrid,\n      offset: previousOffset\n    } = swiper.virtual;\n    if (!swiper.params.cssMode) {\n      swiper.updateActiveIndex();\n    }\n    const activeIndex = typeof forceActiveIndex === 'undefined' ? swiper.activeIndex || 0 : forceActiveIndex;\n    let offsetProp;\n    if (swiper.rtlTranslate) offsetProp = 'right';else offsetProp = swiper.isHorizontal() ? 'left' : 'top';\n    let slidesAfter;\n    let slidesBefore;\n    if (centeredSlides) {\n      slidesAfter = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter;\n      slidesBefore = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore;\n    } else {\n      slidesAfter = slidesPerView + (slidesPerGroup - 1) + addSlidesAfter;\n      slidesBefore = (isLoop ? slidesPerView : slidesPerGroup) + addSlidesBefore;\n    }\n    let from = activeIndex - slidesBefore;\n    let to = activeIndex + slidesAfter;\n    if (!isLoop) {\n      from = Math.max(from, 0);\n      to = Math.min(to, slides.length - 1);\n    }\n    let offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);\n    if (isLoop && activeIndex >= slidesBefore) {\n      from -= slidesBefore;\n      if (!centeredSlides) offset += swiper.slidesGrid[0];\n    } else if (isLoop && activeIndex < slidesBefore) {\n      from = -slidesBefore;\n      if (centeredSlides) offset += swiper.slidesGrid[0];\n    }\n    Object.assign(swiper.virtual, {\n      from,\n      to,\n      offset,\n      slidesGrid: swiper.slidesGrid,\n      slidesBefore,\n      slidesAfter\n    });\n    function onRendered() {\n      swiper.updateSlides();\n      swiper.updateProgress();\n      swiper.updateSlidesClasses();\n      emit('virtualUpdate');\n    }\n    if (previousFrom === from && previousTo === to && !force) {\n      if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) {\n        swiper.slides.forEach(slideEl => {\n          slideEl.style[offsetProp] = `${offset - Math.abs(swiper.cssOverflowAdjustment())}px`;\n        });\n      }\n      swiper.updateProgress();\n      emit('virtualUpdate');\n      return;\n    }\n    if (swiper.params.virtual.renderExternal) {\n      swiper.params.virtual.renderExternal.call(swiper, {\n        offset,\n        from,\n        to,\n        slides: function getSlides() {\n          const slidesToRender = [];\n          for (let i = from; i <= to; i += 1) {\n            slidesToRender.push(slides[i]);\n          }\n          return slidesToRender;\n        }()\n      });\n      if (swiper.params.virtual.renderExternalUpdate) {\n        onRendered();\n      } else {\n        emit('virtualUpdate');\n      }\n      return;\n    }\n    const prependIndexes = [];\n    const appendIndexes = [];\n    const getSlideIndex = index => {\n      let slideIndex = index;\n      if (index < 0) {\n        slideIndex = slides.length + index;\n      } else if (slideIndex >= slides.length) {\n        // eslint-disable-next-line\n        slideIndex = slideIndex - slides.length;\n      }\n      return slideIndex;\n    };\n    if (force) {\n      swiper.slides.filter(el => el.matches(`.${swiper.params.slideClass}, swiper-slide`)).forEach(slideEl => {\n        slideEl.remove();\n      });\n    } else {\n      for (let i = previousFrom; i <= previousTo; i += 1) {\n        if (i < from || i > to) {\n          const slideIndex = getSlideIndex(i);\n          swiper.slides.filter(el => el.matches(`.${swiper.params.slideClass}[data-swiper-slide-index=\"${slideIndex}\"], swiper-slide[data-swiper-slide-index=\"${slideIndex}\"]`)).forEach(slideEl => {\n            slideEl.remove();\n          });\n        }\n      }\n    }\n    const loopFrom = isLoop ? -slides.length : 0;\n    const loopTo = isLoop ? slides.length * 2 : slides.length;\n    for (let i = loopFrom; i < loopTo; i += 1) {\n      if (i >= from && i <= to) {\n        const slideIndex = getSlideIndex(i);\n        if (typeof previousTo === 'undefined' || force) {\n          appendIndexes.push(slideIndex);\n        } else {\n          if (i > previousTo) appendIndexes.push(slideIndex);\n          if (i < previousFrom) prependIndexes.push(slideIndex);\n        }\n      }\n    }\n    appendIndexes.forEach(index => {\n      swiper.slidesEl.append(renderSlide(slides[index], index));\n    });\n    if (isLoop) {\n      for (let i = prependIndexes.length - 1; i >= 0; i -= 1) {\n        const index = prependIndexes[i];\n        swiper.slidesEl.prepend(renderSlide(slides[index], index));\n      }\n    } else {\n      prependIndexes.sort((a, b) => b - a);\n      prependIndexes.forEach(index => {\n        swiper.slidesEl.prepend(renderSlide(slides[index], index));\n      });\n    }\n    elementChildren(swiper.slidesEl, '.swiper-slide, swiper-slide').forEach(slideEl => {\n      slideEl.style[offsetProp] = `${offset - Math.abs(swiper.cssOverflowAdjustment())}px`;\n    });\n    onRendered();\n  }\n  function appendSlide(slides) {\n    if (typeof slides === 'object' && 'length' in slides) {\n      for (let i = 0; i < slides.length; i += 1) {\n        if (slides[i]) swiper.virtual.slides.push(slides[i]);\n      }\n    } else {\n      swiper.virtual.slides.push(slides);\n    }\n    update(true);\n  }\n  function prependSlide(slides) {\n    const activeIndex = swiper.activeIndex;\n    let newActiveIndex = activeIndex + 1;\n    let numberOfNewSlides = 1;\n    if (Array.isArray(slides)) {\n      for (let i = 0; i < slides.length; i += 1) {\n        if (slides[i]) swiper.virtual.slides.unshift(slides[i]);\n      }\n      newActiveIndex = activeIndex + slides.length;\n      numberOfNewSlides = slides.length;\n    } else {\n      swiper.virtual.slides.unshift(slides);\n    }\n    if (swiper.params.virtual.cache) {\n      const cache = swiper.virtual.cache;\n      const newCache = {};\n      Object.keys(cache).forEach(cachedIndex => {\n        const cachedEl = cache[cachedIndex];\n        const cachedElIndex = cachedEl.getAttribute('data-swiper-slide-index');\n        if (cachedElIndex) {\n          cachedEl.setAttribute('data-swiper-slide-index', parseInt(cachedElIndex, 10) + numberOfNewSlides);\n        }\n        newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = cachedEl;\n      });\n      swiper.virtual.cache = newCache;\n    }\n    update(true);\n    swiper.slideTo(newActiveIndex, 0);\n  }\n  function removeSlide(slidesIndexes) {\n    if (typeof slidesIndexes === 'undefined' || slidesIndexes === null) return;\n    let activeIndex = swiper.activeIndex;\n    if (Array.isArray(slidesIndexes)) {\n      for (let i = slidesIndexes.length - 1; i >= 0; i -= 1) {\n        if (swiper.params.virtual.cache) {\n          delete swiper.virtual.cache[slidesIndexes[i]];\n          // shift cache indexes\n          Object.keys(swiper.virtual.cache).forEach(key => {\n            if (key > slidesIndexes) {\n              swiper.virtual.cache[key - 1] = swiper.virtual.cache[key];\n              swiper.virtual.cache[key - 1].setAttribute('data-swiper-slide-index', key - 1);\n              delete swiper.virtual.cache[key];\n            }\n          });\n        }\n        swiper.virtual.slides.splice(slidesIndexes[i], 1);\n        if (slidesIndexes[i] < activeIndex) activeIndex -= 1;\n        activeIndex = Math.max(activeIndex, 0);\n      }\n    } else {\n      if (swiper.params.virtual.cache) {\n        delete swiper.virtual.cache[slidesIndexes];\n        // shift cache indexes\n        Object.keys(swiper.virtual.cache).forEach(key => {\n          if (key > slidesIndexes) {\n            swiper.virtual.cache[key - 1] = swiper.virtual.cache[key];\n            swiper.virtual.cache[key - 1].setAttribute('data-swiper-slide-index', key - 1);\n            delete swiper.virtual.cache[key];\n          }\n        });\n      }\n      swiper.virtual.slides.splice(slidesIndexes, 1);\n      if (slidesIndexes < activeIndex) activeIndex -= 1;\n      activeIndex = Math.max(activeIndex, 0);\n    }\n    update(true);\n    swiper.slideTo(activeIndex, 0);\n  }\n  function removeAllSlides() {\n    swiper.virtual.slides = [];\n    if (swiper.params.virtual.cache) {\n      swiper.virtual.cache = {};\n    }\n    update(true);\n    swiper.slideTo(0, 0);\n  }\n  on('beforeInit', () => {\n    if (!swiper.params.virtual.enabled) return;\n    let domSlidesAssigned;\n    if (typeof swiper.passedParams.virtual.slides === 'undefined') {\n      const slides = [...swiper.slidesEl.children].filter(el => el.matches(`.${swiper.params.slideClass}, swiper-slide`));\n      if (slides && slides.length) {\n        swiper.virtual.slides = [...slides];\n        domSlidesAssigned = true;\n        slides.forEach((slideEl, slideIndex) => {\n          slideEl.setAttribute('data-swiper-slide-index', slideIndex);\n          swiper.virtual.cache[slideIndex] = slideEl;\n          slideEl.remove();\n        });\n      }\n    }\n    if (!domSlidesAssigned) {\n      swiper.virtual.slides = swiper.params.virtual.slides;\n    }\n    swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`);\n    swiper.params.watchSlidesProgress = true;\n    swiper.originalParams.watchSlidesProgress = true;\n    update(false, true);\n  });\n  on('setTranslate', () => {\n    if (!swiper.params.virtual.enabled) return;\n    if (swiper.params.cssMode && !swiper._immediateVirtual) {\n      clearTimeout(cssModeTimeout);\n      cssModeTimeout = setTimeout(() => {\n        update();\n      }, 100);\n    } else {\n      update();\n    }\n  });\n  on('init update resize', () => {\n    if (!swiper.params.virtual.enabled) return;\n    if (swiper.params.cssMode) {\n      setCSSProperty(swiper.wrapperEl, '--swiper-virtual-size', `${swiper.virtualSize}px`);\n    }\n  });\n  Object.assign(swiper.virtual, {\n    appendSlide,\n    prependSlide,\n    removeSlide,\n    removeAllSlides,\n    update\n  });\n}\n\nexport { Virtual as default };\n","import { a as getWindow } from '../shared/ssr-window.esm.mjs';\nimport { e as elementChildren, a as elementParents, b as elementOffset, j as getTranslate } from '../shared/utils.mjs';\n\nfunction Zoom(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on,\n    emit\n  } = _ref;\n  const window = getWindow();\n  extendParams({\n    zoom: {\n      enabled: false,\n      limitToOriginalSize: false,\n      maxRatio: 3,\n      minRatio: 1,\n      panOnMouseMove: false,\n      toggle: true,\n      containerClass: 'swiper-zoom-container',\n      zoomedSlideClass: 'swiper-slide-zoomed'\n    }\n  });\n  swiper.zoom = {\n    enabled: false\n  };\n  let currentScale = 1;\n  let isScaling = false;\n  let isPanningWithMouse = false;\n  let mousePanStart = {\n    x: 0,\n    y: 0\n  };\n  const mousePanSensitivity = -3; // Negative to invert pan direction\n  let fakeGestureTouched;\n  let fakeGestureMoved;\n  const evCache = [];\n  const gesture = {\n    originX: 0,\n    originY: 0,\n    slideEl: undefined,\n    slideWidth: undefined,\n    slideHeight: undefined,\n    imageEl: undefined,\n    imageWrapEl: undefined,\n    maxRatio: 3\n  };\n  const image = {\n    isTouched: undefined,\n    isMoved: undefined,\n    currentX: undefined,\n    currentY: undefined,\n    minX: undefined,\n    minY: undefined,\n    maxX: undefined,\n    maxY: undefined,\n    width: undefined,\n    height: undefined,\n    startX: undefined,\n    startY: undefined,\n    touchesStart: {},\n    touchesCurrent: {}\n  };\n  const velocity = {\n    x: undefined,\n    y: undefined,\n    prevPositionX: undefined,\n    prevPositionY: undefined,\n    prevTime: undefined\n  };\n  let scale = 1;\n  Object.defineProperty(swiper.zoom, 'scale', {\n    get() {\n      return scale;\n    },\n    set(value) {\n      if (scale !== value) {\n        const imageEl = gesture.imageEl;\n        const slideEl = gesture.slideEl;\n        emit('zoomChange', value, imageEl, slideEl);\n      }\n      scale = value;\n    }\n  });\n  function getDistanceBetweenTouches() {\n    if (evCache.length < 2) return 1;\n    const x1 = evCache[0].pageX;\n    const y1 = evCache[0].pageY;\n    const x2 = evCache[1].pageX;\n    const y2 = evCache[1].pageY;\n    const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);\n    return distance;\n  }\n  function getMaxRatio() {\n    const params = swiper.params.zoom;\n    const maxRatio = gesture.imageWrapEl.getAttribute('data-swiper-zoom') || params.maxRatio;\n    if (params.limitToOriginalSize && gesture.imageEl && gesture.imageEl.naturalWidth) {\n      const imageMaxRatio = gesture.imageEl.naturalWidth / gesture.imageEl.offsetWidth;\n      return Math.min(imageMaxRatio, maxRatio);\n    }\n    return maxRatio;\n  }\n  function getScaleOrigin() {\n    if (evCache.length < 2) return {\n      x: null,\n      y: null\n    };\n    const box = gesture.imageEl.getBoundingClientRect();\n    return [(evCache[0].pageX + (evCache[1].pageX - evCache[0].pageX) / 2 - box.x - window.scrollX) / currentScale, (evCache[0].pageY + (evCache[1].pageY - evCache[0].pageY) / 2 - box.y - window.scrollY) / currentScale];\n  }\n  function getSlideSelector() {\n    return swiper.isElement ? `swiper-slide` : `.${swiper.params.slideClass}`;\n  }\n  function eventWithinSlide(e) {\n    const slideSelector = getSlideSelector();\n    if (e.target.matches(slideSelector)) return true;\n    if (swiper.slides.filter(slideEl => slideEl.contains(e.target)).length > 0) return true;\n    return false;\n  }\n  function eventWithinZoomContainer(e) {\n    const selector = `.${swiper.params.zoom.containerClass}`;\n    if (e.target.matches(selector)) return true;\n    if ([...swiper.hostEl.querySelectorAll(selector)].filter(containerEl => containerEl.contains(e.target)).length > 0) return true;\n    return false;\n  }\n\n  // Events\n  function onGestureStart(e) {\n    if (e.pointerType === 'mouse') {\n      evCache.splice(0, evCache.length);\n    }\n    if (!eventWithinSlide(e)) return;\n    const params = swiper.params.zoom;\n    fakeGestureTouched = false;\n    fakeGestureMoved = false;\n    evCache.push(e);\n    if (evCache.length < 2) {\n      return;\n    }\n    fakeGestureTouched = true;\n    gesture.scaleStart = getDistanceBetweenTouches();\n    if (!gesture.slideEl) {\n      gesture.slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);\n      if (!gesture.slideEl) gesture.slideEl = swiper.slides[swiper.activeIndex];\n      let imageEl = gesture.slideEl.querySelector(`.${params.containerClass}`);\n      if (imageEl) {\n        imageEl = imageEl.querySelectorAll('picture, img, svg, canvas, .swiper-zoom-target')[0];\n      }\n      gesture.imageEl = imageEl;\n      if (imageEl) {\n        gesture.imageWrapEl = elementParents(gesture.imageEl, `.${params.containerClass}`)[0];\n      } else {\n        gesture.imageWrapEl = undefined;\n      }\n      if (!gesture.imageWrapEl) {\n        gesture.imageEl = undefined;\n        return;\n      }\n      gesture.maxRatio = getMaxRatio();\n    }\n    if (gesture.imageEl) {\n      const [originX, originY] = getScaleOrigin();\n      gesture.originX = originX;\n      gesture.originY = originY;\n      gesture.imageEl.style.transitionDuration = '0ms';\n    }\n    isScaling = true;\n  }\n  function onGestureChange(e) {\n    if (!eventWithinSlide(e)) return;\n    const params = swiper.params.zoom;\n    const zoom = swiper.zoom;\n    const pointerIndex = evCache.findIndex(cachedEv => cachedEv.pointerId === e.pointerId);\n    if (pointerIndex >= 0) evCache[pointerIndex] = e;\n    if (evCache.length < 2) {\n      return;\n    }\n    fakeGestureMoved = true;\n    gesture.scaleMove = getDistanceBetweenTouches();\n    if (!gesture.imageEl) {\n      return;\n    }\n    zoom.scale = gesture.scaleMove / gesture.scaleStart * currentScale;\n    if (zoom.scale > gesture.maxRatio) {\n      zoom.scale = gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5;\n    }\n    if (zoom.scale < params.minRatio) {\n      zoom.scale = params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5;\n    }\n    gesture.imageEl.style.transform = `translate3d(0,0,0) scale(${zoom.scale})`;\n  }\n  function onGestureEnd(e) {\n    if (!eventWithinSlide(e)) return;\n    if (e.pointerType === 'mouse' && e.type === 'pointerout') return;\n    const params = swiper.params.zoom;\n    const zoom = swiper.zoom;\n    const pointerIndex = evCache.findIndex(cachedEv => cachedEv.pointerId === e.pointerId);\n    if (pointerIndex >= 0) evCache.splice(pointerIndex, 1);\n    if (!fakeGestureTouched || !fakeGestureMoved) {\n      return;\n    }\n    fakeGestureTouched = false;\n    fakeGestureMoved = false;\n    if (!gesture.imageEl) return;\n    zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);\n    gesture.imageEl.style.transitionDuration = `${swiper.params.speed}ms`;\n    gesture.imageEl.style.transform = `translate3d(0,0,0) scale(${zoom.scale})`;\n    currentScale = zoom.scale;\n    isScaling = false;\n    if (zoom.scale > 1 && gesture.slideEl) {\n      gesture.slideEl.classList.add(`${params.zoomedSlideClass}`);\n    } else if (zoom.scale <= 1 && gesture.slideEl) {\n      gesture.slideEl.classList.remove(`${params.zoomedSlideClass}`);\n    }\n    if (zoom.scale === 1) {\n      gesture.originX = 0;\n      gesture.originY = 0;\n      gesture.slideEl = undefined;\n    }\n  }\n  let allowTouchMoveTimeout;\n  function allowTouchMove() {\n    swiper.touchEventsData.preventTouchMoveFromPointerMove = false;\n  }\n  function preventTouchMove() {\n    clearTimeout(allowTouchMoveTimeout);\n    swiper.touchEventsData.preventTouchMoveFromPointerMove = true;\n    allowTouchMoveTimeout = setTimeout(() => {\n      if (swiper.destroyed) return;\n      allowTouchMove();\n    });\n  }\n  function onTouchStart(e) {\n    const device = swiper.device;\n    if (!gesture.imageEl) return;\n    if (image.isTouched) return;\n    if (device.android && e.cancelable) e.preventDefault();\n    image.isTouched = true;\n    const event = evCache.length > 0 ? evCache[0] : e;\n    image.touchesStart.x = event.pageX;\n    image.touchesStart.y = event.pageY;\n  }\n  function onTouchMove(e) {\n    const isMouseEvent = e.pointerType === 'mouse';\n    const isMousePan = isMouseEvent && swiper.params.zoom.panOnMouseMove;\n    if (!eventWithinSlide(e) || !eventWithinZoomContainer(e)) {\n      return;\n    }\n    const zoom = swiper.zoom;\n    if (!gesture.imageEl) {\n      return;\n    }\n    if (!image.isTouched || !gesture.slideEl) {\n      if (isMousePan) onMouseMove(e);\n      return;\n    }\n    if (isMousePan) {\n      onMouseMove(e);\n      return;\n    }\n    if (!image.isMoved) {\n      image.width = gesture.imageEl.offsetWidth || gesture.imageEl.clientWidth;\n      image.height = gesture.imageEl.offsetHeight || gesture.imageEl.clientHeight;\n      image.startX = getTranslate(gesture.imageWrapEl, 'x') || 0;\n      image.startY = getTranslate(gesture.imageWrapEl, 'y') || 0;\n      gesture.slideWidth = gesture.slideEl.offsetWidth;\n      gesture.slideHeight = gesture.slideEl.offsetHeight;\n      gesture.imageWrapEl.style.transitionDuration = '0ms';\n    }\n    // Define if we need image drag\n    const scaledWidth = image.width * zoom.scale;\n    const scaledHeight = image.height * zoom.scale;\n    image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);\n    image.maxX = -image.minX;\n    image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);\n    image.maxY = -image.minY;\n    image.touchesCurrent.x = evCache.length > 0 ? evCache[0].pageX : e.pageX;\n    image.touchesCurrent.y = evCache.length > 0 ? evCache[0].pageY : e.pageY;\n    const touchesDiff = Math.max(Math.abs(image.touchesCurrent.x - image.touchesStart.x), Math.abs(image.touchesCurrent.y - image.touchesStart.y));\n    if (touchesDiff > 5) {\n      swiper.allowClick = false;\n    }\n    if (!image.isMoved && !isScaling) {\n      if (swiper.isHorizontal() && (Math.floor(image.minX) === Math.floor(image.startX) && image.touchesCurrent.x < image.touchesStart.x || Math.floor(image.maxX) === Math.floor(image.startX) && image.touchesCurrent.x > image.touchesStart.x)) {\n        image.isTouched = false;\n        allowTouchMove();\n        return;\n      }\n      if (!swiper.isHorizontal() && (Math.floor(image.minY) === Math.floor(image.startY) && image.touchesCurrent.y < image.touchesStart.y || Math.floor(image.maxY) === Math.floor(image.startY) && image.touchesCurrent.y > image.touchesStart.y)) {\n        image.isTouched = false;\n        allowTouchMove();\n        return;\n      }\n    }\n    if (e.cancelable) {\n      e.preventDefault();\n    }\n    e.stopPropagation();\n    preventTouchMove();\n    image.isMoved = true;\n    const scaleRatio = (zoom.scale - currentScale) / (gesture.maxRatio - swiper.params.zoom.minRatio);\n    const {\n      originX,\n      originY\n    } = gesture;\n    image.currentX = image.touchesCurrent.x - image.touchesStart.x + image.startX + scaleRatio * (image.width - originX * 2);\n    image.currentY = image.touchesCurrent.y - image.touchesStart.y + image.startY + scaleRatio * (image.height - originY * 2);\n    if (image.currentX < image.minX) {\n      image.currentX = image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8;\n    }\n    if (image.currentX > image.maxX) {\n      image.currentX = image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8;\n    }\n    if (image.currentY < image.minY) {\n      image.currentY = image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8;\n    }\n    if (image.currentY > image.maxY) {\n      image.currentY = image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8;\n    }\n\n    // Velocity\n    if (!velocity.prevPositionX) velocity.prevPositionX = image.touchesCurrent.x;\n    if (!velocity.prevPositionY) velocity.prevPositionY = image.touchesCurrent.y;\n    if (!velocity.prevTime) velocity.prevTime = Date.now();\n    velocity.x = (image.touchesCurrent.x - velocity.prevPositionX) / (Date.now() - velocity.prevTime) / 2;\n    velocity.y = (image.touchesCurrent.y - velocity.prevPositionY) / (Date.now() - velocity.prevTime) / 2;\n    if (Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) velocity.x = 0;\n    if (Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) velocity.y = 0;\n    velocity.prevPositionX = image.touchesCurrent.x;\n    velocity.prevPositionY = image.touchesCurrent.y;\n    velocity.prevTime = Date.now();\n    gesture.imageWrapEl.style.transform = `translate3d(${image.currentX}px, ${image.currentY}px,0)`;\n  }\n  function onTouchEnd() {\n    const zoom = swiper.zoom;\n    evCache.length = 0;\n    if (!gesture.imageEl) return;\n    if (!image.isTouched || !image.isMoved) {\n      image.isTouched = false;\n      image.isMoved = false;\n      return;\n    }\n    image.isTouched = false;\n    image.isMoved = false;\n    let momentumDurationX = 300;\n    let momentumDurationY = 300;\n    const momentumDistanceX = velocity.x * momentumDurationX;\n    const newPositionX = image.currentX + momentumDistanceX;\n    const momentumDistanceY = velocity.y * momentumDurationY;\n    const newPositionY = image.currentY + momentumDistanceY;\n\n    // Fix duration\n    if (velocity.x !== 0) momentumDurationX = Math.abs((newPositionX - image.currentX) / velocity.x);\n    if (velocity.y !== 0) momentumDurationY = Math.abs((newPositionY - image.currentY) / velocity.y);\n    const momentumDuration = Math.max(momentumDurationX, momentumDurationY);\n    image.currentX = newPositionX;\n    image.currentY = newPositionY;\n    // Define if we need image drag\n    const scaledWidth = image.width * zoom.scale;\n    const scaledHeight = image.height * zoom.scale;\n    image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);\n    image.maxX = -image.minX;\n    image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);\n    image.maxY = -image.minY;\n    image.currentX = Math.max(Math.min(image.currentX, image.maxX), image.minX);\n    image.currentY = Math.max(Math.min(image.currentY, image.maxY), image.minY);\n    gesture.imageWrapEl.style.transitionDuration = `${momentumDuration}ms`;\n    gesture.imageWrapEl.style.transform = `translate3d(${image.currentX}px, ${image.currentY}px,0)`;\n  }\n  function onTransitionEnd() {\n    const zoom = swiper.zoom;\n    if (gesture.slideEl && swiper.activeIndex !== swiper.slides.indexOf(gesture.slideEl)) {\n      if (gesture.imageEl) {\n        gesture.imageEl.style.transform = 'translate3d(0,0,0) scale(1)';\n      }\n      if (gesture.imageWrapEl) {\n        gesture.imageWrapEl.style.transform = 'translate3d(0,0,0)';\n      }\n      gesture.slideEl.classList.remove(`${swiper.params.zoom.zoomedSlideClass}`);\n      zoom.scale = 1;\n      currentScale = 1;\n      gesture.slideEl = undefined;\n      gesture.imageEl = undefined;\n      gesture.imageWrapEl = undefined;\n      gesture.originX = 0;\n      gesture.originY = 0;\n    }\n  }\n  function onMouseMove(e) {\n    // Only pan if zoomed in and mouse panning is enabled\n    if (currentScale <= 1 || !gesture.imageWrapEl) return;\n    if (!eventWithinSlide(e) || !eventWithinZoomContainer(e)) return;\n    const currentTransform = window.getComputedStyle(gesture.imageWrapEl).transform;\n    const matrix = new window.DOMMatrix(currentTransform);\n    if (!isPanningWithMouse) {\n      isPanningWithMouse = true;\n      mousePanStart.x = e.clientX;\n      mousePanStart.y = e.clientY;\n      image.startX = matrix.e;\n      image.startY = matrix.f;\n      image.width = gesture.imageEl.offsetWidth || gesture.imageEl.clientWidth;\n      image.height = gesture.imageEl.offsetHeight || gesture.imageEl.clientHeight;\n      gesture.slideWidth = gesture.slideEl.offsetWidth;\n      gesture.slideHeight = gesture.slideEl.offsetHeight;\n      return;\n    }\n    const deltaX = (e.clientX - mousePanStart.x) * mousePanSensitivity;\n    const deltaY = (e.clientY - mousePanStart.y) * mousePanSensitivity;\n    const scaledWidth = image.width * currentScale;\n    const scaledHeight = image.height * currentScale;\n    const slideWidth = gesture.slideWidth;\n    const slideHeight = gesture.slideHeight;\n    const minX = Math.min(slideWidth / 2 - scaledWidth / 2, 0);\n    const maxX = -minX;\n    const minY = Math.min(slideHeight / 2 - scaledHeight / 2, 0);\n    const maxY = -minY;\n    const newX = Math.max(Math.min(image.startX + deltaX, maxX), minX);\n    const newY = Math.max(Math.min(image.startY + deltaY, maxY), minY);\n    gesture.imageWrapEl.style.transitionDuration = '0ms';\n    gesture.imageWrapEl.style.transform = `translate3d(${newX}px, ${newY}px, 0)`;\n    mousePanStart.x = e.clientX;\n    mousePanStart.y = e.clientY;\n    image.startX = newX;\n    image.startY = newY;\n    image.currentX = newX;\n    image.currentY = newY;\n  }\n  function zoomIn(e) {\n    const zoom = swiper.zoom;\n    const params = swiper.params.zoom;\n    if (!gesture.slideEl) {\n      if (e && e.target) {\n        gesture.slideEl = e.target.closest(`.${swiper.params.slideClass}, swiper-slide`);\n      }\n      if (!gesture.slideEl) {\n        if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n          gesture.slideEl = elementChildren(swiper.slidesEl, `.${swiper.params.slideActiveClass}`)[0];\n        } else {\n          gesture.slideEl = swiper.slides[swiper.activeIndex];\n        }\n      }\n      let imageEl = gesture.slideEl.querySelector(`.${params.containerClass}`);\n      if (imageEl) {\n        imageEl = imageEl.querySelectorAll('picture, img, svg, canvas, .swiper-zoom-target')[0];\n      }\n      gesture.imageEl = imageEl;\n      if (imageEl) {\n        gesture.imageWrapEl = elementParents(gesture.imageEl, `.${params.containerClass}`)[0];\n      } else {\n        gesture.imageWrapEl = undefined;\n      }\n    }\n    if (!gesture.imageEl || !gesture.imageWrapEl) return;\n    if (swiper.params.cssMode) {\n      swiper.wrapperEl.style.overflow = 'hidden';\n      swiper.wrapperEl.style.touchAction = 'none';\n    }\n    gesture.slideEl.classList.add(`${params.zoomedSlideClass}`);\n    let touchX;\n    let touchY;\n    let offsetX;\n    let offsetY;\n    let diffX;\n    let diffY;\n    let translateX;\n    let translateY;\n    let imageWidth;\n    let imageHeight;\n    let scaledWidth;\n    let scaledHeight;\n    let translateMinX;\n    let translateMinY;\n    let translateMaxX;\n    let translateMaxY;\n    let slideWidth;\n    let slideHeight;\n    if (typeof image.touchesStart.x === 'undefined' && e) {\n      touchX = e.pageX;\n      touchY = e.pageY;\n    } else {\n      touchX = image.touchesStart.x;\n      touchY = image.touchesStart.y;\n    }\n    const prevScale = currentScale;\n    const forceZoomRatio = typeof e === 'number' ? e : null;\n    if (currentScale === 1 && forceZoomRatio) {\n      touchX = undefined;\n      touchY = undefined;\n      image.touchesStart.x = undefined;\n      image.touchesStart.y = undefined;\n    }\n    const maxRatio = getMaxRatio();\n    zoom.scale = forceZoomRatio || maxRatio;\n    currentScale = forceZoomRatio || maxRatio;\n    if (e && !(currentScale === 1 && forceZoomRatio)) {\n      slideWidth = gesture.slideEl.offsetWidth;\n      slideHeight = gesture.slideEl.offsetHeight;\n      offsetX = elementOffset(gesture.slideEl).left + window.scrollX;\n      offsetY = elementOffset(gesture.slideEl).top + window.scrollY;\n      diffX = offsetX + slideWidth / 2 - touchX;\n      diffY = offsetY + slideHeight / 2 - touchY;\n      imageWidth = gesture.imageEl.offsetWidth || gesture.imageEl.clientWidth;\n      imageHeight = gesture.imageEl.offsetHeight || gesture.imageEl.clientHeight;\n      scaledWidth = imageWidth * zoom.scale;\n      scaledHeight = imageHeight * zoom.scale;\n      translateMinX = Math.min(slideWidth / 2 - scaledWidth / 2, 0);\n      translateMinY = Math.min(slideHeight / 2 - scaledHeight / 2, 0);\n      translateMaxX = -translateMinX;\n      translateMaxY = -translateMinY;\n      if (prevScale > 0 && forceZoomRatio && typeof image.currentX === 'number' && typeof image.currentY === 'number') {\n        translateX = image.currentX * zoom.scale / prevScale;\n        translateY = image.currentY * zoom.scale / prevScale;\n      } else {\n        translateX = diffX * zoom.scale;\n        translateY = diffY * zoom.scale;\n      }\n      if (translateX < translateMinX) {\n        translateX = translateMinX;\n      }\n      if (translateX > translateMaxX) {\n        translateX = translateMaxX;\n      }\n      if (translateY < translateMinY) {\n        translateY = translateMinY;\n      }\n      if (translateY > translateMaxY) {\n        translateY = translateMaxY;\n      }\n    } else {\n      translateX = 0;\n      translateY = 0;\n    }\n    if (forceZoomRatio && zoom.scale === 1) {\n      gesture.originX = 0;\n      gesture.originY = 0;\n    }\n    image.currentX = translateX;\n    image.currentY = translateY;\n    gesture.imageWrapEl.style.transitionDuration = '300ms';\n    gesture.imageWrapEl.style.transform = `translate3d(${translateX}px, ${translateY}px,0)`;\n    gesture.imageEl.style.transitionDuration = '300ms';\n    gesture.imageEl.style.transform = `translate3d(0,0,0) scale(${zoom.scale})`;\n  }\n  function zoomOut() {\n    const zoom = swiper.zoom;\n    const params = swiper.params.zoom;\n    if (!gesture.slideEl) {\n      if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {\n        gesture.slideEl = elementChildren(swiper.slidesEl, `.${swiper.params.slideActiveClass}`)[0];\n      } else {\n        gesture.slideEl = swiper.slides[swiper.activeIndex];\n      }\n      let imageEl = gesture.slideEl.querySelector(`.${params.containerClass}`);\n      if (imageEl) {\n        imageEl = imageEl.querySelectorAll('picture, img, svg, canvas, .swiper-zoom-target')[0];\n      }\n      gesture.imageEl = imageEl;\n      if (imageEl) {\n        gesture.imageWrapEl = elementParents(gesture.imageEl, `.${params.containerClass}`)[0];\n      } else {\n        gesture.imageWrapEl = undefined;\n      }\n    }\n    if (!gesture.imageEl || !gesture.imageWrapEl) return;\n    if (swiper.params.cssMode) {\n      swiper.wrapperEl.style.overflow = '';\n      swiper.wrapperEl.style.touchAction = '';\n    }\n    zoom.scale = 1;\n    currentScale = 1;\n    image.currentX = undefined;\n    image.currentY = undefined;\n    image.touchesStart.x = undefined;\n    image.touchesStart.y = undefined;\n    gesture.imageWrapEl.style.transitionDuration = '300ms';\n    gesture.imageWrapEl.style.transform = 'translate3d(0,0,0)';\n    gesture.imageEl.style.transitionDuration = '300ms';\n    gesture.imageEl.style.transform = 'translate3d(0,0,0) scale(1)';\n    gesture.slideEl.classList.remove(`${params.zoomedSlideClass}`);\n    gesture.slideEl = undefined;\n    gesture.originX = 0;\n    gesture.originY = 0;\n    if (swiper.params.zoom.panOnMouseMove) {\n      mousePanStart = {\n        x: 0,\n        y: 0\n      };\n      if (isPanningWithMouse) {\n        isPanningWithMouse = false;\n        image.startX = 0;\n        image.startY = 0;\n      }\n    }\n  }\n\n  // Toggle Zoom\n  function zoomToggle(e) {\n    const zoom = swiper.zoom;\n    if (zoom.scale && zoom.scale !== 1) {\n      // Zoom Out\n      zoomOut();\n    } else {\n      // Zoom In\n      zoomIn(e);\n    }\n  }\n  function getListeners() {\n    const passiveListener = swiper.params.passiveListeners ? {\n      passive: true,\n      capture: false\n    } : false;\n    const activeListenerWithCapture = swiper.params.passiveListeners ? {\n      passive: false,\n      capture: true\n    } : true;\n    return {\n      passiveListener,\n      activeListenerWithCapture\n    };\n  }\n\n  // Attach/Detach Events\n  function enable() {\n    const zoom = swiper.zoom;\n    if (zoom.enabled) return;\n    zoom.enabled = true;\n    const {\n      passiveListener,\n      activeListenerWithCapture\n    } = getListeners();\n\n    // Scale image\n    swiper.wrapperEl.addEventListener('pointerdown', onGestureStart, passiveListener);\n    swiper.wrapperEl.addEventListener('pointermove', onGestureChange, activeListenerWithCapture);\n    ['pointerup', 'pointercancel', 'pointerout'].forEach(eventName => {\n      swiper.wrapperEl.addEventListener(eventName, onGestureEnd, passiveListener);\n    });\n\n    // Move image\n    swiper.wrapperEl.addEventListener('pointermove', onTouchMove, activeListenerWithCapture);\n  }\n  function disable() {\n    const zoom = swiper.zoom;\n    if (!zoom.enabled) return;\n    zoom.enabled = false;\n    const {\n      passiveListener,\n      activeListenerWithCapture\n    } = getListeners();\n\n    // Scale image\n    swiper.wrapperEl.removeEventListener('pointerdown', onGestureStart, passiveListener);\n    swiper.wrapperEl.removeEventListener('pointermove', onGestureChange, activeListenerWithCapture);\n    ['pointerup', 'pointercancel', 'pointerout'].forEach(eventName => {\n      swiper.wrapperEl.removeEventListener(eventName, onGestureEnd, passiveListener);\n    });\n\n    // Move image\n    swiper.wrapperEl.removeEventListener('pointermove', onTouchMove, activeListenerWithCapture);\n  }\n  on('init', () => {\n    if (swiper.params.zoom.enabled) {\n      enable();\n    }\n  });\n  on('destroy', () => {\n    disable();\n  });\n  on('touchStart', (_s, e) => {\n    if (!swiper.zoom.enabled) return;\n    onTouchStart(e);\n  });\n  on('touchEnd', (_s, e) => {\n    if (!swiper.zoom.enabled) return;\n    onTouchEnd();\n  });\n  on('doubleTap', (_s, e) => {\n    if (!swiper.animating && swiper.params.zoom.enabled && swiper.zoom.enabled && swiper.params.zoom.toggle) {\n      zoomToggle(e);\n    }\n  });\n  on('transitionEnd', () => {\n    if (swiper.zoom.enabled && swiper.params.zoom.enabled) {\n      onTransitionEnd();\n    }\n  });\n  on('slideChange', () => {\n    if (swiper.zoom.enabled && swiper.params.zoom.enabled && swiper.params.cssMode) {\n      onTransitionEnd();\n    }\n  });\n  Object.assign(swiper.zoom, {\n    enable,\n    disable,\n    in: zoomIn,\n    out: zoomOut,\n    toggle: zoomToggle\n  });\n}\n\nexport { Zoom as default };\n","function classesToSelector(classes) {\n  if (classes === void 0) {\n    classes = '';\n  }\n  return `.${classes.trim().replace(/([\\.:!+\\/])/g, '\\\\$1') // eslint-disable-line\n  .replace(/ /g, '.')}`;\n}\n\nexport { classesToSelector as c };\n","import { e as elementChildren, c as createElement } from './utils.mjs';\n\nfunction createElementIfNotDefined(swiper, originalParams, params, checkProps) {\n  if (swiper.params.createElements) {\n    Object.keys(checkProps).forEach(key => {\n      if (!params[key] && params.auto === true) {\n        let element = elementChildren(swiper.el, `.${checkProps[key]}`)[0];\n        if (!element) {\n          element = createElement('div', checkProps[key]);\n          element.className = checkProps[key];\n          swiper.el.append(element);\n        }\n        params[key] = element;\n        originalParams[key] = element;\n      }\n    });\n  }\n  return params;\n}\n\nexport { createElementIfNotDefined as c };\n","import { g as getSlideTransformEl, c as createElement } from './utils.mjs';\n\nfunction createShadow(suffix, slideEl, side) {\n  const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ''}${suffix ? ` swiper-slide-shadow-${suffix}` : ''}`;\n  const shadowContainer = getSlideTransformEl(slideEl);\n  let shadowEl = shadowContainer.querySelector(`.${shadowClass.split(' ').join('.')}`);\n  if (!shadowEl) {\n    shadowEl = createElement('div', shadowClass.split(' '));\n    shadowContainer.append(shadowEl);\n  }\n  return shadowEl;\n}\n\nexport { createShadow as c };\n","function effectInit(params) {\n  const {\n    effect,\n    swiper,\n    on,\n    setTranslate,\n    setTransition,\n    overwriteParams,\n    perspective,\n    recreateShadows,\n    getEffectParams\n  } = params;\n  on('beforeInit', () => {\n    if (swiper.params.effect !== effect) return;\n    swiper.classNames.push(`${swiper.params.containerModifierClass}${effect}`);\n    if (perspective && perspective()) {\n      swiper.classNames.push(`${swiper.params.containerModifierClass}3d`);\n    }\n    const overwriteParamsResult = overwriteParams ? overwriteParams() : {};\n    Object.assign(swiper.params, overwriteParamsResult);\n    Object.assign(swiper.originalParams, overwriteParamsResult);\n  });\n  on('setTranslate', () => {\n    if (swiper.params.effect !== effect) return;\n    setTranslate();\n  });\n  on('setTransition', (_s, duration) => {\n    if (swiper.params.effect !== effect) return;\n    setTransition(duration);\n  });\n  on('transitionEnd', () => {\n    if (swiper.params.effect !== effect) return;\n    if (recreateShadows) {\n      if (!getEffectParams || !getEffectParams().slideShadows) return;\n      // remove shadows\n      swiper.slides.forEach(slideEl => {\n        slideEl.querySelectorAll('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').forEach(shadowEl => shadowEl.remove());\n      });\n      // create new one\n      recreateShadows();\n    }\n  });\n  let requireUpdateOnVirtual;\n  on('virtualUpdate', () => {\n    if (swiper.params.effect !== effect) return;\n    if (!swiper.slides.length) {\n      requireUpdateOnVirtual = true;\n    }\n    requestAnimationFrame(() => {\n      if (requireUpdateOnVirtual && swiper.slides && swiper.slides.length) {\n        setTranslate();\n        requireUpdateOnVirtual = false;\n      }\n    });\n  });\n}\n\nexport { effectInit as e };\n","import { g as getSlideTransformEl } from './utils.mjs';\n\nfunction effectTarget(effectParams, slideEl) {\n  const transformEl = getSlideTransformEl(slideEl);\n  if (transformEl !== slideEl) {\n    transformEl.style.backfaceVisibility = 'hidden';\n    transformEl.style['-webkit-backface-visibility'] = 'hidden';\n  }\n  return transformEl;\n}\n\nexport { effectTarget as e };\n","import { k as elementTransitionEnd } from './utils.mjs';\n\nfunction effectVirtualTransitionEnd(_ref) {\n  let {\n    swiper,\n    duration,\n    transformElements,\n    allSlides\n  } = _ref;\n  const {\n    activeIndex\n  } = swiper;\n  const getSlide = el => {\n    if (!el.parentElement) {\n      // assume shadow root\n      const slide = swiper.slides.find(slideEl => slideEl.shadowRoot && slideEl.shadowRoot === el.parentNode);\n      return slide;\n    }\n    return el.parentElement;\n  };\n  if (swiper.params.virtualTranslate && duration !== 0) {\n    let eventTriggered = false;\n    let transitionEndTarget;\n    if (allSlides) {\n      transitionEndTarget = transformElements;\n    } else {\n      transitionEndTarget = transformElements.filter(transformEl => {\n        const el = transformEl.classList.contains('swiper-slide-transform') ? getSlide(transformEl) : transformEl;\n        return swiper.getSlideIndex(el) === activeIndex;\n      });\n    }\n    transitionEndTarget.forEach(el => {\n      elementTransitionEnd(el, () => {\n        if (eventTriggered) return;\n        if (!swiper || swiper.destroyed) return;\n        eventTriggered = true;\n        swiper.animating = false;\n        const evt = new window.CustomEvent('transitionend', {\n          bubbles: true,\n          cancelable: true\n        });\n        swiper.wrapperEl.dispatchEvent(evt);\n      });\n    });\n  }\n}\n\nexport { effectVirtualTransitionEnd as e };\n","/**\n * SSR Window 5.0.0\n * Better handling for window object in SSR environment\n * https://github.com/nolimits4web/ssr-window\n *\n * Copyright 2025, Vladimir Kharlampidi\n *\n * Licensed under MIT\n *\n * Released on: February 12, 2025\n */\n/* eslint-disable no-param-reassign */\nfunction isObject(obj) {\n  return obj !== null && typeof obj === 'object' && 'constructor' in obj && obj.constructor === Object;\n}\nfunction extend(target, src) {\n  if (target === void 0) {\n    target = {};\n  }\n  if (src === void 0) {\n    src = {};\n  }\n  const noExtend = ['__proto__', 'constructor', 'prototype'];\n  Object.keys(src).filter(key => noExtend.indexOf(key) < 0).forEach(key => {\n    if (typeof target[key] === 'undefined') target[key] = src[key];else if (isObject(src[key]) && isObject(target[key]) && Object.keys(src[key]).length > 0) {\n      extend(target[key], src[key]);\n    }\n  });\n}\nconst ssrDocument = {\n  body: {},\n  addEventListener() {},\n  removeEventListener() {},\n  activeElement: {\n    blur() {},\n    nodeName: ''\n  },\n  querySelector() {\n    return null;\n  },\n  querySelectorAll() {\n    return [];\n  },\n  getElementById() {\n    return null;\n  },\n  createEvent() {\n    return {\n      initEvent() {}\n    };\n  },\n  createElement() {\n    return {\n      children: [],\n      childNodes: [],\n      style: {},\n      setAttribute() {},\n      getElementsByTagName() {\n        return [];\n      }\n    };\n  },\n  createElementNS() {\n    return {};\n  },\n  importNode() {\n    return null;\n  },\n  location: {\n    hash: '',\n    host: '',\n    hostname: '',\n    href: '',\n    origin: '',\n    pathname: '',\n    protocol: '',\n    search: ''\n  }\n};\nfunction getDocument() {\n  const doc = typeof document !== 'undefined' ? document : {};\n  extend(doc, ssrDocument);\n  return doc;\n}\nconst ssrWindow = {\n  document: ssrDocument,\n  navigator: {\n    userAgent: ''\n  },\n  location: {\n    hash: '',\n    host: '',\n    hostname: '',\n    href: '',\n    origin: '',\n    pathname: '',\n    protocol: '',\n    search: ''\n  },\n  history: {\n    replaceState() {},\n    pushState() {},\n    go() {},\n    back() {}\n  },\n  CustomEvent: function CustomEvent() {\n    return this;\n  },\n  addEventListener() {},\n  removeEventListener() {},\n  getComputedStyle() {\n    return {\n      getPropertyValue() {\n        return '';\n      }\n    };\n  },\n  Image() {},\n  Date() {},\n  screen: {},\n  setTimeout() {},\n  clearTimeout() {},\n  matchMedia() {\n    return {};\n  },\n  requestAnimationFrame(callback) {\n    if (typeof setTimeout === 'undefined') {\n      callback();\n      return null;\n    }\n    return setTimeout(callback, 0);\n  },\n  cancelAnimationFrame(id) {\n    if (typeof setTimeout === 'undefined') {\n      return;\n    }\n    clearTimeout(id);\n  }\n};\nfunction getWindow() {\n  const win = typeof window !== 'undefined' ? window : {};\n  extend(win, ssrWindow);\n  return win;\n}\n\nexport { getWindow as a, getDocument as g };\n","import { a as getWindow, g as getDocument } from './ssr-window.esm.mjs';\nimport { a as elementParents, p as elementStyle, e as elementChildren, s as setCSSProperty, f as elementOuterSize, q as elementNextAll, r as elementPrevAll, j as getTranslate, t as animateCSSModeScroll, n as nextTick, u as showWarning, c as createElement, v as elementIsChildOf, d as now, w as extend, h as elementIndex, x as deleteProps } from './utils.mjs';\n\nlet support;\nfunction calcSupport() {\n  const window = getWindow();\n  const document = getDocument();\n  return {\n    smoothScroll: document.documentElement && document.documentElement.style && 'scrollBehavior' in document.documentElement.style,\n    touch: !!('ontouchstart' in window || window.DocumentTouch && document instanceof window.DocumentTouch)\n  };\n}\nfunction getSupport() {\n  if (!support) {\n    support = calcSupport();\n  }\n  return support;\n}\n\nlet deviceCached;\nfunction calcDevice(_temp) {\n  let {\n    userAgent\n  } = _temp === void 0 ? {} : _temp;\n  const support = getSupport();\n  const window = getWindow();\n  const platform = window.navigator.platform;\n  const ua = userAgent || window.navigator.userAgent;\n  const device = {\n    ios: false,\n    android: false\n  };\n  const screenWidth = window.screen.width;\n  const screenHeight = window.screen.height;\n  const android = ua.match(/(Android);?[\\s\\/]+([\\d.]+)?/); // eslint-disable-line\n  let ipad = ua.match(/(iPad).*OS\\s([\\d_]+)/);\n  const ipod = ua.match(/(iPod)(.*OS\\s([\\d_]+))?/);\n  const iphone = !ipad && ua.match(/(iPhone\\sOS|iOS)\\s([\\d_]+)/);\n  const windows = platform === 'Win32';\n  let macos = platform === 'MacIntel';\n\n  // iPadOs 13 fix\n  const iPadScreens = ['1024x1366', '1366x1024', '834x1194', '1194x834', '834x1112', '1112x834', '768x1024', '1024x768', '820x1180', '1180x820', '810x1080', '1080x810'];\n  if (!ipad && macos && support.touch && iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0) {\n    ipad = ua.match(/(Version)\\/([\\d.]+)/);\n    if (!ipad) ipad = [0, 1, '13_0_0'];\n    macos = false;\n  }\n\n  // Android\n  if (android && !windows) {\n    device.os = 'android';\n    device.android = true;\n  }\n  if (ipad || iphone || ipod) {\n    device.os = 'ios';\n    device.ios = true;\n  }\n\n  // Export object\n  return device;\n}\nfunction getDevice(overrides) {\n  if (overrides === void 0) {\n    overrides = {};\n  }\n  if (!deviceCached) {\n    deviceCached = calcDevice(overrides);\n  }\n  return deviceCached;\n}\n\nlet browser;\nfunction calcBrowser() {\n  const window = getWindow();\n  const device = getDevice();\n  let needPerspectiveFix = false;\n  function isSafari() {\n    const ua = window.navigator.userAgent.toLowerCase();\n    return ua.indexOf('safari') >= 0 && ua.indexOf('chrome') < 0 && ua.indexOf('android') < 0;\n  }\n  if (isSafari()) {\n    const ua = String(window.navigator.userAgent);\n    if (ua.includes('Version/')) {\n      const [major, minor] = ua.split('Version/')[1].split(' ')[0].split('.').map(num => Number(num));\n      needPerspectiveFix = major < 16 || major === 16 && minor < 2;\n    }\n  }\n  const isWebView = /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent);\n  const isSafariBrowser = isSafari();\n  const need3dFix = isSafariBrowser || isWebView && device.ios;\n  return {\n    isSafari: needPerspectiveFix || isSafariBrowser,\n    needPerspectiveFix,\n    need3dFix,\n    isWebView\n  };\n}\nfunction getBrowser() {\n  if (!browser) {\n    browser = calcBrowser();\n  }\n  return browser;\n}\n\nfunction Resize(_ref) {\n  let {\n    swiper,\n    on,\n    emit\n  } = _ref;\n  const window = getWindow();\n  let observer = null;\n  let animationFrame = null;\n  const resizeHandler = () => {\n    if (!swiper || swiper.destroyed || !swiper.initialized) return;\n    emit('beforeResize');\n    emit('resize');\n  };\n  const createObserver = () => {\n    if (!swiper || swiper.destroyed || !swiper.initialized) return;\n    observer = new ResizeObserver(entries => {\n      animationFrame = window.requestAnimationFrame(() => {\n        const {\n          width,\n          height\n        } = swiper;\n        let newWidth = width;\n        let newHeight = height;\n        entries.forEach(_ref2 => {\n          let {\n            contentBoxSize,\n            contentRect,\n            target\n          } = _ref2;\n          if (target && target !== swiper.el) return;\n          newWidth = contentRect ? contentRect.width : (contentBoxSize[0] || contentBoxSize).inlineSize;\n          newHeight = contentRect ? contentRect.height : (contentBoxSize[0] || contentBoxSize).blockSize;\n        });\n        if (newWidth !== width || newHeight !== height) {\n          resizeHandler();\n        }\n      });\n    });\n    observer.observe(swiper.el);\n  };\n  const removeObserver = () => {\n    if (animationFrame) {\n      window.cancelAnimationFrame(animationFrame);\n    }\n    if (observer && observer.unobserve && swiper.el) {\n      observer.unobserve(swiper.el);\n      observer = null;\n    }\n  };\n  const orientationChangeHandler = () => {\n    if (!swiper || swiper.destroyed || !swiper.initialized) return;\n    emit('orientationchange');\n  };\n  on('init', () => {\n    if (swiper.params.resizeObserver && typeof window.ResizeObserver !== 'undefined') {\n      createObserver();\n      return;\n    }\n    window.addEventListener('resize', resizeHandler);\n    window.addEventListener('orientationchange', orientationChangeHandler);\n  });\n  on('destroy', () => {\n    removeObserver();\n    window.removeEventListener('resize', resizeHandler);\n    window.removeEventListener('orientationchange', orientationChangeHandler);\n  });\n}\n\nfunction Observer(_ref) {\n  let {\n    swiper,\n    extendParams,\n    on,\n    emit\n  } = _ref;\n  const observers = [];\n  const window = getWindow();\n  const attach = function (target, options) {\n    if (options === void 0) {\n      options = {};\n    }\n    const ObserverFunc = window.MutationObserver || window.WebkitMutationObserver;\n    const observer = new ObserverFunc(mutations => {\n      // The observerUpdate event should only be triggered\n      // once despite the number of mutations.  Additional\n      // triggers are redundant and are very costly\n      if (swiper.__preventObserver__) return;\n      if (mutations.length === 1) {\n        emit('observerUpdate', mutations[0]);\n        return;\n      }\n      const observerUpdate = function observerUpdate() {\n        emit('observerUpdate', mutations[0]);\n      };\n      if (window.requestAnimationFrame) {\n        window.requestAnimationFrame(observerUpdate);\n      } else {\n        window.setTimeout(observerUpdate, 0);\n      }\n    });\n    observer.observe(target, {\n      attributes: typeof options.attributes === 'undefined' ? true : options.attributes,\n      childList: swiper.isElement || (typeof options.childList === 'undefined' ? true : options).childList,\n      characterData: typeof options.characterData === 'undefined' ? true : options.characterData\n    });\n    observers.push(observer);\n  };\n  const init = () => {\n    if (!swiper.params.observer) return;\n    if (swiper.params.observeParents) {\n      const containerParents = elementParents(swiper.hostEl);\n      for (let i = 0; i < containerParents.length; i += 1) {\n        attach(containerParents[i]);\n      }\n    }\n    // Observe container\n    attach(swiper.hostEl, {\n      childList: swiper.params.observeSlideChildren\n    });\n\n    // Observe wrapper\n    attach(swiper.wrapperEl, {\n      attributes: false\n    });\n  };\n  const destroy = () => {\n    observers.forEach(observer => {\n      observer.disconnect();\n    });\n    observers.splice(0, observers.length);\n  };\n  extendParams({\n    observer: false,\n    observeParents: false,\n    observeSlideChildren: false\n  });\n  on('init', init);\n  on('destroy', destroy);\n}\n\n/* eslint-disable no-underscore-dangle */\n\nvar eventsEmitter = {\n  on(events, handler, priority) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (typeof handler !== 'function') return self;\n    const method = priority ? 'unshift' : 'push';\n    events.split(' ').forEach(event => {\n      if (!self.eventsListeners[event]) self.eventsListeners[event] = [];\n      self.eventsListeners[event][method](handler);\n    });\n    return self;\n  },\n  once(events, handler, priority) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (typeof handler !== 'function') return self;\n    function onceHandler() {\n      self.off(events, onceHandler);\n      if (onceHandler.__emitterProxy) {\n        delete onceHandler.__emitterProxy;\n      }\n      for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n        args[_key] = arguments[_key];\n      }\n      handler.apply(self, args);\n    }\n    onceHandler.__emitterProxy = handler;\n    return self.on(events, onceHandler, priority);\n  },\n  onAny(handler, priority) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (typeof handler !== 'function') return self;\n    const method = priority ? 'unshift' : 'push';\n    if (self.eventsAnyListeners.indexOf(handler) < 0) {\n      self.eventsAnyListeners[method](handler);\n    }\n    return self;\n  },\n  offAny(handler) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (!self.eventsAnyListeners) return self;\n    const index = self.eventsAnyListeners.indexOf(handler);\n    if (index >= 0) {\n      self.eventsAnyListeners.splice(index, 1);\n    }\n    return self;\n  },\n  off(events, handler) {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (!self.eventsListeners) return self;\n    events.split(' ').forEach(event => {\n      if (typeof handler === 'undefined') {\n        self.eventsListeners[event] = [];\n      } else if (self.eventsListeners[event]) {\n        self.eventsListeners[event].forEach((eventHandler, index) => {\n          if (eventHandler === handler || eventHandler.__emitterProxy && eventHandler.__emitterProxy === handler) {\n            self.eventsListeners[event].splice(index, 1);\n          }\n        });\n      }\n    });\n    return self;\n  },\n  emit() {\n    const self = this;\n    if (!self.eventsListeners || self.destroyed) return self;\n    if (!self.eventsListeners) return self;\n    let events;\n    let data;\n    let context;\n    for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n      args[_key2] = arguments[_key2];\n    }\n    if (typeof args[0] === 'string' || Array.isArray(args[0])) {\n      events = args[0];\n      data = args.slice(1, args.length);\n      context = self;\n    } else {\n      events = args[0].events;\n      data = args[0].data;\n      context = args[0].context || self;\n    }\n    data.unshift(context);\n    const eventsArray = Array.isArray(events) ? events : events.split(' ');\n    eventsArray.forEach(event => {\n      if (self.eventsAnyListeners && self.eventsAnyListeners.length) {\n        self.eventsAnyListeners.forEach(eventHandler => {\n          eventHandler.apply(context, [event, ...data]);\n        });\n      }\n      if (self.eventsListeners && self.eventsListeners[event]) {\n        self.eventsListeners[event].forEach(eventHandler => {\n          eventHandler.apply(context, data);\n        });\n      }\n    });\n    return self;\n  }\n};\n\nfunction updateSize() {\n  const swiper = this;\n  let width;\n  let height;\n  const el = swiper.el;\n  if (typeof swiper.params.width !== 'undefined' && swiper.params.width !== null) {\n    width = swiper.params.width;\n  } else {\n    width = el.clientWidth;\n  }\n  if (typeof swiper.params.height !== 'undefined' && swiper.params.height !== null) {\n    height = swiper.params.height;\n  } else {\n    height = el.clientHeight;\n  }\n  if (width === 0 && swiper.isHorizontal() || height === 0 && swiper.isVertical()) {\n    return;\n  }\n\n  // Subtract paddings\n  width = width - parseInt(elementStyle(el, 'padding-left') || 0, 10) - parseInt(elementStyle(el, 'padding-right') || 0, 10);\n  height = height - parseInt(elementStyle(el, 'padding-top') || 0, 10) - parseInt(elementStyle(el, 'padding-bottom') || 0, 10);\n  if (Number.isNaN(width)) width = 0;\n  if (Number.isNaN(height)) height = 0;\n  Object.assign(swiper, {\n    width,\n    height,\n    size: swiper.isHorizontal() ? width : height\n  });\n}\n\nfunction updateSlides() {\n  const swiper = this;\n  function getDirectionPropertyValue(node, label) {\n    return parseFloat(node.getPropertyValue(swiper.getDirectionLabel(label)) || 0);\n  }\n  const params = swiper.params;\n  const {\n    wrapperEl,\n    slidesEl,\n    size: swiperSize,\n    rtlTranslate: rtl,\n    wrongRTL\n  } = swiper;\n  const isVirtual = swiper.virtual && params.virtual.enabled;\n  const previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;\n  const slides = elementChildren(slidesEl, `.${swiper.params.slideClass}, swiper-slide`);\n  const slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;\n  let snapGrid = [];\n  const slidesGrid = [];\n  const slidesSizesGrid = [];\n  let offsetBefore = params.slidesOffsetBefore;\n  if (typeof offsetBefore === 'function') {\n    offsetBefore = params.slidesOffsetBefore.call(swiper);\n  }\n  let offsetAfter = params.slidesOffsetAfter;\n  if (typeof offsetAfter === 'function') {\n    offsetAfter = params.slidesOffsetAfter.call(swiper);\n  }\n  const previousSnapGridLength = swiper.snapGrid.length;\n  const previousSlidesGridLength = swiper.slidesGrid.length;\n  let spaceBetween = params.spaceBetween;\n  let slidePosition = -offsetBefore;\n  let prevSlideSize = 0;\n  let index = 0;\n  if (typeof swiperSize === 'undefined') {\n    return;\n  }\n  if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n    spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiperSize;\n  } else if (typeof spaceBetween === 'string') {\n    spaceBetween = parseFloat(spaceBetween);\n  }\n  swiper.virtualSize = -spaceBetween;\n\n  // reset margins\n  slides.forEach(slideEl => {\n    if (rtl) {\n      slideEl.style.marginLeft = '';\n    } else {\n      slideEl.style.marginRight = '';\n    }\n    slideEl.style.marginBottom = '';\n    slideEl.style.marginTop = '';\n  });\n\n  // reset cssMode offsets\n  if (params.centeredSlides && params.cssMode) {\n    setCSSProperty(wrapperEl, '--swiper-centered-offset-before', '');\n    setCSSProperty(wrapperEl, '--swiper-centered-offset-after', '');\n  }\n  const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid;\n  if (gridEnabled) {\n    swiper.grid.initSlides(slides);\n  } else if (swiper.grid) {\n    swiper.grid.unsetSlides();\n  }\n\n  // Calc slides\n  let slideSize;\n  const shouldResetSlideSize = params.slidesPerView === 'auto' && params.breakpoints && Object.keys(params.breakpoints).filter(key => {\n    return typeof params.breakpoints[key].slidesPerView !== 'undefined';\n  }).length > 0;\n  for (let i = 0; i < slidesLength; i += 1) {\n    slideSize = 0;\n    let slide;\n    if (slides[i]) slide = slides[i];\n    if (gridEnabled) {\n      swiper.grid.updateSlide(i, slide, slides);\n    }\n    if (slides[i] && elementStyle(slide, 'display') === 'none') continue; // eslint-disable-line\n\n    if (params.slidesPerView === 'auto') {\n      if (shouldResetSlideSize) {\n        slides[i].style[swiper.getDirectionLabel('width')] = ``;\n      }\n      const slideStyles = getComputedStyle(slide);\n      const currentTransform = slide.style.transform;\n      const currentWebKitTransform = slide.style.webkitTransform;\n      if (currentTransform) {\n        slide.style.transform = 'none';\n      }\n      if (currentWebKitTransform) {\n        slide.style.webkitTransform = 'none';\n      }\n      if (params.roundLengths) {\n        slideSize = swiper.isHorizontal() ? elementOuterSize(slide, 'width', true) : elementOuterSize(slide, 'height', true);\n      } else {\n        // eslint-disable-next-line\n        const width = getDirectionPropertyValue(slideStyles, 'width');\n        const paddingLeft = getDirectionPropertyValue(slideStyles, 'padding-left');\n        const paddingRight = getDirectionPropertyValue(slideStyles, 'padding-right');\n        const marginLeft = getDirectionPropertyValue(slideStyles, 'margin-left');\n        const marginRight = getDirectionPropertyValue(slideStyles, 'margin-right');\n        const boxSizing = slideStyles.getPropertyValue('box-sizing');\n        if (boxSizing && boxSizing === 'border-box') {\n          slideSize = width + marginLeft + marginRight;\n        } else {\n          const {\n            clientWidth,\n            offsetWidth\n          } = slide;\n          slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth);\n        }\n      }\n      if (currentTransform) {\n        slide.style.transform = currentTransform;\n      }\n      if (currentWebKitTransform) {\n        slide.style.webkitTransform = currentWebKitTransform;\n      }\n      if (params.roundLengths) slideSize = Math.floor(slideSize);\n    } else {\n      slideSize = (swiperSize - (params.slidesPerView - 1) * spaceBetween) / params.slidesPerView;\n      if (params.roundLengths) slideSize = Math.floor(slideSize);\n      if (slides[i]) {\n        slides[i].style[swiper.getDirectionLabel('width')] = `${slideSize}px`;\n      }\n    }\n    if (slides[i]) {\n      slides[i].swiperSlideSize = slideSize;\n    }\n    slidesSizesGrid.push(slideSize);\n    if (params.centeredSlides) {\n      slidePosition = slidePosition + slideSize / 2 + prevSlideSize / 2 + spaceBetween;\n      if (prevSlideSize === 0 && i !== 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n      if (i === 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;\n      if (Math.abs(slidePosition) < 1 / 1000) slidePosition = 0;\n      if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n      if (index % params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n      slidesGrid.push(slidePosition);\n    } else {\n      if (params.roundLengths) slidePosition = Math.floor(slidePosition);\n      if ((index - Math.min(swiper.params.slidesPerGroupSkip, index)) % swiper.params.slidesPerGroup === 0) snapGrid.push(slidePosition);\n      slidesGrid.push(slidePosition);\n      slidePosition = slidePosition + slideSize + spaceBetween;\n    }\n    swiper.virtualSize += slideSize + spaceBetween;\n    prevSlideSize = slideSize;\n    index += 1;\n  }\n  swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;\n  if (rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {\n    wrapperEl.style.width = `${swiper.virtualSize + spaceBetween}px`;\n  }\n  if (params.setWrapperSize) {\n    wrapperEl.style[swiper.getDirectionLabel('width')] = `${swiper.virtualSize + spaceBetween}px`;\n  }\n  if (gridEnabled) {\n    swiper.grid.updateWrapperSize(slideSize, snapGrid);\n  }\n\n  // Remove last grid elements depending on width\n  if (!params.centeredSlides) {\n    const newSlidesGrid = [];\n    for (let i = 0; i < snapGrid.length; i += 1) {\n      let slidesGridItem = snapGrid[i];\n      if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem);\n      if (snapGrid[i] <= swiper.virtualSize - swiperSize) {\n        newSlidesGrid.push(slidesGridItem);\n      }\n    }\n    snapGrid = newSlidesGrid;\n    if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {\n      snapGrid.push(swiper.virtualSize - swiperSize);\n    }\n  }\n  if (isVirtual && params.loop) {\n    const size = slidesSizesGrid[0] + spaceBetween;\n    if (params.slidesPerGroup > 1) {\n      const groups = Math.ceil((swiper.virtual.slidesBefore + swiper.virtual.slidesAfter) / params.slidesPerGroup);\n      const groupSize = size * params.slidesPerGroup;\n      for (let i = 0; i < groups; i += 1) {\n        snapGrid.push(snapGrid[snapGrid.length - 1] + groupSize);\n      }\n    }\n    for (let i = 0; i < swiper.virtual.slidesBefore + swiper.virtual.slidesAfter; i += 1) {\n      if (params.slidesPerGroup === 1) {\n        snapGrid.push(snapGrid[snapGrid.length - 1] + size);\n      }\n      slidesGrid.push(slidesGrid[slidesGrid.length - 1] + size);\n      swiper.virtualSize += size;\n    }\n  }\n  if (snapGrid.length === 0) snapGrid = [0];\n  if (spaceBetween !== 0) {\n    const key = swiper.isHorizontal() && rtl ? 'marginLeft' : swiper.getDirectionLabel('marginRight');\n    slides.filter((_, slideIndex) => {\n      if (!params.cssMode || params.loop) return true;\n      if (slideIndex === slides.length - 1) {\n        return false;\n      }\n      return true;\n    }).forEach(slideEl => {\n      slideEl.style[key] = `${spaceBetween}px`;\n    });\n  }\n  if (params.centeredSlides && params.centeredSlidesBounds) {\n    let allSlidesSize = 0;\n    slidesSizesGrid.forEach(slideSizeValue => {\n      allSlidesSize += slideSizeValue + (spaceBetween || 0);\n    });\n    allSlidesSize -= spaceBetween;\n    const maxSnap = allSlidesSize > swiperSize ? allSlidesSize - swiperSize : 0;\n    snapGrid = snapGrid.map(snap => {\n      if (snap <= 0) return -offsetBefore;\n      if (snap > maxSnap) return maxSnap + offsetAfter;\n      return snap;\n    });\n  }\n  if (params.centerInsufficientSlides) {\n    let allSlidesSize = 0;\n    slidesSizesGrid.forEach(slideSizeValue => {\n      allSlidesSize += slideSizeValue + (spaceBetween || 0);\n    });\n    allSlidesSize -= spaceBetween;\n    const offsetSize = (params.slidesOffsetBefore || 0) + (params.slidesOffsetAfter || 0);\n    if (allSlidesSize + offsetSize < swiperSize) {\n      const allSlidesOffset = (swiperSize - allSlidesSize - offsetSize) / 2;\n      snapGrid.forEach((snap, snapIndex) => {\n        snapGrid[snapIndex] = snap - allSlidesOffset;\n      });\n      slidesGrid.forEach((snap, snapIndex) => {\n        slidesGrid[snapIndex] = snap + allSlidesOffset;\n      });\n    }\n  }\n  Object.assign(swiper, {\n    slides,\n    snapGrid,\n    slidesGrid,\n    slidesSizesGrid\n  });\n  if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) {\n    setCSSProperty(wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);\n    setCSSProperty(wrapperEl, '--swiper-centered-offset-after', `${swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2}px`);\n    const addToSnapGrid = -swiper.snapGrid[0];\n    const addToSlidesGrid = -swiper.slidesGrid[0];\n    swiper.snapGrid = swiper.snapGrid.map(v => v + addToSnapGrid);\n    swiper.slidesGrid = swiper.slidesGrid.map(v => v + addToSlidesGrid);\n  }\n  if (slidesLength !== previousSlidesLength) {\n    swiper.emit('slidesLengthChange');\n  }\n  if (snapGrid.length !== previousSnapGridLength) {\n    if (swiper.params.watchOverflow) swiper.checkOverflow();\n    swiper.emit('snapGridLengthChange');\n  }\n  if (slidesGrid.length !== previousSlidesGridLength) {\n    swiper.emit('slidesGridLengthChange');\n  }\n  if (params.watchSlidesProgress) {\n    swiper.updateSlidesOffset();\n  }\n  swiper.emit('slidesUpdated');\n  if (!isVirtual && !params.cssMode && (params.effect === 'slide' || params.effect === 'fade')) {\n    const backFaceHiddenClass = `${params.containerModifierClass}backface-hidden`;\n    const hasClassBackfaceClassAdded = swiper.el.classList.contains(backFaceHiddenClass);\n    if (slidesLength <= params.maxBackfaceHiddenSlides) {\n      if (!hasClassBackfaceClassAdded) swiper.el.classList.add(backFaceHiddenClass);\n    } else if (hasClassBackfaceClassAdded) {\n      swiper.el.classList.remove(backFaceHiddenClass);\n    }\n  }\n}\n\nfunction updateAutoHeight(speed) {\n  const swiper = this;\n  const activeSlides = [];\n  const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n  let newHeight = 0;\n  let i;\n  if (typeof speed === 'number') {\n    swiper.setTransition(speed);\n  } else if (speed === true) {\n    swiper.setTransition(swiper.params.speed);\n  }\n  const getSlideByIndex = index => {\n    if (isVirtual) {\n      return swiper.slides[swiper.getSlideIndexByData(index)];\n    }\n    return swiper.slides[index];\n  };\n  // Find slides currently in view\n  if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {\n    if (swiper.params.centeredSlides) {\n      (swiper.visibleSlides || []).forEach(slide => {\n        activeSlides.push(slide);\n      });\n    } else {\n      for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) {\n        const index = swiper.activeIndex + i;\n        if (index > swiper.slides.length && !isVirtual) break;\n        activeSlides.push(getSlideByIndex(index));\n      }\n    }\n  } else {\n    activeSlides.push(getSlideByIndex(swiper.activeIndex));\n  }\n\n  // Find new height from highest slide in view\n  for (i = 0; i < activeSlides.length; i += 1) {\n    if (typeof activeSlides[i] !== 'undefined') {\n      const height = activeSlides[i].offsetHeight;\n      newHeight = height > newHeight ? height : newHeight;\n    }\n  }\n\n  // Update Height\n  if (newHeight || newHeight === 0) swiper.wrapperEl.style.height = `${newHeight}px`;\n}\n\nfunction updateSlidesOffset() {\n  const swiper = this;\n  const slides = swiper.slides;\n  // eslint-disable-next-line\n  const minusOffset = swiper.isElement ? swiper.isHorizontal() ? swiper.wrapperEl.offsetLeft : swiper.wrapperEl.offsetTop : 0;\n  for (let i = 0; i < slides.length; i += 1) {\n    slides[i].swiperSlideOffset = (swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop) - minusOffset - swiper.cssOverflowAdjustment();\n  }\n}\n\nconst toggleSlideClasses$1 = (slideEl, condition, className) => {\n  if (condition && !slideEl.classList.contains(className)) {\n    slideEl.classList.add(className);\n  } else if (!condition && slideEl.classList.contains(className)) {\n    slideEl.classList.remove(className);\n  }\n};\nfunction updateSlidesProgress(translate) {\n  if (translate === void 0) {\n    translate = this && this.translate || 0;\n  }\n  const swiper = this;\n  const params = swiper.params;\n  const {\n    slides,\n    rtlTranslate: rtl,\n    snapGrid\n  } = swiper;\n  if (slides.length === 0) return;\n  if (typeof slides[0].swiperSlideOffset === 'undefined') swiper.updateSlidesOffset();\n  let offsetCenter = -translate;\n  if (rtl) offsetCenter = translate;\n  swiper.visibleSlidesIndexes = [];\n  swiper.visibleSlides = [];\n  let spaceBetween = params.spaceBetween;\n  if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {\n    spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiper.size;\n  } else if (typeof spaceBetween === 'string') {\n    spaceBetween = parseFloat(spaceBetween);\n  }\n  for (let i = 0; i < slides.length; i += 1) {\n    const slide = slides[i];\n    let slideOffset = slide.swiperSlideOffset;\n    if (params.cssMode && params.centeredSlides) {\n      slideOffset -= slides[0].swiperSlideOffset;\n    }\n    const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + spaceBetween);\n    const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + spaceBetween);\n    const slideBefore = -(offsetCenter - slideOffset);\n    const slideAfter = slideBefore + swiper.slidesSizesGrid[i];\n    const isFullyVisible = slideBefore >= 0 && slideBefore <= swiper.size - swiper.slidesSizesGrid[i];\n    const isVisible = slideBefore >= 0 && slideBefore < swiper.size - 1 || slideAfter > 1 && slideAfter <= swiper.size || slideBefore <= 0 && slideAfter >= swiper.size;\n    if (isVisible) {\n      swiper.visibleSlides.push(slide);\n      swiper.visibleSlidesIndexes.push(i);\n    }\n    toggleSlideClasses$1(slide, isVisible, params.slideVisibleClass);\n    toggleSlideClasses$1(slide, isFullyVisible, params.slideFullyVisibleClass);\n    slide.progress = rtl ? -slideProgress : slideProgress;\n    slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;\n  }\n}\n\nfunction updateProgress(translate) {\n  const swiper = this;\n  if (typeof translate === 'undefined') {\n    const multiplier = swiper.rtlTranslate ? -1 : 1;\n    // eslint-disable-next-line\n    translate = swiper && swiper.translate && swiper.translate * multiplier || 0;\n  }\n  const params = swiper.params;\n  const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n  let {\n    progress,\n    isBeginning,\n    isEnd,\n    progressLoop\n  } = swiper;\n  const wasBeginning = isBeginning;\n  const wasEnd = isEnd;\n  if (translatesDiff === 0) {\n    progress = 0;\n    isBeginning = true;\n    isEnd = true;\n  } else {\n    progress = (translate - swiper.minTranslate()) / translatesDiff;\n    const isBeginningRounded = Math.abs(translate - swiper.minTranslate()) < 1;\n    const isEndRounded = Math.abs(translate - swiper.maxTranslate()) < 1;\n    isBeginning = isBeginningRounded || progress <= 0;\n    isEnd = isEndRounded || progress >= 1;\n    if (isBeginningRounded) progress = 0;\n    if (isEndRounded) progress = 1;\n  }\n  if (params.loop) {\n    const firstSlideIndex = swiper.getSlideIndexByData(0);\n    const lastSlideIndex = swiper.getSlideIndexByData(swiper.slides.length - 1);\n    const firstSlideTranslate = swiper.slidesGrid[firstSlideIndex];\n    const lastSlideTranslate = swiper.slidesGrid[lastSlideIndex];\n    const translateMax = swiper.slidesGrid[swiper.slidesGrid.length - 1];\n    const translateAbs = Math.abs(translate);\n    if (translateAbs >= firstSlideTranslate) {\n      progressLoop = (translateAbs - firstSlideTranslate) / translateMax;\n    } else {\n      progressLoop = (translateAbs + translateMax - lastSlideTranslate) / translateMax;\n    }\n    if (progressLoop > 1) progressLoop -= 1;\n  }\n  Object.assign(swiper, {\n    progress,\n    progressLoop,\n    isBeginning,\n    isEnd\n  });\n  if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate);\n  if (isBeginning && !wasBeginning) {\n    swiper.emit('reachBeginning toEdge');\n  }\n  if (isEnd && !wasEnd) {\n    swiper.emit('reachEnd toEdge');\n  }\n  if (wasBeginning && !isBeginning || wasEnd && !isEnd) {\n    swiper.emit('fromEdge');\n  }\n  swiper.emit('progress', progress);\n}\n\nconst toggleSlideClasses = (slideEl, condition, className) => {\n  if (condition && !slideEl.classList.contains(className)) {\n    slideEl.classList.add(className);\n  } else if (!condition && slideEl.classList.contains(className)) {\n    slideEl.classList.remove(className);\n  }\n};\nfunction updateSlidesClasses() {\n  const swiper = this;\n  const {\n    slides,\n    params,\n    slidesEl,\n    activeIndex\n  } = swiper;\n  const isVirtual = swiper.virtual && params.virtual.enabled;\n  const gridEnabled = swiper.grid && params.grid && params.grid.rows > 1;\n  const getFilteredSlide = selector => {\n    return elementChildren(slidesEl, `.${params.slideClass}${selector}, swiper-slide${selector}`)[0];\n  };\n  let activeSlide;\n  let prevSlide;\n  let nextSlide;\n  if (isVirtual) {\n    if (params.loop) {\n      let slideIndex = activeIndex - swiper.virtual.slidesBefore;\n      if (slideIndex < 0) slideIndex = swiper.virtual.slides.length + slideIndex;\n      if (slideIndex >= swiper.virtual.slides.length) slideIndex -= swiper.virtual.slides.length;\n      activeSlide = getFilteredSlide(`[data-swiper-slide-index=\"${slideIndex}\"]`);\n    } else {\n      activeSlide = getFilteredSlide(`[data-swiper-slide-index=\"${activeIndex}\"]`);\n    }\n  } else {\n    if (gridEnabled) {\n      activeSlide = slides.find(slideEl => slideEl.column === activeIndex);\n      nextSlide = slides.find(slideEl => slideEl.column === activeIndex + 1);\n      prevSlide = slides.find(slideEl => slideEl.column === activeIndex - 1);\n    } else {\n      activeSlide = slides[activeIndex];\n    }\n  }\n  if (activeSlide) {\n    if (!gridEnabled) {\n      // Next Slide\n      nextSlide = elementNextAll(activeSlide, `.${params.slideClass}, swiper-slide`)[0];\n      if (params.loop && !nextSlide) {\n        nextSlide = slides[0];\n      }\n\n      // Prev Slide\n      prevSlide = elementPrevAll(activeSlide, `.${params.slideClass}, swiper-slide`)[0];\n      if (params.loop && !prevSlide === 0) {\n        prevSlide = slides[slides.length - 1];\n      }\n    }\n  }\n  slides.forEach(slideEl => {\n    toggleSlideClasses(slideEl, slideEl === activeSlide, params.slideActiveClass);\n    toggleSlideClasses(slideEl, slideEl === nextSlide, params.slideNextClass);\n    toggleSlideClasses(slideEl, slideEl === prevSlide, params.slidePrevClass);\n  });\n  swiper.emitSlidesClasses();\n}\n\nconst processLazyPreloader = (swiper, imageEl) => {\n  if (!swiper || swiper.destroyed || !swiper.params) return;\n  const slideSelector = () => swiper.isElement ? `swiper-slide` : `.${swiper.params.slideClass}`;\n  const slideEl = imageEl.closest(slideSelector());\n  if (slideEl) {\n    let lazyEl = slideEl.querySelector(`.${swiper.params.lazyPreloaderClass}`);\n    if (!lazyEl && swiper.isElement) {\n      if (slideEl.shadowRoot) {\n        lazyEl = slideEl.shadowRoot.querySelector(`.${swiper.params.lazyPreloaderClass}`);\n      } else {\n        // init later\n        requestAnimationFrame(() => {\n          if (slideEl.shadowRoot) {\n            lazyEl = slideEl.shadowRoot.querySelector(`.${swiper.params.lazyPreloaderClass}`);\n            if (lazyEl) lazyEl.remove();\n          }\n        });\n      }\n    }\n    if (lazyEl) lazyEl.remove();\n  }\n};\nconst unlazy = (swiper, index) => {\n  if (!swiper.slides[index]) return;\n  const imageEl = swiper.slides[index].querySelector('[loading=\"lazy\"]');\n  if (imageEl) imageEl.removeAttribute('loading');\n};\nconst preload = swiper => {\n  if (!swiper || swiper.destroyed || !swiper.params) return;\n  let amount = swiper.params.lazyPreloadPrevNext;\n  const len = swiper.slides.length;\n  if (!len || !amount || amount < 0) return;\n  amount = Math.min(amount, len);\n  const slidesPerView = swiper.params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : Math.ceil(swiper.params.slidesPerView);\n  const activeIndex = swiper.activeIndex;\n  if (swiper.params.grid && swiper.params.grid.rows > 1) {\n    const activeColumn = activeIndex;\n    const preloadColumns = [activeColumn - amount];\n    preloadColumns.push(...Array.from({\n      length: amount\n    }).map((_, i) => {\n      return activeColumn + slidesPerView + i;\n    }));\n    swiper.slides.forEach((slideEl, i) => {\n      if (preloadColumns.includes(slideEl.column)) unlazy(swiper, i);\n    });\n    return;\n  }\n  const slideIndexLastInView = activeIndex + slidesPerView - 1;\n  if (swiper.params.rewind || swiper.params.loop) {\n    for (let i = activeIndex - amount; i <= slideIndexLastInView + amount; i += 1) {\n      const realIndex = (i % len + len) % len;\n      if (realIndex < activeIndex || realIndex > slideIndexLastInView) unlazy(swiper, realIndex);\n    }\n  } else {\n    for (let i = Math.max(activeIndex - amount, 0); i <= Math.min(slideIndexLastInView + amount, len - 1); i += 1) {\n      if (i !== activeIndex && (i > slideIndexLastInView || i < activeIndex)) {\n        unlazy(swiper, i);\n      }\n    }\n  }\n};\n\nfunction getActiveIndexByTranslate(swiper) {\n  const {\n    slidesGrid,\n    params\n  } = swiper;\n  const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n  let activeIndex;\n  for (let i = 0; i < slidesGrid.length; i += 1) {\n    if (typeof slidesGrid[i + 1] !== 'undefined') {\n      if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2) {\n        activeIndex = i;\n      } else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) {\n        activeIndex = i + 1;\n      }\n    } else if (translate >= slidesGrid[i]) {\n      activeIndex = i;\n    }\n  }\n  // Normalize slideIndex\n  if (params.normalizeSlideIndex) {\n    if (activeIndex < 0 || typeof activeIndex === 'undefined') activeIndex = 0;\n  }\n  return activeIndex;\n}\nfunction updateActiveIndex(newActiveIndex) {\n  const swiper = this;\n  const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n  const {\n    snapGrid,\n    params,\n    activeIndex: previousIndex,\n    realIndex: previousRealIndex,\n    snapIndex: previousSnapIndex\n  } = swiper;\n  let activeIndex = newActiveIndex;\n  let snapIndex;\n  const getVirtualRealIndex = aIndex => {\n    let realIndex = aIndex - swiper.virtual.slidesBefore;\n    if (realIndex < 0) {\n      realIndex = swiper.virtual.slides.length + realIndex;\n    }\n    if (realIndex >= swiper.virtual.slides.length) {\n      realIndex -= swiper.virtual.slides.length;\n    }\n    return realIndex;\n  };\n  if (typeof activeIndex === 'undefined') {\n    activeIndex = getActiveIndexByTranslate(swiper);\n  }\n  if (snapGrid.indexOf(translate) >= 0) {\n    snapIndex = snapGrid.indexOf(translate);\n  } else {\n    const skip = Math.min(params.slidesPerGroupSkip, activeIndex);\n    snapIndex = skip + Math.floor((activeIndex - skip) / params.slidesPerGroup);\n  }\n  if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n  if (activeIndex === previousIndex && !swiper.params.loop) {\n    if (snapIndex !== previousSnapIndex) {\n      swiper.snapIndex = snapIndex;\n      swiper.emit('snapIndexChange');\n    }\n    return;\n  }\n  if (activeIndex === previousIndex && swiper.params.loop && swiper.virtual && swiper.params.virtual.enabled) {\n    swiper.realIndex = getVirtualRealIndex(activeIndex);\n    return;\n  }\n  const gridEnabled = swiper.grid && params.grid && params.grid.rows > 1;\n\n  // Get real index\n  let realIndex;\n  if (swiper.virtual && params.virtual.enabled && params.loop) {\n    realIndex = getVirtualRealIndex(activeIndex);\n  } else if (gridEnabled) {\n    const firstSlideInColumn = swiper.slides.find(slideEl => slideEl.column === activeIndex);\n    let activeSlideIndex = parseInt(firstSlideInColumn.getAttribute('data-swiper-slide-index'), 10);\n    if (Number.isNaN(activeSlideIndex)) {\n      activeSlideIndex = Math.max(swiper.slides.indexOf(firstSlideInColumn), 0);\n    }\n    realIndex = Math.floor(activeSlideIndex / params.grid.rows);\n  } else if (swiper.slides[activeIndex]) {\n    const slideIndex = swiper.slides[activeIndex].getAttribute('data-swiper-slide-index');\n    if (slideIndex) {\n      realIndex = parseInt(slideIndex, 10);\n    } else {\n      realIndex = activeIndex;\n    }\n  } else {\n    realIndex = activeIndex;\n  }\n  Object.assign(swiper, {\n    previousSnapIndex,\n    snapIndex,\n    previousRealIndex,\n    realIndex,\n    previousIndex,\n    activeIndex\n  });\n  if (swiper.initialized) {\n    preload(swiper);\n  }\n  swiper.emit('activeIndexChange');\n  swiper.emit('snapIndexChange');\n  if (swiper.initialized || swiper.params.runCallbacksOnInit) {\n    if (previousRealIndex !== realIndex) {\n      swiper.emit('realIndexChange');\n    }\n    swiper.emit('slideChange');\n  }\n}\n\nfunction updateClickedSlide(el, path) {\n  const swiper = this;\n  const params = swiper.params;\n  let slide = el.closest(`.${params.slideClass}, swiper-slide`);\n  if (!slide && swiper.isElement && path && path.length > 1 && path.includes(el)) {\n    [...path.slice(path.indexOf(el) + 1, path.length)].forEach(pathEl => {\n      if (!slide && pathEl.matches && pathEl.matches(`.${params.slideClass}, swiper-slide`)) {\n        slide = pathEl;\n      }\n    });\n  }\n  let slideFound = false;\n  let slideIndex;\n  if (slide) {\n    for (let i = 0; i < swiper.slides.length; i += 1) {\n      if (swiper.slides[i] === slide) {\n        slideFound = true;\n        slideIndex = i;\n        break;\n      }\n    }\n  }\n  if (slide && slideFound) {\n    swiper.clickedSlide = slide;\n    if (swiper.virtual && swiper.params.virtual.enabled) {\n      swiper.clickedIndex = parseInt(slide.getAttribute('data-swiper-slide-index'), 10);\n    } else {\n      swiper.clickedIndex = slideIndex;\n    }\n  } else {\n    swiper.clickedSlide = undefined;\n    swiper.clickedIndex = undefined;\n    return;\n  }\n  if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) {\n    swiper.slideToClickedSlide();\n  }\n}\n\nvar update = {\n  updateSize,\n  updateSlides,\n  updateAutoHeight,\n  updateSlidesOffset,\n  updateSlidesProgress,\n  updateProgress,\n  updateSlidesClasses,\n  updateActiveIndex,\n  updateClickedSlide\n};\n\nfunction getSwiperTranslate(axis) {\n  if (axis === void 0) {\n    axis = this.isHorizontal() ? 'x' : 'y';\n  }\n  const swiper = this;\n  const {\n    params,\n    rtlTranslate: rtl,\n    translate,\n    wrapperEl\n  } = swiper;\n  if (params.virtualTranslate) {\n    return rtl ? -translate : translate;\n  }\n  if (params.cssMode) {\n    return translate;\n  }\n  let currentTranslate = getTranslate(wrapperEl, axis);\n  currentTranslate += swiper.cssOverflowAdjustment();\n  if (rtl) currentTranslate = -currentTranslate;\n  return currentTranslate || 0;\n}\n\nfunction setTranslate(translate, byController) {\n  const swiper = this;\n  const {\n    rtlTranslate: rtl,\n    params,\n    wrapperEl,\n    progress\n  } = swiper;\n  let x = 0;\n  let y = 0;\n  const z = 0;\n  if (swiper.isHorizontal()) {\n    x = rtl ? -translate : translate;\n  } else {\n    y = translate;\n  }\n  if (params.roundLengths) {\n    x = Math.floor(x);\n    y = Math.floor(y);\n  }\n  swiper.previousTranslate = swiper.translate;\n  swiper.translate = swiper.isHorizontal() ? x : y;\n  if (params.cssMode) {\n    wrapperEl[swiper.isHorizontal() ? 'scrollLeft' : 'scrollTop'] = swiper.isHorizontal() ? -x : -y;\n  } else if (!params.virtualTranslate) {\n    if (swiper.isHorizontal()) {\n      x -= swiper.cssOverflowAdjustment();\n    } else {\n      y -= swiper.cssOverflowAdjustment();\n    }\n    wrapperEl.style.transform = `translate3d(${x}px, ${y}px, ${z}px)`;\n  }\n\n  // Check if we need to update progress\n  let newProgress;\n  const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n  if (translatesDiff === 0) {\n    newProgress = 0;\n  } else {\n    newProgress = (translate - swiper.minTranslate()) / translatesDiff;\n  }\n  if (newProgress !== progress) {\n    swiper.updateProgress(translate);\n  }\n  swiper.emit('setTranslate', swiper.translate, byController);\n}\n\nfunction minTranslate() {\n  return -this.snapGrid[0];\n}\n\nfunction maxTranslate() {\n  return -this.snapGrid[this.snapGrid.length - 1];\n}\n\nfunction translateTo(translate, speed, runCallbacks, translateBounds, internal) {\n  if (translate === void 0) {\n    translate = 0;\n  }\n  if (speed === void 0) {\n    speed = this.params.speed;\n  }\n  if (runCallbacks === void 0) {\n    runCallbacks = true;\n  }\n  if (translateBounds === void 0) {\n    translateBounds = true;\n  }\n  const swiper = this;\n  const {\n    params,\n    wrapperEl\n  } = swiper;\n  if (swiper.animating && params.preventInteractionOnTransition) {\n    return false;\n  }\n  const minTranslate = swiper.minTranslate();\n  const maxTranslate = swiper.maxTranslate();\n  let newTranslate;\n  if (translateBounds && translate > minTranslate) newTranslate = minTranslate;else if (translateBounds && translate < maxTranslate) newTranslate = maxTranslate;else newTranslate = translate;\n\n  // Update progress\n  swiper.updateProgress(newTranslate);\n  if (params.cssMode) {\n    const isH = swiper.isHorizontal();\n    if (speed === 0) {\n      wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = -newTranslate;\n    } else {\n      if (!swiper.support.smoothScroll) {\n        animateCSSModeScroll({\n          swiper,\n          targetPosition: -newTranslate,\n          side: isH ? 'left' : 'top'\n        });\n        return true;\n      }\n      wrapperEl.scrollTo({\n        [isH ? 'left' : 'top']: -newTranslate,\n        behavior: 'smooth'\n      });\n    }\n    return true;\n  }\n  if (speed === 0) {\n    swiper.setTransition(0);\n    swiper.setTranslate(newTranslate);\n    if (runCallbacks) {\n      swiper.emit('beforeTransitionStart', speed, internal);\n      swiper.emit('transitionEnd');\n    }\n  } else {\n    swiper.setTransition(speed);\n    swiper.setTranslate(newTranslate);\n    if (runCallbacks) {\n      swiper.emit('beforeTransitionStart', speed, internal);\n      swiper.emit('transitionStart');\n    }\n    if (!swiper.animating) {\n      swiper.animating = true;\n      if (!swiper.onTranslateToWrapperTransitionEnd) {\n        swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) {\n          if (!swiper || swiper.destroyed) return;\n          if (e.target !== this) return;\n          swiper.wrapperEl.removeEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n          swiper.onTranslateToWrapperTransitionEnd = null;\n          delete swiper.onTranslateToWrapperTransitionEnd;\n          swiper.animating = false;\n          if (runCallbacks) {\n            swiper.emit('transitionEnd');\n          }\n        };\n      }\n      swiper.wrapperEl.addEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);\n    }\n  }\n  return true;\n}\n\nvar translate = {\n  getTranslate: getSwiperTranslate,\n  setTranslate,\n  minTranslate,\n  maxTranslate,\n  translateTo\n};\n\nfunction setTransition(duration, byController) {\n  const swiper = this;\n  if (!swiper.params.cssMode) {\n    swiper.wrapperEl.style.transitionDuration = `${duration}ms`;\n    swiper.wrapperEl.style.transitionDelay = duration === 0 ? `0ms` : '';\n  }\n  swiper.emit('setTransition', duration, byController);\n}\n\nfunction transitionEmit(_ref) {\n  let {\n    swiper,\n    runCallbacks,\n    direction,\n    step\n  } = _ref;\n  const {\n    activeIndex,\n    previousIndex\n  } = swiper;\n  let dir = direction;\n  if (!dir) {\n    if (activeIndex > previousIndex) dir = 'next';else if (activeIndex < previousIndex) dir = 'prev';else dir = 'reset';\n  }\n  swiper.emit(`transition${step}`);\n  if (runCallbacks && activeIndex !== previousIndex) {\n    if (dir === 'reset') {\n      swiper.emit(`slideResetTransition${step}`);\n      return;\n    }\n    swiper.emit(`slideChangeTransition${step}`);\n    if (dir === 'next') {\n      swiper.emit(`slideNextTransition${step}`);\n    } else {\n      swiper.emit(`slidePrevTransition${step}`);\n    }\n  }\n}\n\nfunction transitionStart(runCallbacks, direction) {\n  if (runCallbacks === void 0) {\n    runCallbacks = true;\n  }\n  const swiper = this;\n  const {\n    params\n  } = swiper;\n  if (params.cssMode) return;\n  if (params.autoHeight) {\n    swiper.updateAutoHeight();\n  }\n  transitionEmit({\n    swiper,\n    runCallbacks,\n    direction,\n    step: 'Start'\n  });\n}\n\nfunction transitionEnd(runCallbacks, direction) {\n  if (runCallbacks === void 0) {\n    runCallbacks = true;\n  }\n  const swiper = this;\n  const {\n    params\n  } = swiper;\n  swiper.animating = false;\n  if (params.cssMode) return;\n  swiper.setTransition(0);\n  transitionEmit({\n    swiper,\n    runCallbacks,\n    direction,\n    step: 'End'\n  });\n}\n\nvar transition = {\n  setTransition,\n  transitionStart,\n  transitionEnd\n};\n\nfunction slideTo(index, speed, runCallbacks, internal, initial) {\n  if (index === void 0) {\n    index = 0;\n  }\n  if (runCallbacks === void 0) {\n    runCallbacks = true;\n  }\n  if (typeof index === 'string') {\n    index = parseInt(index, 10);\n  }\n  const swiper = this;\n  let slideIndex = index;\n  if (slideIndex < 0) slideIndex = 0;\n  const {\n    params,\n    snapGrid,\n    slidesGrid,\n    previousIndex,\n    activeIndex,\n    rtlTranslate: rtl,\n    wrapperEl,\n    enabled\n  } = swiper;\n  if (!enabled && !internal && !initial || swiper.destroyed || swiper.animating && params.preventInteractionOnTransition) {\n    return false;\n  }\n  if (typeof speed === 'undefined') {\n    speed = swiper.params.speed;\n  }\n  const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex);\n  let snapIndex = skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup);\n  if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;\n  const translate = -snapGrid[snapIndex];\n  // Normalize slideIndex\n  if (params.normalizeSlideIndex) {\n    for (let i = 0; i < slidesGrid.length; i += 1) {\n      const normalizedTranslate = -Math.floor(translate * 100);\n      const normalizedGrid = Math.floor(slidesGrid[i] * 100);\n      const normalizedGridNext = Math.floor(slidesGrid[i + 1] * 100);\n      if (typeof slidesGrid[i + 1] !== 'undefined') {\n        if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext - (normalizedGridNext - normalizedGrid) / 2) {\n          slideIndex = i;\n        } else if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext) {\n          slideIndex = i + 1;\n        }\n      } else if (normalizedTranslate >= normalizedGrid) {\n        slideIndex = i;\n      }\n    }\n  }\n  // Directions locks\n  if (swiper.initialized && slideIndex !== activeIndex) {\n    if (!swiper.allowSlideNext && (rtl ? translate > swiper.translate && translate > swiper.minTranslate() : translate < swiper.translate && translate < swiper.minTranslate())) {\n      return false;\n    }\n    if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {\n      if ((activeIndex || 0) !== slideIndex) {\n        return false;\n      }\n    }\n  }\n  if (slideIndex !== (previousIndex || 0) && runCallbacks) {\n    swiper.emit('beforeSlideChangeStart');\n  }\n\n  // Update progress\n  swiper.updateProgress(translate);\n  let direction;\n  if (slideIndex > activeIndex) direction = 'next';else if (slideIndex < activeIndex) direction = 'prev';else direction = 'reset';\n\n  // initial virtual\n  const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n  const isInitialVirtual = isVirtual && initial;\n  // Update Index\n  if (!isInitialVirtual && (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate)) {\n    swiper.updateActiveIndex(slideIndex);\n    // Update Height\n    if (params.autoHeight) {\n      swiper.updateAutoHeight();\n    }\n    swiper.updateSlidesClasses();\n    if (params.effect !== 'slide') {\n      swiper.setTranslate(translate);\n    }\n    if (direction !== 'reset') {\n      swiper.transitionStart(runCallbacks, direction);\n      swiper.transitionEnd(runCallbacks, direction);\n    }\n    return false;\n  }\n  if (params.cssMode) {\n    const isH = swiper.isHorizontal();\n    const t = rtl ? translate : -translate;\n    if (speed === 0) {\n      if (isVirtual) {\n        swiper.wrapperEl.style.scrollSnapType = 'none';\n        swiper._immediateVirtual = true;\n      }\n      if (isVirtual && !swiper._cssModeVirtualInitialSet && swiper.params.initialSlide > 0) {\n        swiper._cssModeVirtualInitialSet = true;\n        requestAnimationFrame(() => {\n          wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;\n        });\n      } else {\n        wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;\n      }\n      if (isVirtual) {\n        requestAnimationFrame(() => {\n          swiper.wrapperEl.style.scrollSnapType = '';\n          swiper._immediateVirtual = false;\n        });\n      }\n    } else {\n      if (!swiper.support.smoothScroll) {\n        animateCSSModeScroll({\n          swiper,\n          targetPosition: t,\n          side: isH ? 'left' : 'top'\n        });\n        return true;\n      }\n      wrapperEl.scrollTo({\n        [isH ? 'left' : 'top']: t,\n        behavior: 'smooth'\n      });\n    }\n    return true;\n  }\n  const browser = getBrowser();\n  const isSafari = browser.isSafari;\n  if (isVirtual && !initial && isSafari && swiper.isElement) {\n    swiper.virtual.update(false, false, slideIndex);\n  }\n  swiper.setTransition(speed);\n  swiper.setTranslate(translate);\n  swiper.updateActiveIndex(slideIndex);\n  swiper.updateSlidesClasses();\n  swiper.emit('beforeTransitionStart', speed, internal);\n  swiper.transitionStart(runCallbacks, direction);\n  if (speed === 0) {\n    swiper.transitionEnd(runCallbacks, direction);\n  } else if (!swiper.animating) {\n    swiper.animating = true;\n    if (!swiper.onSlideToWrapperTransitionEnd) {\n      swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {\n        if (!swiper || swiper.destroyed) return;\n        if (e.target !== this) return;\n        swiper.wrapperEl.removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n        swiper.onSlideToWrapperTransitionEnd = null;\n        delete swiper.onSlideToWrapperTransitionEnd;\n        swiper.transitionEnd(runCallbacks, direction);\n      };\n    }\n    swiper.wrapperEl.addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);\n  }\n  return true;\n}\n\nfunction slideToLoop(index, speed, runCallbacks, internal) {\n  if (index === void 0) {\n    index = 0;\n  }\n  if (runCallbacks === void 0) {\n    runCallbacks = true;\n  }\n  if (typeof index === 'string') {\n    const indexAsNumber = parseInt(index, 10);\n    index = indexAsNumber;\n  }\n  const swiper = this;\n  if (swiper.destroyed) return;\n  if (typeof speed === 'undefined') {\n    speed = swiper.params.speed;\n  }\n  const gridEnabled = swiper.grid && swiper.params.grid && swiper.params.grid.rows > 1;\n  let newIndex = index;\n  if (swiper.params.loop) {\n    if (swiper.virtual && swiper.params.virtual.enabled) {\n      // eslint-disable-next-line\n      newIndex = newIndex + swiper.virtual.slidesBefore;\n    } else {\n      let targetSlideIndex;\n      if (gridEnabled) {\n        const slideIndex = newIndex * swiper.params.grid.rows;\n        targetSlideIndex = swiper.slides.find(slideEl => slideEl.getAttribute('data-swiper-slide-index') * 1 === slideIndex).column;\n      } else {\n        targetSlideIndex = swiper.getSlideIndexByData(newIndex);\n      }\n      const cols = gridEnabled ? Math.ceil(swiper.slides.length / swiper.params.grid.rows) : swiper.slides.length;\n      const {\n        centeredSlides\n      } = swiper.params;\n      let slidesPerView = swiper.params.slidesPerView;\n      if (slidesPerView === 'auto') {\n        slidesPerView = swiper.slidesPerViewDynamic();\n      } else {\n        slidesPerView = Math.ceil(parseFloat(swiper.params.slidesPerView, 10));\n        if (centeredSlides && slidesPerView % 2 === 0) {\n          slidesPerView = slidesPerView + 1;\n        }\n      }\n      let needLoopFix = cols - targetSlideIndex < slidesPerView;\n      if (centeredSlides) {\n        needLoopFix = needLoopFix || targetSlideIndex < Math.ceil(slidesPerView / 2);\n      }\n      if (internal && centeredSlides && swiper.params.slidesPerView !== 'auto' && !gridEnabled) {\n        needLoopFix = false;\n      }\n      if (needLoopFix) {\n        const direction = centeredSlides ? targetSlideIndex < swiper.activeIndex ? 'prev' : 'next' : targetSlideIndex - swiper.activeIndex - 1 < swiper.params.slidesPerView ? 'next' : 'prev';\n        swiper.loopFix({\n          direction,\n          slideTo: true,\n          activeSlideIndex: direction === 'next' ? targetSlideIndex + 1 : targetSlideIndex - cols + 1,\n          slideRealIndex: direction === 'next' ? swiper.realIndex : undefined\n        });\n      }\n      if (gridEnabled) {\n        const slideIndex = newIndex * swiper.params.grid.rows;\n        newIndex = swiper.slides.find(slideEl => slideEl.getAttribute('data-swiper-slide-index') * 1 === slideIndex).column;\n      } else {\n        newIndex = swiper.getSlideIndexByData(newIndex);\n      }\n    }\n  }\n  requestAnimationFrame(() => {\n    swiper.slideTo(newIndex, speed, runCallbacks, internal);\n  });\n  return swiper;\n}\n\n/* eslint no-unused-vars: \"off\" */\nfunction slideNext(speed, runCallbacks, internal) {\n  if (runCallbacks === void 0) {\n    runCallbacks = true;\n  }\n  const swiper = this;\n  const {\n    enabled,\n    params,\n    animating\n  } = swiper;\n  if (!enabled || swiper.destroyed) return swiper;\n  if (typeof speed === 'undefined') {\n    speed = swiper.params.speed;\n  }\n  let perGroup = params.slidesPerGroup;\n  if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n    perGroup = Math.max(swiper.slidesPerViewDynamic('current', true), 1);\n  }\n  const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup;\n  const isVirtual = swiper.virtual && params.virtual.enabled;\n  if (params.loop) {\n    if (animating && !isVirtual && params.loopPreventsSliding) return false;\n    swiper.loopFix({\n      direction: 'next'\n    });\n    // eslint-disable-next-line\n    swiper._clientLeft = swiper.wrapperEl.clientLeft;\n    if (swiper.activeIndex === swiper.slides.length - 1 && params.cssMode) {\n      requestAnimationFrame(() => {\n        swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);\n      });\n      return true;\n    }\n  }\n  if (params.rewind && swiper.isEnd) {\n    return swiper.slideTo(0, speed, runCallbacks, internal);\n  }\n  return swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);\n}\n\n/* eslint no-unused-vars: \"off\" */\nfunction slidePrev(speed, runCallbacks, internal) {\n  if (runCallbacks === void 0) {\n    runCallbacks = true;\n  }\n  const swiper = this;\n  const {\n    params,\n    snapGrid,\n    slidesGrid,\n    rtlTranslate,\n    enabled,\n    animating\n  } = swiper;\n  if (!enabled || swiper.destroyed) return swiper;\n  if (typeof speed === 'undefined') {\n    speed = swiper.params.speed;\n  }\n  const isVirtual = swiper.virtual && params.virtual.enabled;\n  if (params.loop) {\n    if (animating && !isVirtual && params.loopPreventsSliding) return false;\n    swiper.loopFix({\n      direction: 'prev'\n    });\n    // eslint-disable-next-line\n    swiper._clientLeft = swiper.wrapperEl.clientLeft;\n  }\n  const translate = rtlTranslate ? swiper.translate : -swiper.translate;\n  function normalize(val) {\n    if (val < 0) return -Math.floor(Math.abs(val));\n    return Math.floor(val);\n  }\n  const normalizedTranslate = normalize(translate);\n  const normalizedSnapGrid = snapGrid.map(val => normalize(val));\n  const isFreeMode = params.freeMode && params.freeMode.enabled;\n  let prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];\n  if (typeof prevSnap === 'undefined' && (params.cssMode || isFreeMode)) {\n    let prevSnapIndex;\n    snapGrid.forEach((snap, snapIndex) => {\n      if (normalizedTranslate >= snap) {\n        // prevSnap = snap;\n        prevSnapIndex = snapIndex;\n      }\n    });\n    if (typeof prevSnapIndex !== 'undefined') {\n      prevSnap = isFreeMode ? snapGrid[prevSnapIndex] : snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex];\n    }\n  }\n  let prevIndex = 0;\n  if (typeof prevSnap !== 'undefined') {\n    prevIndex = slidesGrid.indexOf(prevSnap);\n    if (prevIndex < 0) prevIndex = swiper.activeIndex - 1;\n    if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {\n      prevIndex = prevIndex - swiper.slidesPerViewDynamic('previous', true) + 1;\n      prevIndex = Math.max(prevIndex, 0);\n    }\n  }\n  if (params.rewind && swiper.isBeginning) {\n    const lastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;\n    return swiper.slideTo(lastIndex, speed, runCallbacks, internal);\n  } else if (params.loop && swiper.activeIndex === 0 && params.cssMode) {\n    requestAnimationFrame(() => {\n      swiper.slideTo(prevIndex, speed, runCallbacks, internal);\n    });\n    return true;\n  }\n  return swiper.slideTo(prevIndex, speed, runCallbacks, internal);\n}\n\n/* eslint no-unused-vars: \"off\" */\nfunction slideReset(speed, runCallbacks, internal) {\n  if (runCallbacks === void 0) {\n    runCallbacks = true;\n  }\n  const swiper = this;\n  if (swiper.destroyed) return;\n  if (typeof speed === 'undefined') {\n    speed = swiper.params.speed;\n  }\n  return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);\n}\n\n/* eslint no-unused-vars: \"off\" */\nfunction slideToClosest(speed, runCallbacks, internal, threshold) {\n  if (runCallbacks === void 0) {\n    runCallbacks = true;\n  }\n  if (threshold === void 0) {\n    threshold = 0.5;\n  }\n  const swiper = this;\n  if (swiper.destroyed) return;\n  if (typeof speed === 'undefined') {\n    speed = swiper.params.speed;\n  }\n  let index = swiper.activeIndex;\n  const skip = Math.min(swiper.params.slidesPerGroupSkip, index);\n  const snapIndex = skip + Math.floor((index - skip) / swiper.params.slidesPerGroup);\n  const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;\n  if (translate >= swiper.snapGrid[snapIndex]) {\n    // The current translate is on or after the current snap index, so the choice\n    // is between the current index and the one after it.\n    const currentSnap = swiper.snapGrid[snapIndex];\n    const nextSnap = swiper.snapGrid[snapIndex + 1];\n    if (translate - currentSnap > (nextSnap - currentSnap) * threshold) {\n      index += swiper.params.slidesPerGroup;\n    }\n  } else {\n    // The current translate is before the current snap index, so the choice\n    // is between the current index and the one before it.\n    const prevSnap = swiper.snapGrid[snapIndex - 1];\n    const currentSnap = swiper.snapGrid[snapIndex];\n    if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) {\n      index -= swiper.params.slidesPerGroup;\n    }\n  }\n  index = Math.max(index, 0);\n  index = Math.min(index, swiper.slidesGrid.length - 1);\n  return swiper.slideTo(index, speed, runCallbacks, internal);\n}\n\nfunction slideToClickedSlide() {\n  const swiper = this;\n  if (swiper.destroyed) return;\n  const {\n    params,\n    slidesEl\n  } = swiper;\n  const slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;\n  let slideToIndex = swiper.clickedIndex;\n  let realIndex;\n  const slideSelector = swiper.isElement ? `swiper-slide` : `.${params.slideClass}`;\n  if (params.loop) {\n    if (swiper.animating) return;\n    realIndex = parseInt(swiper.clickedSlide.getAttribute('data-swiper-slide-index'), 10);\n    if (params.centeredSlides) {\n      if (slideToIndex < swiper.loopedSlides - slidesPerView / 2 || slideToIndex > swiper.slides.length - swiper.loopedSlides + slidesPerView / 2) {\n        swiper.loopFix();\n        slideToIndex = swiper.getSlideIndex(elementChildren(slidesEl, `${slideSelector}[data-swiper-slide-index=\"${realIndex}\"]`)[0]);\n        nextTick(() => {\n          swiper.slideTo(slideToIndex);\n        });\n      } else {\n        swiper.slideTo(slideToIndex);\n      }\n    } else if (slideToIndex > swiper.slides.length - slidesPerView) {\n      swiper.loopFix();\n      slideToIndex = swiper.getSlideIndex(elementChildren(slidesEl, `${slideSelector}[data-swiper-slide-index=\"${realIndex}\"]`)[0]);\n      nextTick(() => {\n        swiper.slideTo(slideToIndex);\n      });\n    } else {\n      swiper.slideTo(slideToIndex);\n    }\n  } else {\n    swiper.slideTo(slideToIndex);\n  }\n}\n\nvar slide = {\n  slideTo,\n  slideToLoop,\n  slideNext,\n  slidePrev,\n  slideReset,\n  slideToClosest,\n  slideToClickedSlide\n};\n\nfunction loopCreate(slideRealIndex) {\n  const swiper = this;\n  const {\n    params,\n    slidesEl\n  } = swiper;\n  if (!params.loop || swiper.virtual && swiper.params.virtual.enabled) return;\n  const initSlides = () => {\n    const slides = elementChildren(slidesEl, `.${params.slideClass}, swiper-slide`);\n    slides.forEach((el, index) => {\n      el.setAttribute('data-swiper-slide-index', index);\n    });\n  };\n  const gridEnabled = swiper.grid && params.grid && params.grid.rows > 1;\n  const slidesPerGroup = params.slidesPerGroup * (gridEnabled ? params.grid.rows : 1);\n  const shouldFillGroup = swiper.slides.length % slidesPerGroup !== 0;\n  const shouldFillGrid = gridEnabled && swiper.slides.length % params.grid.rows !== 0;\n  const addBlankSlides = amountOfSlides => {\n    for (let i = 0; i < amountOfSlides; i += 1) {\n      const slideEl = swiper.isElement ? createElement('swiper-slide', [params.slideBlankClass]) : createElement('div', [params.slideClass, params.slideBlankClass]);\n      swiper.slidesEl.append(slideEl);\n    }\n  };\n  if (shouldFillGroup) {\n    if (params.loopAddBlankSlides) {\n      const slidesToAdd = slidesPerGroup - swiper.slides.length % slidesPerGroup;\n      addBlankSlides(slidesToAdd);\n      swiper.recalcSlides();\n      swiper.updateSlides();\n    } else {\n      showWarning('Swiper Loop Warning: The number of slides is not even to slidesPerGroup, loop mode may not function properly. You need to add more slides (or make duplicates, or empty slides)');\n    }\n    initSlides();\n  } else if (shouldFillGrid) {\n    if (params.loopAddBlankSlides) {\n      const slidesToAdd = params.grid.rows - swiper.slides.length % params.grid.rows;\n      addBlankSlides(slidesToAdd);\n      swiper.recalcSlides();\n      swiper.updateSlides();\n    } else {\n      showWarning('Swiper Loop Warning: The number of slides is not even to grid.rows, loop mode may not function properly. You need to add more slides (or make duplicates, or empty slides)');\n    }\n    initSlides();\n  } else {\n    initSlides();\n  }\n  swiper.loopFix({\n    slideRealIndex,\n    direction: params.centeredSlides ? undefined : 'next'\n  });\n}\n\nfunction loopFix(_temp) {\n  let {\n    slideRealIndex,\n    slideTo = true,\n    direction,\n    setTranslate,\n    activeSlideIndex,\n    byController,\n    byMousewheel\n  } = _temp === void 0 ? {} : _temp;\n  const swiper = this;\n  if (!swiper.params.loop) return;\n  swiper.emit('beforeLoopFix');\n  const {\n    slides,\n    allowSlidePrev,\n    allowSlideNext,\n    slidesEl,\n    params\n  } = swiper;\n  const {\n    centeredSlides\n  } = params;\n  swiper.allowSlidePrev = true;\n  swiper.allowSlideNext = true;\n  if (swiper.virtual && params.virtual.enabled) {\n    if (slideTo) {\n      if (!params.centeredSlides && swiper.snapIndex === 0) {\n        swiper.slideTo(swiper.virtual.slides.length, 0, false, true);\n      } else if (params.centeredSlides && swiper.snapIndex < params.slidesPerView) {\n        swiper.slideTo(swiper.virtual.slides.length + swiper.snapIndex, 0, false, true);\n      } else if (swiper.snapIndex === swiper.snapGrid.length - 1) {\n        swiper.slideTo(swiper.virtual.slidesBefore, 0, false, true);\n      }\n    }\n    swiper.allowSlidePrev = allowSlidePrev;\n    swiper.allowSlideNext = allowSlideNext;\n    swiper.emit('loopFix');\n    return;\n  }\n  let slidesPerView = params.slidesPerView;\n  if (slidesPerView === 'auto') {\n    slidesPerView = swiper.slidesPerViewDynamic();\n  } else {\n    slidesPerView = Math.ceil(parseFloat(params.slidesPerView, 10));\n    if (centeredSlides && slidesPerView % 2 === 0) {\n      slidesPerView = slidesPerView + 1;\n    }\n  }\n  const slidesPerGroup = params.slidesPerGroupAuto ? slidesPerView : params.slidesPerGroup;\n  let loopedSlides = slidesPerGroup;\n  if (loopedSlides % slidesPerGroup !== 0) {\n    loopedSlides += slidesPerGroup - loopedSlides % slidesPerGroup;\n  }\n  loopedSlides += params.loopAdditionalSlides;\n  swiper.loopedSlides = loopedSlides;\n  const gridEnabled = swiper.grid && params.grid && params.grid.rows > 1;\n  if (slides.length < slidesPerView + loopedSlides) {\n    showWarning('Swiper Loop Warning: The number of slides is not enough for loop mode, it will be disabled and not function properly. You need to add more slides (or make duplicates) or lower the values of slidesPerView and slidesPerGroup parameters');\n  } else if (gridEnabled && params.grid.fill === 'row') {\n    showWarning('Swiper Loop Warning: Loop mode is not compatible with grid.fill = `row`');\n  }\n  const prependSlidesIndexes = [];\n  const appendSlidesIndexes = [];\n  let activeIndex = swiper.activeIndex;\n  if (typeof activeSlideIndex === 'undefined') {\n    activeSlideIndex = swiper.getSlideIndex(slides.find(el => el.classList.contains(params.slideActiveClass)));\n  } else {\n    activeIndex = activeSlideIndex;\n  }\n  const isNext = direction === 'next' || !direction;\n  const isPrev = direction === 'prev' || !direction;\n  let slidesPrepended = 0;\n  let slidesAppended = 0;\n  const cols = gridEnabled ? Math.ceil(slides.length / params.grid.rows) : slides.length;\n  const activeColIndex = gridEnabled ? slides[activeSlideIndex].column : activeSlideIndex;\n  const activeColIndexWithShift = activeColIndex + (centeredSlides && typeof setTranslate === 'undefined' ? -slidesPerView / 2 + 0.5 : 0);\n  // prepend last slides before start\n  if (activeColIndexWithShift < loopedSlides) {\n    slidesPrepended = Math.max(loopedSlides - activeColIndexWithShift, slidesPerGroup);\n    for (let i = 0; i < loopedSlides - activeColIndexWithShift; i += 1) {\n      const index = i - Math.floor(i / cols) * cols;\n      if (gridEnabled) {\n        const colIndexToPrepend = cols - index - 1;\n        for (let i = slides.length - 1; i >= 0; i -= 1) {\n          if (slides[i].column === colIndexToPrepend) prependSlidesIndexes.push(i);\n        }\n        // slides.forEach((slide, slideIndex) => {\n        //   if (slide.column === colIndexToPrepend) prependSlidesIndexes.push(slideIndex);\n        // });\n      } else {\n        prependSlidesIndexes.push(cols - index - 1);\n      }\n    }\n  } else if (activeColIndexWithShift + slidesPerView > cols - loopedSlides) {\n    slidesAppended = Math.max(activeColIndexWithShift - (cols - loopedSlides * 2), slidesPerGroup);\n    for (let i = 0; i < slidesAppended; i += 1) {\n      const index = i - Math.floor(i / cols) * cols;\n      if (gridEnabled) {\n        slides.forEach((slide, slideIndex) => {\n          if (slide.column === index) appendSlidesIndexes.push(slideIndex);\n        });\n      } else {\n        appendSlidesIndexes.push(index);\n      }\n    }\n  }\n  swiper.__preventObserver__ = true;\n  requestAnimationFrame(() => {\n    swiper.__preventObserver__ = false;\n  });\n  if (isPrev) {\n    prependSlidesIndexes.forEach(index => {\n      slides[index].swiperLoopMoveDOM = true;\n      slidesEl.prepend(slides[index]);\n      slides[index].swiperLoopMoveDOM = false;\n    });\n  }\n  if (isNext) {\n    appendSlidesIndexes.forEach(index => {\n      slides[index].swiperLoopMoveDOM = true;\n      slidesEl.append(slides[index]);\n      slides[index].swiperLoopMoveDOM = false;\n    });\n  }\n  swiper.recalcSlides();\n  if (params.slidesPerView === 'auto') {\n    swiper.updateSlides();\n  } else if (gridEnabled && (prependSlidesIndexes.length > 0 && isPrev || appendSlidesIndexes.length > 0 && isNext)) {\n    swiper.slides.forEach((slide, slideIndex) => {\n      swiper.grid.updateSlide(slideIndex, slide, swiper.slides);\n    });\n  }\n  if (params.watchSlidesProgress) {\n    swiper.updateSlidesOffset();\n  }\n  if (slideTo) {\n    if (prependSlidesIndexes.length > 0 && isPrev) {\n      if (typeof slideRealIndex === 'undefined') {\n        const currentSlideTranslate = swiper.slidesGrid[activeIndex];\n        const newSlideTranslate = swiper.slidesGrid[activeIndex + slidesPrepended];\n        const diff = newSlideTranslate - currentSlideTranslate;\n        if (byMousewheel) {\n          swiper.setTranslate(swiper.translate - diff);\n        } else {\n          swiper.slideTo(activeIndex + Math.ceil(slidesPrepended), 0, false, true);\n          if (setTranslate) {\n            swiper.touchEventsData.startTranslate = swiper.touchEventsData.startTranslate - diff;\n            swiper.touchEventsData.currentTranslate = swiper.touchEventsData.currentTranslate - diff;\n          }\n        }\n      } else {\n        if (setTranslate) {\n          const shift = gridEnabled ? prependSlidesIndexes.length / params.grid.rows : prependSlidesIndexes.length;\n          swiper.slideTo(swiper.activeIndex + shift, 0, false, true);\n          swiper.touchEventsData.currentTranslate = swiper.translate;\n        }\n      }\n    } else if (appendSlidesIndexes.length > 0 && isNext) {\n      if (typeof slideRealIndex === 'undefined') {\n        const currentSlideTranslate = swiper.slidesGrid[activeIndex];\n        const newSlideTranslate = swiper.slidesGrid[activeIndex - slidesAppended];\n        const diff = newSlideTranslate - currentSlideTranslate;\n        if (byMousewheel) {\n          swiper.setTranslate(swiper.translate - diff);\n        } else {\n          swiper.slideTo(activeIndex - slidesAppended, 0, false, true);\n          if (setTranslate) {\n            swiper.touchEventsData.startTranslate = swiper.touchEventsData.startTranslate - diff;\n            swiper.touchEventsData.currentTranslate = swiper.touchEventsData.currentTranslate - diff;\n          }\n        }\n      } else {\n        const shift = gridEnabled ? appendSlidesIndexes.length / params.grid.rows : appendSlidesIndexes.length;\n        swiper.slideTo(swiper.activeIndex - shift, 0, false, true);\n      }\n    }\n  }\n  swiper.allowSlidePrev = allowSlidePrev;\n  swiper.allowSlideNext = allowSlideNext;\n  if (swiper.controller && swiper.controller.control && !byController) {\n    const loopParams = {\n      slideRealIndex,\n      direction,\n      setTranslate,\n      activeSlideIndex,\n      byController: true\n    };\n    if (Array.isArray(swiper.controller.control)) {\n      swiper.controller.control.forEach(c => {\n        if (!c.destroyed && c.params.loop) c.loopFix({\n          ...loopParams,\n          slideTo: c.params.slidesPerView === params.slidesPerView ? slideTo : false\n        });\n      });\n    } else if (swiper.controller.control instanceof swiper.constructor && swiper.controller.control.params.loop) {\n      swiper.controller.control.loopFix({\n        ...loopParams,\n        slideTo: swiper.controller.control.params.slidesPerView === params.slidesPerView ? slideTo : false\n      });\n    }\n  }\n  swiper.emit('loopFix');\n}\n\nfunction loopDestroy() {\n  const swiper = this;\n  const {\n    params,\n    slidesEl\n  } = swiper;\n  if (!params.loop || !slidesEl || swiper.virtual && swiper.params.virtual.enabled) return;\n  swiper.recalcSlides();\n  const newSlidesOrder = [];\n  swiper.slides.forEach(slideEl => {\n    const index = typeof slideEl.swiperSlideIndex === 'undefined' ? slideEl.getAttribute('data-swiper-slide-index') * 1 : slideEl.swiperSlideIndex;\n    newSlidesOrder[index] = slideEl;\n  });\n  swiper.slides.forEach(slideEl => {\n    slideEl.removeAttribute('data-swiper-slide-index');\n  });\n  newSlidesOrder.forEach(slideEl => {\n    slidesEl.append(slideEl);\n  });\n  swiper.recalcSlides();\n  swiper.slideTo(swiper.realIndex, 0);\n}\n\nvar loop = {\n  loopCreate,\n  loopFix,\n  loopDestroy\n};\n\nfunction setGrabCursor(moving) {\n  const swiper = this;\n  if (!swiper.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;\n  const el = swiper.params.touchEventsTarget === 'container' ? swiper.el : swiper.wrapperEl;\n  if (swiper.isElement) {\n    swiper.__preventObserver__ = true;\n  }\n  el.style.cursor = 'move';\n  el.style.cursor = moving ? 'grabbing' : 'grab';\n  if (swiper.isElement) {\n    requestAnimationFrame(() => {\n      swiper.__preventObserver__ = false;\n    });\n  }\n}\n\nfunction unsetGrabCursor() {\n  const swiper = this;\n  if (swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) {\n    return;\n  }\n  if (swiper.isElement) {\n    swiper.__preventObserver__ = true;\n  }\n  swiper[swiper.params.touchEventsTarget === 'container' ? 'el' : 'wrapperEl'].style.cursor = '';\n  if (swiper.isElement) {\n    requestAnimationFrame(() => {\n      swiper.__preventObserver__ = false;\n    });\n  }\n}\n\nvar grabCursor = {\n  setGrabCursor,\n  unsetGrabCursor\n};\n\n// Modified from https://stackoverflow.com/questions/54520554/custom-element-getrootnode-closest-function-crossing-multiple-parent-shadowd\nfunction closestElement(selector, base) {\n  if (base === void 0) {\n    base = this;\n  }\n  function __closestFrom(el) {\n    if (!el || el === getDocument() || el === getWindow()) return null;\n    if (el.assignedSlot) el = el.assignedSlot;\n    const found = el.closest(selector);\n    if (!found && !el.getRootNode) {\n      return null;\n    }\n    return found || __closestFrom(el.getRootNode().host);\n  }\n  return __closestFrom(base);\n}\nfunction preventEdgeSwipe(swiper, event, startX) {\n  const window = getWindow();\n  const {\n    params\n  } = swiper;\n  const edgeSwipeDetection = params.edgeSwipeDetection;\n  const edgeSwipeThreshold = params.edgeSwipeThreshold;\n  if (edgeSwipeDetection && (startX <= edgeSwipeThreshold || startX >= window.innerWidth - edgeSwipeThreshold)) {\n    if (edgeSwipeDetection === 'prevent') {\n      event.preventDefault();\n      return true;\n    }\n    return false;\n  }\n  return true;\n}\nfunction onTouchStart(event) {\n  const swiper = this;\n  const document = getDocument();\n  let e = event;\n  if (e.originalEvent) e = e.originalEvent;\n  const data = swiper.touchEventsData;\n  if (e.type === 'pointerdown') {\n    if (data.pointerId !== null && data.pointerId !== e.pointerId) {\n      return;\n    }\n    data.pointerId = e.pointerId;\n  } else if (e.type === 'touchstart' && e.targetTouches.length === 1) {\n    data.touchId = e.targetTouches[0].identifier;\n  }\n  if (e.type === 'touchstart') {\n    // don't proceed touch event\n    preventEdgeSwipe(swiper, e, e.targetTouches[0].pageX);\n    return;\n  }\n  const {\n    params,\n    touches,\n    enabled\n  } = swiper;\n  if (!enabled) return;\n  if (!params.simulateTouch && e.pointerType === 'mouse') return;\n  if (swiper.animating && params.preventInteractionOnTransition) {\n    return;\n  }\n  if (!swiper.animating && params.cssMode && params.loop) {\n    swiper.loopFix();\n  }\n  let targetEl = e.target;\n  if (params.touchEventsTarget === 'wrapper') {\n    if (!elementIsChildOf(targetEl, swiper.wrapperEl)) return;\n  }\n  if ('which' in e && e.which === 3) return;\n  if ('button' in e && e.button > 0) return;\n  if (data.isTouched && data.isMoved) return;\n\n  // change target el for shadow root component\n  const swipingClassHasValue = !!params.noSwipingClass && params.noSwipingClass !== '';\n  // eslint-disable-next-line\n  const eventPath = e.composedPath ? e.composedPath() : e.path;\n  if (swipingClassHasValue && e.target && e.target.shadowRoot && eventPath) {\n    targetEl = eventPath[0];\n  }\n  const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`;\n  const isTargetShadow = !!(e.target && e.target.shadowRoot);\n\n  // use closestElement for shadow root element to get the actual closest for nested shadow root element\n  if (params.noSwiping && (isTargetShadow ? closestElement(noSwipingSelector, targetEl) : targetEl.closest(noSwipingSelector))) {\n    swiper.allowClick = true;\n    return;\n  }\n  if (params.swipeHandler) {\n    if (!targetEl.closest(params.swipeHandler)) return;\n  }\n  touches.currentX = e.pageX;\n  touches.currentY = e.pageY;\n  const startX = touches.currentX;\n  const startY = touches.currentY;\n\n  // Do NOT start if iOS edge swipe is detected. Otherwise iOS app cannot swipe-to-go-back anymore\n\n  if (!preventEdgeSwipe(swiper, e, startX)) {\n    return;\n  }\n  Object.assign(data, {\n    isTouched: true,\n    isMoved: false,\n    allowTouchCallbacks: true,\n    isScrolling: undefined,\n    startMoving: undefined\n  });\n  touches.startX = startX;\n  touches.startY = startY;\n  data.touchStartTime = now();\n  swiper.allowClick = true;\n  swiper.updateSize();\n  swiper.swipeDirection = undefined;\n  if (params.threshold > 0) data.allowThresholdMove = false;\n  let preventDefault = true;\n  if (targetEl.matches(data.focusableElements)) {\n    preventDefault = false;\n    if (targetEl.nodeName === 'SELECT') {\n      data.isTouched = false;\n    }\n  }\n  if (document.activeElement && document.activeElement.matches(data.focusableElements) && document.activeElement !== targetEl && (e.pointerType === 'mouse' || e.pointerType !== 'mouse' && !targetEl.matches(data.focusableElements))) {\n    document.activeElement.blur();\n  }\n  const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;\n  if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !targetEl.isContentEditable) {\n    e.preventDefault();\n  }\n  if (params.freeMode && params.freeMode.enabled && swiper.freeMode && swiper.animating && !params.cssMode) {\n    swiper.freeMode.onTouchStart();\n  }\n  swiper.emit('touchStart', e);\n}\n\nfunction onTouchMove(event) {\n  const document = getDocument();\n  const swiper = this;\n  const data = swiper.touchEventsData;\n  const {\n    params,\n    touches,\n    rtlTranslate: rtl,\n    enabled\n  } = swiper;\n  if (!enabled) return;\n  if (!params.simulateTouch && event.pointerType === 'mouse') return;\n  let e = event;\n  if (e.originalEvent) e = e.originalEvent;\n  if (e.type === 'pointermove') {\n    if (data.touchId !== null) return; // return from pointer if we use touch\n    const id = e.pointerId;\n    if (id !== data.pointerId) return;\n  }\n  let targetTouch;\n  if (e.type === 'touchmove') {\n    targetTouch = [...e.changedTouches].find(t => t.identifier === data.touchId);\n    if (!targetTouch || targetTouch.identifier !== data.touchId) return;\n  } else {\n    targetTouch = e;\n  }\n  if (!data.isTouched) {\n    if (data.startMoving && data.isScrolling) {\n      swiper.emit('touchMoveOpposite', e);\n    }\n    return;\n  }\n  const pageX = targetTouch.pageX;\n  const pageY = targetTouch.pageY;\n  if (e.preventedByNestedSwiper) {\n    touches.startX = pageX;\n    touches.startY = pageY;\n    return;\n  }\n  if (!swiper.allowTouchMove) {\n    if (!e.target.matches(data.focusableElements)) {\n      swiper.allowClick = false;\n    }\n    if (data.isTouched) {\n      Object.assign(touches, {\n        startX: pageX,\n        startY: pageY,\n        currentX: pageX,\n        currentY: pageY\n      });\n      data.touchStartTime = now();\n    }\n    return;\n  }\n  if (params.touchReleaseOnEdges && !params.loop) {\n    if (swiper.isVertical()) {\n      // Vertical\n      if (pageY < touches.startY && swiper.translate <= swiper.maxTranslate() || pageY > touches.startY && swiper.translate >= swiper.minTranslate()) {\n        data.isTouched = false;\n        data.isMoved = false;\n        return;\n      }\n    } else if (pageX < touches.startX && swiper.translate <= swiper.maxTranslate() || pageX > touches.startX && swiper.translate >= swiper.minTranslate()) {\n      return;\n    }\n  }\n  if (document.activeElement && document.activeElement.matches(data.focusableElements) && document.activeElement !== e.target && e.pointerType !== 'mouse') {\n    document.activeElement.blur();\n  }\n  if (document.activeElement) {\n    if (e.target === document.activeElement && e.target.matches(data.focusableElements)) {\n      data.isMoved = true;\n      swiper.allowClick = false;\n      return;\n    }\n  }\n  if (data.allowTouchCallbacks) {\n    swiper.emit('touchMove', e);\n  }\n  touches.previousX = touches.currentX;\n  touches.previousY = touches.currentY;\n  touches.currentX = pageX;\n  touches.currentY = pageY;\n  const diffX = touches.currentX - touches.startX;\n  const diffY = touches.currentY - touches.startY;\n  if (swiper.params.threshold && Math.sqrt(diffX ** 2 + diffY ** 2) < swiper.params.threshold) return;\n  if (typeof data.isScrolling === 'undefined') {\n    let touchAngle;\n    if (swiper.isHorizontal() && touches.currentY === touches.startY || swiper.isVertical() && touches.currentX === touches.startX) {\n      data.isScrolling = false;\n    } else {\n      // eslint-disable-next-line\n      if (diffX * diffX + diffY * diffY >= 25) {\n        touchAngle = Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180 / Math.PI;\n        data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : 90 - touchAngle > params.touchAngle;\n      }\n    }\n  }\n  if (data.isScrolling) {\n    swiper.emit('touchMoveOpposite', e);\n  }\n  if (typeof data.startMoving === 'undefined') {\n    if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {\n      data.startMoving = true;\n    }\n  }\n  if (data.isScrolling || e.type === 'touchmove' && data.preventTouchMoveFromPointerMove) {\n    data.isTouched = false;\n    return;\n  }\n  if (!data.startMoving) {\n    return;\n  }\n  swiper.allowClick = false;\n  if (!params.cssMode && e.cancelable) {\n    e.preventDefault();\n  }\n  if (params.touchMoveStopPropagation && !params.nested) {\n    e.stopPropagation();\n  }\n  let diff = swiper.isHorizontal() ? diffX : diffY;\n  let touchesDiff = swiper.isHorizontal() ? touches.currentX - touches.previousX : touches.currentY - touches.previousY;\n  if (params.oneWayMovement) {\n    diff = Math.abs(diff) * (rtl ? 1 : -1);\n    touchesDiff = Math.abs(touchesDiff) * (rtl ? 1 : -1);\n  }\n  touches.diff = diff;\n  diff *= params.touchRatio;\n  if (rtl) {\n    diff = -diff;\n    touchesDiff = -touchesDiff;\n  }\n  const prevTouchesDirection = swiper.touchesDirection;\n  swiper.swipeDirection = diff > 0 ? 'prev' : 'next';\n  swiper.touchesDirection = touchesDiff > 0 ? 'prev' : 'next';\n  const isLoop = swiper.params.loop && !params.cssMode;\n  const allowLoopFix = swiper.touchesDirection === 'next' && swiper.allowSlideNext || swiper.touchesDirection === 'prev' && swiper.allowSlidePrev;\n  if (!data.isMoved) {\n    if (isLoop && allowLoopFix) {\n      swiper.loopFix({\n        direction: swiper.swipeDirection\n      });\n    }\n    data.startTranslate = swiper.getTranslate();\n    swiper.setTransition(0);\n    if (swiper.animating) {\n      const evt = new window.CustomEvent('transitionend', {\n        bubbles: true,\n        cancelable: true,\n        detail: {\n          bySwiperTouchMove: true\n        }\n      });\n      swiper.wrapperEl.dispatchEvent(evt);\n    }\n    data.allowMomentumBounce = false;\n    // Grab Cursor\n    if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n      swiper.setGrabCursor(true);\n    }\n    swiper.emit('sliderFirstMove', e);\n  }\n  let loopFixed;\n  new Date().getTime();\n  if (params._loopSwapReset !== false && data.isMoved && data.allowThresholdMove && prevTouchesDirection !== swiper.touchesDirection && isLoop && allowLoopFix && Math.abs(diff) >= 1) {\n    Object.assign(touches, {\n      startX: pageX,\n      startY: pageY,\n      currentX: pageX,\n      currentY: pageY,\n      startTranslate: data.currentTranslate\n    });\n    data.loopSwapReset = true;\n    data.startTranslate = data.currentTranslate;\n    return;\n  }\n  swiper.emit('sliderMove', e);\n  data.isMoved = true;\n  data.currentTranslate = diff + data.startTranslate;\n  let disableParentSwiper = true;\n  let resistanceRatio = params.resistanceRatio;\n  if (params.touchReleaseOnEdges) {\n    resistanceRatio = 0;\n  }\n  if (diff > 0) {\n    if (isLoop && allowLoopFix && !loopFixed && data.allowThresholdMove && data.currentTranslate > (params.centeredSlides ? swiper.minTranslate() - swiper.slidesSizesGrid[swiper.activeIndex + 1] - (params.slidesPerView !== 'auto' && swiper.slides.length - params.slidesPerView >= 2 ? swiper.slidesSizesGrid[swiper.activeIndex + 1] + swiper.params.spaceBetween : 0) - swiper.params.spaceBetween : swiper.minTranslate())) {\n      swiper.loopFix({\n        direction: 'prev',\n        setTranslate: true,\n        activeSlideIndex: 0\n      });\n    }\n    if (data.currentTranslate > swiper.minTranslate()) {\n      disableParentSwiper = false;\n      if (params.resistance) {\n        data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio;\n      }\n    }\n  } else if (diff < 0) {\n    if (isLoop && allowLoopFix && !loopFixed && data.allowThresholdMove && data.currentTranslate < (params.centeredSlides ? swiper.maxTranslate() + swiper.slidesSizesGrid[swiper.slidesSizesGrid.length - 1] + swiper.params.spaceBetween + (params.slidesPerView !== 'auto' && swiper.slides.length - params.slidesPerView >= 2 ? swiper.slidesSizesGrid[swiper.slidesSizesGrid.length - 1] + swiper.params.spaceBetween : 0) : swiper.maxTranslate())) {\n      swiper.loopFix({\n        direction: 'next',\n        setTranslate: true,\n        activeSlideIndex: swiper.slides.length - (params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : Math.ceil(parseFloat(params.slidesPerView, 10)))\n      });\n    }\n    if (data.currentTranslate < swiper.maxTranslate()) {\n      disableParentSwiper = false;\n      if (params.resistance) {\n        data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio;\n      }\n    }\n  }\n  if (disableParentSwiper) {\n    e.preventedByNestedSwiper = true;\n  }\n\n  // Directions locks\n  if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {\n    data.currentTranslate = data.startTranslate;\n  }\n  if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {\n    data.currentTranslate = data.startTranslate;\n  }\n  if (!swiper.allowSlidePrev && !swiper.allowSlideNext) {\n    data.currentTranslate = data.startTranslate;\n  }\n\n  // Threshold\n  if (params.threshold > 0) {\n    if (Math.abs(diff) > params.threshold || data.allowThresholdMove) {\n      if (!data.allowThresholdMove) {\n        data.allowThresholdMove = true;\n        touches.startX = touches.currentX;\n        touches.startY = touches.currentY;\n        data.currentTranslate = data.startTranslate;\n        touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY;\n        return;\n      }\n    } else {\n      data.currentTranslate = data.startTranslate;\n      return;\n    }\n  }\n  if (!params.followFinger || params.cssMode) return;\n\n  // Update active index in free mode\n  if (params.freeMode && params.freeMode.enabled && swiper.freeMode || params.watchSlidesProgress) {\n    swiper.updateActiveIndex();\n    swiper.updateSlidesClasses();\n  }\n  if (params.freeMode && params.freeMode.enabled && swiper.freeMode) {\n    swiper.freeMode.onTouchMove();\n  }\n  // Update progress\n  swiper.updateProgress(data.currentTranslate);\n  // Update translate\n  swiper.setTranslate(data.currentTranslate);\n}\n\nfunction onTouchEnd(event) {\n  const swiper = this;\n  const data = swiper.touchEventsData;\n  let e = event;\n  if (e.originalEvent) e = e.originalEvent;\n  let targetTouch;\n  const isTouchEvent = e.type === 'touchend' || e.type === 'touchcancel';\n  if (!isTouchEvent) {\n    if (data.touchId !== null) return; // return from pointer if we use touch\n    if (e.pointerId !== data.pointerId) return;\n    targetTouch = e;\n  } else {\n    targetTouch = [...e.changedTouches].find(t => t.identifier === data.touchId);\n    if (!targetTouch || targetTouch.identifier !== data.touchId) return;\n  }\n  if (['pointercancel', 'pointerout', 'pointerleave', 'contextmenu'].includes(e.type)) {\n    const proceed = ['pointercancel', 'contextmenu'].includes(e.type) && (swiper.browser.isSafari || swiper.browser.isWebView);\n    if (!proceed) {\n      return;\n    }\n  }\n  data.pointerId = null;\n  data.touchId = null;\n  const {\n    params,\n    touches,\n    rtlTranslate: rtl,\n    slidesGrid,\n    enabled\n  } = swiper;\n  if (!enabled) return;\n  if (!params.simulateTouch && e.pointerType === 'mouse') return;\n  if (data.allowTouchCallbacks) {\n    swiper.emit('touchEnd', e);\n  }\n  data.allowTouchCallbacks = false;\n  if (!data.isTouched) {\n    if (data.isMoved && params.grabCursor) {\n      swiper.setGrabCursor(false);\n    }\n    data.isMoved = false;\n    data.startMoving = false;\n    return;\n  }\n\n  // Return Grab Cursor\n  if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {\n    swiper.setGrabCursor(false);\n  }\n\n  // Time diff\n  const touchEndTime = now();\n  const timeDiff = touchEndTime - data.touchStartTime;\n\n  // Tap, doubleTap, Click\n  if (swiper.allowClick) {\n    const pathTree = e.path || e.composedPath && e.composedPath();\n    swiper.updateClickedSlide(pathTree && pathTree[0] || e.target, pathTree);\n    swiper.emit('tap click', e);\n    if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) {\n      swiper.emit('doubleTap doubleClick', e);\n    }\n  }\n  data.lastClickTime = now();\n  nextTick(() => {\n    if (!swiper.destroyed) swiper.allowClick = true;\n  });\n  if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || touches.diff === 0 && !data.loopSwapReset || data.currentTranslate === data.startTranslate && !data.loopSwapReset) {\n    data.isTouched = false;\n    data.isMoved = false;\n    data.startMoving = false;\n    return;\n  }\n  data.isTouched = false;\n  data.isMoved = false;\n  data.startMoving = false;\n  let currentPos;\n  if (params.followFinger) {\n    currentPos = rtl ? swiper.translate : -swiper.translate;\n  } else {\n    currentPos = -data.currentTranslate;\n  }\n  if (params.cssMode) {\n    return;\n  }\n  if (params.freeMode && params.freeMode.enabled) {\n    swiper.freeMode.onTouchEnd({\n      currentPos\n    });\n    return;\n  }\n\n  // Find current slide\n  const swipeToLast = currentPos >= -swiper.maxTranslate() && !swiper.params.loop;\n  let stopIndex = 0;\n  let groupSize = swiper.slidesSizesGrid[0];\n  for (let i = 0; i < slidesGrid.length; i += i < params.slidesPerGroupSkip ? 1 : params.slidesPerGroup) {\n    const increment = i < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n    if (typeof slidesGrid[i + increment] !== 'undefined') {\n      if (swipeToLast || currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + increment]) {\n        stopIndex = i;\n        groupSize = slidesGrid[i + increment] - slidesGrid[i];\n      }\n    } else if (swipeToLast || currentPos >= slidesGrid[i]) {\n      stopIndex = i;\n      groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2];\n    }\n  }\n  let rewindFirstIndex = null;\n  let rewindLastIndex = null;\n  if (params.rewind) {\n    if (swiper.isBeginning) {\n      rewindLastIndex = params.virtual && params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;\n    } else if (swiper.isEnd) {\n      rewindFirstIndex = 0;\n    }\n  }\n  // Find current slide size\n  const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;\n  const increment = stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;\n  if (timeDiff > params.longSwipesMs) {\n    // Long touches\n    if (!params.longSwipes) {\n      swiper.slideTo(swiper.activeIndex);\n      return;\n    }\n    if (swiper.swipeDirection === 'next') {\n      if (ratio >= params.longSwipesRatio) swiper.slideTo(params.rewind && swiper.isEnd ? rewindFirstIndex : stopIndex + increment);else swiper.slideTo(stopIndex);\n    }\n    if (swiper.swipeDirection === 'prev') {\n      if (ratio > 1 - params.longSwipesRatio) {\n        swiper.slideTo(stopIndex + increment);\n      } else if (rewindLastIndex !== null && ratio < 0 && Math.abs(ratio) > params.longSwipesRatio) {\n        swiper.slideTo(rewindLastIndex);\n      } else {\n        swiper.slideTo(stopIndex);\n      }\n    }\n  } else {\n    // Short swipes\n    if (!params.shortSwipes) {\n      swiper.slideTo(swiper.activeIndex);\n      return;\n    }\n    const isNavButtonTarget = swiper.navigation && (e.target === swiper.navigation.nextEl || e.target === swiper.navigation.prevEl);\n    if (!isNavButtonTarget) {\n      if (swiper.swipeDirection === 'next') {\n        swiper.slideTo(rewindFirstIndex !== null ? rewindFirstIndex : stopIndex + increment);\n      }\n      if (swiper.swipeDirection === 'prev') {\n        swiper.slideTo(rewindLastIndex !== null ? rewindLastIndex : stopIndex);\n      }\n    } else if (e.target === swiper.navigation.nextEl) {\n      swiper.slideTo(stopIndex + increment);\n    } else {\n      swiper.slideTo(stopIndex);\n    }\n  }\n}\n\nfunction onResize() {\n  const swiper = this;\n  const {\n    params,\n    el\n  } = swiper;\n  if (el && el.offsetWidth === 0) return;\n\n  // Breakpoints\n  if (params.breakpoints) {\n    swiper.setBreakpoint();\n  }\n\n  // Save locks\n  const {\n    allowSlideNext,\n    allowSlidePrev,\n    snapGrid\n  } = swiper;\n  const isVirtual = swiper.virtual && swiper.params.virtual.enabled;\n\n  // Disable locks on resize\n  swiper.allowSlideNext = true;\n  swiper.allowSlidePrev = true;\n  swiper.updateSize();\n  swiper.updateSlides();\n  swiper.updateSlidesClasses();\n  const isVirtualLoop = isVirtual && params.loop;\n  if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides && !isVirtualLoop) {\n    swiper.slideTo(swiper.slides.length - 1, 0, false, true);\n  } else {\n    if (swiper.params.loop && !isVirtual) {\n      swiper.slideToLoop(swiper.realIndex, 0, false, true);\n    } else {\n      swiper.slideTo(swiper.activeIndex, 0, false, true);\n    }\n  }\n  if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {\n    clearTimeout(swiper.autoplay.resizeTimeout);\n    swiper.autoplay.resizeTimeout = setTimeout(() => {\n      if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {\n        swiper.autoplay.resume();\n      }\n    }, 500);\n  }\n  // Return locks after resize\n  swiper.allowSlidePrev = allowSlidePrev;\n  swiper.allowSlideNext = allowSlideNext;\n  if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) {\n    swiper.checkOverflow();\n  }\n}\n\nfunction onClick(e) {\n  const swiper = this;\n  if (!swiper.enabled) return;\n  if (!swiper.allowClick) {\n    if (swiper.params.preventClicks) e.preventDefault();\n    if (swiper.params.preventClicksPropagation && swiper.animating) {\n      e.stopPropagation();\n      e.stopImmediatePropagation();\n    }\n  }\n}\n\nfunction onScroll() {\n  const swiper = this;\n  const {\n    wrapperEl,\n    rtlTranslate,\n    enabled\n  } = swiper;\n  if (!enabled) return;\n  swiper.previousTranslate = swiper.translate;\n  if (swiper.isHorizontal()) {\n    swiper.translate = -wrapperEl.scrollLeft;\n  } else {\n    swiper.translate = -wrapperEl.scrollTop;\n  }\n  // eslint-disable-next-line\n  if (swiper.translate === 0) swiper.translate = 0;\n  swiper.updateActiveIndex();\n  swiper.updateSlidesClasses();\n  let newProgress;\n  const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();\n  if (translatesDiff === 0) {\n    newProgress = 0;\n  } else {\n    newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff;\n  }\n  if (newProgress !== swiper.progress) {\n    swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate);\n  }\n  swiper.emit('setTranslate', swiper.translate, false);\n}\n\nfunction onLoad(e) {\n  const swiper = this;\n  processLazyPreloader(swiper, e.target);\n  if (swiper.params.cssMode || swiper.params.slidesPerView !== 'auto' && !swiper.params.autoHeight) {\n    return;\n  }\n  swiper.update();\n}\n\nfunction onDocumentTouchStart() {\n  const swiper = this;\n  if (swiper.documentTouchHandlerProceeded) return;\n  swiper.documentTouchHandlerProceeded = true;\n  if (swiper.params.touchReleaseOnEdges) {\n    swiper.el.style.touchAction = 'auto';\n  }\n}\n\nconst events = (swiper, method) => {\n  const document = getDocument();\n  const {\n    params,\n    el,\n    wrapperEl,\n    device\n  } = swiper;\n  const capture = !!params.nested;\n  const domMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';\n  const swiperMethod = method;\n  if (!el || typeof el === 'string') return;\n\n  // Touch Events\n  document[domMethod]('touchstart', swiper.onDocumentTouchStart, {\n    passive: false,\n    capture\n  });\n  el[domMethod]('touchstart', swiper.onTouchStart, {\n    passive: false\n  });\n  el[domMethod]('pointerdown', swiper.onTouchStart, {\n    passive: false\n  });\n  document[domMethod]('touchmove', swiper.onTouchMove, {\n    passive: false,\n    capture\n  });\n  document[domMethod]('pointermove', swiper.onTouchMove, {\n    passive: false,\n    capture\n  });\n  document[domMethod]('touchend', swiper.onTouchEnd, {\n    passive: true\n  });\n  document[domMethod]('pointerup', swiper.onTouchEnd, {\n    passive: true\n  });\n  document[domMethod]('pointercancel', swiper.onTouchEnd, {\n    passive: true\n  });\n  document[domMethod]('touchcancel', swiper.onTouchEnd, {\n    passive: true\n  });\n  document[domMethod]('pointerout', swiper.onTouchEnd, {\n    passive: true\n  });\n  document[domMethod]('pointerleave', swiper.onTouchEnd, {\n    passive: true\n  });\n  document[domMethod]('contextmenu', swiper.onTouchEnd, {\n    passive: true\n  });\n\n  // Prevent Links Clicks\n  if (params.preventClicks || params.preventClicksPropagation) {\n    el[domMethod]('click', swiper.onClick, true);\n  }\n  if (params.cssMode) {\n    wrapperEl[domMethod]('scroll', swiper.onScroll);\n  }\n\n  // Resize handler\n  if (params.updateOnWindowResize) {\n    swiper[swiperMethod](device.ios || device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate', onResize, true);\n  } else {\n    swiper[swiperMethod]('observerUpdate', onResize, true);\n  }\n\n  // Images loader\n  el[domMethod]('load', swiper.onLoad, {\n    capture: true\n  });\n};\nfunction attachEvents() {\n  const swiper = this;\n  const {\n    params\n  } = swiper;\n  swiper.onTouchStart = onTouchStart.bind(swiper);\n  swiper.onTouchMove = onTouchMove.bind(swiper);\n  swiper.onTouchEnd = onTouchEnd.bind(swiper);\n  swiper.onDocumentTouchStart = onDocumentTouchStart.bind(swiper);\n  if (params.cssMode) {\n    swiper.onScroll = onScroll.bind(swiper);\n  }\n  swiper.onClick = onClick.bind(swiper);\n  swiper.onLoad = onLoad.bind(swiper);\n  events(swiper, 'on');\n}\nfunction detachEvents() {\n  const swiper = this;\n  events(swiper, 'off');\n}\nvar events$1 = {\n  attachEvents,\n  detachEvents\n};\n\nconst isGridEnabled = (swiper, params) => {\n  return swiper.grid && params.grid && params.grid.rows > 1;\n};\nfunction setBreakpoint() {\n  const swiper = this;\n  const {\n    realIndex,\n    initialized,\n    params,\n    el\n  } = swiper;\n  const breakpoints = params.breakpoints;\n  if (!breakpoints || breakpoints && Object.keys(breakpoints).length === 0) return;\n  const document = getDocument();\n\n  // Get breakpoint for window/container width and update parameters\n  const breakpointsBase = params.breakpointsBase === 'window' || !params.breakpointsBase ? params.breakpointsBase : 'container';\n  const breakpointContainer = ['window', 'container'].includes(params.breakpointsBase) || !params.breakpointsBase ? swiper.el : document.querySelector(params.breakpointsBase);\n  const breakpoint = swiper.getBreakpoint(breakpoints, breakpointsBase, breakpointContainer);\n  if (!breakpoint || swiper.currentBreakpoint === breakpoint) return;\n  const breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : undefined;\n  const breakpointParams = breakpointOnlyParams || swiper.originalParams;\n  const wasMultiRow = isGridEnabled(swiper, params);\n  const isMultiRow = isGridEnabled(swiper, breakpointParams);\n  const wasGrabCursor = swiper.params.grabCursor;\n  const isGrabCursor = breakpointParams.grabCursor;\n  const wasEnabled = params.enabled;\n  if (wasMultiRow && !isMultiRow) {\n    el.classList.remove(`${params.containerModifierClass}grid`, `${params.containerModifierClass}grid-column`);\n    swiper.emitContainerClasses();\n  } else if (!wasMultiRow && isMultiRow) {\n    el.classList.add(`${params.containerModifierClass}grid`);\n    if (breakpointParams.grid.fill && breakpointParams.grid.fill === 'column' || !breakpointParams.grid.fill && params.grid.fill === 'column') {\n      el.classList.add(`${params.containerModifierClass}grid-column`);\n    }\n    swiper.emitContainerClasses();\n  }\n  if (wasGrabCursor && !isGrabCursor) {\n    swiper.unsetGrabCursor();\n  } else if (!wasGrabCursor && isGrabCursor) {\n    swiper.setGrabCursor();\n  }\n\n  // Toggle navigation, pagination, scrollbar\n  ['navigation', 'pagination', 'scrollbar'].forEach(prop => {\n    if (typeof breakpointParams[prop] === 'undefined') return;\n    const wasModuleEnabled = params[prop] && params[prop].enabled;\n    const isModuleEnabled = breakpointParams[prop] && breakpointParams[prop].enabled;\n    if (wasModuleEnabled && !isModuleEnabled) {\n      swiper[prop].disable();\n    }\n    if (!wasModuleEnabled && isModuleEnabled) {\n      swiper[prop].enable();\n    }\n  });\n  const directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;\n  const needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);\n  const wasLoop = params.loop;\n  if (directionChanged && initialized) {\n    swiper.changeDirection();\n  }\n  extend(swiper.params, breakpointParams);\n  const isEnabled = swiper.params.enabled;\n  const hasLoop = swiper.params.loop;\n  Object.assign(swiper, {\n    allowTouchMove: swiper.params.allowTouchMove,\n    allowSlideNext: swiper.params.allowSlideNext,\n    allowSlidePrev: swiper.params.allowSlidePrev\n  });\n  if (wasEnabled && !isEnabled) {\n    swiper.disable();\n  } else if (!wasEnabled && isEnabled) {\n    swiper.enable();\n  }\n  swiper.currentBreakpoint = breakpoint;\n  swiper.emit('_beforeBreakpoint', breakpointParams);\n  if (initialized) {\n    if (needsReLoop) {\n      swiper.loopDestroy();\n      swiper.loopCreate(realIndex);\n      swiper.updateSlides();\n    } else if (!wasLoop && hasLoop) {\n      swiper.loopCreate(realIndex);\n      swiper.updateSlides();\n    } else if (wasLoop && !hasLoop) {\n      swiper.loopDestroy();\n    }\n  }\n  swiper.emit('breakpoint', breakpointParams);\n}\n\nfunction getBreakpoint(breakpoints, base, containerEl) {\n  if (base === void 0) {\n    base = 'window';\n  }\n  if (!breakpoints || base === 'container' && !containerEl) return undefined;\n  let breakpoint = false;\n  const window = getWindow();\n  const currentHeight = base === 'window' ? window.innerHeight : containerEl.clientHeight;\n  const points = Object.keys(breakpoints).map(point => {\n    if (typeof point === 'string' && point.indexOf('@') === 0) {\n      const minRatio = parseFloat(point.substr(1));\n      const value = currentHeight * minRatio;\n      return {\n        value,\n        point\n      };\n    }\n    return {\n      value: point,\n      point\n    };\n  });\n  points.sort((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10));\n  for (let i = 0; i < points.length; i += 1) {\n    const {\n      point,\n      value\n    } = points[i];\n    if (base === 'window') {\n      if (window.matchMedia(`(min-width: ${value}px)`).matches) {\n        breakpoint = point;\n      }\n    } else if (value <= containerEl.clientWidth) {\n      breakpoint = point;\n    }\n  }\n  return breakpoint || 'max';\n}\n\nvar breakpoints = {\n  setBreakpoint,\n  getBreakpoint\n};\n\nfunction prepareClasses(entries, prefix) {\n  const resultClasses = [];\n  entries.forEach(item => {\n    if (typeof item === 'object') {\n      Object.keys(item).forEach(classNames => {\n        if (item[classNames]) {\n          resultClasses.push(prefix + classNames);\n        }\n      });\n    } else if (typeof item === 'string') {\n      resultClasses.push(prefix + item);\n    }\n  });\n  return resultClasses;\n}\nfunction addClasses() {\n  const swiper = this;\n  const {\n    classNames,\n    params,\n    rtl,\n    el,\n    device\n  } = swiper;\n  // prettier-ignore\n  const suffixes = prepareClasses(['initialized', params.direction, {\n    'free-mode': swiper.params.freeMode && params.freeMode.enabled\n  }, {\n    'autoheight': params.autoHeight\n  }, {\n    'rtl': rtl\n  }, {\n    'grid': params.grid && params.grid.rows > 1\n  }, {\n    'grid-column': params.grid && params.grid.rows > 1 && params.grid.fill === 'column'\n  }, {\n    'android': device.android\n  }, {\n    'ios': device.ios\n  }, {\n    'css-mode': params.cssMode\n  }, {\n    'centered': params.cssMode && params.centeredSlides\n  }, {\n    'watch-progress': params.watchSlidesProgress\n  }], params.containerModifierClass);\n  classNames.push(...suffixes);\n  el.classList.add(...classNames);\n  swiper.emitContainerClasses();\n}\n\nfunction removeClasses() {\n  const swiper = this;\n  const {\n    el,\n    classNames\n  } = swiper;\n  if (!el || typeof el === 'string') return;\n  el.classList.remove(...classNames);\n  swiper.emitContainerClasses();\n}\n\nvar classes = {\n  addClasses,\n  removeClasses\n};\n\nfunction checkOverflow() {\n  const swiper = this;\n  const {\n    isLocked: wasLocked,\n    params\n  } = swiper;\n  const {\n    slidesOffsetBefore\n  } = params;\n  if (slidesOffsetBefore) {\n    const lastSlideIndex = swiper.slides.length - 1;\n    const lastSlideRightEdge = swiper.slidesGrid[lastSlideIndex] + swiper.slidesSizesGrid[lastSlideIndex] + slidesOffsetBefore * 2;\n    swiper.isLocked = swiper.size > lastSlideRightEdge;\n  } else {\n    swiper.isLocked = swiper.snapGrid.length === 1;\n  }\n  if (params.allowSlideNext === true) {\n    swiper.allowSlideNext = !swiper.isLocked;\n  }\n  if (params.allowSlidePrev === true) {\n    swiper.allowSlidePrev = !swiper.isLocked;\n  }\n  if (wasLocked && wasLocked !== swiper.isLocked) {\n    swiper.isEnd = false;\n  }\n  if (wasLocked !== swiper.isLocked) {\n    swiper.emit(swiper.isLocked ? 'lock' : 'unlock');\n  }\n}\nvar checkOverflow$1 = {\n  checkOverflow\n};\n\nvar defaults = {\n  init: true,\n  direction: 'horizontal',\n  oneWayMovement: false,\n  swiperElementNodeName: 'SWIPER-CONTAINER',\n  touchEventsTarget: 'wrapper',\n  initialSlide: 0,\n  speed: 300,\n  cssMode: false,\n  updateOnWindowResize: true,\n  resizeObserver: true,\n  nested: false,\n  createElements: false,\n  eventsPrefix: 'swiper',\n  enabled: true,\n  focusableElements: 'input, select, option, textarea, button, video, label',\n  // Overrides\n  width: null,\n  height: null,\n  //\n  preventInteractionOnTransition: false,\n  // ssr\n  userAgent: null,\n  url: null,\n  // To support iOS's swipe-to-go-back gesture (when being used in-app).\n  edgeSwipeDetection: false,\n  edgeSwipeThreshold: 20,\n  // Autoheight\n  autoHeight: false,\n  // Set wrapper width\n  setWrapperSize: false,\n  // Virtual Translate\n  virtualTranslate: false,\n  // Effects\n  effect: 'slide',\n  // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'\n\n  // Breakpoints\n  breakpoints: undefined,\n  breakpointsBase: 'window',\n  // Slides grid\n  spaceBetween: 0,\n  slidesPerView: 1,\n  slidesPerGroup: 1,\n  slidesPerGroupSkip: 0,\n  slidesPerGroupAuto: false,\n  centeredSlides: false,\n  centeredSlidesBounds: false,\n  slidesOffsetBefore: 0,\n  // in px\n  slidesOffsetAfter: 0,\n  // in px\n  normalizeSlideIndex: true,\n  centerInsufficientSlides: false,\n  // Disable swiper and hide navigation when container not overflow\n  watchOverflow: true,\n  // Round length\n  roundLengths: false,\n  // Touches\n  touchRatio: 1,\n  touchAngle: 45,\n  simulateTouch: true,\n  shortSwipes: true,\n  longSwipes: true,\n  longSwipesRatio: 0.5,\n  longSwipesMs: 300,\n  followFinger: true,\n  allowTouchMove: true,\n  threshold: 5,\n  touchMoveStopPropagation: false,\n  touchStartPreventDefault: true,\n  touchStartForcePreventDefault: false,\n  touchReleaseOnEdges: false,\n  // Unique Navigation Elements\n  uniqueNavElements: true,\n  // Resistance\n  resistance: true,\n  resistanceRatio: 0.85,\n  // Progress\n  watchSlidesProgress: false,\n  // Cursor\n  grabCursor: false,\n  // Clicks\n  preventClicks: true,\n  preventClicksPropagation: true,\n  slideToClickedSlide: false,\n  // loop\n  loop: false,\n  loopAddBlankSlides: true,\n  loopAdditionalSlides: 0,\n  loopPreventsSliding: true,\n  // rewind\n  rewind: false,\n  // Swiping/no swiping\n  allowSlidePrev: true,\n  allowSlideNext: true,\n  swipeHandler: null,\n  // '.swipe-handler',\n  noSwiping: true,\n  noSwipingClass: 'swiper-no-swiping',\n  noSwipingSelector: null,\n  // Passive Listeners\n  passiveListeners: true,\n  maxBackfaceHiddenSlides: 10,\n  // NS\n  containerModifierClass: 'swiper-',\n  // NEW\n  slideClass: 'swiper-slide',\n  slideBlankClass: 'swiper-slide-blank',\n  slideActiveClass: 'swiper-slide-active',\n  slideVisibleClass: 'swiper-slide-visible',\n  slideFullyVisibleClass: 'swiper-slide-fully-visible',\n  slideNextClass: 'swiper-slide-next',\n  slidePrevClass: 'swiper-slide-prev',\n  wrapperClass: 'swiper-wrapper',\n  lazyPreloaderClass: 'swiper-lazy-preloader',\n  lazyPreloadPrevNext: 0,\n  // Callbacks\n  runCallbacksOnInit: true,\n  // Internals\n  _emitClasses: false\n};\n\nfunction moduleExtendParams(params, allModulesParams) {\n  return function extendParams(obj) {\n    if (obj === void 0) {\n      obj = {};\n    }\n    const moduleParamName = Object.keys(obj)[0];\n    const moduleParams = obj[moduleParamName];\n    if (typeof moduleParams !== 'object' || moduleParams === null) {\n      extend(allModulesParams, obj);\n      return;\n    }\n    if (params[moduleParamName] === true) {\n      params[moduleParamName] = {\n        enabled: true\n      };\n    }\n    if (moduleParamName === 'navigation' && params[moduleParamName] && params[moduleParamName].enabled && !params[moduleParamName].prevEl && !params[moduleParamName].nextEl) {\n      params[moduleParamName].auto = true;\n    }\n    if (['pagination', 'scrollbar'].indexOf(moduleParamName) >= 0 && params[moduleParamName] && params[moduleParamName].enabled && !params[moduleParamName].el) {\n      params[moduleParamName].auto = true;\n    }\n    if (!(moduleParamName in params && 'enabled' in moduleParams)) {\n      extend(allModulesParams, obj);\n      return;\n    }\n    if (typeof params[moduleParamName] === 'object' && !('enabled' in params[moduleParamName])) {\n      params[moduleParamName].enabled = true;\n    }\n    if (!params[moduleParamName]) params[moduleParamName] = {\n      enabled: false\n    };\n    extend(allModulesParams, obj);\n  };\n}\n\n/* eslint no-param-reassign: \"off\" */\nconst prototypes = {\n  eventsEmitter,\n  update,\n  translate,\n  transition,\n  slide,\n  loop,\n  grabCursor,\n  events: events$1,\n  breakpoints,\n  checkOverflow: checkOverflow$1,\n  classes\n};\nconst extendedDefaults = {};\nclass Swiper {\n  constructor() {\n    let el;\n    let params;\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n    if (args.length === 1 && args[0].constructor && Object.prototype.toString.call(args[0]).slice(8, -1) === 'Object') {\n      params = args[0];\n    } else {\n      [el, params] = args;\n    }\n    if (!params) params = {};\n    params = extend({}, params);\n    if (el && !params.el) params.el = el;\n    const document = getDocument();\n    if (params.el && typeof params.el === 'string' && document.querySelectorAll(params.el).length > 1) {\n      const swipers = [];\n      document.querySelectorAll(params.el).forEach(containerEl => {\n        const newParams = extend({}, params, {\n          el: containerEl\n        });\n        swipers.push(new Swiper(newParams));\n      });\n      // eslint-disable-next-line no-constructor-return\n      return swipers;\n    }\n\n    // Swiper Instance\n    const swiper = this;\n    swiper.__swiper__ = true;\n    swiper.support = getSupport();\n    swiper.device = getDevice({\n      userAgent: params.userAgent\n    });\n    swiper.browser = getBrowser();\n    swiper.eventsListeners = {};\n    swiper.eventsAnyListeners = [];\n    swiper.modules = [...swiper.__modules__];\n    if (params.modules && Array.isArray(params.modules)) {\n      swiper.modules.push(...params.modules);\n    }\n    const allModulesParams = {};\n    swiper.modules.forEach(mod => {\n      mod({\n        params,\n        swiper,\n        extendParams: moduleExtendParams(params, allModulesParams),\n        on: swiper.on.bind(swiper),\n        once: swiper.once.bind(swiper),\n        off: swiper.off.bind(swiper),\n        emit: swiper.emit.bind(swiper)\n      });\n    });\n\n    // Extend defaults with modules params\n    const swiperParams = extend({}, defaults, allModulesParams);\n\n    // Extend defaults with passed params\n    swiper.params = extend({}, swiperParams, extendedDefaults, params);\n    swiper.originalParams = extend({}, swiper.params);\n    swiper.passedParams = extend({}, params);\n\n    // add event listeners\n    if (swiper.params && swiper.params.on) {\n      Object.keys(swiper.params.on).forEach(eventName => {\n        swiper.on(eventName, swiper.params.on[eventName]);\n      });\n    }\n    if (swiper.params && swiper.params.onAny) {\n      swiper.onAny(swiper.params.onAny);\n    }\n\n    // Extend Swiper\n    Object.assign(swiper, {\n      enabled: swiper.params.enabled,\n      el,\n      // Classes\n      classNames: [],\n      // Slides\n      slides: [],\n      slidesGrid: [],\n      snapGrid: [],\n      slidesSizesGrid: [],\n      // isDirection\n      isHorizontal() {\n        return swiper.params.direction === 'horizontal';\n      },\n      isVertical() {\n        return swiper.params.direction === 'vertical';\n      },\n      // Indexes\n      activeIndex: 0,\n      realIndex: 0,\n      //\n      isBeginning: true,\n      isEnd: false,\n      // Props\n      translate: 0,\n      previousTranslate: 0,\n      progress: 0,\n      velocity: 0,\n      animating: false,\n      cssOverflowAdjustment() {\n        // Returns 0 unless `translate` is > 2**23\n        // Should be subtracted from css values to prevent overflow\n        return Math.trunc(this.translate / 2 ** 23) * 2 ** 23;\n      },\n      // Locks\n      allowSlideNext: swiper.params.allowSlideNext,\n      allowSlidePrev: swiper.params.allowSlidePrev,\n      // Touch Events\n      touchEventsData: {\n        isTouched: undefined,\n        isMoved: undefined,\n        allowTouchCallbacks: undefined,\n        touchStartTime: undefined,\n        isScrolling: undefined,\n        currentTranslate: undefined,\n        startTranslate: undefined,\n        allowThresholdMove: undefined,\n        // Form elements to match\n        focusableElements: swiper.params.focusableElements,\n        // Last click time\n        lastClickTime: 0,\n        clickTimeout: undefined,\n        // Velocities\n        velocities: [],\n        allowMomentumBounce: undefined,\n        startMoving: undefined,\n        pointerId: null,\n        touchId: null\n      },\n      // Clicks\n      allowClick: true,\n      // Touches\n      allowTouchMove: swiper.params.allowTouchMove,\n      touches: {\n        startX: 0,\n        startY: 0,\n        currentX: 0,\n        currentY: 0,\n        diff: 0\n      },\n      // Images\n      imagesToLoad: [],\n      imagesLoaded: 0\n    });\n    swiper.emit('_swiper');\n\n    // Init\n    if (swiper.params.init) {\n      swiper.init();\n    }\n\n    // Return app instance\n    // eslint-disable-next-line no-constructor-return\n    return swiper;\n  }\n  getDirectionLabel(property) {\n    if (this.isHorizontal()) {\n      return property;\n    }\n    // prettier-ignore\n    return {\n      'width': 'height',\n      'margin-top': 'margin-left',\n      'margin-bottom ': 'margin-right',\n      'margin-left': 'margin-top',\n      'margin-right': 'margin-bottom',\n      'padding-left': 'padding-top',\n      'padding-right': 'padding-bottom',\n      'marginRight': 'marginBottom'\n    }[property];\n  }\n  getSlideIndex(slideEl) {\n    const {\n      slidesEl,\n      params\n    } = this;\n    const slides = elementChildren(slidesEl, `.${params.slideClass}, swiper-slide`);\n    const firstSlideIndex = elementIndex(slides[0]);\n    return elementIndex(slideEl) - firstSlideIndex;\n  }\n  getSlideIndexByData(index) {\n    return this.getSlideIndex(this.slides.find(slideEl => slideEl.getAttribute('data-swiper-slide-index') * 1 === index));\n  }\n  recalcSlides() {\n    const swiper = this;\n    const {\n      slidesEl,\n      params\n    } = swiper;\n    swiper.slides = elementChildren(slidesEl, `.${params.slideClass}, swiper-slide`);\n  }\n  enable() {\n    const swiper = this;\n    if (swiper.enabled) return;\n    swiper.enabled = true;\n    if (swiper.params.grabCursor) {\n      swiper.setGrabCursor();\n    }\n    swiper.emit('enable');\n  }\n  disable() {\n    const swiper = this;\n    if (!swiper.enabled) return;\n    swiper.enabled = false;\n    if (swiper.params.grabCursor) {\n      swiper.unsetGrabCursor();\n    }\n    swiper.emit('disable');\n  }\n  setProgress(progress, speed) {\n    const swiper = this;\n    progress = Math.min(Math.max(progress, 0), 1);\n    const min = swiper.minTranslate();\n    const max = swiper.maxTranslate();\n    const current = (max - min) * progress + min;\n    swiper.translateTo(current, typeof speed === 'undefined' ? 0 : speed);\n    swiper.updateActiveIndex();\n    swiper.updateSlidesClasses();\n  }\n  emitContainerClasses() {\n    const swiper = this;\n    if (!swiper.params._emitClasses || !swiper.el) return;\n    const cls = swiper.el.className.split(' ').filter(className => {\n      return className.indexOf('swiper') === 0 || className.indexOf(swiper.params.containerModifierClass) === 0;\n    });\n    swiper.emit('_containerClasses', cls.join(' '));\n  }\n  getSlideClasses(slideEl) {\n    const swiper = this;\n    if (swiper.destroyed) return '';\n    return slideEl.className.split(' ').filter(className => {\n      return className.indexOf('swiper-slide') === 0 || className.indexOf(swiper.params.slideClass) === 0;\n    }).join(' ');\n  }\n  emitSlidesClasses() {\n    const swiper = this;\n    if (!swiper.params._emitClasses || !swiper.el) return;\n    const updates = [];\n    swiper.slides.forEach(slideEl => {\n      const classNames = swiper.getSlideClasses(slideEl);\n      updates.push({\n        slideEl,\n        classNames\n      });\n      swiper.emit('_slideClass', slideEl, classNames);\n    });\n    swiper.emit('_slideClasses', updates);\n  }\n  slidesPerViewDynamic(view, exact) {\n    if (view === void 0) {\n      view = 'current';\n    }\n    if (exact === void 0) {\n      exact = false;\n    }\n    const swiper = this;\n    const {\n      params,\n      slides,\n      slidesGrid,\n      slidesSizesGrid,\n      size: swiperSize,\n      activeIndex\n    } = swiper;\n    let spv = 1;\n    if (typeof params.slidesPerView === 'number') return params.slidesPerView;\n    if (params.centeredSlides) {\n      let slideSize = slides[activeIndex] ? Math.ceil(slides[activeIndex].swiperSlideSize) : 0;\n      let breakLoop;\n      for (let i = activeIndex + 1; i < slides.length; i += 1) {\n        if (slides[i] && !breakLoop) {\n          slideSize += Math.ceil(slides[i].swiperSlideSize);\n          spv += 1;\n          if (slideSize > swiperSize) breakLoop = true;\n        }\n      }\n      for (let i = activeIndex - 1; i >= 0; i -= 1) {\n        if (slides[i] && !breakLoop) {\n          slideSize += slides[i].swiperSlideSize;\n          spv += 1;\n          if (slideSize > swiperSize) breakLoop = true;\n        }\n      }\n    } else {\n      // eslint-disable-next-line\n      if (view === 'current') {\n        for (let i = activeIndex + 1; i < slides.length; i += 1) {\n          const slideInView = exact ? slidesGrid[i] + slidesSizesGrid[i] - slidesGrid[activeIndex] < swiperSize : slidesGrid[i] - slidesGrid[activeIndex] < swiperSize;\n          if (slideInView) {\n            spv += 1;\n          }\n        }\n      } else {\n        // previous\n        for (let i = activeIndex - 1; i >= 0; i -= 1) {\n          const slideInView = slidesGrid[activeIndex] - slidesGrid[i] < swiperSize;\n          if (slideInView) {\n            spv += 1;\n          }\n        }\n      }\n    }\n    return spv;\n  }\n  update() {\n    const swiper = this;\n    if (!swiper || swiper.destroyed) return;\n    const {\n      snapGrid,\n      params\n    } = swiper;\n    // Breakpoints\n    if (params.breakpoints) {\n      swiper.setBreakpoint();\n    }\n    [...swiper.el.querySelectorAll('[loading=\"lazy\"]')].forEach(imageEl => {\n      if (imageEl.complete) {\n        processLazyPreloader(swiper, imageEl);\n      }\n    });\n    swiper.updateSize();\n    swiper.updateSlides();\n    swiper.updateProgress();\n    swiper.updateSlidesClasses();\n    function setTranslate() {\n      const translateValue = swiper.rtlTranslate ? swiper.translate * -1 : swiper.translate;\n      const newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate());\n      swiper.setTranslate(newTranslate);\n      swiper.updateActiveIndex();\n      swiper.updateSlidesClasses();\n    }\n    let translated;\n    if (params.freeMode && params.freeMode.enabled && !params.cssMode) {\n      setTranslate();\n      if (params.autoHeight) {\n        swiper.updateAutoHeight();\n      }\n    } else {\n      if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !params.centeredSlides) {\n        const slides = swiper.virtual && params.virtual.enabled ? swiper.virtual.slides : swiper.slides;\n        translated = swiper.slideTo(slides.length - 1, 0, false, true);\n      } else {\n        translated = swiper.slideTo(swiper.activeIndex, 0, false, true);\n      }\n      if (!translated) {\n        setTranslate();\n      }\n    }\n    if (params.watchOverflow && snapGrid !== swiper.snapGrid) {\n      swiper.checkOverflow();\n    }\n    swiper.emit('update');\n  }\n  changeDirection(newDirection, needUpdate) {\n    if (needUpdate === void 0) {\n      needUpdate = true;\n    }\n    const swiper = this;\n    const currentDirection = swiper.params.direction;\n    if (!newDirection) {\n      // eslint-disable-next-line\n      newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';\n    }\n    if (newDirection === currentDirection || newDirection !== 'horizontal' && newDirection !== 'vertical') {\n      return swiper;\n    }\n    swiper.el.classList.remove(`${swiper.params.containerModifierClass}${currentDirection}`);\n    swiper.el.classList.add(`${swiper.params.containerModifierClass}${newDirection}`);\n    swiper.emitContainerClasses();\n    swiper.params.direction = newDirection;\n    swiper.slides.forEach(slideEl => {\n      if (newDirection === 'vertical') {\n        slideEl.style.width = '';\n      } else {\n        slideEl.style.height = '';\n      }\n    });\n    swiper.emit('changeDirection');\n    if (needUpdate) swiper.update();\n    return swiper;\n  }\n  changeLanguageDirection(direction) {\n    const swiper = this;\n    if (swiper.rtl && direction === 'rtl' || !swiper.rtl && direction === 'ltr') return;\n    swiper.rtl = direction === 'rtl';\n    swiper.rtlTranslate = swiper.params.direction === 'horizontal' && swiper.rtl;\n    if (swiper.rtl) {\n      swiper.el.classList.add(`${swiper.params.containerModifierClass}rtl`);\n      swiper.el.dir = 'rtl';\n    } else {\n      swiper.el.classList.remove(`${swiper.params.containerModifierClass}rtl`);\n      swiper.el.dir = 'ltr';\n    }\n    swiper.update();\n  }\n  mount(element) {\n    const swiper = this;\n    if (swiper.mounted) return true;\n\n    // Find el\n    let el = element || swiper.params.el;\n    if (typeof el === 'string') {\n      el = document.querySelector(el);\n    }\n    if (!el) {\n      return false;\n    }\n    el.swiper = swiper;\n    if (el.parentNode && el.parentNode.host && el.parentNode.host.nodeName === swiper.params.swiperElementNodeName.toUpperCase()) {\n      swiper.isElement = true;\n    }\n    const getWrapperSelector = () => {\n      return `.${(swiper.params.wrapperClass || '').trim().split(' ').join('.')}`;\n    };\n    const getWrapper = () => {\n      if (el && el.shadowRoot && el.shadowRoot.querySelector) {\n        const res = el.shadowRoot.querySelector(getWrapperSelector());\n        // Children needs to return slot items\n        return res;\n      }\n      return elementChildren(el, getWrapperSelector())[0];\n    };\n    // Find Wrapper\n    let wrapperEl = getWrapper();\n    if (!wrapperEl && swiper.params.createElements) {\n      wrapperEl = createElement('div', swiper.params.wrapperClass);\n      el.append(wrapperEl);\n      elementChildren(el, `.${swiper.params.slideClass}`).forEach(slideEl => {\n        wrapperEl.append(slideEl);\n      });\n    }\n    Object.assign(swiper, {\n      el,\n      wrapperEl,\n      slidesEl: swiper.isElement && !el.parentNode.host.slideSlots ? el.parentNode.host : wrapperEl,\n      hostEl: swiper.isElement ? el.parentNode.host : el,\n      mounted: true,\n      // RTL\n      rtl: el.dir.toLowerCase() === 'rtl' || elementStyle(el, 'direction') === 'rtl',\n      rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || elementStyle(el, 'direction') === 'rtl'),\n      wrongRTL: elementStyle(wrapperEl, 'display') === '-webkit-box'\n    });\n    return true;\n  }\n  init(el) {\n    const swiper = this;\n    if (swiper.initialized) return swiper;\n    const mounted = swiper.mount(el);\n    if (mounted === false) return swiper;\n    swiper.emit('beforeInit');\n\n    // Set breakpoint\n    if (swiper.params.breakpoints) {\n      swiper.setBreakpoint();\n    }\n\n    // Add Classes\n    swiper.addClasses();\n\n    // Update size\n    swiper.updateSize();\n\n    // Update slides\n    swiper.updateSlides();\n    if (swiper.params.watchOverflow) {\n      swiper.checkOverflow();\n    }\n\n    // Set Grab Cursor\n    if (swiper.params.grabCursor && swiper.enabled) {\n      swiper.setGrabCursor();\n    }\n\n    // Slide To Initial Slide\n    if (swiper.params.loop && swiper.virtual && swiper.params.virtual.enabled) {\n      swiper.slideTo(swiper.params.initialSlide + swiper.virtual.slidesBefore, 0, swiper.params.runCallbacksOnInit, false, true);\n    } else {\n      swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true);\n    }\n\n    // Create loop\n    if (swiper.params.loop) {\n      swiper.loopCreate();\n    }\n\n    // Attach events\n    swiper.attachEvents();\n    const lazyElements = [...swiper.el.querySelectorAll('[loading=\"lazy\"]')];\n    if (swiper.isElement) {\n      lazyElements.push(...swiper.hostEl.querySelectorAll('[loading=\"lazy\"]'));\n    }\n    lazyElements.forEach(imageEl => {\n      if (imageEl.complete) {\n        processLazyPreloader(swiper, imageEl);\n      } else {\n        imageEl.addEventListener('load', e => {\n          processLazyPreloader(swiper, e.target);\n        });\n      }\n    });\n    preload(swiper);\n\n    // Init Flag\n    swiper.initialized = true;\n    preload(swiper);\n\n    // Emit\n    swiper.emit('init');\n    swiper.emit('afterInit');\n    return swiper;\n  }\n  destroy(deleteInstance, cleanStyles) {\n    if (deleteInstance === void 0) {\n      deleteInstance = true;\n    }\n    if (cleanStyles === void 0) {\n      cleanStyles = true;\n    }\n    const swiper = this;\n    const {\n      params,\n      el,\n      wrapperEl,\n      slides\n    } = swiper;\n    if (typeof swiper.params === 'undefined' || swiper.destroyed) {\n      return null;\n    }\n    swiper.emit('beforeDestroy');\n\n    // Init Flag\n    swiper.initialized = false;\n\n    // Detach events\n    swiper.detachEvents();\n\n    // Destroy loop\n    if (params.loop) {\n      swiper.loopDestroy();\n    }\n\n    // Cleanup styles\n    if (cleanStyles) {\n      swiper.removeClasses();\n      if (el && typeof el !== 'string') {\n        el.removeAttribute('style');\n      }\n      if (wrapperEl) {\n        wrapperEl.removeAttribute('style');\n      }\n      if (slides && slides.length) {\n        slides.forEach(slideEl => {\n          slideEl.classList.remove(params.slideVisibleClass, params.slideFullyVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass);\n          slideEl.removeAttribute('style');\n          slideEl.removeAttribute('data-swiper-slide-index');\n        });\n      }\n    }\n    swiper.emit('destroy');\n\n    // Detach emitter events\n    Object.keys(swiper.eventsListeners).forEach(eventName => {\n      swiper.off(eventName);\n    });\n    if (deleteInstance !== false) {\n      if (swiper.el && typeof swiper.el !== 'string') {\n        swiper.el.swiper = null;\n      }\n      deleteProps(swiper);\n    }\n    swiper.destroyed = true;\n    return null;\n  }\n  static extendDefaults(newDefaults) {\n    extend(extendedDefaults, newDefaults);\n  }\n  static get extendedDefaults() {\n    return extendedDefaults;\n  }\n  static get defaults() {\n    return defaults;\n  }\n  static installModule(mod) {\n    if (!Swiper.prototype.__modules__) Swiper.prototype.__modules__ = [];\n    const modules = Swiper.prototype.__modules__;\n    if (typeof mod === 'function' && modules.indexOf(mod) < 0) {\n      modules.push(mod);\n    }\n  }\n  static use(module) {\n    if (Array.isArray(module)) {\n      module.forEach(m => Swiper.installModule(m));\n      return Swiper;\n    }\n    Swiper.installModule(module);\n    return Swiper;\n  }\n}\nObject.keys(prototypes).forEach(prototypeGroup => {\n  Object.keys(prototypes[prototypeGroup]).forEach(protoMethod => {\n    Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];\n  });\n});\nSwiper.use([Resize, Observer]);\n\nexport { Swiper as S, defaults as d };\n","import { a as getWindow, g as getDocument } from './ssr-window.esm.mjs';\n\nfunction classesToTokens(classes) {\n  if (classes === void 0) {\n    classes = '';\n  }\n  return classes.trim().split(' ').filter(c => !!c.trim());\n}\n\nfunction deleteProps(obj) {\n  const object = obj;\n  Object.keys(object).forEach(key => {\n    try {\n      object[key] = null;\n    } catch (e) {\n      // no getter for object\n    }\n    try {\n      delete object[key];\n    } catch (e) {\n      // something got wrong\n    }\n  });\n}\nfunction nextTick(callback, delay) {\n  if (delay === void 0) {\n    delay = 0;\n  }\n  return setTimeout(callback, delay);\n}\nfunction now() {\n  return Date.now();\n}\nfunction getComputedStyle(el) {\n  const window = getWindow();\n  let style;\n  if (window.getComputedStyle) {\n    style = window.getComputedStyle(el, null);\n  }\n  if (!style && el.currentStyle) {\n    style = el.currentStyle;\n  }\n  if (!style) {\n    style = el.style;\n  }\n  return style;\n}\nfunction getTranslate(el, axis) {\n  if (axis === void 0) {\n    axis = 'x';\n  }\n  const window = getWindow();\n  let matrix;\n  let curTransform;\n  let transformMatrix;\n  const curStyle = getComputedStyle(el);\n  if (window.WebKitCSSMatrix) {\n    curTransform = curStyle.transform || curStyle.webkitTransform;\n    if (curTransform.split(',').length > 6) {\n      curTransform = curTransform.split(', ').map(a => a.replace(',', '.')).join(', ');\n    }\n    // Some old versions of Webkit choke when 'none' is passed; pass\n    // empty string instead in this case\n    transformMatrix = new window.WebKitCSSMatrix(curTransform === 'none' ? '' : curTransform);\n  } else {\n    transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');\n    matrix = transformMatrix.toString().split(',');\n  }\n  if (axis === 'x') {\n    // Latest Chrome and webkits Fix\n    if (window.WebKitCSSMatrix) curTransform = transformMatrix.m41;\n    // Crazy IE10 Matrix\n    else if (matrix.length === 16) curTransform = parseFloat(matrix[12]);\n    // Normal Browsers\n    else curTransform = parseFloat(matrix[4]);\n  }\n  if (axis === 'y') {\n    // Latest Chrome and webkits Fix\n    if (window.WebKitCSSMatrix) curTransform = transformMatrix.m42;\n    // Crazy IE10 Matrix\n    else if (matrix.length === 16) curTransform = parseFloat(matrix[13]);\n    // Normal Browsers\n    else curTransform = parseFloat(matrix[5]);\n  }\n  return curTransform || 0;\n}\nfunction isObject(o) {\n  return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';\n}\nfunction isNode(node) {\n  // eslint-disable-next-line\n  if (typeof window !== 'undefined' && typeof window.HTMLElement !== 'undefined') {\n    return node instanceof HTMLElement;\n  }\n  return node && (node.nodeType === 1 || node.nodeType === 11);\n}\nfunction extend() {\n  const to = Object(arguments.length <= 0 ? undefined : arguments[0]);\n  const noExtend = ['__proto__', 'constructor', 'prototype'];\n  for (let i = 1; i < arguments.length; i += 1) {\n    const nextSource = i < 0 || arguments.length <= i ? undefined : arguments[i];\n    if (nextSource !== undefined && nextSource !== null && !isNode(nextSource)) {\n      const keysArray = Object.keys(Object(nextSource)).filter(key => noExtend.indexOf(key) < 0);\n      for (let nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {\n        const nextKey = keysArray[nextIndex];\n        const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);\n        if (desc !== undefined && desc.enumerable) {\n          if (isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n            if (nextSource[nextKey].__swiper__) {\n              to[nextKey] = nextSource[nextKey];\n            } else {\n              extend(to[nextKey], nextSource[nextKey]);\n            }\n          } else if (!isObject(to[nextKey]) && isObject(nextSource[nextKey])) {\n            to[nextKey] = {};\n            if (nextSource[nextKey].__swiper__) {\n              to[nextKey] = nextSource[nextKey];\n            } else {\n              extend(to[nextKey], nextSource[nextKey]);\n            }\n          } else {\n            to[nextKey] = nextSource[nextKey];\n          }\n        }\n      }\n    }\n  }\n  return to;\n}\nfunction setCSSProperty(el, varName, varValue) {\n  el.style.setProperty(varName, varValue);\n}\nfunction animateCSSModeScroll(_ref) {\n  let {\n    swiper,\n    targetPosition,\n    side\n  } = _ref;\n  const window = getWindow();\n  const startPosition = -swiper.translate;\n  let startTime = null;\n  let time;\n  const duration = swiper.params.speed;\n  swiper.wrapperEl.style.scrollSnapType = 'none';\n  window.cancelAnimationFrame(swiper.cssModeFrameID);\n  const dir = targetPosition > startPosition ? 'next' : 'prev';\n  const isOutOfBound = (current, target) => {\n    return dir === 'next' && current >= target || dir === 'prev' && current <= target;\n  };\n  const animate = () => {\n    time = new Date().getTime();\n    if (startTime === null) {\n      startTime = time;\n    }\n    const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);\n    const easeProgress = 0.5 - Math.cos(progress * Math.PI) / 2;\n    let currentPosition = startPosition + easeProgress * (targetPosition - startPosition);\n    if (isOutOfBound(currentPosition, targetPosition)) {\n      currentPosition = targetPosition;\n    }\n    swiper.wrapperEl.scrollTo({\n      [side]: currentPosition\n    });\n    if (isOutOfBound(currentPosition, targetPosition)) {\n      swiper.wrapperEl.style.overflow = 'hidden';\n      swiper.wrapperEl.style.scrollSnapType = '';\n      setTimeout(() => {\n        swiper.wrapperEl.style.overflow = '';\n        swiper.wrapperEl.scrollTo({\n          [side]: currentPosition\n        });\n      });\n      window.cancelAnimationFrame(swiper.cssModeFrameID);\n      return;\n    }\n    swiper.cssModeFrameID = window.requestAnimationFrame(animate);\n  };\n  animate();\n}\nfunction getSlideTransformEl(slideEl) {\n  return slideEl.querySelector('.swiper-slide-transform') || slideEl.shadowRoot && slideEl.shadowRoot.querySelector('.swiper-slide-transform') || slideEl;\n}\nfunction elementChildren(element, selector) {\n  if (selector === void 0) {\n    selector = '';\n  }\n  const window = getWindow();\n  const children = [...element.children];\n  if (window.HTMLSlotElement && element instanceof HTMLSlotElement) {\n    children.push(...element.assignedElements());\n  }\n  if (!selector) {\n    return children;\n  }\n  return children.filter(el => el.matches(selector));\n}\nfunction elementIsChildOfSlot(el, slot) {\n  // Breadth-first search through all parent's children and assigned elements\n  const elementsQueue = [slot];\n  while (elementsQueue.length > 0) {\n    const elementToCheck = elementsQueue.shift();\n    if (el === elementToCheck) {\n      return true;\n    }\n    elementsQueue.push(...elementToCheck.children, ...(elementToCheck.shadowRoot ? elementToCheck.shadowRoot.children : []), ...(elementToCheck.assignedElements ? elementToCheck.assignedElements() : []));\n  }\n}\nfunction elementIsChildOf(el, parent) {\n  const window = getWindow();\n  let isChild = parent.contains(el);\n  if (!isChild && window.HTMLSlotElement && parent instanceof HTMLSlotElement) {\n    const children = [...parent.assignedElements()];\n    isChild = children.includes(el);\n    if (!isChild) {\n      isChild = elementIsChildOfSlot(el, parent);\n    }\n  }\n  return isChild;\n}\nfunction showWarning(text) {\n  try {\n    console.warn(text);\n    return;\n  } catch (err) {\n    // err\n  }\n}\nfunction createElement(tag, classes) {\n  if (classes === void 0) {\n    classes = [];\n  }\n  const el = document.createElement(tag);\n  el.classList.add(...(Array.isArray(classes) ? classes : classesToTokens(classes)));\n  return el;\n}\nfunction elementOffset(el) {\n  const window = getWindow();\n  const document = getDocument();\n  const box = el.getBoundingClientRect();\n  const body = document.body;\n  const clientTop = el.clientTop || body.clientTop || 0;\n  const clientLeft = el.clientLeft || body.clientLeft || 0;\n  const scrollTop = el === window ? window.scrollY : el.scrollTop;\n  const scrollLeft = el === window ? window.scrollX : el.scrollLeft;\n  return {\n    top: box.top + scrollTop - clientTop,\n    left: box.left + scrollLeft - clientLeft\n  };\n}\nfunction elementPrevAll(el, selector) {\n  const prevEls = [];\n  while (el.previousElementSibling) {\n    const prev = el.previousElementSibling; // eslint-disable-line\n    if (selector) {\n      if (prev.matches(selector)) prevEls.push(prev);\n    } else prevEls.push(prev);\n    el = prev;\n  }\n  return prevEls;\n}\nfunction elementNextAll(el, selector) {\n  const nextEls = [];\n  while (el.nextElementSibling) {\n    const next = el.nextElementSibling; // eslint-disable-line\n    if (selector) {\n      if (next.matches(selector)) nextEls.push(next);\n    } else nextEls.push(next);\n    el = next;\n  }\n  return nextEls;\n}\nfunction elementStyle(el, prop) {\n  const window = getWindow();\n  return window.getComputedStyle(el, null).getPropertyValue(prop);\n}\nfunction elementIndex(el) {\n  let child = el;\n  let i;\n  if (child) {\n    i = 0;\n    // eslint-disable-next-line\n    while ((child = child.previousSibling) !== null) {\n      if (child.nodeType === 1) i += 1;\n    }\n    return i;\n  }\n  return undefined;\n}\nfunction elementParents(el, selector) {\n  const parents = []; // eslint-disable-line\n  let parent = el.parentElement; // eslint-disable-line\n  while (parent) {\n    if (selector) {\n      if (parent.matches(selector)) parents.push(parent);\n    } else {\n      parents.push(parent);\n    }\n    parent = parent.parentElement;\n  }\n  return parents;\n}\nfunction elementTransitionEnd(el, callback) {\n  function fireCallBack(e) {\n    if (e.target !== el) return;\n    callback.call(el, e);\n    el.removeEventListener('transitionend', fireCallBack);\n  }\n  if (callback) {\n    el.addEventListener('transitionend', fireCallBack);\n  }\n}\nfunction elementOuterSize(el, size, includeMargins) {\n  const window = getWindow();\n  if (includeMargins) {\n    return el[size === 'width' ? 'offsetWidth' : 'offsetHeight'] + parseFloat(window.getComputedStyle(el, null).getPropertyValue(size === 'width' ? 'margin-right' : 'margin-top')) + parseFloat(window.getComputedStyle(el, null).getPropertyValue(size === 'width' ? 'margin-left' : 'margin-bottom'));\n  }\n  return el.offsetWidth;\n}\nfunction makeElementsArray(el) {\n  return (Array.isArray(el) ? el : [el]).filter(e => !!e);\n}\nfunction getRotateFix(swiper) {\n  return v => {\n    if (Math.abs(v) > 0 && swiper.browser && swiper.browser.need3dFix && Math.abs(v) % 90 === 0) {\n      return v + 0.001;\n    }\n    return v;\n  };\n}\n\nexport { elementParents as a, elementOffset as b, createElement as c, now as d, elementChildren as e, elementOuterSize as f, getSlideTransformEl as g, elementIndex as h, classesToTokens as i, getTranslate as j, elementTransitionEnd as k, isObject as l, makeElementsArray as m, nextTick as n, getRotateFix as o, elementStyle as p, elementNextAll as q, elementPrevAll as r, setCSSProperty as s, animateCSSModeScroll as t, showWarning as u, elementIsChildOf as v, extend as w, deleteProps as x };\n","/**\n * Swiper 11.2.5\n * Most modern mobile touch slider and framework with hardware accelerated transitions\n * https://swiperjs.com\n *\n * Copyright 2014-2025 Vladimir Kharlampidi\n *\n * Released under the MIT License\n *\n * Released on: March 3, 2025\n */\n\nexport { S as Swiper, S as default } from './shared/swiper-core.mjs';\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","/* eslint-disable import/no-extraneous-dependencies */\n\nimport { MembershipTiles } from './membershipTilesSwiper';\n\nimport { debounce } from './util';\n\nlet windowWidth = $(window).width();\n\n$(window).on('load resize', debounce((e) => {\n    // Check window width has actually changed and it's not just iOS triggering a resize event on scroll\n    if (e.type === 'load' || $(window).width() !== windowWidth) {\n        // Update the window width for next time\n        windowWidth = $(window).width();\n        if ($(window).width() > 900) {\n            MembershipTiles.destroy();\n        } else {\n            MembershipTiles.init();\n        }\n    }\n}, 300));\n"],"names":["checkoutFlow","require","formError","dropinConfig","dropin","adyenObj","brand","PAYMENT_PROVIDER","createOrder","component","orderId","actions","data","peopleId","url","$","attr","window","location","href","params","orderid","peopleid","adyenPaymentMethod","activePaymentMethod","displayName","dropinSessionAmount","props","amount","value","indexOf","Object","keys","map","key","encodeURIComponent","join","ajax","type","success","response","error","priceIssue","undefined","closeActivePaymentMethod","contentType","dataType","JSON","stringify","done","responseUpdateSession","val","adyenSessionData","unmount","mountAdyenObj","reCrateAdyenConfig","renderFailedPayments","reload","Error","errorMessage","continueUrl","orderID","orderToken","$checkoutDataContainer","gtmProductsNew","urlParams","ID","token","pushPaymentMethodSelectedEvent","products","parse","paymentType","paymentMethod","pushPaymentInfoEvent","resolve","sessionStorage","clear","prop","console","log","check3DS2","state","payload","setStatus","response3ds2","resultCode","toLowerCase","authorised","action","handleAction","fail","xhr","addClass","text","removeClass","resources","failResponse","config","countryCode","locale","environment","clientKey","session","id","sessionData","beforeSubmit","defer","Deferred","$accountHolder","$accountNumber","$sepaAgreement","$termsAndConditions","requiredName","length","valid","requiredIban","requiredSepa","requiredTermsCon","reject","$form","method","serialize","cartError","redirectUrl","fieldErrors","forEach","loadFormErrors","onChange","isValid","onAdditionalDetails","onActionHandled","onPaymentCompleted","res","then","stts","onPaymentFailed","result","toString","paymentMethodsConfiguration","card","onBrand","onError","adyenDropin","hasHolderName","holderNameRequired","name","paypal","applepay","buttonType","buttonColor","AdyenWeb","AdyenCheckout","Dropin","mount","module","exports","parentSelector","each","closest","find","html","clearPreviousErrors","hide","pushErrorEvent","pushSelectMembershipEvent","updateMiniCart","dynamicCountdown","equalizeTiles","payementInitialize","handleMembershipUSP","$viewMore","$viewLess","$allUSP","on","show","updateMembershipBlock","$membershipStep","empty","append","membershipsData","resetMembershipTables","$membershipTables","i","table","$membershipTable","resetMembershipDurationWrapper","$membershipDuration","className","resetMembershipDurations","$membershipDurations","$currentMembershipDuration","duration","handleMembershipButtonClick","e","$membershipButton","currentTarget","$membershipStepWrapper","$membershipDurationWrapper","$nextStepButton","membershipUrl","membershipName","$selectedMembershipDuration","durationId","addMembershipPlanToCart","updateMembershipTable","membershipTileHTML","membershipTileContent","pid","isUSPSectionExpanded","isMembershipButtonClick","css","gtmProducts","errorText","$checkoutStage","handleMembershipSelection","$membershipButtons","button","handleMembershipDuration","durationItem","$currentMembershipDurations","is","handleRedirectFromCDP","membershipTablesArray","get","membershipTable","hasClass","getPreselectedMembershipInfo","$selectedMembershipTable","charAt","toUpperCase","slice","countdown","$counter","$counterWrapper","$daysValue","$hoursValue","$minutesValue","date","countDownDate","Date","getTime","interval","setInterval","now","distance","days","Math","floor","hours","minutes","clearInterval","equalizeElements","selector","elements","minHeight","index","element","height","outerHeight","updatePaymentScheduleOptions","scrollLock","LAPTOP_MAX_WIDTH","LOW_ENTRY_BARRIER_MESSAGE_ID","initSummaryAccordion","target","toggleClass","initStep5SummaryAccordion","bindClickEvent","off","showSummary","step","toggleMobileSummary","slideToggle","closeMobileSummary","$floatingSummary","$floatingSummaryHeader","trigger","mobileSummaryFloat","$navWrapper","$orderSummary","navWrapperHeight","resizePending","updateNavWrapperHeight","newHeight","handleScroll","navWrapperBottom","getBoundingClientRect","bottom","handleResize","requestAnimationFrame","bindOrderSummaryToggleTouchDevices","innerWidth","bindOrderSummaryLowEntryBarrierPopup","$lowEntryBarrierPlanMessage","$tooltip","initStep5bindOrderSummaryLowEntryBarrierPopup","$injectedPopupLink","$injectedTooltip","add","toggleOneCentPromotionContent","isOneCentPromotion","$oneCentPromotionContractDisclaimer","$4Weeks","$oneCentPromotionAsset","$paymentSummaryNew","isFirstCheckoutStep","miniCartHtml","setItem","clone","spinner","stop","toggleDropinButtons","$paypalButton","$applepayButton","$bizumButton","$idealButton","isAccountHolderValid","isAccountNumberValid","isSepaAgreementValid","isTermsAndConditionsValid","updateMembershipDuration","membershipDurationPlanHTML","memberShipDurationPlan","activeMemberShipDuration","replaceWith","isFlex","isPromotionAvailable","is13PeriodDiscount","isLowEntryBarrierPromotion","isFoundingMember","subscriptionPrice","discountedMonthlyPrice","originalTotalPrice","totalPrice","promotionFlexLabel","promotionLabel4Weeks","promotionLabel52Weeks","promotion13Label4Weeks","promotion13Label52Weeks","defaultDescription4Weeks","lowEntryBarrierDescription4Weeks","isStrikeThroughPrice","$4WeeksPaymentScheduleOption","$52WeeksPaymentScheduleOption","$4WeeksDescription","$4WeeksPrice","$52WeeksPrice","$4WeeksDiscountedPrice","$52WeeksDiscountedPrice","$4WeeksStrikeThroughPrice","$52WeeksStrikeThroughPrice","$4WeeksPromotionLabel","$52WeeksPromotionLabel","label4Weeks","paymentInterval","is4Weeks","$52Weeks","$oneCentPromotionDisclaimer","$oneCentPromotionMobileDisclaimer","pushSelectPaymentIntervalEvent","ibanInputs","detach","sepaCheckbox","$target","$wrapper","endpointUrl","isSepaYearPlanAllowed","cart","subscriptionBasePrice","allRecurringCosts","addOnsHtml","extraYearlyPaymentPromo","after","prepend","message","sanitizeMessage","includes","split","removeAttr","totals","subTotal","isPlanAdjusted","periodPromoDiscount","available","periodPromoDiscountMsg","isFoundingMemberPromoTextInclude","foundingPromoMsg","stPrice","percentage","$paymentSummary","$checkoutOrderSummary","$checkoutOrderSummaryStatic","formatName","GtmParametersBuilder","GtmCheckoutBuilder","GtmEcommBuilder","buildCheckoutOption","checkoutData","ecommData","withCheckoutOption","build","withEvent","withEcommerce","buildCheckout","withCheckout","buildPurchaseOption","user","withPurchaseOption","withUser","pushMembershipStepCTAEvent","dataLayer","push","ecommerce","event","step_name","step_index","pushMembershipViewDetailsEvent","membershipType","withParameter","pushMembershipHideDetailsEvent","pushPaymentMethodLoaded","option","withActionField","withProducts","product","gtmParams","pushConfirmationPageLoaded","actionField","marketingID","userID","withMarketingID","userId","localStorage","removeItem","pushPurchaseEvent","userData","actionData","items","membership","item","item_category","user_email","user_phone_number","user_first_name","user_last_name","user_gender","user_city","user_country","user_country_code","user_street","user_postal_code","user_zip_code","user_age_group","member_id","club","club_name","club_id","club_services","club_founding_member","transaction_id","affiliation","order_amount","orderAmount","currency","payment_type","payment_provider","paymentProvider","item_name","item_variant","payment_interval","pushOriginalLocation","originalLocation","pushPageView","events","withPage","withTraffic","pushPersonalInformationEvent","pushAddToCartEvent","isOnlyAddonsAdded","isOnlyMembershipAdded","filter","pushRemoveFromCartEvent","isOnlyAddonsRemoved","isOnlyMembershipRemoved","pushPaymentMethodEvent","pushSelectClubEvent","view","position","club_list_position","errorType","error_type","error_message","withError","pushSelectFilterEvent","isSelected","eventName","pushViewTypeSelectEvent","viewTypeName","pushSelectAddonEvent","addon","checkoutParameters","prototype","ecommParameters","checkout","checkout_option","purchase","withCurrencyCode","currencyCode","withImpressions","impressions","withProductClick","click","gtmParameters","withEventCategory","eventCategory","withEventAction","eventAction","withEventLabel","eventLabel","country","language","page","page_type","page_country","page_location","page_title","title","page_language","traffictype","platform","ip_address","ip","Swiper","Navigation","Pagination","A11y","swiperClass","MembershipTiles","membershipSwiper","handleMembershipSwiper","slideNumber","options","modules","speed","loop","spaceBetween","loopedSlides","slidesPerView","initialSlide","centeredSlides","pagination","el","clickable","navigation","nextEl","prevEl","a11y","prevSlideMessage","nextSlideMessage","firstSlideMessage","lastSlideMessage","slideChange","setSwipeText","slideChangePush","modifyOptionsForUspTilesSlider","destroy","slideTo","slideIdArray","goToMembership","activeIndex","startX","touches","currentX","eventType","navigation_method","PrevText","NextText","destroyParams","cleanStyles","destroyMembershipSwiper","width","init","tingle","getYouTubeID","smallDesktopMin","mobileViewMax","tabletViewMin","tabletViewMax","processInclude","include","category","getScreenSizeType","getScreenSize","mediaQuery","matchMedia","matches","isElementInViewport","rect","document","querySelector","windowHeight","innerHeight","documentElement","clientHeight","windowWidth","clientWidth","vertInView","top","horInView","left","isDOMElementInViewport","bounding","currentPageScrollPosition","onoff","$body","scrollY","classList","style","overflow","remove","removeProperty","scrollTo","createErrorNotification","errorHtml","appendToUrl","newUrl","openVideoInModal","videoUrl","videoId","iframeVimeo","videoInModal","modal","cssClass","closeLabel","onClose","setContent","open","scrollToAnchor","anchor","defaultOptions","headerElemHeight","extraMargin","scrollPos","parseInt","offset","animate","scrollTop","setEqualHeights","arrayItems","count","maxH","arrays","splice","j","currentH","k","currentH2","fontSizeReduced","pages","querySelectorAll","titleContainer","fontReduceComponent","offsetWidth","checkForContent","hasChildNodes","validateEmail","email","regex","test","calculateTitleHeight","heroBannerTitle","heroBannerImg","marginTop","offsetHeight","display","opacity","openTabs","tabSelector","tabContentSelector","tab","tabContent","removeActive","addEventListener","current","currentID","getAttribute","getElementById","readMoreButton","content","btnText","btnLessText","btnClassName","num","readLess","readMoreBtn","createElement","innerHTML","appendChild","toggle","contains","imageResizeiOSFix","$img","backToTop","$backToTop","$scrollPos","pageYOffset","preventDefault","customStickyPosition","stickyElement","elementOne","elementTwo","elementThree","stickyEl","offSetOne","offSetTwo","offSetThree","updateCountdown","timeLeftSeconds","parseFloat","self","timer","seconds","remainingTime","removeHiddenAssets","$Selector","parentToRemoveSelector","debounce","func","wait","immediate","timeout","args","context","later","apply","callNow","clearTimeout","setTimeout"],"sourceRoot":""}