.ihbw43d{display:inline-block;}
.r1e46lhc{display:inline-block;-webkit-animation:countDownAnimation-r1e46lhc 33s;animation:countDownAnimation-r1e46lhc 33s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;}@-webkit-keyframes countDownAnimation-r1e46lhc{0%{color:rgb(var(--gray60));}60%{color:rgb(var(--gray60));}100%{color:rgb(var(--red60));}}@keyframes countDownAnimation-r1e46lhc{0%{color:rgb(var(--gray60));}60%{color:rgb(var(--gray60));}100%{color:rgb(var(--red60));}}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYnMvd2FsbGV0LWNkcy1leHRlbnNpb24vY29tcG9uZW50cy9SZWZyZXNoQ291bnRkb3duLnRzeCJdLCJuYW1lcyI6WyIuaWhidzQzZCIsIi5yMWU0NmxoYyJdLCJtYXBwaW5ncyI6IkFBcUNNQTtBQUlBQyIsImZpbGUiOiIuLi8uLi9saWJzL3dhbGxldC1jZHMtZXh0ZW5zaW9uL2NvbXBvbmVudHMvUmVmcmVzaENvdW50ZG93bi50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBkZWZpbmVNZXNzYWdlcywgdXNlSW50bCB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGxpbmFyaWEvY29yZSc7XG5pbXBvcnQgeyB1c2VSZWZyZXNoQ291bnRkb3duIH0gZnJvbSAnY2Itd2FsbGV0LWRhdGEvaG9va3MvU3dhcC91c2VSZWZyZXNoQ291bnRkb3duL3VzZVJlZnJlc2hDb3VudGRvd24nO1xuaW1wb3J0IHsgVGV4dExhYmVsMiB9IGZyb20gJ0BjYmhxL2Nkcy13ZWIvdHlwb2dyYXBoeSc7XG5cbmNvbnN0IG1lc3NhZ2VzID0gZGVmaW5lTWVzc2FnZXMoe1xuICBuZXdRdW90ZUluOiB7XG4gICAgZGVmYXVsdE1lc3NhZ2U6ICdOZXcgcXVvdGUgaW46IHtxdW90ZUNvdW50ZG93bn0nLFxuICAgIGRlc2NyaXB0aW9uOlxuICAgICAgJ0xhYmVsIGZvciByZXByZXNldGluZyBob3cgbWFueSBzZWNvbmRzIHdlIGhhdmUgdW50aWwgdGhlIG5leHQgbmV0d29yayBmZWUgcmVmcmVzaCcsXG4gIH0sXG59KTtcblxudHlwZSBQcm9wcyA9IHtcbiAgbGFzdFVwZGF0ZVRpbWU/OiBEYXRlO1xuICBpc1BhZ2VMb2FkaW5nOiBib29sZWFuO1xuICBkaXNhYmxlQ29sb3JBbmltYXRpb24/OiBib29sZWFuO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIFJlZnJlc2hDb3VudGRvd24oe1xuICBsYXN0VXBkYXRlVGltZSxcbiAgaXNQYWdlTG9hZGluZyxcbiAgZGlzYWJsZUNvbG9yQW5pbWF0aW9uID0gZmFsc2UsXG59OiBQcm9wcykge1xuICBjb25zdCB7IGZvcm1hdE1lc3NhZ2UgfSA9IHVzZUludGwoKTtcbiAgY29uc3QgeyBub3JtYWxpemVkU2Vjb25kcyB9ID0gdXNlUmVmcmVzaENvdW50ZG93bihsYXN0VXBkYXRlVGltZSwgaXNQYWdlTG9hZGluZyk7XG4gIGNvbnN0IGNvdW50RG93blN0eWxlID1cbiAgICBpc1BhZ2VMb2FkaW5nIHx8IGRpc2FibGVDb2xvckFuaW1hdGlvbiA/IGlubGluZUJsb2NrU3R5bGUgOiByZWRDb3VudERvd25TdHlsZTtcbiAgcmV0dXJuIChcbiAgICA8VGV4dExhYmVsMiBhcz1cInBcIiBjb2xvcj1cImZvcmVncm91bmRNdXRlZFwiIHRlc3RJRD1cInJlZnJlc2gtY291bnRkb3duXCI+XG4gICAgICB7Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5uZXdRdW90ZUluLCB7XG4gICAgICAgIHF1b3RlQ291bnRkb3duOiA8c3BhbiBjbGFzc05hbWU9e2NvdW50RG93blN0eWxlfT57bm9ybWFsaXplZFNlY29uZHN9PC9zcGFuPixcbiAgICAgIH0pfVxuICAgIDwvVGV4dExhYmVsMj5cbiAgKTtcbn1cblxuY29uc3QgaW5saW5lQmxvY2tTdHlsZSA9IGNzc2BcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuYDtcblxuY29uc3QgcmVkQ291bnREb3duU3R5bGUgPSBjc3NgXG4gIEBrZXlmcmFtZXMgY291bnREb3duQW5pbWF0aW9uIHtcbiAgICAwJSB7XG4gICAgICBjb2xvcjogcmdiKHZhcigtLWdyYXk2MCkpO1xuICAgIH1cbiAgICA2MCUge1xuICAgICAgY29sb3I6IHJnYih2YXIoLS1ncmF5NjApKTtcbiAgICB9XG4gICAgMTAwJSB7XG4gICAgICBjb2xvcjogcmdiKHZhcigtLXJlZDYwKSk7XG4gICAgfVxuICB9XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgYW5pbWF0aW9uOiBjb3VudERvd25BbmltYXRpb24gMzNzO1xuICBhbmltYXRpb24taXRlcmF0aW9uLWNvdW50OiBpbmZpbml0ZTtcbmA7XG4iXX0=*/
.a1q37wuz{-webkit-transform:scale(calc(2 / 3));-ms-transform:scale(calc(2 / 3));transform:scale(calc(2 / 3));padding-right:var(--spacing-0.5);}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYnMvd2FsbGV0LWNkcy1leHRlbnNpb24vY29tcG9uZW50cy9Vc2VyQXZhdGFyL0F2YXRhckJveC50c3giXSwibmFtZXMiOlsiLmExcTM3d3V6Il0sIm1hcHBpbmdzIjoiQUFFYUEiLCJmaWxlIjoiLi4vLi4vbGlicy93YWxsZXQtY2RzLWV4dGVuc2lvbi9jb21wb25lbnRzL1VzZXJBdmF0YXIvQXZhdGFyQm94LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHN0eWxlZCB9IGZyb20gJ0BsaW5hcmlhL3JlYWN0JztcblxuZXhwb3J0IGNvbnN0IEF2YXRhckJveCA9IHN0eWxlZC5kaXZgXG4gIHRyYW5zZm9ybTogc2NhbGUoY2FsYygyIC8gMykpO1xuICBwYWRkaW5nLXJpZ2h0OiB2YXIoLS1zcGFjaW5nLTBcXC41KTtcbmA7XG4iXX0=*/
.o8ndml8{position:relative;}.o8ndml8::before{content:'';width:0;height:0;border:1em solid transparent;position:absolute;left:85%;top:-28px;border-bottom:16px solid #330004;}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYnMvd2FsbGV0LWNkcy1leHRlbnNpb24vY29tcG9uZW50cy9PdXRsaW5lQm94LnRzeCJdLCJuYW1lcyI6WyIubzhuZG1sOCJdLCJtYXBwaW5ncyI6IkFBMEJhQSIsImZpbGUiOiIuLi8uLi9saWJzL3dhbGxldC1jZHMtZXh0ZW5zaW9uL2NvbXBvbmVudHMvT3V0bGluZUJveC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAbGluYXJpYS9jb3JlJztcbmltcG9ydCB7IHVzZVNwZWN0cnVtIH0gZnJvbSAnQGNiaHEvY2RzLXdlYic7XG5pbXBvcnQgeyBCb3ggfSBmcm9tICdAY2JocS9jZHMtd2ViL2xheW91dCc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGU7XG4gIHRlc3RJRD86IHN0cmluZztcbn07XG5leHBvcnQgZnVuY3Rpb24gT3V0bGluZUJveCh7IGNoaWxkcmVuIH06IFByb3BzKSB7XG4gIGNvbnN0IHNwZWN0cnVtID0gdXNlU3BlY3RydW0oKTtcblxuICByZXR1cm4gKFxuICAgIDxCb3hcbiAgICAgIGRhbmdlcm91c2x5U2V0Q2xhc3NOYW1lPXtPdXRsaW5lfVxuICAgICAgYm9yZGVyUmFkaXVzPVwic3RhbmRhcmRcIlxuICAgICAgZGFuZ2Vyb3VzbHlTZXRCYWNrZ3JvdW5kPXtzcGVjdHJ1bSA9PT0gJ2RhcmsnID8gJyMzMzAwMDQnIDogJ0ZGRjVGNid9XG4gICAgICBzcGFjaW5nSG9yaXpvbnRhbD17MX1cbiAgICAgIHNwYWNpbmdWZXJ0aWNhbD17MX1cbiAgICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvQm94PlxuICApO1xufVxuXG5leHBvcnQgY29uc3QgT3V0bGluZSA9IGNzc2BcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICA6OmJlZm9yZSB7XG4gICAgY29udGVudDogJyc7XG4gICAgd2lkdGg6IDA7XG4gICAgaGVpZ2h0OiAwO1xuICAgIGJvcmRlcjogMWVtIHNvbGlkIHRyYW5zcGFyZW50O1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICBsZWZ0OiA4NSU7XG4gICAgdG9wOiAtMjhweDtcbiAgICBib3JkZXItYm90dG9tOiAxNnB4IHNvbGlkICMzMzAwMDQ7XG4gIH1cbmA7XG4iXX0=*/
.n1wo4ekf{position:absolute;bottom:0;right:0;width:16px;height:16px;left:20px;top:22px;border-radius:50%;}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYnMvd2FsbGV0LWNkcy1leHRlbnNpb24vY29tcG9uZW50cy9UeERldGFpbHMvRGFwcFR4UmVxdWVzdEhlYWRlci50c3giXSwibmFtZXMiOlsiLm4xd280ZWtmIl0sIm1hcHBpbmdzIjoiQUEwSE1BIiwiZmlsZSI6Ii4uLy4uL2xpYnMvd2FsbGV0LWNkcy1leHRlbnNpb24vY29tcG9uZW50cy9UeERldGFpbHMvRGFwcFR4UmVxdWVzdEhlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtZW1vLCB1c2VDYWxsYmFjaywgdXNlTWVtbywgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBkZWZpbmVNZXNzYWdlcywgdXNlSW50bCB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGxpbmFyaWEvY29yZSc7XG5pbXBvcnQgeyBEYXBwSW5mbyB9IGZyb20gJ2NiLXdhbGxldC1kYXRhL2NoYWlucy9BY2NvdW50QmFzZWQvc2hhcmVkL3R5cGVzL0RhcHBJbmZvJztcbmltcG9ydCB7IGdldEhvc3ROYW1lRm9yRGFwcCB9IGZyb20gJ3dhbGxldC1jZHMtZXh0ZW5zaW9uL3V0aWwvZ2V0SG9zdE5hbWVGb3JEYXBwL2dldEhvc3ROYW1lRm9yRGFwcCc7XG5pbXBvcnQgeyBJY29uTmFtZSB9IGZyb20gJ0BjYmhxL2Nkcy1jb21tb24nO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0BjYmhxL2Nkcy13ZWIvaWNvbnMvSWNvbic7XG5pbXBvcnQgeyBCb3gsIEhTdGFjaywgVlN0YWNrIH0gZnJvbSAnQGNiaHEvY2RzLXdlYi9sYXlvdXQnO1xuaW1wb3J0IHsgUmVtb3RlSW1hZ2UgfSBmcm9tICdAY2JocS9jZHMtd2ViL21lZGlhL1JlbW90ZUltYWdlJztcbmltcG9ydCB7IFRvb2x0aXAgfSBmcm9tICdAY2JocS9jZHMtd2ViL292ZXJsYXlzL1Rvb2x0aXAvVG9vbHRpcCc7XG5pbXBvcnQgeyBUZXh0SGVhZGxpbmUsIFRleHRMZWdhbCB9IGZyb20gJ0BjYmhxL2Nkcy13ZWIvdHlwb2dyYXBoeSc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGRhcHBJbmZvOiBEYXBwSW5mbztcbiAgaWNvbj86IEljb25OYW1lO1xuICBoZWFkZXJEYXBwTmFtZT86IHN0cmluZztcbiAgaXNSZXZva2VPcGVyYXRpb24/OiBib29sZWFuO1xufTtcblxuY29uc3QgbWVzc2FnZXMgPSBkZWZpbmVNZXNzYWdlcyh7XG4gIHRpdGxlOiB7XG4gICAgZGVmYXVsdE1lc3NhZ2U6ICdSZXZpZXcnLFxuICAgIGRlc2NyaXB0aW9uOiAncmV2aWV3IHRpdGxlJyxcbiAgfSxcbiAgZGFwcFVybFJlcXVlc3RUZXh0OiB7XG4gICAgZGVmYXVsdE1lc3NhZ2U6ICdSZXF1ZXN0IGZyb20ge2RhcHBVUkx9JyxcbiAgICBkZXNjcmlwdGlvbjogJ0RhcHAgcmVxdWVzdCBob3N0IFVSTCcsXG4gIH0sXG4gIGRhcHBVcmxSZXZva2VUZXh0OiB7XG4gICAgZGVmYXVsdE1lc3NhZ2U6ICdSZXZva2UgYWxsb3dhbmNlIHRvIHtkYXBwVVJMfScsXG4gICAgZGVzY3JpcHRpb246ICdEYXBwIHJlcXVlc3QgaG9zdCBVUkwnLFxuICB9LFxuICBoZWFkZXJUb290bHRpcDoge1xuICAgIGRlZmF1bHRNZXNzYWdlOiAnT25seSBzaWduIGlmIHlvdSBmdWxseSB0cnVzdCB0aGlzIHNpdGUgd2l0aCBhY2Nlc3MgdG8geW91ciBhY2NvdW50JyxcbiAgICBkZXNjcmlwdGlvbjogJ0hlYWRlciB0b29sdGlwIGNvbnRlbnQnLFxuICB9LFxufSk7XG5cbmZ1bmN0aW9uIERhcHBUeEhlYWRlckRldGFpbCh7IGRhcHBJbmZvLCBpY29uLCBoZWFkZXJEYXBwTmFtZSwgaXNSZXZva2VPcGVyYXRpb24gfTogUHJvcHMpIHtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG5cbiAgY29uc3QgeyBkYXBwTG9nb1VSTCwgZGFwcExvZ29VUkxBbHQsIG5ldHdvcmtCYWRnZVVSTCwgbmV0d29ya0JhZGdlQWx0LCBkYXBwVVJMIH0gPSBkYXBwSW5mbztcbiAgY29uc3QgW3NvdXJjZVVybCwgc2V0U291cmNlVXJsXSA9IHVzZVN0YXRlKGRhcHBMb2dvVVJMKTtcbiAgY29uc3Qgc2V0QWx0ZXJuYXRpdmVEYXBwTG9nb1VSTCA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTb3VyY2VVcmwoZGFwcExvZ29VUkxBbHQpO1xuICB9LCBbZGFwcExvZ29VUkxBbHRdKTtcblxuICBjb25zdCBkYXBwTmFtZTogc3RyaW5nID0gdXNlTWVtbygoKSA9PiB7XG4gICAgcmV0dXJuIGhlYWRlckRhcHBOYW1lIHx8IGdldEhvc3ROYW1lRm9yRGFwcChkYXBwVVJMKTtcbiAgfSwgW2RhcHBVUkwsIGhlYWRlckRhcHBOYW1lXSk7XG5cbiAgY29uc3QgaW1hZ2UgPSB1c2VNZW1vKFxuICAgICgpID0+XG4gICAgICBpY29uID8gKFxuICAgICAgICA8SWNvbiBuYW1lPXtpY29ufSBzaXplPVwibVwiIGNvbG9yPVwiZm9yZWdyb3VuZE11dGVkXCIgLz5cbiAgICAgICkgOiAoXG4gICAgICAgIDw+XG4gICAgICAgICAgPFJlbW90ZUltYWdlXG4gICAgICAgICAgICBzb3VyY2U9e3NvdXJjZVVybH1cbiAgICAgICAgICAgIHJlc2l6ZU1vZGU9XCJjb250YWluXCJcbiAgICAgICAgICAgIHdpZHRoPXszMn1cbiAgICAgICAgICAgIGhlaWdodD17MzJ9XG4gICAgICAgICAgICBzaGFwZT1cInNxdWlyY2xlXCJcbiAgICAgICAgICAgIGFsdD17ZGFwcExvZ29VUkxBbHR9XG4gICAgICAgICAgICBvbkVycm9yPXtzZXRBbHRlcm5hdGl2ZURhcHBMb2dvVVJMfVxuICAgICAgICAgIC8+XG4gICAgICAgICAge25ldHdvcmtCYWRnZVVSTCA/IChcbiAgICAgICAgICAgIDxpbWcgY2xhc3NOYW1lPXtuZXR3b3JrQmFkZ2V9IHNyYz17bmV0d29ya0JhZGdlVVJMfSBhbHQ9e25ldHdvcmtCYWRnZUFsdH0gLz5cbiAgICAgICAgICApIDogbnVsbH1cbiAgICAgICAgPC8+XG4gICAgICApLFxuICAgIFtkYXBwTG9nb1VSTEFsdCwgaWNvbiwgbmV0d29ya0JhZGdlQWx0LCBuZXR3b3JrQmFkZ2VVUkwsIHNldEFsdGVybmF0aXZlRGFwcExvZ29VUkwsIHNvdXJjZVVybF0sXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8Qm94IGFsaWduSXRlbXM9XCJmbGV4LXN0YXJ0XCIgc3BhY2luZ0hvcml6b250YWw9ezN9IHNwYWNpbmdWZXJ0aWNhbD17Mn0+XG4gICAgICA8SFN0YWNrXG4gICAgICAgIHNwYWNpbmdFbmQ9ezJ9XG4gICAgICAgIGhlaWdodD1cIjEwMCVcIlxuICAgICAgICBhbGlnblNlbGY9XCJjZW50ZXJcIlxuICAgICAgICBwb3NpdGlvbj1cInJlbGF0aXZlXCJcbiAgICAgICAgdGVzdElEPVwiZGFwcC10cmFuc2FjdGlvbi1yZXF1ZXN0LWhlYWRlclwiXG4gICAgICAgIGFsaWduSXRlbXM9e2ljb24gPyAnY2VudGVyJyA6IHVuZGVmaW5lZH1cbiAgICAgID5cbiAgICAgICAgPEJveCBwb3NpdGlvbj1cInJlbGF0aXZlXCI+e2ltYWdlfTwvQm94PlxuICAgICAgPC9IU3RhY2s+XG4gICAgICA8SFN0YWNrPlxuICAgICAgICA8VlN0YWNrPlxuICAgICAgICAgIDxUZXh0SGVhZGxpbmUgYXM9XCJoMVwiIHRhYkluZGV4PXswfSBzcGFjaW5nQm90dG9tPXswLjV9PlxuICAgICAgICAgICAge2Zvcm1hdE1lc3NhZ2UobWVzc2FnZXMudGl0bGUpfVxuICAgICAgICAgIDwvVGV4dEhlYWRsaW5lPlxuICAgICAgICAgIDxCb3ggYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRMZWdhbCBhcz1cInNwYW5cIiBjb2xvcj1cImZvcmVncm91bmRNdXRlZFwiPlxuICAgICAgICAgICAgICB7Zm9ybWF0TWVzc2FnZShcbiAgICAgICAgICAgICAgICBpc1Jldm9rZU9wZXJhdGlvbiA/IG1lc3NhZ2VzLmRhcHBVcmxSZXZva2VUZXh0IDogbWVzc2FnZXMuZGFwcFVybFJlcXVlc3RUZXh0LFxuICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgIGRhcHBVUkw6IChcbiAgICAgICAgICAgICAgICAgICAgPFRleHRMZWdhbFxuICAgICAgICAgICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgICAgICAgICAgY29sb3I9XCJmb3JlZ3JvdW5kXCJcbiAgICAgICAgICAgICAgICAgICAgICBrZXk9XCJkb21haW4tbmFtZS1zdHlsZVwiXG4gICAgICAgICAgICAgICAgICAgICAgdGVzdElEPVwic3Vic2NyaXB0aW9uLWJvbGQtdGV4dFwiXG4gICAgICAgICAgICAgICAgICAgICAgb3ZlcmZsb3c9XCJicmVha1wiXG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICB7ZGFwcE5hbWV9XG4gICAgICAgICAgICAgICAgICAgIDwvVGV4dExlZ2FsPlxuICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICApfVxuICAgICAgICAgICAgPC9UZXh0TGVnYWw+XG4gICAgICAgICAgICA8VG9vbHRpcCBjb250ZW50PXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLmhlYWRlclRvb3RsdGlwKX0gcGxhY2VtZW50PVwiYm90dG9tXCI+XG4gICAgICAgICAgICAgIDxJY29uIG5hbWU9XCJpbmZvXCIgc2l6ZT1cInhzXCIgY29sb3I9XCJmb3JlZ3JvdW5kTXV0ZWRcIiBzcGFjaW5nU3RhcnQ9ezF9IC8+XG4gICAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICAgPC9Cb3g+XG4gICAgICAgIDwvVlN0YWNrPlxuICAgICAgPC9IU3RhY2s+XG4gICAgPC9Cb3g+XG4gICk7XG59XG5cbmV4cG9ydCBjb25zdCBEYXBwVHhSZXF1ZXN0SGVhZGVyID0gbWVtbyhEYXBwVHhIZWFkZXJEZXRhaWwpO1xuXG5jb25zdCBuZXR3b3JrQmFkZ2UgPSBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgYm90dG9tOiAwO1xuICByaWdodDogMDtcbiAgd2lkdGg6IDE2cHg7XG4gIGhlaWdodDogMTZweDtcbiAgbGVmdDogMjBweDtcbiAgdG9wOiAyMnB4O1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG5gO1xuIl19*/
.dsem9bc{margin:0 8px 0 0;color:var(--foreground-muted);font-size:16px;}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../libs/wallet-cds-extension/components/TxDetails/TxDetailRow.tsx"],"names":[".dsem9bc"],"mappings":"AA6SMA","file":"../../libs/wallet-cds-extension/components/TxDetails/TxDetailRow.tsx","sourcesContent":["import { useMemo } from 'react';\nimport { defineMessages, useIntl } from 'react-intl';\nimport { css } from '@linaria/core';\nimport { TransactionDetailRowItem } from 'cb-wallet-data/hooks/Swap/useTransactionDetailRowItems/useTransactionDetailRowItems';\nimport { abridgeAddress } from 'cb-wallet-data/utils/abridgeAddress';\nimport { AssetIcon } from 'wallet-cds-extension/components/AssetIcon/AssetIcon';\nimport { Icon } from '@cbhq/cds-web/icons/Icon';\nimport { Box, Fallback, HStack, VStack } from '@cbhq/cds-web/layout';\nimport { Tooltip } from '@cbhq/cds-web/overlays/Tooltip/Tooltip';\nimport { PressableOpacity } from '@cbhq/cds-web/system';\nimport {\n  Link,\n  TextBody,\n  TextCaption,\n  TextHeadline,\n  TextLabel2,\n  TextLegal,\n} from '@cbhq/cds-web/typography';\n\nimport { OutlineBox } from '../OutlineBox';\n\nconst messages = defineMessages({\n  coinbaseFeeDiscountPercentage: {\n    defaultMessage: '{discountPercentage}% off',\n    description: 'Label for transaction detail row displaying the account creation fee',\n  },\n  contractAddressA11yLabel: {\n    defaultMessage: '{contractAddress} opens new window',\n    description: 'Contract Address accessibility label',\n  },\n});\n\nexport function TxDetailRow({\n  label,\n  subLabel,\n  subLabelIcon,\n  detailText,\n  detailTextPreFormatted,\n  subDetailText,\n  tooltipText,\n  tooltipObject,\n  tooltipDetailText,\n  detailTextLabel,\n  warningTooltipText,\n  actionIcon,\n  testID,\n  detailTextVariant = 'textBody',\n  withWarning = false,\n  outlineDetailText,\n  detailTextColor = 'foregroundMuted',\n  detailTextIcon,\n  loadingLabelNode,\n  loadingDetailTextNode,\n  keyLabel,\n  tooltipAccessibilityLabel,\n}: TransactionDetailRowItem) {\n  const { formatMessage } = useIntl();\n\n  const textDetail = useMemo(() => {\n    const TextComponent = detailTextVariant === 'textHeadline' ? TextHeadline : TextBody;\n    const detailTextString = typeof detailText === 'string' ? detailText : undefined;\n    const detailTextContractAddress = typeof detailText !== 'string' ? detailText : undefined;\n\n    if (detailTextString || detailTextPreFormatted) {\n      if (withWarning) {\n        return (\n          <>\n            <TextComponent\n              as=\"div\"\n              align=\"end\"\n              tabIndex={0}\n              color=\"negative\"\n              testID={`${testID}-details`}\n            >\n              {detailTextPreFormatted || detailTextString}\n            </TextComponent>\n\n            <Box justifyContent=\"flex-end\" alignItems=\"center\">\n              <Icon\n                testID={`${testID}-warning-detail-tooltip-icon`}\n                name=\"warning\"\n                size=\"s\"\n                color=\"negative\"\n                spacingStart={1}\n              />\n            </Box>\n          </>\n        );\n      }\n\n      return (\n        <HStack gap={1} alignItems=\"center\">\n          {detailTextIcon ? <AssetIcon asset={detailTextIcon} size=\"24x24\" /> : null}\n          {detailTextLabel ? (\n            <Box\n              spacingHorizontal={1}\n              borderRadius=\"rounded\"\n              background=\"positive\"\n              width={75}\n              justifyContent=\"center\"\n              alignItems=\"center\"\n            >\n              <TextCaption as=\"p\" align=\"center\" color=\"primaryForeground\" tabIndex={0}>\n                {formatMessage(messages.coinbaseFeeDiscountPercentage, {\n                  discountPercentage: detailTextLabel,\n                })}\n              </TextCaption>\n            </Box>\n          ) : null}\n\n          <TextComponent\n            as=\"div\"\n            align=\"end\"\n            tabIndex={0}\n            color={detailTextColor}\n            testID={`${testID}-details`}\n          >\n            {detailTextString || detailTextPreFormatted}\n          </TextComponent>\n        </HStack>\n      );\n    }\n\n    if (detailTextContractAddress) {\n      return (\n        <HStack alignItems=\"center\">\n          <Link\n            to={detailTextContractAddress.blockExplorerUrl}\n            openInNewWindow\n            accessibilityLabel={formatMessage(messages.contractAddressA11yLabel, {\n              contractAddress: abridgeAddress(detailTextContractAddress.text),\n            })}\n          >\n            <HStack>\n              <p className={detailTextClass} data-testid={`${testID}-details`}>\n                {abridgeAddress(detailTextContractAddress.text)}\n              </p>\n              <Box tabIndex={-1}>\n                <Icon name=\"externalLink\" color=\"foreground\" size=\"s\" />\n              </Box>\n            </HStack>\n          </Link>\n        </HStack>\n      );\n    }\n    return <></>;\n  }, [\n    detailTextVariant,\n    detailText,\n    detailTextPreFormatted,\n    withWarning,\n    detailTextIcon,\n    detailTextLabel,\n    formatMessage,\n    detailTextColor,\n    testID,\n  ]);\n\n  const tooltipContent = useMemo(() => {\n    if (tooltipObject?.message) {\n      return <TextLegal as=\"p\">{tooltipObject?.message}</TextLegal>;\n    }\n  }, [tooltipObject]);\n\n  const textDetailContent = loadingDetailTextNode ? (\n    <Fallback width={100} height={25} testID={`${testID}-text-detail-loader`} />\n  ) : (\n    textDetail\n  );\n  return (\n    <VStack key={keyLabel || label} spacingVertical={1} position=\"relative\" width=\"100%\">\n      <HStack justifyContent=\"space-between\" alignItems=\"center\">\n        <HStack justifyContent=\"flex-start\" alignItems=\"center\">\n          {loadingLabelNode ? (\n            <Fallback width={125} height={25} testID={`${testID}-label-loader`} />\n          ) : (\n            <TextBody testID={testID} as=\"p\" tabIndex={-1}>\n              {label}\n            </TextBody>\n          )}\n          {tooltipText ? (\n            <Tooltip testID={`${testID}-tooltip`} content={tooltipText} placement=\"bottom\">\n              <PressableOpacity accessibilityLabel={tooltipAccessibilityLabel}>\n                <Icon\n                  testID={`${testID}-tooltip-icon`}\n                  name=\"info\"\n                  size=\"xs\"\n                  color=\"foregroundMuted\"\n                  spacingStart={1}\n                />\n              </PressableOpacity>\n            </Tooltip>\n          ) : null}\n          {tooltipContent ? (\n            <Tooltip placement=\"bottom\" testID={`${testID}-tooltip`} content={tooltipContent}>\n              <Icon\n                testID={`${testID}-tooltip-icon`}\n                name=\"info\"\n                size=\"xs\"\n                color=\"foregroundMuted\"\n                spacingStart={1}\n              />\n            </Tooltip>\n          ) : null}\n          {warningTooltipText ? (\n            <Tooltip\n              testID={`${testID}-warning-tooltip`}\n              content={warningTooltipText}\n              placement=\"right\"\n            >\n              <Icon\n                testID={`${testID}-warning-tooltip-icon`}\n                name=\"warning\"\n                size=\"xs\"\n                color=\"negative\"\n                spacingStart={1}\n              />\n            </Tooltip>\n          ) : null}\n        </HStack>\n        <HStack justifyContent=\"flex-end\" alignItems=\"center\">\n          {tooltipDetailText ? (\n            <Tooltip\n              testID={`${testID}-tooltipDetail`}\n              content={tooltipDetailText}\n              placement=\"bottom\"\n            >\n              {withWarning ? (\n                <>\n                  <TextBody testID={`${testID}-details`} as=\"p\" align=\"end\" color=\"negative\">\n                    {typeof detailText === 'string' ? detailText : detailText?.text}\n                  </TextBody>\n\n                  <Box justifyContent=\"flex-end\" alignItems=\"center\">\n                    <Icon\n                      testID={`${testID}-warning-detail-tooltip-icon`}\n                      name=\"warning\"\n                      size=\"s\"\n                      color=\"negative\"\n                      spacingStart={1}\n                    />\n                  </Box>\n                </>\n              ) : (\n                textDetail\n              )}\n            </Tooltip>\n          ) : (\n            textDetailContent\n          )}\n          {actionIcon}\n        </HStack>\n      </HStack>\n\n      {Boolean(outlineDetailText) && (\n        <HStack spacingTop={3}>\n          <OutlineBox>\n            <TextLabel2\n              as=\"p\"\n              color=\"negative\"\n              spacingVertical={1}\n              spacingHorizontal={1}\n              tabIndex={0}\n            >\n              {outlineDetailText}\n            </TextLabel2>\n          </OutlineBox>\n        </HStack>\n      )}\n\n      {Boolean(subLabel || subDetailText) && (\n        <HStack justifyContent=\"space-between\" alignItems=\"center\">\n          <HStack justifyContent=\"flex-start\" alignItems=\"center\">\n            {subLabelIcon ?? null}\n            {typeof subLabel === 'string' ? (\n              <TextLegal testID={`${testID}-sublabel`} as=\"p\" tabIndex={0} color=\"foregroundMuted\">\n                {subLabel}\n              </TextLegal>\n            ) : (\n              subLabel\n            )}\n          </HStack>\n          <HStack justifyContent=\"flex-end\" alignItems=\"center\">\n            {subDetailText && (\n              <TextLegal\n                testID={`${testID}-details`}\n                as=\"p\"\n                align=\"end\"\n                color=\"foregroundMuted\"\n                tabIndex={0}\n              >\n                {subDetailText}\n              </TextLegal>\n            )}\n          </HStack>\n        </HStack>\n      )}\n    </VStack>\n  );\n}\n\nconst detailTextClass = css`\n  margin: 0 8px 0 0;\n  color: var(--foreground-muted);\n  font-size: 16px;\n`;\n"]}*/
.h10vhxwd::-webkit-scrollbar{display:none;}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../libs/wallet-cds-extension/components/TxDetails/TxDetails.tsx"],"names":[".h10vhxwd"],"mappings":"AAgUaA","file":"../../libs/wallet-cds-extension/components/TxDetails/TxDetails.tsx","sourcesContent":["import { memo, ReactElement, ReactNode, useEffect, useMemo } from 'react';\nimport { defineMessages, useIntl } from 'react-intl';\nimport { css } from '@linaria/core';\nimport { ChainDetails } from 'cb-wallet-analytics/swap';\nimport { DappInfo } from 'cb-wallet-data/chains/AccountBased/shared/types/DappInfo';\nimport { ButtonPropsType } from 'cb-wallet-data/hooks/Swap/useTransactionDetailButtons/useTransactionDetailButtons';\nimport {\n  RowType,\n  TransactionDetailRowItem,\n} from 'cb-wallet-data/hooks/Swap/useTransactionDetailRowItems/useTransactionDetailRowItems';\nimport { TransactionDetailsError } from 'cb-wallet-data/hooks/transactionDetailsErrorTypes';\nimport { useOnMount } from 'cb-wallet-data/hooks/useOnMount';\nimport { GenerateTransactionsError } from 'cb-wallet-data/stores/Swap/hooks/useGenerateTransactions';\nimport { CategorizedParsedOperations } from 'cb-wallet-data/stores/TxScanner/interfaces/ScanTxResult';\nimport { PERF_MARKS, SWAP_MARKS, toExtensionName } from 'cb-wallet-data/utils/perf-constants';\nimport { ButtonProps } from 'reakit/ts';\nimport { NavBar } from 'wallet-cds-extension/components/Header/NavBar';\nimport { RefreshCountdown } from 'wallet-cds-extension/components/RefreshCountdown';\nimport { Screen } from 'wallet-cds-extension/components/Screen/Screen';\nimport { SigningAddressHeader } from 'wallet-cds-extension/components/SigningAddressHeader/SigningAddressHeader';\nimport { WarningBanner } from 'wallet-cds-extension/components/WarningBanner/WarningBanner';\nimport { useExtensionPerfMark } from 'wallet-cds-extension/hooks/useExtensionPerfMark/useExtensionPerfMark';\nimport { DimensionValue, IconName } from '@cbhq/cds-common';\nimport { Button, ButtonGroup } from '@cbhq/cds-web/buttons';\nimport { Icon } from '@cbhq/cds-web/icons';\nimport { Box, Divider, HStack, VStack } from '@cbhq/cds-web/layout';\nimport { PressableOpacity } from '@cbhq/cds-web/system';\nimport { TextHeadline, TextLabel2 } from '@cbhq/cds-web/typography';\n\nimport { DappTxRequestHeader } from './DappTxRequestHeader';\nimport { NetworkFeeRow } from './NetworkFeeRow';\nimport { SlippageRow } from './SlippageRow';\nimport { TxDetailError } from './TxDetailError';\nimport { TxDetailRow } from './TxDetailRow';\n\nconst messages = defineMessages({\n  error: {\n    defaultMessage: 'Something went wrong. Try again.',\n    description: 'A general error occurred',\n  },\n  warning: {\n    defaultMessage:\n      'The dapp is requesting an action which would take money from your wallet. Make sure you trust this site.',\n    description: 'Transaction Warning for the user.',\n  },\n});\n\nexport type TxDetailsProps = {\n  headerText: string;\n  chainDetails: ChainDetails;\n  subHeaderText?: string;\n  headerAction?: ReactElement;\n  topSection: ReactNode;\n  detailRowItems: TransactionDetailRowItem[];\n  disableBackBtn?: boolean;\n  handleBackButton?: () => void;\n  error?: TransactionDetailsError;\n  infoBanner?: ReactNode;\n  buttonProps?: ButtonPropsType[];\n  buttonPropsAdditional?: ButtonPropsType;\n  onPrimaryButtonDisabled?: (error: { errorType: string }) => void;\n  showTransactionWarning?: boolean;\n  advancedDetailsSection?: ReactNode;\n  dappInfo?: DappInfo;\n  shouldRenderTxPreviewHeader?: boolean;\n  isTxScannerEnabled?: boolean;\n  isRevokeOperation?: boolean;\n  txScannerData?: CategorizedParsedOperations;\n  signingAddressToDisplay?: string;\n  height?: DimensionValue;\n  signAndSubmitError?: null | GenerateTransactionsError;\n  headerIcon?: IconName;\n  headerDappName?: string;\n  hideNavbarInHeader?: boolean;\n  faqSection?: ReactNode;\n};\n\nexport function TxDetails({\n  signAndSubmitError,\n  showTransactionWarning,\n  headerText,\n  chainDetails,\n  subHeaderText,\n  headerAction,\n  topSection,\n  detailRowItems,\n  error,\n  infoBanner,\n  buttonProps,\n  buttonPropsAdditional,\n  handleBackButton,\n  onPrimaryButtonDisabled,\n  advancedDetailsSection,\n  dappInfo,\n  shouldRenderTxPreviewHeader,\n  isRevokeOperation,\n  signingAddressToDisplay,\n  height,\n  headerIcon,\n  headerDappName,\n  hideNavbarInHeader,\n  faqSection,\n  isTxScannerEnabled,\n}: TxDetailsProps) {\n  const { formatMessage } = useIntl();\n  const { end: markEndLoadPreviewPerf } = useExtensionPerfMark(\n    toExtensionName(PERF_MARKS.swap),\n    SWAP_MARKS.load_preview,\n    {\n      logMetric: true,\n    },\n  );\n\n  const isAdvancedTransaction = !!advancedDetailsSection;\n\n  const showFooterDivider = useMemo(() => {\n    return !(showTransactionWarning || signAndSubmitError || error || infoBanner);\n  }, [error, signAndSubmitError, infoBanner, showTransactionWarning]);\n\n  useEffect(\n    function perfMarkEnd() {\n      if (!error) markEndLoadPreviewPerf();\n    },\n    [error, markEndLoadPreviewPerf],\n  );\n\n  const additionalDetailRowBottomSpacing = useMemo(() => {\n    return infoBanner && error ? 8 : undefined;\n  }, [error, infoBanner]);\n\n  return (\n    <Screen\n      height={height}\n      header={\n        hideNavbarInHeader ? undefined : (\n          <NavBar\n            variant=\"secondary\"\n            title={headerText}\n            handleBack={handleBackButton}\n            actions={headerAction}\n          />\n        )\n      }\n      footer={\n        <VStack background=\"background\" width=\"100%\">\n          {showTransactionWarning && (\n            <WarningBanner\n              testID=\"txn-warning\"\n              isDismissible\n              spacingBottom={1}\n              message={formatMessage(messages.warning)}\n            />\n          )}\n          {signAndSubmitError && (\n            <TxDetailError\n              chainDetails={chainDetails}\n              message={signAndSubmitError.message ?? formatMessage(messages.error)}\n              isDismissible={false}\n              showErrorIcon\n            />\n          )}\n          {error && (\n            <TxDetailError\n              chainDetails={chainDetails}\n              isDismissible={error.isDismissible}\n              showErrorIcon={error.showErrorIcon}\n              message={error.message}\n              learnMore={error.learnMore}\n            />\n          )}\n          {infoBanner}\n          <VStack\n            spacingHorizontal={3}\n            spacingBottom={2}\n            gap={2}\n            borderedTop={showFooterDivider || isAdvancedTransaction}\n          >\n            <TxDetailsButtonGroup\n              buttonProps={buttonProps}\n              buttonPropsAdditional={buttonPropsAdditional}\n              onPrimaryButtonDisabled={onPrimaryButtonDisabled}\n              error={error}\n            />\n          </VStack>\n        </VStack>\n      }\n    >\n      {Boolean(signingAddressToDisplay) && (\n        <VStack alignItems=\"stretch\" width=\"100%\">\n          <SigningAddressHeader address={signingAddressToDisplay!} />\n        </VStack>\n      )}\n      <VStack spacingHorizontal={isTxScannerEnabled ? undefined : 3} spacingBottom={6} flexGrow={1}>\n        {shouldRenderTxPreviewHeader && (\n          <DappTxRequestHeader\n            dappInfo={dappInfo!}\n            icon={headerIcon}\n            headerDappName={headerDappName}\n            isRevokeOperation={isRevokeOperation}\n          />\n        )}\n        <VStack spacingBottom={error ? 10 : 0} flexGrow={1}>\n          {subHeaderText ? (\n            <TextLabel2 as=\"p\" align=\"center\" spacingBottom={1} tabIndex={0}>\n              {subHeaderText}\n            </TextLabel2>\n          ) : null}\n\n          {Boolean(shouldRenderTxPreviewHeader) && topSection}\n\n          <VStack flexGrow={1} offsetHorizontal={3} spacingHorizontal={3}>\n            {!shouldRenderTxPreviewHeader && topSection}\n\n            <VStack\n              spacingVertical={2}\n              spacingHorizontal={shouldRenderTxPreviewHeader ? 3 : undefined}\n              spacingBottom={additionalDetailRowBottomSpacing}\n            >\n              {detailRowItems.map((rowItem) => {\n                switch (rowItem.rowType) {\n                  case RowType.SLIPPAGE:\n                    return <SlippageRow key={rowItem.label || rowItem.keyLabel} {...rowItem} />;\n\n                  case RowType.NETWORK_FEE:\n                    return <NetworkFeeRow key={rowItem.label || rowItem.keyLabel} {...rowItem} />;\n\n                  default:\n                    return (\n                      <TxDetailRow\n                        key={rowItem.label || rowItem.keyLabel}\n                        {...rowItem}\n                        subLabel={\n                          rowItem.lastUpdateTime ? (\n                            <RefreshCountdown\n                              lastUpdateTime={rowItem.lastUpdateTime}\n                              isPageLoading={Boolean(rowItem.isPageLoading)}\n                            />\n                          ) : (\n                            rowItem.subLabel\n                          )\n                        }\n                      />\n                    );\n                }\n              })}\n            </VStack>\n            {faqSection}\n            {isAdvancedTransaction ? (\n              <>\n                <Divider direction=\"horizontal\" spacingTop={2} />\n                <Box spacingTop={2} spacingBottom={8}>\n                  {advancedDetailsSection}\n                </Box>\n              </>\n            ) : null}\n          </VStack>\n        </VStack>\n      </VStack>\n    </Screen>\n  );\n}\n\ntype TransactionDetailsButtonGroupProps = Pick<\n  TxDetailsProps,\n  'buttonProps' | 'buttonPropsAdditional' | 'onPrimaryButtonDisabled' | 'error'\n>;\n\nconst TxDetailsButtonGroup = memo(\n  ({\n    buttonProps,\n    buttonPropsAdditional,\n    onPrimaryButtonDisabled,\n    error,\n  }: TransactionDetailsButtonGroupProps) => {\n    useOnMount(function triggerAnalyticsForPrimaryButtonDisabled() {\n      if (!buttonProps || buttonProps.length === 0) return;\n\n      if (buttonProps[1]?.disabled) {\n        onPrimaryButtonDisabled?.({\n          errorType: error?.type ?? '',\n        });\n      }\n    });\n\n    if (!buttonProps || buttonProps.length === 0) return null;\n\n    return (\n      <VStack spacingTop={2} gap={2}>\n        {buttonPropsAdditional ? (\n          <PressableOpacity onPress={buttonPropsAdditional.onPress as any}>\n            <HStack gap={1} spacing={2} width=\"100%\" justifyContent=\"center\" alignItems=\"center\">\n              <TextHeadline\n                as=\"p\"\n                color=\"foregroundMuted\"\n                align=\"center\"\n                testID={buttonPropsAdditional.testID}\n              >\n                {buttonPropsAdditional.children}\n              </TextHeadline>\n              <Icon name=\"externalLink\" size=\"s\" color=\"foregroundMuted\" />\n            </HStack>\n          </PressableOpacity>\n        ) : null}\n        <ButtonGroup accessibilityLabel=\"Group\" block>\n          {buttonProps.map(({ children, ...rest }, index) => {\n            return (\n              <Button\n                key={typeof children === 'string' ? children : `transaction-details-${index}`}\n                {...(rest as ButtonProps)}\n              >\n                {children}\n              </Button>\n            );\n          })}\n        </ButtonGroup>\n      </VStack>\n    );\n  },\n);\n\nexport const hideVerticalScrollClassName = css`\n  &::-webkit-scrollbar {\n    display: none;\n  }\n`;\n"]}*/

/*# sourceMappingURL=6123.css.map*/