#modalDialog{border-radius:0;height:100%;padding:0;width:90vw;max-width:1280px}@media(max-width: 414px){#modalDialog{width:100%;height:100vh;max-height:100%;-webkit-transform:translate(-50%, -50%);transform:translate(-50%, -50%)}}#modalDialog .modalDialogContent{height:100%}#modalDialog .modalDialogContent #twp-close-button{position:absolute;right:28px;top:28px;min-width:unset;width:15px;height:15px;z-index:1}#modalDialog .modalDialogContent #twp-close-button svg>path{color:#000}#modalDialog #modal-iframe{height:100%;padding-bottom:0;width:100%}#modalDialog #modal-dialog-close-button{position:absolute;right:16px;top:10px;transform:scale(1.68, 1.68);z-index:1}#modalDialog .hideIframe{display:none}#modalDialog .modalLoader{width:100%;height:100%;position:absolute;display:flex;top:0px;left:0px;align-items:center;justify-content:center;display:flex;flex-direction:column}#modalDialog .modal-busy-text{color:var(--spectrum-global-color-gray-800);font-size:1rem;margin-top:1.25rem}#modalDialog.modal-request-access{height:500px;width:500px}@media(max-width: 414px){#modalDialog.modal-request-access{width:100%;height:100vh}}#modalDialog.modal-webinar{height:608px;width:580px}#modalDialog.cme1-modal,#modalDialog.twp-modal{max-height:850px;width:100%;border-radius:20px;overflow:hidden}#modalDialog.twp-modal{max-width:1024px}@media(min-width: 415px){#modalDialog.cme1-modal,#modalDialog.twp-modal{top:52%}}@media(max-width: 1023px){#modalDialog.cme1-modal,#modalDialog.twp-modal{border-radius:0;max-height:100vh;min-height:-webkit-fill-available;height:100%}}
.legalTermsDialogContainer{max-width:36.25rem;min-width:21.25rem}.legalTermsDialogContainer .linkText{margin-bottom:.25rem;color:#0d66d0}.legalTermsDialogContainer .linkText span:hover{cursor:pointer;text-decoration:underline}.legalTermsDialogContainer .copyRightHeader{margin-top:1rem}.legalTermsDialogContainer .copyRightText{margin-top:1rem}
.K8HMpl_iTMi6CKwcCInK{min-width:20rem}.SP9eTo0rB76xZ1s585ny{width:100%}.e6mkV8f7EfUujN2V4fC1{margin-top:1.5rem}
.rdmDialog{background:#fff !important;border-radius:0;width:640px;height:376px}.rdmDialog .rdmDialogContent{height:100%;width:100%;overflow:auto}.rdmDialog .rdmDialogContent .modalLoader{width:100%;height:100%;position:absolute;display:flex;top:0px;left:0px;align-items:center;justify-content:center;display:flex;flex-direction:column}.rdmDialog--dark{background:#000 !important}
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._tc92 {
    flex-direction: row;
  }


  .qe92 {
    column-gap: 0.5rem;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJtYXBwaW5ncyI6IkFBb0N1QjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXMiOlsiLi4vLi4vYXBwbGV0cy9vbmJvYXJkaW5nL3NyYy92aWV3L2NvbXBvbmVudHMvQ2FyZHNTZWN0aW9uL0NhcmRCdXR0b25Hcm91cC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBBRE9CRSBDT05GSURFTlRJQUxcbiAqXG4gKiBDb3B5cmlnaHQgMjAyNSBBZG9iZVxuICogQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBOT1RJQ0U6ICBBbGwgaW5mb3JtYXRpb24gY29udGFpbmVkIGhlcmVpbiBpcywgYW5kIHJlbWFpbnNcbiAqIHRoZSBwcm9wZXJ0eSBvZiBBZG9iZSBhbmQgaXRzIHN1cHBsaWVycywgaWYgYW55LiBUaGUgaW50ZWxsZWN0dWFsXG4gKiBhbmQgdGVjaG5pY2FsIGNvbmNlcHRzIGNvbnRhaW5lZCBoZXJlaW4gYXJlIHByb3ByaWV0YXJ5IHRvIEFkb2JlXG4gKiBhbmQgaXRzIHN1cHBsaWVycyBhbmQgYXJlIHByb3RlY3RlZCBieSBhbGwgYXBwbGljYWJsZSBpbnRlbGxlY3R1YWxcbiAqIHByb3BlcnR5IGxhd3MsIGluY2x1ZGluZyB0cmFkZSBzZWNyZXQgYW5kIGNvcHlyaWdodCBsYXdzLlxuICogRGlzc2VtaW5hdGlvbiBvZiB0aGlzIGluZm9ybWF0aW9uIG9yIHJlcHJvZHVjdGlvbiBvZiB0aGlzIG1hdGVyaWFsXG4gKiBpcyBzdHJpY3RseSBmb3JiaWRkZW4gdW5sZXNzIHByaW9yIHdyaXR0ZW4gcGVybWlzc2lvbiBpcyBvYnRhaW5lZFxuICogZnJvbSBBZG9iZS5cbiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG5pbXBvcnQge0J1dHRvbn0gZnJvbSAnQHJlYWN0LXNwZWN0cnVtL3MyJztcbmltcG9ydCB7c3R5bGV9IGZyb20gJ0ByZWFjdC1zcGVjdHJ1bS9zMi9zdHlsZScgd2l0aCB7dHlwZTogJ21hY3JvJ307XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHtwYXJzZVN0eWxlfSBmcm9tICcuLi8uLi8uLi91dGlsL3V0aWxzJztcbmltcG9ydCB7QXBwc1VybH0gZnJvbSAnLi4vLi4vLi4vdXRpbC90eXBlcyc7XG5cbnR5cGUgQ2FyZEJ1dHRvbkdyb3VwUHJvcHMgPSB7XG5cdGFjdGlvbkxpc3Q6IEFwcHNVcmxbXSB8IG51bGw7XG5cdGNhcmRJRDogc3RyaW5nO1xuXHRvbkFjdGlvbjogKGFjdGlvbjogQXBwc1VybCwgY2FyZElEOiBzdHJpbmcpID0+IHZvaWQ7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBDYXJkQnV0dG9uR3JvdXAoe1xuXHRhY3Rpb25MaXN0LFxuXHRjYXJkSUQsXG5cdG9uQWN0aW9uLFxufTogQ2FyZEJ1dHRvbkdyb3VwUHJvcHMpOiBKU1guRWxlbWVudCB8IG51bGwge1xuXHQvLyBSZW5kZXIgb25seSBpZiBhY3Rpb25MaXN0IGlzIG5vdCBudWxsIGFuZCBoYXMgYXQgbGVhc3Qgb25lIGFjdGlvblxuXHRyZXR1cm4gYWN0aW9uTGlzdCAmJiBhY3Rpb25MaXN0Lmxlbmd0aCA+IDAgPyAoXG5cdFx0PGRpdlxuXHRcdFx0Y2xhc3NOYW1lPXtzdHlsZSh7XG5cdFx0XHRcdGRpc3BsYXk6ICdmbGV4Jyxcblx0XHRcdFx0ZmxleERpcmVjdGlvbjogJ3JvdycsXG5cdFx0XHRcdGNvbHVtbkdhcDogOCxcblx0XHRcdH0pfVxuXHRcdD5cblx0XHRcdHthY3Rpb25MaXN0Lm1hcCgoYWN0aW9uLCBidG5JbmRleCkgPT4ge1xuXHRcdFx0XHQvLyBQYXJzZSBzdHlsZSBwcm9wZXJ0aWVzIGZvciB0aGUgYnV0dG9uXG5cdFx0XHRcdGNvbnN0IHtcblx0XHRcdFx0XHR2YXJpYW50ID0gYnRuSW5kZXggPT09IDAgPyAnYWNjZW50JyA6ICdwcmltYXJ5JywgLy8gRGVmYXVsdCB2YXJpYW50IGJhc2VkIG9uIGluZGV4XG5cdFx0XHRcdFx0dHJlYXRtZW50ID0gYnRuSW5kZXggPT09IDAgPyAnZmlsbCcgOiAnb3V0bGluZScsIC8vIERlZmF1bHQgdHJlYXRtZW50IHN0eWxlXG5cdFx0XHRcdH0gPSBwYXJzZVN0eWxlKGFjdGlvbi5zdHlsZSBhcyBzdHJpbmcpO1xuXHRcdFx0XHRyZXR1cm4gKFxuXHRcdFx0XHRcdDxCdXR0b25cblx0XHRcdFx0XHRcdGtleT17YCR7YWN0aW9uLm5hbWV9LSR7YnRuSW5kZXh9YH1cblx0XHRcdFx0XHRcdHZhcmlhbnQ9e3ZhcmlhbnR9XG5cdFx0XHRcdFx0XHRmaWxsU3R5bGU9e3RyZWF0bWVudH1cblx0XHRcdFx0XHRcdG9uUHJlc3M9eygpID0+IHtcblx0XHRcdFx0XHRcdFx0Ly8gSGFuZGxlIGFjdGlvbiBjbGlja1xuXHRcdFx0XHRcdFx0XHRvbkFjdGlvbihhY3Rpb24sIGNhcmRJRCk7XG5cdFx0XHRcdFx0XHR9fVxuXHRcdFx0XHRcdFx0VU5TQUZFX3N0eWxlPXt7Y3Vyc29yOiAncG9pbnRlcid9fVxuXHRcdFx0XHRcdD5cblx0XHRcdFx0XHRcdHsvKiBEaXNwbGF5IGJ1dHRvbiB0aXRsZSAqL31cblx0XHRcdFx0XHRcdHthY3Rpb24ubGFiZWx9XG5cdFx0XHRcdFx0PC9CdXR0b24+XG5cdFx0XHRcdCk7XG5cdFx0XHR9KX1cblx0XHQ8L2Rpdj5cblx0KSA6IG51bGw7IC8vIFJldHVybiBudWxsIGlmIG5vIGFjdGlvbnMgYXJlIHByb3ZpZGVkXG59XG4iXSwibmFtZXMiOltdLCJ2ZXJzaW9uIjozfQ== */
@layer _.a;

@layer _.a {
  .Tt92 {
    padding-top: 8px;
  }


  .Td92 {
    padding-top: 0px;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJtYXBwaW5ncyI6IkFBZ0VrQztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBIiwic291cmNlcyI6WyIuLi8uLi9hcHBsZXRzL29uYm9hcmRpbmcvc3JjL3ZpZXcvY29tcG9uZW50cy9DYXJkc1NlY3Rpb24vQ2FyZEluZm9TZWN0aW9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAqIEFET0JFIENPTkZJREVOVElBTFxuICpcbiAqIENvcHlyaWdodCAyMDI1IEFkb2JlXG4gKiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIE5PVElDRTogIEFsbCBpbmZvcm1hdGlvbiBjb250YWluZWQgaGVyZWluIGlzLCBhbmQgcmVtYWluc1xuICogdGhlIHByb3BlcnR5IG9mIEFkb2JlIGFuZCBpdHMgc3VwcGxpZXJzLCBpZiBhbnkuIFRoZSBpbnRlbGxlY3R1YWxcbiAqIGFuZCB0ZWNobmljYWwgY29uY2VwdHMgY29udGFpbmVkIGhlcmVpbiBhcmUgcHJvcHJpZXRhcnkgdG8gQWRvYmVcbiAqIGFuZCBpdHMgc3VwcGxpZXJzIGFuZCBhcmUgcHJvdGVjdGVkIGJ5IGFsbCBhcHBsaWNhYmxlIGludGVsbGVjdHVhbFxuICogcHJvcGVydHkgbGF3cywgaW5jbHVkaW5nIHRyYWRlIHNlY3JldCBhbmQgY29weXJpZ2h0IGxhd3MuXG4gKiBEaXNzZW1pbmF0aW9uIG9mIHRoaXMgaW5mb3JtYXRpb24gb3IgcmVwcm9kdWN0aW9uIG9mIHRoaXMgbWF0ZXJpYWxcbiAqIGlzIHN0cmljdGx5IGZvcmJpZGRlbiB1bmxlc3MgcHJpb3Igd3JpdHRlbiBwZXJtaXNzaW9uIGlzIG9idGFpbmVkXG4gKiBmcm9tIEFkb2JlLlxuICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbmltcG9ydCB7QWN0aW9ufSBmcm9tICdAbmVzdC9pbnRlcmZhY2UnO1xuaW1wb3J0IHtzdHlsZX0gZnJvbSAnQHJlYWN0LXNwZWN0cnVtL3MyL3N0eWxlJyB3aXRoIHt0eXBlOiAnbWFjcm8nfTtcbmltcG9ydCBSZWFjdCwge3VzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZVJlZn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHtQcm9tb3Rpb259IGZyb20gJy4uLy4uLy4uL3V0aWwvdHlwZXMnO1xuXG50eXBlIENhcmRJbmZvU2VjdGlvblByb3BzID0ge1xuXHRjYXJkSUQ6IHN0cmluZztcblx0ZGVzY3JpcHRpb246IHN0cmluZztcblx0aXNTaWRlTmF2U2hvd246IGJvb2xlYW47XG5cdHByb21vdGlvbjogUHJvbW90aW9uIHwgbnVsbDtcblx0b25Qcm9tb3Rpb25BY3Rpb246IChhY3Rpb246IEFjdGlvbiwgY2FyZElEOiBzdHJpbmcpID0+IHZvaWQ7XG5cdHRpdGxlOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBDYXJkSW5mb1NlY3Rpb24oe1xuXHRjYXJkSUQsXG5cdGRlc2NyaXB0aW9uLFxuXHRpc1NpZGVOYXZTaG93bixcblx0cHJvbW90aW9uLFxuXHRvblByb21vdGlvbkFjdGlvbixcblx0dGl0bGUsXG59OiBDYXJkSW5mb1NlY3Rpb25Qcm9wcyk6IEpTWC5FbGVtZW50IHwgbnVsbCB7XG5cdC8vIFJlZmVyZW5jZSB0byB0aGUgYW5jaG9yIGVsZW1lbnRcblx0Y29uc3QgYW5jaG9yUmVmID0gdXNlUmVmPEhUTUxBbmNob3JFbGVtZW50PihudWxsKTtcblxuXHQvLyBNZW1vaXplIHRoZSBvbkNsaWNrIGhhbmRsZXIgdG8gZW5zdXJlIHN0YWJpbGl0eVxuXHRjb25zdCBvbkNsaWNrID0gdXNlQ2FsbGJhY2soXG5cdFx0KGU6IE1vdXNlRXZlbnQpID0+IHtcblx0XHRcdGUucHJldmVudERlZmF1bHQoKTsgLy8gUHJldmVudCBkZWZhdWx0IGFuY2hvciBjbGljayBiZWhhdmlvclxuXHRcdFx0b25Qcm9tb3Rpb25BY3Rpb24ocHJvbW90aW9uPy5hY3Rpb24gYXMgQWN0aW9uLCBjYXJkSUQpO1xuXHRcdH0sXG5cdFx0W29uUHJvbW90aW9uQWN0aW9uLCBwcm9tb3Rpb24/LmFjdGlvbiwgY2FyZElEXSxcblx0KTtcblxuXHQvLyBBZGQgYW5kIHJlbW92ZSBjbGljayBldmVudCBsaXN0ZW5lciB0byBwcmV2ZW50IGRlZmF1bHQgYmVoYXZpb3Jcblx0dXNlRWZmZWN0KCgpID0+IHtcblx0XHRjb25zdCB0YXJnZXQgPSBhbmNob3JSZWYuY3VycmVudDtcblx0XHRpZiAodGFyZ2V0KSB7XG5cdFx0XHR0YXJnZXQuYWRkRXZlbnRMaXN0ZW5lcignY2xpY2snLCBvbkNsaWNrKTtcblx0XHR9XG5cblx0XHRyZXR1cm4gKCkgPT4ge1xuXHRcdFx0dGFyZ2V0Py5yZW1vdmVFdmVudExpc3RlbmVyKCdjbGljaycsIG9uQ2xpY2spOyAvLyBDbGVhbnVwIGV2ZW50IGxpc3RlbmVyXG5cdFx0fTtcblx0XHQvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgcmVhY3QtaG9va3MvZXhoYXVzdGl2ZS1kZXBzXG5cdH0sIFtdKTtcblxuXHQvLyBEZWZpbmUgc3R5bGVzIGZvciB0aGUgYWN0aXZhdGlvbiBtb2RhbFxuXHRjb25zdCBhY3RpdmF0aW9uTW9kYWxTdHlsZXMgPSBzdHlsZSh7XG5cdFx0cGFkZGluZ1RvcDoge1xuXHRcdFx0ZGVmYXVsdDogOCxcblx0XHRcdGlzU2lkZU5hdlNob3duOiAwLFxuXHRcdH0sXG5cdH0pO1xuXG5cdHJldHVybiAoXG5cdFx0PGRpdiBjbGFzc05hbWU9e3N0eWxlKHtmb250OiAnYm9keSd9KX0gc3R5bGU9e3tvdmVyZmxvd1dyYXA6ICdicmVhay13b3JkJ319PlxuXHRcdFx0ey8qIFJlbmRlciB0aGUgdGl0bGUgKi99XG5cdFx0XHQ8ZGl2IGNsYXNzTmFtZT17c3R5bGUoe21hcmdpblk6IDAsIGZvbnQ6ICd0aXRsZS1sZyd9KX0+e3RpdGxlfTwvZGl2PlxuXG5cdFx0XHR7LyogUmVuZGVyIHRoZSBkZXNjcmlwdGlvbiB3aXRoIGNvbmRpdGlvbmFsIHBhZGRpbmcgKi99XG5cdFx0XHQ8ZGl2IGNsYXNzTmFtZT17YWN0aXZhdGlvbk1vZGFsU3R5bGVzKHtpc1NpZGVOYXZTaG93bn0pfT5cblx0XHRcdFx0e2Rlc2NyaXB0aW9ufVxuXHRcdFx0PC9kaXY+XG5cblx0XHRcdHsvKiBSZW5kZXIgcHJvbW90aW9uIGRldGFpbHMgaWYgYXZhaWxhYmxlICovfVxuXHRcdFx0e3Byb21vdGlvbiAmJiAoXG5cdFx0XHRcdDxkaXZcblx0XHRcdFx0XHRjbGFzc05hbWU9e3N0eWxlKHtcblx0XHRcdFx0XHRcdGRpc3BsYXk6ICdmbGV4Jyxcblx0XHRcdFx0XHRcdGZsZXhEaXJlY3Rpb246ICdyb3cnLFxuXHRcdFx0XHRcdFx0Y29sdW1uR2FwOiA0LFxuXHRcdFx0XHRcdH0pfVxuXHRcdFx0XHQ+XG5cdFx0XHRcdFx0ey8qIFJlbmRlciBwcm9tb3Rpb24gZW5kIHRleHQgKi99XG5cdFx0XHRcdFx0e3Byb21vdGlvbi5lbmRUZXh0ICYmIDxkaXY+e3Byb21vdGlvbi5lbmRUZXh0fTwvZGl2Pn1cblxuXHRcdFx0XHRcdHsvKiBSZW5kZXIgcHJvbW90aW9uIGFjdGlvbiBsaW5rIGlmIGF2YWlsYWJsZSAqL31cblx0XHRcdFx0XHR7cHJvbW90aW9uLmFjdGlvbj8udGl0bGUgJiYgKFxuXHRcdFx0XHRcdFx0PGFcblx0XHRcdFx0XHRcdFx0aHJlZj17cHJvbW90aW9uLmFjdGlvbi50YXJnZXR9XG5cdFx0XHRcdFx0XHRcdHJlZj17YW5jaG9yUmVmfVxuXHRcdFx0XHRcdFx0XHRhcmlhLWxhYmVsPXtwcm9tb3Rpb24uYWN0aW9uLnRpdGxlfVxuXHRcdFx0XHRcdFx0PlxuXHRcdFx0XHRcdFx0XHR7cHJvbW90aW9uLmFjdGlvbi50aXRsZX0gey8qIERpc3BsYXkgcHJvbW90aW9uIGFjdGlvbiB0aXRsZSAqL31cblx0XHRcdFx0XHRcdDwvYT5cblx0XHRcdFx0XHQpfVxuXHRcdFx0XHQ8L2Rpdj5cblx0XHRcdCl9XG5cdFx0PC9kaXY+XG5cdCk7XG59XG4iXSwibmFtZXMiOltdLCJ2ZXJzaW9uIjozfQ== */
@layer _.a, _.b, _.c, _.d, _.e, _.f, _.g, _.h;

@layer _.a {
  .ug92 {
    font-family: adobe-clean-variable, adobe-clean, ui-sans-serif, system-ui, sans-serif;
  }


  .vp92 {
    font-size: 1rem;
  }


  .wb92 {
    font-variation-settings: "wght" 400;
  }


  .xb92 {
    font-weight: 400;
  }


  ._xa92 {
    font-synthesis-weight: none;
  }


  ._Fb92 {
    line-height: 1.5;
  }


  .pt92 {
    color: light-dark(rgb(41, 41, 41), rgb(219, 219, 219));
  }
}

@layer _.b {
  .uch92:lang(ar) {
    font-family: myriad-arabic, ui-sans-serif, system-ui, sans-serif;
  }


  ._Ffc92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    line-height: 1.7;
  }
}

@layer _.c {
  .udi92:lang(he) {
    font-family: myriad-hebrew, ui-sans-serif, system-ui, sans-serif;
  }
}

@layer _.d {
  .uea92:lang(ja) {
    font-family: adobe-clean-han-japanese, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Osaka, YuGothic, 'Yu Gothic', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  }
}

@layer _.e {
  .ugb92:lang(ko) {
    font-family: adobe-clean-han-korean, source-han-korean, 'Malgun Gothic', 'Apple Gothic', sans-serif;
  }
}

@layer _.f {
  .uhd92:lang(zh) {
    font-family: adobe-clean-han-traditional, source-han-traditional, 'MingLiu', 'Heiti TC Light', sans-serif;
  }
}

@layer _.g {
  .uje92:lang(zh-hant) {
    font-family: adobe-clean-han-traditional, source-han-traditional, 'MingLiu', 'Microsoft JhengHei UI', 'Microsoft JhengHei', 'Heiti TC Light', sans-serif;
  }
}

@layer _.h {
  .uic92:lang(zh-Hans, zh-CN, zh-SG) {
    font-family: adobe-clean-han-simplified-c, source-han-simplified-c, 'SimSun', 'Heiti SC Light', sans-serif;
  }
}

@layer _.b.s {
  @media not ((hover: hover) and (pointer: fine)) {
    .vsh92 {
      font-size: 1.1875rem;
    }
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJtYXBwaW5ncyI6IkFBd0V3QjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXMiOlsiLi4vLi4vYXBwbGV0cy9vbmJvYXJkaW5nL3NyYy92aWV3L2NvbXBvbmVudHMvQ2FyZHNTZWN0aW9uL0NhcmRJbmZvU2VjdGlvbi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBBRE9CRSBDT05GSURFTlRJQUxcbiAqXG4gKiBDb3B5cmlnaHQgMjAyNSBBZG9iZVxuICogQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBOT1RJQ0U6ICBBbGwgaW5mb3JtYXRpb24gY29udGFpbmVkIGhlcmVpbiBpcywgYW5kIHJlbWFpbnNcbiAqIHRoZSBwcm9wZXJ0eSBvZiBBZG9iZSBhbmQgaXRzIHN1cHBsaWVycywgaWYgYW55LiBUaGUgaW50ZWxsZWN0dWFsXG4gKiBhbmQgdGVjaG5pY2FsIGNvbmNlcHRzIGNvbnRhaW5lZCBoZXJlaW4gYXJlIHByb3ByaWV0YXJ5IHRvIEFkb2JlXG4gKiBhbmQgaXRzIHN1cHBsaWVycyBhbmQgYXJlIHByb3RlY3RlZCBieSBhbGwgYXBwbGljYWJsZSBpbnRlbGxlY3R1YWxcbiAqIHByb3BlcnR5IGxhd3MsIGluY2x1ZGluZyB0cmFkZSBzZWNyZXQgYW5kIGNvcHlyaWdodCBsYXdzLlxuICogRGlzc2VtaW5hdGlvbiBvZiB0aGlzIGluZm9ybWF0aW9uIG9yIHJlcHJvZHVjdGlvbiBvZiB0aGlzIG1hdGVyaWFsXG4gKiBpcyBzdHJpY3RseSBmb3JiaWRkZW4gdW5sZXNzIHByaW9yIHdyaXR0ZW4gcGVybWlzc2lvbiBpcyBvYnRhaW5lZFxuICogZnJvbSBBZG9iZS5cbiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG5pbXBvcnQge0FjdGlvbn0gZnJvbSAnQG5lc3QvaW50ZXJmYWNlJztcbmltcG9ydCB7c3R5bGV9IGZyb20gJ0ByZWFjdC1zcGVjdHJ1bS9zMi9zdHlsZScgd2l0aCB7dHlwZTogJ21hY3JvJ307XG5pbXBvcnQgUmVhY3QsIHt1c2VDYWxsYmFjaywgdXNlRWZmZWN0LCB1c2VSZWZ9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7UHJvbW90aW9ufSBmcm9tICcuLi8uLi8uLi91dGlsL3R5cGVzJztcblxudHlwZSBDYXJkSW5mb1NlY3Rpb25Qcm9wcyA9IHtcblx0Y2FyZElEOiBzdHJpbmc7XG5cdGRlc2NyaXB0aW9uOiBzdHJpbmc7XG5cdGlzU2lkZU5hdlNob3duOiBib29sZWFuO1xuXHRwcm9tb3Rpb246IFByb21vdGlvbiB8IG51bGw7XG5cdG9uUHJvbW90aW9uQWN0aW9uOiAoYWN0aW9uOiBBY3Rpb24sIGNhcmRJRDogc3RyaW5nKSA9PiB2b2lkO1xuXHR0aXRsZTogc3RyaW5nO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gQ2FyZEluZm9TZWN0aW9uKHtcblx0Y2FyZElELFxuXHRkZXNjcmlwdGlvbixcblx0aXNTaWRlTmF2U2hvd24sXG5cdHByb21vdGlvbixcblx0b25Qcm9tb3Rpb25BY3Rpb24sXG5cdHRpdGxlLFxufTogQ2FyZEluZm9TZWN0aW9uUHJvcHMpOiBKU1guRWxlbWVudCB8IG51bGwge1xuXHQvLyBSZWZlcmVuY2UgdG8gdGhlIGFuY2hvciBlbGVtZW50XG5cdGNvbnN0IGFuY2hvclJlZiA9IHVzZVJlZjxIVE1MQW5jaG9yRWxlbWVudD4obnVsbCk7XG5cblx0Ly8gTWVtb2l6ZSB0aGUgb25DbGljayBoYW5kbGVyIHRvIGVuc3VyZSBzdGFiaWxpdHlcblx0Y29uc3Qgb25DbGljayA9IHVzZUNhbGxiYWNrKFxuXHRcdChlOiBNb3VzZUV2ZW50KSA9PiB7XG5cdFx0XHRlLnByZXZlbnREZWZhdWx0KCk7IC8vIFByZXZlbnQgZGVmYXVsdCBhbmNob3IgY2xpY2sgYmVoYXZpb3Jcblx0XHRcdG9uUHJvbW90aW9uQWN0aW9uKHByb21vdGlvbj8uYWN0aW9uIGFzIEFjdGlvbiwgY2FyZElEKTtcblx0XHR9LFxuXHRcdFtvblByb21vdGlvbkFjdGlvbiwgcHJvbW90aW9uPy5hY3Rpb24sIGNhcmRJRF0sXG5cdCk7XG5cblx0Ly8gQWRkIGFuZCByZW1vdmUgY2xpY2sgZXZlbnQgbGlzdGVuZXIgdG8gcHJldmVudCBkZWZhdWx0IGJlaGF2aW9yXG5cdHVzZUVmZmVjdCgoKSA9PiB7XG5cdFx0Y29uc3QgdGFyZ2V0ID0gYW5jaG9yUmVmLmN1cnJlbnQ7XG5cdFx0aWYgKHRhcmdldCkge1xuXHRcdFx0dGFyZ2V0LmFkZEV2ZW50TGlzdGVuZXIoJ2NsaWNrJywgb25DbGljayk7XG5cdFx0fVxuXG5cdFx0cmV0dXJuICgpID0+IHtcblx0XHRcdHRhcmdldD8ucmVtb3ZlRXZlbnRMaXN0ZW5lcignY2xpY2snLCBvbkNsaWNrKTsgLy8gQ2xlYW51cCBldmVudCBsaXN0ZW5lclxuXHRcdH07XG5cdFx0Ly8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0LWhvb2tzL2V4aGF1c3RpdmUtZGVwc1xuXHR9LCBbXSk7XG5cblx0Ly8gRGVmaW5lIHN0eWxlcyBmb3IgdGhlIGFjdGl2YXRpb24gbW9kYWxcblx0Y29uc3QgYWN0aXZhdGlvbk1vZGFsU3R5bGVzID0gc3R5bGUoe1xuXHRcdHBhZGRpbmdUb3A6IHtcblx0XHRcdGRlZmF1bHQ6IDgsXG5cdFx0XHRpc1NpZGVOYXZTaG93bjogMCxcblx0XHR9LFxuXHR9KTtcblxuXHRyZXR1cm4gKFxuXHRcdDxkaXYgY2xhc3NOYW1lPXtzdHlsZSh7Zm9udDogJ2JvZHknfSl9IHN0eWxlPXt7b3ZlcmZsb3dXcmFwOiAnYnJlYWstd29yZCd9fT5cblx0XHRcdHsvKiBSZW5kZXIgdGhlIHRpdGxlICovfVxuXHRcdFx0PGRpdiBjbGFzc05hbWU9e3N0eWxlKHttYXJnaW5ZOiAwLCBmb250OiAndGl0bGUtbGcnfSl9Pnt0aXRsZX08L2Rpdj5cblxuXHRcdFx0ey8qIFJlbmRlciB0aGUgZGVzY3JpcHRpb24gd2l0aCBjb25kaXRpb25hbCBwYWRkaW5nICovfVxuXHRcdFx0PGRpdiBjbGFzc05hbWU9e2FjdGl2YXRpb25Nb2RhbFN0eWxlcyh7aXNTaWRlTmF2U2hvd259KX0+XG5cdFx0XHRcdHtkZXNjcmlwdGlvbn1cblx0XHRcdDwvZGl2PlxuXG5cdFx0XHR7LyogUmVuZGVyIHByb21vdGlvbiBkZXRhaWxzIGlmIGF2YWlsYWJsZSAqL31cblx0XHRcdHtwcm9tb3Rpb24gJiYgKFxuXHRcdFx0XHQ8ZGl2XG5cdFx0XHRcdFx0Y2xhc3NOYW1lPXtzdHlsZSh7XG5cdFx0XHRcdFx0XHRkaXNwbGF5OiAnZmxleCcsXG5cdFx0XHRcdFx0XHRmbGV4RGlyZWN0aW9uOiAncm93Jyxcblx0XHRcdFx0XHRcdGNvbHVtbkdhcDogNCxcblx0XHRcdFx0XHR9KX1cblx0XHRcdFx0PlxuXHRcdFx0XHRcdHsvKiBSZW5kZXIgcHJvbW90aW9uIGVuZCB0ZXh0ICovfVxuXHRcdFx0XHRcdHtwcm9tb3Rpb24uZW5kVGV4dCAmJiA8ZGl2Pntwcm9tb3Rpb24uZW5kVGV4dH08L2Rpdj59XG5cblx0XHRcdFx0XHR7LyogUmVuZGVyIHByb21vdGlvbiBhY3Rpb24gbGluayBpZiBhdmFpbGFibGUgKi99XG5cdFx0XHRcdFx0e3Byb21vdGlvbi5hY3Rpb24/LnRpdGxlICYmIChcblx0XHRcdFx0XHRcdDxhXG5cdFx0XHRcdFx0XHRcdGhyZWY9e3Byb21vdGlvbi5hY3Rpb24udGFyZ2V0fVxuXHRcdFx0XHRcdFx0XHRyZWY9e2FuY2hvclJlZn1cblx0XHRcdFx0XHRcdFx0YXJpYS1sYWJlbD17cHJvbW90aW9uLmFjdGlvbi50aXRsZX1cblx0XHRcdFx0XHRcdD5cblx0XHRcdFx0XHRcdFx0e3Byb21vdGlvbi5hY3Rpb24udGl0bGV9IHsvKiBEaXNwbGF5IHByb21vdGlvbiBhY3Rpb24gdGl0bGUgKi99XG5cdFx0XHRcdFx0XHQ8L2E+XG5cdFx0XHRcdFx0KX1cblx0XHRcdFx0PC9kaXY+XG5cdFx0XHQpfVxuXHRcdDwvZGl2PlxuXHQpO1xufVxuIl0sIm5hbWVzIjpbXSwidmVyc2lvbiI6M30= */
@layer _.a, _.b, _.c, _.d, _.e, _.f, _.g, _.h;

@layer _.a {
  .Jy92 {
    margin-top: 0rem;
  }


  .Gy92 {
    margin-bottom: 0rem;
  }


  .ug92 {
    font-family: adobe-clean-variable, adobe-clean, ui-sans-serif, system-ui, sans-serif;
  }


  .vg92 {
    font-size: 1.125rem;
  }


  .wd92 {
    font-variation-settings: "wght" 700;
  }


  .xd92 {
    font-weight: 700;
  }


  ._xa92 {
    font-synthesis-weight: none;
  }


  ._Fa92 {
    line-height: 1.3;
  }


  .po92 {
    color: light-dark(rgb(19, 19, 19), rgb(242, 242, 242));
  }
}

@layer _.b {
  .uch92:lang(ar) {
    font-family: myriad-arabic, ui-sans-serif, system-ui, sans-serif;
  }


  .wfd92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    font-variation-settings: "wght" 700;
  }


  .xfd92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    font-weight: 700;
  }


  ._xfa92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    font-synthesis-weight: none;
  }


  ._Ffb92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    line-height: 1.5;
  }
}

@layer _.c {
  .udi92:lang(he) {
    font-family: myriad-hebrew, ui-sans-serif, system-ui, sans-serif;
  }
}

@layer _.d {
  .uea92:lang(ja) {
    font-family: adobe-clean-han-japanese, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Osaka, YuGothic, 'Yu Gothic', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  }
}

@layer _.e {
  .ugb92:lang(ko) {
    font-family: adobe-clean-han-korean, source-han-korean, 'Malgun Gothic', 'Apple Gothic', sans-serif;
  }
}

@layer _.f {
  .uhd92:lang(zh) {
    font-family: adobe-clean-han-traditional, source-han-traditional, 'MingLiu', 'Heiti TC Light', sans-serif;
  }
}

@layer _.g {
  .uje92:lang(zh-hant) {
    font-family: adobe-clean-han-traditional, source-han-traditional, 'MingLiu', 'Microsoft JhengHei UI', 'Microsoft JhengHei', 'Heiti TC Light', sans-serif;
  }
}

@layer _.h {
  .uic92:lang(zh-Hans, zh-CN, zh-SG) {
    font-family: adobe-clean-han-simplified-c, source-han-simplified-c, 'SimSun', 'Heiti SC Light', sans-serif;
  }
}

@layer _.b.s {
  @media not ((hover: hover) and (pointer: fine)) {
    .vsj92 {
      font-size: 1.375rem;
    }
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJtYXBwaW5ncyI6IkFBMEU0QjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBIiwic291cmNlcyI6WyIuLi8uLi9hcHBsZXRzL29uYm9hcmRpbmcvc3JjL3ZpZXcvY29tcG9uZW50cy9DYXJkc1NlY3Rpb24vQ2FyZEluZm9TZWN0aW9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAqIEFET0JFIENPTkZJREVOVElBTFxuICpcbiAqIENvcHlyaWdodCAyMDI1IEFkb2JlXG4gKiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIE5PVElDRTogIEFsbCBpbmZvcm1hdGlvbiBjb250YWluZWQgaGVyZWluIGlzLCBhbmQgcmVtYWluc1xuICogdGhlIHByb3BlcnR5IG9mIEFkb2JlIGFuZCBpdHMgc3VwcGxpZXJzLCBpZiBhbnkuIFRoZSBpbnRlbGxlY3R1YWxcbiAqIGFuZCB0ZWNobmljYWwgY29uY2VwdHMgY29udGFpbmVkIGhlcmVpbiBhcmUgcHJvcHJpZXRhcnkgdG8gQWRvYmVcbiAqIGFuZCBpdHMgc3VwcGxpZXJzIGFuZCBhcmUgcHJvdGVjdGVkIGJ5IGFsbCBhcHBsaWNhYmxlIGludGVsbGVjdHVhbFxuICogcHJvcGVydHkgbGF3cywgaW5jbHVkaW5nIHRyYWRlIHNlY3JldCBhbmQgY29weXJpZ2h0IGxhd3MuXG4gKiBEaXNzZW1pbmF0aW9uIG9mIHRoaXMgaW5mb3JtYXRpb24gb3IgcmVwcm9kdWN0aW9uIG9mIHRoaXMgbWF0ZXJpYWxcbiAqIGlzIHN0cmljdGx5IGZvcmJpZGRlbiB1bmxlc3MgcHJpb3Igd3JpdHRlbiBwZXJtaXNzaW9uIGlzIG9idGFpbmVkXG4gKiBmcm9tIEFkb2JlLlxuICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbmltcG9ydCB7QWN0aW9ufSBmcm9tICdAbmVzdC9pbnRlcmZhY2UnO1xuaW1wb3J0IHtzdHlsZX0gZnJvbSAnQHJlYWN0LXNwZWN0cnVtL3MyL3N0eWxlJyB3aXRoIHt0eXBlOiAnbWFjcm8nfTtcbmltcG9ydCBSZWFjdCwge3VzZUNhbGxiYWNrLCB1c2VFZmZlY3QsIHVzZVJlZn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHtQcm9tb3Rpb259IGZyb20gJy4uLy4uLy4uL3V0aWwvdHlwZXMnO1xuXG50eXBlIENhcmRJbmZvU2VjdGlvblByb3BzID0ge1xuXHRjYXJkSUQ6IHN0cmluZztcblx0ZGVzY3JpcHRpb246IHN0cmluZztcblx0aXNTaWRlTmF2U2hvd246IGJvb2xlYW47XG5cdHByb21vdGlvbjogUHJvbW90aW9uIHwgbnVsbDtcblx0b25Qcm9tb3Rpb25BY3Rpb246IChhY3Rpb246IEFjdGlvbiwgY2FyZElEOiBzdHJpbmcpID0+IHZvaWQ7XG5cdHRpdGxlOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBDYXJkSW5mb1NlY3Rpb24oe1xuXHRjYXJkSUQsXG5cdGRlc2NyaXB0aW9uLFxuXHRpc1NpZGVOYXZTaG93bixcblx0cHJvbW90aW9uLFxuXHRvblByb21vdGlvbkFjdGlvbixcblx0dGl0bGUsXG59OiBDYXJkSW5mb1NlY3Rpb25Qcm9wcyk6IEpTWC5FbGVtZW50IHwgbnVsbCB7XG5cdC8vIFJlZmVyZW5jZSB0byB0aGUgYW5jaG9yIGVsZW1lbnRcblx0Y29uc3QgYW5jaG9yUmVmID0gdXNlUmVmPEhUTUxBbmNob3JFbGVtZW50PihudWxsKTtcblxuXHQvLyBNZW1vaXplIHRoZSBvbkNsaWNrIGhhbmRsZXIgdG8gZW5zdXJlIHN0YWJpbGl0eVxuXHRjb25zdCBvbkNsaWNrID0gdXNlQ2FsbGJhY2soXG5cdFx0KGU6IE1vdXNlRXZlbnQpID0+IHtcblx0XHRcdGUucHJldmVudERlZmF1bHQoKTsgLy8gUHJldmVudCBkZWZhdWx0IGFuY2hvciBjbGljayBiZWhhdmlvclxuXHRcdFx0b25Qcm9tb3Rpb25BY3Rpb24ocHJvbW90aW9uPy5hY3Rpb24gYXMgQWN0aW9uLCBjYXJkSUQpO1xuXHRcdH0sXG5cdFx0W29uUHJvbW90aW9uQWN0aW9uLCBwcm9tb3Rpb24/LmFjdGlvbiwgY2FyZElEXSxcblx0KTtcblxuXHQvLyBBZGQgYW5kIHJlbW92ZSBjbGljayBldmVudCBsaXN0ZW5lciB0byBwcmV2ZW50IGRlZmF1bHQgYmVoYXZpb3Jcblx0dXNlRWZmZWN0KCgpID0+IHtcblx0XHRjb25zdCB0YXJnZXQgPSBhbmNob3JSZWYuY3VycmVudDtcblx0XHRpZiAodGFyZ2V0KSB7XG5cdFx0XHR0YXJnZXQuYWRkRXZlbnRMaXN0ZW5lcignY2xpY2snLCBvbkNsaWNrKTtcblx0XHR9XG5cblx0XHRyZXR1cm4gKCkgPT4ge1xuXHRcdFx0dGFyZ2V0Py5yZW1vdmVFdmVudExpc3RlbmVyKCdjbGljaycsIG9uQ2xpY2spOyAvLyBDbGVhbnVwIGV2ZW50IGxpc3RlbmVyXG5cdFx0fTtcblx0XHQvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgcmVhY3QtaG9va3MvZXhoYXVzdGl2ZS1kZXBzXG5cdH0sIFtdKTtcblxuXHQvLyBEZWZpbmUgc3R5bGVzIGZvciB0aGUgYWN0aXZhdGlvbiBtb2RhbFxuXHRjb25zdCBhY3RpdmF0aW9uTW9kYWxTdHlsZXMgPSBzdHlsZSh7XG5cdFx0cGFkZGluZ1RvcDoge1xuXHRcdFx0ZGVmYXVsdDogOCxcblx0XHRcdGlzU2lkZU5hdlNob3duOiAwLFxuXHRcdH0sXG5cdH0pO1xuXG5cdHJldHVybiAoXG5cdFx0PGRpdiBjbGFzc05hbWU9e3N0eWxlKHtmb250OiAnYm9keSd9KX0gc3R5bGU9e3tvdmVyZmxvd1dyYXA6ICdicmVhay13b3JkJ319PlxuXHRcdFx0ey8qIFJlbmRlciB0aGUgdGl0bGUgKi99XG5cdFx0XHQ8ZGl2IGNsYXNzTmFtZT17c3R5bGUoe21hcmdpblk6IDAsIGZvbnQ6ICd0aXRsZS1sZyd9KX0+e3RpdGxlfTwvZGl2PlxuXG5cdFx0XHR7LyogUmVuZGVyIHRoZSBkZXNjcmlwdGlvbiB3aXRoIGNvbmRpdGlvbmFsIHBhZGRpbmcgKi99XG5cdFx0XHQ8ZGl2IGNsYXNzTmFtZT17YWN0aXZhdGlvbk1vZGFsU3R5bGVzKHtpc1NpZGVOYXZTaG93bn0pfT5cblx0XHRcdFx0e2Rlc2NyaXB0aW9ufVxuXHRcdFx0PC9kaXY+XG5cblx0XHRcdHsvKiBSZW5kZXIgcHJvbW90aW9uIGRldGFpbHMgaWYgYXZhaWxhYmxlICovfVxuXHRcdFx0e3Byb21vdGlvbiAmJiAoXG5cdFx0XHRcdDxkaXZcblx0XHRcdFx0XHRjbGFzc05hbWU9e3N0eWxlKHtcblx0XHRcdFx0XHRcdGRpc3BsYXk6ICdmbGV4Jyxcblx0XHRcdFx0XHRcdGZsZXhEaXJlY3Rpb246ICdyb3cnLFxuXHRcdFx0XHRcdFx0Y29sdW1uR2FwOiA0LFxuXHRcdFx0XHRcdH0pfVxuXHRcdFx0XHQ+XG5cdFx0XHRcdFx0ey8qIFJlbmRlciBwcm9tb3Rpb24gZW5kIHRleHQgKi99XG5cdFx0XHRcdFx0e3Byb21vdGlvbi5lbmRUZXh0ICYmIDxkaXY+e3Byb21vdGlvbi5lbmRUZXh0fTwvZGl2Pn1cblxuXHRcdFx0XHRcdHsvKiBSZW5kZXIgcHJvbW90aW9uIGFjdGlvbiBsaW5rIGlmIGF2YWlsYWJsZSAqL31cblx0XHRcdFx0XHR7cHJvbW90aW9uLmFjdGlvbj8udGl0bGUgJiYgKFxuXHRcdFx0XHRcdFx0PGFcblx0XHRcdFx0XHRcdFx0aHJlZj17cHJvbW90aW9uLmFjdGlvbi50YXJnZXR9XG5cdFx0XHRcdFx0XHRcdHJlZj17YW5jaG9yUmVmfVxuXHRcdFx0XHRcdFx0XHRhcmlhLWxhYmVsPXtwcm9tb3Rpb24uYWN0aW9uLnRpdGxlfVxuXHRcdFx0XHRcdFx0PlxuXHRcdFx0XHRcdFx0XHR7cHJvbW90aW9uLmFjdGlvbi50aXRsZX0gey8qIERpc3BsYXkgcHJvbW90aW9uIGFjdGlvbiB0aXRsZSAqL31cblx0XHRcdFx0XHRcdDwvYT5cblx0XHRcdFx0XHQpfVxuXHRcdFx0XHQ8L2Rpdj5cblx0XHRcdCl9XG5cdFx0PC9kaXY+XG5cdCk7XG59XG4iXSwibmFtZXMiOltdLCJ2ZXJzaW9uIjozfQ== */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._tc92 {
    flex-direction: row;
  }


  .qb92 {
    column-gap: 0.25rem;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJtYXBwaW5ncyI6IkFBb0YrQjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXMiOlsiLi4vLi4vYXBwbGV0cy9vbmJvYXJkaW5nL3NyYy92aWV3L2NvbXBvbmVudHMvQ2FyZHNTZWN0aW9uL0NhcmRJbmZvU2VjdGlvbi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBBRE9CRSBDT05GSURFTlRJQUxcbiAqXG4gKiBDb3B5cmlnaHQgMjAyNSBBZG9iZVxuICogQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBOT1RJQ0U6ICBBbGwgaW5mb3JtYXRpb24gY29udGFpbmVkIGhlcmVpbiBpcywgYW5kIHJlbWFpbnNcbiAqIHRoZSBwcm9wZXJ0eSBvZiBBZG9iZSBhbmQgaXRzIHN1cHBsaWVycywgaWYgYW55LiBUaGUgaW50ZWxsZWN0dWFsXG4gKiBhbmQgdGVjaG5pY2FsIGNvbmNlcHRzIGNvbnRhaW5lZCBoZXJlaW4gYXJlIHByb3ByaWV0YXJ5IHRvIEFkb2JlXG4gKiBhbmQgaXRzIHN1cHBsaWVycyBhbmQgYXJlIHByb3RlY3RlZCBieSBhbGwgYXBwbGljYWJsZSBpbnRlbGxlY3R1YWxcbiAqIHByb3BlcnR5IGxhd3MsIGluY2x1ZGluZyB0cmFkZSBzZWNyZXQgYW5kIGNvcHlyaWdodCBsYXdzLlxuICogRGlzc2VtaW5hdGlvbiBvZiB0aGlzIGluZm9ybWF0aW9uIG9yIHJlcHJvZHVjdGlvbiBvZiB0aGlzIG1hdGVyaWFsXG4gKiBpcyBzdHJpY3RseSBmb3JiaWRkZW4gdW5sZXNzIHByaW9yIHdyaXR0ZW4gcGVybWlzc2lvbiBpcyBvYnRhaW5lZFxuICogZnJvbSBBZG9iZS5cbiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG5pbXBvcnQge0FjdGlvbn0gZnJvbSAnQG5lc3QvaW50ZXJmYWNlJztcbmltcG9ydCB7c3R5bGV9IGZyb20gJ0ByZWFjdC1zcGVjdHJ1bS9zMi9zdHlsZScgd2l0aCB7dHlwZTogJ21hY3JvJ307XG5pbXBvcnQgUmVhY3QsIHt1c2VDYWxsYmFjaywgdXNlRWZmZWN0LCB1c2VSZWZ9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7UHJvbW90aW9ufSBmcm9tICcuLi8uLi8uLi91dGlsL3R5cGVzJztcblxudHlwZSBDYXJkSW5mb1NlY3Rpb25Qcm9wcyA9IHtcblx0Y2FyZElEOiBzdHJpbmc7XG5cdGRlc2NyaXB0aW9uOiBzdHJpbmc7XG5cdGlzU2lkZU5hdlNob3duOiBib29sZWFuO1xuXHRwcm9tb3Rpb246IFByb21vdGlvbiB8IG51bGw7XG5cdG9uUHJvbW90aW9uQWN0aW9uOiAoYWN0aW9uOiBBY3Rpb24sIGNhcmRJRDogc3RyaW5nKSA9PiB2b2lkO1xuXHR0aXRsZTogc3RyaW5nO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gQ2FyZEluZm9TZWN0aW9uKHtcblx0Y2FyZElELFxuXHRkZXNjcmlwdGlvbixcblx0aXNTaWRlTmF2U2hvd24sXG5cdHByb21vdGlvbixcblx0b25Qcm9tb3Rpb25BY3Rpb24sXG5cdHRpdGxlLFxufTogQ2FyZEluZm9TZWN0aW9uUHJvcHMpOiBKU1guRWxlbWVudCB8IG51bGwge1xuXHQvLyBSZWZlcmVuY2UgdG8gdGhlIGFuY2hvciBlbGVtZW50XG5cdGNvbnN0IGFuY2hvclJlZiA9IHVzZVJlZjxIVE1MQW5jaG9yRWxlbWVudD4obnVsbCk7XG5cblx0Ly8gTWVtb2l6ZSB0aGUgb25DbGljayBoYW5kbGVyIHRvIGVuc3VyZSBzdGFiaWxpdHlcblx0Y29uc3Qgb25DbGljayA9IHVzZUNhbGxiYWNrKFxuXHRcdChlOiBNb3VzZUV2ZW50KSA9PiB7XG5cdFx0XHRlLnByZXZlbnREZWZhdWx0KCk7IC8vIFByZXZlbnQgZGVmYXVsdCBhbmNob3IgY2xpY2sgYmVoYXZpb3Jcblx0XHRcdG9uUHJvbW90aW9uQWN0aW9uKHByb21vdGlvbj8uYWN0aW9uIGFzIEFjdGlvbiwgY2FyZElEKTtcblx0XHR9LFxuXHRcdFtvblByb21vdGlvbkFjdGlvbiwgcHJvbW90aW9uPy5hY3Rpb24sIGNhcmRJRF0sXG5cdCk7XG5cblx0Ly8gQWRkIGFuZCByZW1vdmUgY2xpY2sgZXZlbnQgbGlzdGVuZXIgdG8gcHJldmVudCBkZWZhdWx0IGJlaGF2aW9yXG5cdHVzZUVmZmVjdCgoKSA9PiB7XG5cdFx0Y29uc3QgdGFyZ2V0ID0gYW5jaG9yUmVmLmN1cnJlbnQ7XG5cdFx0aWYgKHRhcmdldCkge1xuXHRcdFx0dGFyZ2V0LmFkZEV2ZW50TGlzdGVuZXIoJ2NsaWNrJywgb25DbGljayk7XG5cdFx0fVxuXG5cdFx0cmV0dXJuICgpID0+IHtcblx0XHRcdHRhcmdldD8ucmVtb3ZlRXZlbnRMaXN0ZW5lcignY2xpY2snLCBvbkNsaWNrKTsgLy8gQ2xlYW51cCBldmVudCBsaXN0ZW5lclxuXHRcdH07XG5cdFx0Ly8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0LWhvb2tzL2V4aGF1c3RpdmUtZGVwc1xuXHR9LCBbXSk7XG5cblx0Ly8gRGVmaW5lIHN0eWxlcyBmb3IgdGhlIGFjdGl2YXRpb24gbW9kYWxcblx0Y29uc3QgYWN0aXZhdGlvbk1vZGFsU3R5bGVzID0gc3R5bGUoe1xuXHRcdHBhZGRpbmdUb3A6IHtcblx0XHRcdGRlZmF1bHQ6IDgsXG5cdFx0XHRpc1NpZGVOYXZTaG93bjogMCxcblx0XHR9LFxuXHR9KTtcblxuXHRyZXR1cm4gKFxuXHRcdDxkaXYgY2xhc3NOYW1lPXtzdHlsZSh7Zm9udDogJ2JvZHknfSl9IHN0eWxlPXt7b3ZlcmZsb3dXcmFwOiAnYnJlYWstd29yZCd9fT5cblx0XHRcdHsvKiBSZW5kZXIgdGhlIHRpdGxlICovfVxuXHRcdFx0PGRpdiBjbGFzc05hbWU9e3N0eWxlKHttYXJnaW5ZOiAwLCBmb250OiAndGl0bGUtbGcnfSl9Pnt0aXRsZX08L2Rpdj5cblxuXHRcdFx0ey8qIFJlbmRlciB0aGUgZGVzY3JpcHRpb24gd2l0aCBjb25kaXRpb25hbCBwYWRkaW5nICovfVxuXHRcdFx0PGRpdiBjbGFzc05hbWU9e2FjdGl2YXRpb25Nb2RhbFN0eWxlcyh7aXNTaWRlTmF2U2hvd259KX0+XG5cdFx0XHRcdHtkZXNjcmlwdGlvbn1cblx0XHRcdDwvZGl2PlxuXG5cdFx0XHR7LyogUmVuZGVyIHByb21vdGlvbiBkZXRhaWxzIGlmIGF2YWlsYWJsZSAqL31cblx0XHRcdHtwcm9tb3Rpb24gJiYgKFxuXHRcdFx0XHQ8ZGl2XG5cdFx0XHRcdFx0Y2xhc3NOYW1lPXtzdHlsZSh7XG5cdFx0XHRcdFx0XHRkaXNwbGF5OiAnZmxleCcsXG5cdFx0XHRcdFx0XHRmbGV4RGlyZWN0aW9uOiAncm93Jyxcblx0XHRcdFx0XHRcdGNvbHVtbkdhcDogNCxcblx0XHRcdFx0XHR9KX1cblx0XHRcdFx0PlxuXHRcdFx0XHRcdHsvKiBSZW5kZXIgcHJvbW90aW9uIGVuZCB0ZXh0ICovfVxuXHRcdFx0XHRcdHtwcm9tb3Rpb24uZW5kVGV4dCAmJiA8ZGl2Pntwcm9tb3Rpb24uZW5kVGV4dH08L2Rpdj59XG5cblx0XHRcdFx0XHR7LyogUmVuZGVyIHByb21vdGlvbiBhY3Rpb24gbGluayBpZiBhdmFpbGFibGUgKi99XG5cdFx0XHRcdFx0e3Byb21vdGlvbi5hY3Rpb24/LnRpdGxlICYmIChcblx0XHRcdFx0XHRcdDxhXG5cdFx0XHRcdFx0XHRcdGhyZWY9e3Byb21vdGlvbi5hY3Rpb24udGFyZ2V0fVxuXHRcdFx0XHRcdFx0XHRyZWY9e2FuY2hvclJlZn1cblx0XHRcdFx0XHRcdFx0YXJpYS1sYWJlbD17cHJvbW90aW9uLmFjdGlvbi50aXRsZX1cblx0XHRcdFx0XHRcdD5cblx0XHRcdFx0XHRcdFx0e3Byb21vdGlvbi5hY3Rpb24udGl0bGV9IHsvKiBEaXNwbGF5IHByb21vdGlvbiBhY3Rpb24gdGl0bGUgKi99XG5cdFx0XHRcdFx0XHQ8L2E+XG5cdFx0XHRcdFx0KX1cblx0XHRcdFx0PC9kaXY+XG5cdFx0XHQpfVxuXHRcdDwvZGl2PlxuXHQpO1xufVxuIl0sIm5hbWVzIjpbXSwidmVyc2lvbiI6M30= */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._Ca92 {
    justify-content: center;
  }


  .eb92 {
    align-items: center;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJtYXBwaW5ncyI6IkFBcUJtQjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSIsInNvdXJjZXMiOlsiLi4vLi4vYXBwbGV0cy9vbmJvYXJkaW5nL3NyYy92aWV3L2NvbXBvbmVudHMvQ2FyZHNTZWN0aW9uL0ltYWdlRmFpbHVyZUljb24udHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICogQURPQkUgQ09ORklERU5USUFMXG4gKlxuICogQ29weXJpZ2h0IDIwMjUgQWRvYmVcbiAqIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogTk9USUNFOiAgQWxsIGluZm9ybWF0aW9uIGNvbnRhaW5lZCBoZXJlaW4gaXMsIGFuZCByZW1haW5zXG4gKiB0aGUgcHJvcGVydHkgb2YgQWRvYmUgYW5kIGl0cyBzdXBwbGllcnMsIGlmIGFueS4gVGhlIGludGVsbGVjdHVhbFxuICogYW5kIHRlY2huaWNhbCBjb25jZXB0cyBjb250YWluZWQgaGVyZWluIGFyZSBwcm9wcmlldGFyeSB0byBBZG9iZVxuICogYW5kIGl0cyBzdXBwbGllcnMgYW5kIGFyZSBwcm90ZWN0ZWQgYnkgYWxsIGFwcGxpY2FibGUgaW50ZWxsZWN0dWFsXG4gKiBwcm9wZXJ0eSBsYXdzLCBpbmNsdWRpbmcgdHJhZGUgc2VjcmV0IGFuZCBjb3B5cmlnaHQgbGF3cy5cbiAqIERpc3NlbWluYXRpb24gb2YgdGhpcyBpbmZvcm1hdGlvbiBvciByZXByb2R1Y3Rpb24gb2YgdGhpcyBtYXRlcmlhbFxuICogaXMgc3RyaWN0bHkgZm9yYmlkZGVuIHVubGVzcyBwcmlvciB3cml0dGVuIHBlcm1pc3Npb24gaXMgb2J0YWluZWRcbiAqIGZyb20gQWRvYmUuXG4gKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuaW1wb3J0IHtzdHlsZX0gZnJvbSAnQHJlYWN0LXNwZWN0cnVtL3MyL3N0eWxlJyB3aXRoIHt0eXBlOiAnbWFjcm8nfTtcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5cbmNvbnN0IEltYWdlRmFpbHVyZUljb246IFJlYWN0LkZDID0gKCkgPT4gKFxuXHQ8ZGl2XG5cdFx0Y2xhc3NOYW1lPXtzdHlsZSh7XG5cdFx0XHRkaXNwbGF5OiAnZmxleCcsXG5cdFx0XHRqdXN0aWZ5Q29udGVudDogJ2NlbnRlcicsXG5cdFx0XHRhbGlnbkl0ZW1zOiAnY2VudGVyJyxcblx0XHR9KX1cblx0XHRzdHlsZT17e2hlaWdodDogJzEwMCUnfX1cblx0PlxuXHRcdDxzdmdcblx0XHRcdHhtbG5zPSdodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Zydcblx0XHRcdHdpZHRoPSc3Mi45OTgnXG5cdFx0XHRoZWlnaHQ9Jzc1J1xuXHRcdFx0dmlld0JveD0nMCAwIDcyLjk5OCA3NSdcblx0XHQ+XG5cdFx0XHQ8ZyBpZD0nTGF5ZXJfMicgZGF0YS1uYW1lPSdMYXllciAyJyB0cmFuc2Zvcm09J3RyYW5zbGF0ZSgtNi4wMDMgLTEwKSc+XG5cdFx0XHRcdDxwYXRoXG5cdFx0XHRcdFx0aWQ9J1BhdGhfNidcblx0XHRcdFx0XHRkYXRhLW5hbWU9J1BhdGggNidcblx0XHRcdFx0XHRkPSdNMTguOTU3LDQ1LjU1MmExLDEsMCwwLDEtMS0xVjM5Ljk3M2ExLDEsMCwwLDEsMiwwdjQuNTc5QTEsMSwwLDAsMSwxOC45NTcsNDUuNTUyWidcblx0XHRcdFx0XHRmaWxsPScjYjNiM2IzJ1xuXHRcdFx0XHQvPlxuXHRcdFx0XHQ8Y2lyY2xlXG5cdFx0XHRcdFx0aWQ9J0VsbGlwc2VfMSdcblx0XHRcdFx0XHRkYXRhLW5hbWU9J0VsbGlwc2UgMSdcblx0XHRcdFx0XHRjeD0nMS4yNDMnXG5cdFx0XHRcdFx0Y3k9JzEuMjQzJ1xuXHRcdFx0XHRcdHI9JzEuMjQzJ1xuXHRcdFx0XHRcdHRyYW5zZm9ybT0ndHJhbnNsYXRlKDE3Ljc5MyA0Ny41NDcpJ1xuXHRcdFx0XHRcdGZpbGw9JyNiM2IzYjMnXG5cdFx0XHRcdC8+XG5cdFx0XHRcdDxwYXRoXG5cdFx0XHRcdFx0aWQ9J1BhdGhfNydcblx0XHRcdFx0XHRkYXRhLW5hbWU9J1BhdGggNydcblx0XHRcdFx0XHRkPSdNMjkuMDU5LDU0SDguNjY5YTIuNjY1LDIuNjY1LDAsMCwxLTIuMzA4LTRsMTAuMi0xNy42NzJhMi42NjUsMi42NjUsMCwwLDEsNC42MTUsMEwzMS4zNjYsNTBhMi42NjUsMi42NjUsMCwwLDEtMi4zMDcsNFptLTEwLjItMjEuMDI4YS42NzkuNjc5LDAsMCwwLS42LjM0NWgwTDguMDY4LDUwLjk5YS42OTMuNjkzLDAsMCwwLC42LDEuMDM4aDIwLjM5YS42OTMuNjkzLDAsMCwwLC42LTEuMDM4TDE5LjQ2NCwzMy4zMThhLjY4LjY4LDAsMCwwLS42LS4zNDZabS0xLjQ1My0uMTQ3Widcblx0XHRcdFx0XHRmaWxsPScjYjNiM2IzJ1xuXHRcdFx0XHQvPlxuXHRcdFx0XHQ8ZyBpZD0nZG9jdW1lbnRfYWxlcnRfbGcnIGRhdGEtbmFtZT0nZG9jdW1lbnQgYWxlcnQgbGcnPlxuXHRcdFx0XHRcdDxwYXRoXG5cdFx0XHRcdFx0XHRpZD0nUGF0aF84J1xuXHRcdFx0XHRcdFx0ZGF0YS1uYW1lPSdQYXRoIDgnXG5cdFx0XHRcdFx0XHRkPSdNMjYuMyw4NUE4LjMxLDguMzEsMCwwLDEsMTgsNzYuNzNWNTcuOTY0YTEsMSwwLDAsMSwyLDBWNzYuNzI2QTYuMyw2LjMsMCwwLDAsMjYuMyw4M0g3MC43MjNBNi4zLDYuMywwLDAsMCw3Nyw3Ni42Nzd2LTQ4LjFhNi4zNSw2LjM1LDAsMCwwLTEuODcxLTQuNDU5TDY0LjcyLDEzLjgxOEE2LjI2Nyw2LjI2NywwLDAsMCw2MC4yOSwxMkgyNi4yNzdBNi4zMTEsNi4zMTEsMCwwLDAsMjAsMTguMzIydjguODg3YTEsMSwwLDEsMS0yLDBWMTguMzI2QTguMzA5LDguMzA5LDAsMCwxLDI2LjI3LDEwSDYwLjI5YTguMjQ4LDguMjQ4LDAsMCwxLDUuODM3LDIuNGwxMC40MSwxMC4zQTguMzU4LDguMzU4LDAsMCwxLDc5LDI4LjU2NnY0OC4xQTguMyw4LjMsMCwwLDEsNzAuNzMsODVaJ1xuXHRcdFx0XHRcdFx0ZmlsbD0nI2IzYjNiMydcblx0XHRcdFx0XHQvPlxuXHRcdFx0XHQ8L2c+XG5cdFx0XHRcdDxwYXRoXG5cdFx0XHRcdFx0aWQ9J1BhdGhfOSdcblx0XHRcdFx0XHRkYXRhLW5hbWU9J1BhdGggOSdcblx0XHRcdFx0XHRkPSdNNjMuOTI5LDU1LjU0MWgtLjA3NmE0Ljg4OCw0Ljg4OCwwLDAsMS0zLjQ3OC0xLjUxOSw1LjAxNSw1LjAxNSwwLDAsMSwuMS03LjA1MUE0Ljg1NSw0Ljg1NSwwLDAsMSw2NCw0NS41NTdhNSw1LDAsMCwxLDMuMzcyLDguNTcsNC45LDQuOSwwLDAsMS0zLjQ0MywxLjQxNFptMC04LjQ4NGEzLjQwNywzLjQwNywwLDAsMC0yLjQuOTg0LDMuNTE3LDMuNTE3LDAsMCwwLS4wNzQsNC45NDEsMy40LDMuNCwwLDAsMCwyLjQxOSwxLjA1OGgwYTMuNDkyLDMuNDkyLDAsMSwwLC4xMDYtNi45ODNaJ1xuXHRcdFx0XHRcdGZpbGw9JyNiM2IzYjMnXG5cdFx0XHRcdC8+XG5cdFx0XHRcdDxwYXRoXG5cdFx0XHRcdFx0aWQ9J1BhdGhfMTAnXG5cdFx0XHRcdFx0ZGF0YS1uYW1lPSdQYXRoIDEwJ1xuXHRcdFx0XHRcdGQ9J001Ny45MzEsNzAuOTYzaC0zMC43YS43NS43NSwwLDAsMS0uNTMtMS4yODFsMTUuMjEtMTUuMTUxYTEuNjkzLDEuNjkzLDAsMCwxLDIuNDE1LjAzMUw1OC40NzksNjkuN2EuNzUuNzUsMCwwLDEtLjU0OCwxLjI2MlptLTI4Ljg4OC0xLjVINTYuMkw0My4yMzcsNTUuNTkzYS4xNzQuMTc0LDAsMCwwLS4xMzQtLjA1My4xOTQuMTk0LDAsMCwwLS4xMzcuMDU3Widcblx0XHRcdFx0XHRmaWxsPScjYjNiM2IzJ1xuXHRcdFx0XHQvPlxuXHRcdFx0XHQ8cGF0aFxuXHRcdFx0XHRcdGlkPSdQYXRoXzExJ1xuXHRcdFx0XHRcdGRhdGEtbmFtZT0nUGF0aCAxMSdcblx0XHRcdFx0XHRkPSdNNjAuNSw3MC45NzVhLjc1Ljc1LDAsMCwxLDAtMS41bDUuNTQyLS4wMDktOS4yLTkuOGEuNDEyLjQxMiwwLDAsMC0uMjg1LS4xMTEuNC40LDAsMCwwLS4zLjEwOGwtMi4yNzcsMi4zNWEuNzUzLjc1MywwLDAsMS0xLjA4LTEuMDQ5TDU1LjE5LDU4LjZhMS44NTQsMS44NTQsMCwwLDEsMS4zODEtLjU1LDEuOTIyLDEuOTIyLDAsMCwxLDEuMzUuNTc4TDY4LjMxMiw2OS43YS43NDkuNzQ5LDAsMCwxLS41NDUsMS4yNjNsLTcuMjcxLjAxMlonXG5cdFx0XHRcdFx0ZmlsbD0nI2IzYjNiMydcblx0XHRcdFx0Lz5cblx0XHRcdDwvZz5cblx0XHQ8L3N2Zz5cblx0PC9kaXY+XG4pO1xuZXhwb3J0IGRlZmF1bHQgSW1hZ2VGYWlsdXJlSWNvbjtcbiJdLCJuYW1lcyI6W10sInZlcnNpb24iOjN9 */
@layer _.a;

@layer _.a {
  .oa92 {
    border-start-start-radius: 0.25rem;
  }


  .na92 {
    border-start-end-radius: 0.25rem;
  }


  .ka92 {
    border-end-start-radius: 0.25rem;
  }


  .ja92 {
    border-end-end-radius: 0.25rem;
  }


  .F46M4le92 {
    height: calc(22.5rem * var(--s2-scale));
  }


  .JC92 {
    margin-top: 1rem;
  }


  .GC92 {
    margin-bottom: 1rem;
  }


  ._Hb92 {
    object-fit: cover;
  }


  .sb92 {
    display: block;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AAgFc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .oa92 {
    border-start-start-radius: 0.25rem;
  }


  .na92 {
    border-start-end-radius: 0.25rem;
  }


  .ka92 {
    border-end-start-radius: 0.25rem;
  }


  .ja92 {
    border-end-end-radius: 0.25rem;
  }


  .Li1RGCe92 {
    max-width: calc(32rem * var(--s2-scale));
  }


  .FUAB5h92 {
    height: calc(18rem * var(--s2-scale));
  }


  ._Hb92 {
    object-fit: cover;
  }


  .sb92 {
    display: block;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AAuFc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._ta92 {
    flex-direction: column;
  }


  .Td92 {
    padding-top: 0px;
  }


  .Qk92 {
    padding-bottom: 32px;
  }


  .Sk92 {
    padding-inline-start: 32px;
  }


  .Rk92 {
    padding-inline-end: 32px;
  }


  .Llo4nC92 {
    max-width: calc(40.8125rem * var(--s2-scale));
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AAiI2B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._ta92 {
    flex-direction: column;
  }


  .Uh92 {
    row-gap: 0rem;
  }


  .Uq92 {
    row-gap: 3.5rem;
  }


  .qh92 {
    column-gap: 0rem;
  }


  .qq92 {
    column-gap: 3.5rem;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AA0IyB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .Tk92 {
    padding-top: 32px;
  }


  .Td92 {
    padding-top: 0px;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AAoJ4B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .FI6Ixhb92 {
    height: calc(24.5rem * var(--s2-scale));
  }


  .FUAB5h92 {
    height: calc(18rem * var(--s2-scale));
  }


  .Li1RGCe92 {
    max-width: calc(32rem * var(--s2-scale));
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AA2JgC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._ta92 {
    flex-direction: column;
  }


  .Tt92 {
    padding-top: 8px;
  }


  .Qm92 {
    padding-bottom: 40px;
  }


  .Sm92 {
    padding-inline-start: 40px;
  }


  .Rm92 {
    padding-inline-end: 40px;
  }


  .L9l6Cce92 {
    max-width: calc(37rem * var(--s2-scale));
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AA0KsB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a, _.b, _.c, _.d, _.e, _.f, _.g, _.h;

@layer _.a {
  .ug92 {
    font-family: adobe-clean-variable, adobe-clean, ui-sans-serif, system-ui, sans-serif;
  }


  .vn92 {
    font-size: 1.75rem;
  }


  .we92 {
    font-variation-settings: "wght" 800;
  }


  .xe92 {
    font-weight: 800;
  }


  ._xa92 {
    font-synthesis-weight: none;
  }


  ._Fa92 {
    line-height: 1.3;
  }


  .po92 {
    color: light-dark(rgb(19, 19, 19), rgb(242, 242, 242));
  }


  .Jy92 {
    margin-top: 0rem;
  }


  .Gy92 {
    margin-bottom: 0rem;
  }
}

@layer _.b {
  .uch92:lang(ar) {
    font-family: myriad-arabic, ui-sans-serif, system-ui, sans-serif;
  }


  .wfe92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    font-variation-settings: "wght" 800;
  }


  .xfe92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    font-weight: 800;
  }


  ._xfa92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    font-synthesis-weight: none;
  }


  ._Ffb92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    line-height: 1.5;
  }
}

@layer _.c {
  .udi92:lang(he) {
    font-family: myriad-hebrew, ui-sans-serif, system-ui, sans-serif;
  }
}

@layer _.d {
  .uea92:lang(ja) {
    font-family: adobe-clean-han-japanese, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Osaka, YuGothic, 'Yu Gothic', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  }
}

@layer _.e {
  .ugb92:lang(ko) {
    font-family: adobe-clean-han-korean, source-han-korean, 'Malgun Gothic', 'Apple Gothic', sans-serif;
  }
}

@layer _.f {
  .uhd92:lang(zh) {
    font-family: adobe-clean-han-traditional, source-han-traditional, 'MingLiu', 'Heiti TC Light', sans-serif;
  }
}

@layer _.g {
  .uje92:lang(zh-hant) {
    font-family: adobe-clean-han-traditional, source-han-traditional, 'MingLiu', 'Microsoft JhengHei UI', 'Microsoft JhengHei', 'Heiti TC Light', sans-serif;
  }
}

@layer _.h {
  .uic92:lang(zh-Hans, zh-CN, zh-SG) {
    font-family: adobe-clean-han-simplified-c, source-han-simplified-c, 'SimSun', 'Heiti SC Light', sans-serif;
  }
}

@layer _.b.s {
  @media not ((hover: hover) and (pointer: fine)) {
    .vsq92 {
      font-size: 2.125rem;
    }
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AAwLgC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a, _.b;

@layer _.a {
  .pn92 {
    color: light-dark(rgb(113, 113, 113), rgb(138, 138, 138));
  }


  .vn92 {
    font-size: 1.75rem;
  }


  .Jy92 {
    margin-top: 0rem;
  }


  .Gy92 {
    margin-bottom: 0rem;
  }
}

@layer _.b.s {
  @media not ((hover: hover) and (pointer: fine)) {
    .vsq92 {
      font-size: 2.125rem;
    }
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AAkMoC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._ta92 {
    flex-direction: column;
  }


  .Uh92 {
    row-gap: 0rem;
  }


  .qh92 {
    column-gap: 0rem;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AA0NkC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._ta92 {
    flex-direction: column;
  }


  .Uk92 {
    row-gap: 1.75rem;
  }


  .qk92 {
    column-gap: 1.75rem;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AA+NkC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/CardsSection/CardsSection.tsx"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE:  All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport {Action} from '@nest/interface';\nimport {Heading, Image} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {useEffect, useRef} from 'react';\nimport CardButtonGroup from './CardButtonGroup';\nimport CardInfoSection from './CardInfoSection';\nimport ImageFailureIcon from './ImageFailureIcon';\nimport {CARD_TYPES} from '../../../constants';\nimport {AppsUrl, Card} from '../../../util/types';\nimport {isWhatsNewExperience} from '../../../util/utils';\n\ntype CardsSectionProps = {\n\tcardList: Card[]; // List of cards to display\n\tcardRefs: React.MutableRefObject<(HTMLDivElement | null)[]>; // References to card elements\n\theading: string; // Heading text\n\tisWindowVisible: boolean; // Visibility state of the window\n\tlayoutId: string; // Layout identifier\n\tmuteVideo: boolean; // Whether to mute videos\n\tnonSideNavExperience: boolean; // non side nav experience flag\n\tonAction: (action: AppsUrl, cardID: string) => void; // Callback for card actions\n\tonPromotionAction: (action: Action, cardID: string) => void; // Callback for promotion actions\n\tselectedKey: number; // Currently selected card key\n\tsubHeading: string | undefined; // Subheading text\n};\n\nexport default function CardsSection({\n\tcardList,\n\tcardRefs,\n\theading,\n\tisWindowVisible,\n\tlayoutId,\n\tmuteVideo,\n\tnonSideNavExperience,\n\tonAction,\n\tonPromotionAction,\n\tselectedKey,\n\tsubHeading,\n}: CardsSectionProps): JSX.Element {\n\t// Reference to video elements\n\tconst videoRefs = useRef<{[key: number]: HTMLVideoElement | null}>({});\n\n\t// Handle video play/pause when selectedKey changes\n\tuseEffect(() => {\n\t\tconst handleVideoPlayback = () => {\n\t\t\tif (isWhatsNewExperience(layoutId)) {\n\t\t\t\tconst video = videoRefs.current[selectedKey];\n\t\t\t\tif (video) {\n\t\t\t\t\tif (isWindowVisible) {\n\t\t\t\t\t\tvideo.play(); // Play video if window is visible\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvideo.pause(); // Pause video if window is not visible\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t\thandleVideoPlayback();\n\t}, [isWindowVisible, layoutId, selectedKey]);\n\n\t// Render media (image, video, etc.)\n\tconst renderMedia = (card: Card, index: number) => {\n\t\tconst {type, src, mediaType, thumbnailSrc} = card;\n\n\t\t// Define styles for media elements\n\t\tconst mediaStyle = nonSideNavExperience\n\t\t\t? style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\theight: 360,\n\t\t\t\t\tmarginY: 16,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t})\n\t\t\t: style({\n\t\t\t\t\tborderRadius: 'sm',\n\t\t\t\t\tmaxWidth: 512,\n\t\t\t\t\theight: 288,\n\t\t\t\t\tobjectFit: 'cover',\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t});\n\n\t\t// Render media based on its type\n\t\tswitch (type) {\n\t\t\tcase CARD_TYPES.IMAGE:\n\t\t\tcase CARD_TYPES.GIF:\n\t\t\t\treturn (\n\t\t\t\t\t<Image\n\t\t\t\t\t\tsrc={src}\n\t\t\t\t\t\tstyles={mediaStyle}\n\t\t\t\t\t\talt={mediaType}\n\t\t\t\t\t\trenderError={() => <ImageFailureIcon />} // Fallback for image load failure\n\t\t\t\t\t/>\n\t\t\t\t);\n\t\t\tcase CARD_TYPES.VIDEO:\n\t\t\t\treturn (\n\t\t\t\t\t// eslint-disable-next-line jsx-a11y/media-has-caption\n\t\t\t\t\t<video\n\t\t\t\t\t\tstyle={{width: '100%'}}\n\t\t\t\t\t\tclassName={mediaStyle}\n\t\t\t\t\t\tkey={src}\n\t\t\t\t\t\tref={(el) => (videoRefs.current[index] = el)}\n\t\t\t\t\t\tautoPlay\n\t\t\t\t\t\tmuted={muteVideo}\n\t\t\t\t\t\tcontrols={false}\n\t\t\t\t\t\tposter={thumbnailSrc}\n\t\t\t\t\t>\n\t\t\t\t\t\t<source src={src} type={mediaType} />\n\t\t\t\t\t</video>\n\t\t\t\t);\n\t\t\tdefault:\n\t\t\t\treturn null; // Return null for unsupported media types\n\t\t}\n\t};\n\n\t// Define styles for the no-side-nav experience\n\tconst noSideNavStyle = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tpadding: 32,\n\t\tpaddingTop: 0,\n\t\tmaxWidth: 653,\n\t});\n\n\t// Define styles for the cards container\n\tconst cardsStyling = style({\n\t\tdisplay: 'flex',\n\t\tflexDirection: 'column',\n\t\tgap: {\n\t\t\tdefault: 0,\n\t\t\tisSideNavShown: 56,\n\t\t},\n\t});\n\n\t// Define styles for padding at the top\n\tconst paddingTopStyle = style({\n\t\tpaddingTop: {\n\t\t\tdefault: 32,\n\t\t\tisSideNavShown: 0,\n\t\t},\n\t});\n\n\tconst mediaContainerStyle = style({\n\t\theight: {\n\t\t\tdefault: 392,\n\t\t\tisSideNavShown: 288,\n\t\t},\n\t\tmaxWidth: {\n\t\t\tisSideNavShown: 512,\n\t\t},\n\t});\n\n\treturn (\n\t\t<div\n\t\t\tclassName={\n\t\t\t\tnonSideNavExperience\n\t\t\t\t\t? noSideNavStyle\n\t\t\t\t\t: style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\tpadding: 40,\n\t\t\t\t\t\t\tpaddingTop: 8,\n\t\t\t\t\t\t\tmaxWidth: 592,\n\t\t\t\t\t\t})\n\t\t\t}\n\t\t>\n\t\t\t{/* Render heading and subheading for non-side-nav experience */}\n\t\t\t{nonSideNavExperience && (\n\t\t\t\t<div style={{overflowWrap: 'break-word'}}>\n\t\t\t\t\t<Heading\n\t\t\t\t\t\tslot='title'\n\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\tfont: 'heading-lg',\n\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{heading}\n\t\t\t\t\t</Heading>\n\n\t\t\t\t\t{subHeading && (\n\t\t\t\t\t\t<Heading\n\t\t\t\t\t\t\tstyles={style({\n\t\t\t\t\t\t\t\tcolor: 'gray-600',\n\t\t\t\t\t\t\t\tfontSize: 'heading-lg',\n\t\t\t\t\t\t\t\tmarginY: 0,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{subHeading}\n\t\t\t\t\t\t</Heading>\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t)}\n\n\t\t\t{/* Render the list of cards */}\n\t\t\t<div\n\t\t\t\tclassName={cardsStyling({\n\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t})}\n\t\t\t>\n\t\t\t\t{cardList.map((card, index) => (\n\t\t\t\t\t<div\n\t\t\t\t\t\tkey={`${card.id}-${index}`}\n\t\t\t\t\t\tref={(el) => (cardRefs.current[index] = el)}\n\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\tnonSideNavExperience\n\t\t\t\t\t\t\t\t? style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 0,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\t: style({\n\t\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\t\tgap: 28,\n\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render media for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={mediaContainerStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{renderMedia(card, index)}\n\t\t\t\t\t\t</div>\n\n\t\t\t\t\t\t{/* Render card information section */}\n\t\t\t\t\t\t<CardInfoSection\n\t\t\t\t\t\t\tdescription={card.description}\n\t\t\t\t\t\t\tpromotion={card.promotion}\n\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\ttitle={card.title}\n\t\t\t\t\t\t\tisSideNavShown={!nonSideNavExperience}\n\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t/>\n\n\t\t\t\t\t\t{/* Render button group for the card */}\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tclassName={paddingTopStyle({\n\t\t\t\t\t\t\t\tisSideNavShown: !nonSideNavExperience,\n\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<CardButtonGroup\n\t\t\t\t\t\t\t\tactionList={card.actionList}\n\t\t\t\t\t\t\t\tcardID={card.id}\n\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t))}\n\t\t\t</div>\n\t\t</div>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._ta92 {
    flex-direction: column;
  }


  .Ui92 {
    row-gap: 1.25rem;
  }


  .Tk92 {
    padding-top: 32px;
  }


  .St92 {
    padding-inline-start: 8px;
  }


  .Rm92 {
    padding-inline-end: 40px;
  }


  .ZoxpMkc92 {
    width: calc(16rem * var(--s2-scale));
  }


  .gqlRAZb92 {
    background-color: light-dark(rgb(248, 248, 248), rgb(27, 27, 27));
  }


  ._va92 {
    flex-shrink: 0;
  }


  .Pa92 {
    overflow-y: auto;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJtYXBwaW5ncyI6IkFBd0N1QjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEiLCJzb3VyY2VzIjpbIi4uLy4uL2FwcGxldHMvb25ib2FyZGluZy9zcmMvdmlldy9jb21wb25lbnRzL1NpZGVOYXYvU2lkZU5hdi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBBRE9CRSBDT05GSURFTlRJQUxcbiAqXG4gKiBDb3B5cmlnaHQgMjAyNSBBZG9iZVxuICogQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBOT1RJQ0U6ICBBbGwgaW5mb3JtYXRpb24gY29udGFpbmVkIGhlcmVpbiBpcywgYW5kIHJlbWFpbnNcbiAqIHRoZSBwcm9wZXJ0eSBvZiBBZG9iZSBhbmQgaXRzIHN1cHBsaWVycywgaWYgYW55LiBUaGUgaW50ZWxsZWN0dWFsXG4gKiBhbmQgdGVjaG5pY2FsIGNvbmNlcHRzIGNvbnRhaW5lZCBoZXJlaW4gYXJlIHByb3ByaWV0YXJ5IHRvIEFkb2JlXG4gKiBhbmQgaXRzIHN1cHBsaWVycyBhbmQgYXJlIHByb3RlY3RlZCBieSBhbGwgYXBwbGljYWJsZSBpbnRlbGxlY3R1YWxcbiAqIHByb3BlcnR5IGxhd3MsIGluY2x1ZGluZyB0cmFkZSBzZWNyZXQgYW5kIGNvcHlyaWdodCBsYXdzLlxuICogRGlzc2VtaW5hdGlvbiBvZiB0aGlzIGluZm9ybWF0aW9uIG9yIHJlcHJvZHVjdGlvbiBvZiB0aGlzIG1hdGVyaWFsXG4gKiBpcyBzdHJpY3RseSBmb3JiaWRkZW4gdW5sZXNzIHByaW9yIHdyaXR0ZW4gcGVybWlzc2lvbiBpcyBvYnRhaW5lZFxuICogZnJvbSBBZG9iZS5cbiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG5pbXBvcnQge0hlYWRpbmcsIFRhYiwgVGFiTGlzdCwgVGFic30gZnJvbSAnQHJlYWN0LXNwZWN0cnVtL3MyJztcbmltcG9ydCB7c3R5bGV9IGZyb20gJ0ByZWFjdC1zcGVjdHJ1bS9zMi9zdHlsZScgd2l0aCB7dHlwZTogJ21hY3JvJ307XG5pbXBvcnQgUmVhY3QsIHtLZXl9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7TWVkaWF9IGZyb20gJy4uLy4uLy4uL3V0aWwvdHlwZXMnO1xuXG50eXBlIFNpZGVOYXZQcm9wcyA9IHtcblx0bWVkaWFMaXN0OiBNZWRpYVtdO1xuXHRvblRhYlNlbGVjdGlvbkNoYW5nZTogKGtleTogS2V5KSA9PiB2b2lkO1xuXHRzZWxlY3RlZFRhYjogbnVtYmVyO1xuXHRzdWJUaXRsZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXHR0YWJSZWZzOiBSZWFjdC5NdXRhYmxlUmVmT2JqZWN0PChIVE1MRGl2RWxlbWVudCB8IG51bGwpW10+O1xuXHR0aXRsZTogc3RyaW5nO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gU2lkZU5hdih7XG5cdG1lZGlhTGlzdCxcblx0b25UYWJTZWxlY3Rpb25DaGFuZ2UsXG5cdHNlbGVjdGVkVGFiLFxuXHRzdWJUaXRsZTogc3ViSGVhZGluZyxcblx0dGFiUmVmcyxcblx0dGl0bGUsXG59OiBTaWRlTmF2UHJvcHMpOiBKU1guRWxlbWVudCB7XG5cdHJldHVybiAoXG5cdFx0PGRpdlxuXHRcdFx0Y2xhc3NOYW1lPXtzdHlsZSh7XG5cdFx0XHRcdGRpc3BsYXk6ICdmbGV4Jyxcblx0XHRcdFx0ZmxleERpcmVjdGlvbjogJ2NvbHVtbicsXG5cdFx0XHRcdHJvd0dhcDogMjAsXG5cdFx0XHRcdHBhZGRpbmdUb3A6IDMyLFxuXHRcdFx0XHRwYWRkaW5nU3RhcnQ6IDgsXG5cdFx0XHRcdHBhZGRpbmdFbmQ6IDQwLFxuXHRcdFx0XHR3aWR0aDogMjU2LFxuXHRcdFx0XHRiYWNrZ3JvdW5kQ29sb3I6ICdncmF5LTUwJyxcblx0XHRcdFx0ZmxleFNocmluazogMCxcblx0XHRcdFx0b3ZlcmZsb3dZOiAnYXV0bycsXG5cdFx0XHR9KX1cblx0XHRcdHN0eWxlPXt7b3ZlcmZsb3dXcmFwOiAnYnJlYWstd29yZCd9fVxuXHRcdD5cblx0XHRcdHsvKiBDb250YWluZXIgZm9yIHRoZSB0aXRsZSBhbmQgb3B0aW9uYWwgc3VidGl0bGUgKi99XG5cblx0XHRcdDxkaXYgaWQ9J3NpZGVuYXYtdGl0bGUnPlxuXHRcdFx0XHR7LyogUmVuZGVyIHRoZSBtYWluIHRpdGxlIG9mIHRoZSBTaWRlTmF2ICovfVxuXHRcdFx0XHQ8SGVhZGluZ1xuXHRcdFx0XHRcdHN0eWxlcz17c3R5bGUoe1xuXHRcdFx0XHRcdFx0Zm9udDogJ3RpdGxlLTN4bCcsXG5cdFx0XHRcdFx0XHRtYXJnaW5TdGFydDogMzIsXG5cdFx0XHRcdFx0fSl9XG5cdFx0XHRcdD5cblx0XHRcdFx0XHR7dGl0bGV9XG5cdFx0XHRcdDwvSGVhZGluZz5cblxuXHRcdFx0XHR7LyogQ29uZGl0aW9uYWxseSByZW5kZXIgdGhlIHN1YnRpdGxlIGlmIHByb3ZpZGVkICovfVxuXHRcdFx0XHR7c3ViSGVhZGluZyAmJiAoXG5cdFx0XHRcdFx0PEhlYWRpbmdcblx0XHRcdFx0XHRcdHN0eWxlcz17c3R5bGUoe1xuXHRcdFx0XHRcdFx0XHRjb2xvcjogJ2dyYXktNjAwJyxcblx0XHRcdFx0XHRcdFx0Zm9udFNpemU6ICd0aXRsZS0zeGwnLFxuXHRcdFx0XHRcdFx0XHRtYXJnaW5TdGFydDogMzIsXG5cdFx0XHRcdFx0XHR9KX1cblx0XHRcdFx0XHQ+XG5cdFx0XHRcdFx0XHR7c3ViSGVhZGluZ31cblx0XHRcdFx0XHQ8L0hlYWRpbmc+XG5cdFx0XHRcdCl9XG5cdFx0XHQ8L2Rpdj5cblxuXHRcdFx0ey8qIFJlbmRlciB0aGUgVGFicyBjb21wb25lbnQgd2l0aCB2ZXJ0aWNhbCBvcmllbnRhdGlvbiAqL31cblx0XHRcdHsvKiBIYW5kbGUgdGFiIHNlbGVjdGlvbiBjaGFuZ2VzIHZpYSB0aGUgb25UYWJTZWxlY3Rpb25DaGFuZ2UgY2FsbGJhY2sgKi99XG5cdFx0XHQ8VGFic1xuXHRcdFx0XHRvcmllbnRhdGlvbj0ndmVydGljYWwnXG5cdFx0XHRcdHNlbGVjdGVkS2V5PXtzZWxlY3RlZFRhYn1cblx0XHRcdFx0b25TZWxlY3Rpb25DaGFuZ2U9e29uVGFiU2VsZWN0aW9uQ2hhbmdlfVxuXHRcdFx0XHRkZW5zaXR5PSdyZWd1bGFyJ1xuXHRcdFx0XHRhcmlhLWxhYmVsbGVkYnk9J3NpZGVuYXYtdGl0bGUnXG5cdFx0XHQ+XG5cdFx0XHRcdDxUYWJMaXN0PlxuXHRcdFx0XHRcdHsvKiBNYXAgdGhyb3VnaCB0aGUgbWVkaWFMaXN0IHRvIHJlbmRlciBpbmRpdmlkdWFsIHRhYnMgKi99XG5cdFx0XHRcdFx0ey8qIEVhY2ggdGFiIGNvbnRhaW5zIGEgZGl2IHdpdGggYSByZWYgZm9yIHN0YWJsZSB1cGRhdGVzICovfVxuXHRcdFx0XHRcdHttZWRpYUxpc3QubWFwKCh7c3ViVGl0bGUsIGluQXBwSUR9LCBpbmRleCkgPT4gKFxuXHRcdFx0XHRcdFx0PFRhYlxuXHRcdFx0XHRcdFx0XHRpZD17aW5kZXh9XG5cdFx0XHRcdFx0XHRcdGtleT17YCR7aW5BcHBJRH0tJHtpbmRleH1gfVxuXHRcdFx0XHRcdFx0XHRVTlNBRkVfc3R5bGU9e3tjdXJzb3I6ICdwb2ludGVyJ319XG5cdFx0XHRcdFx0XHQ+XG5cdFx0XHRcdFx0XHRcdDxkaXZcblx0XHRcdFx0XHRcdFx0XHRyZWY9eyhlbCkgPT4ge1xuXHRcdFx0XHRcdFx0XHRcdFx0aWYgKGVsKSB7XG5cdFx0XHRcdFx0XHRcdFx0XHRcdHRhYlJlZnMuY3VycmVudFtpbmRleF0gPSBlbDtcblx0XHRcdFx0XHRcdFx0XHRcdH1cblx0XHRcdFx0XHRcdFx0XHR9fVxuXHRcdFx0XHRcdFx0XHRcdHN0eWxlPXt7XG5cdFx0XHRcdFx0XHRcdFx0XHRkaXNwbGF5OiAnLXdlYmtpdC1ib3gnLFxuXHRcdFx0XHRcdFx0XHRcdFx0V2Via2l0TGluZUNsYW1wOiAyLFxuXHRcdFx0XHRcdFx0XHRcdFx0V2Via2l0Qm94T3JpZW50OiAndmVydGljYWwnLFxuXHRcdFx0XHRcdFx0XHRcdFx0b3ZlcmZsb3c6ICdoaWRkZW4nLFxuXHRcdFx0XHRcdFx0XHRcdFx0dGV4dE92ZXJmbG93OiAnZWxsaXBzaXMnLFxuXHRcdFx0XHRcdFx0XHRcdH19XG5cdFx0XHRcdFx0XHRcdD5cblx0XHRcdFx0XHRcdFx0XHR7c3ViVGl0bGV9XG5cdFx0XHRcdFx0XHRcdDwvZGl2PlxuXHRcdFx0XHRcdFx0PC9UYWI+XG5cdFx0XHRcdFx0KSl9XG5cdFx0XHRcdDwvVGFiTGlzdD5cblx0XHRcdDwvVGFicz5cblx0XHQ8L2Rpdj5cblx0KTtcbn1cbiJdLCJuYW1lcyI6W10sInZlcnNpb24iOjN9 */
@layer _.a, _.b, _.c, _.d, _.e, _.f, _.g, _.h;

@layer _.a {
  .ug92 {
    font-family: adobe-clean-variable, adobe-clean, ui-sans-serif, system-ui, sans-serif;
  }


  .vk92 {
    font-size: 1.5625rem;
  }


  .wd92 {
    font-variation-settings: "wght" 700;
  }


  .xd92 {
    font-weight: 700;
  }


  ._xa92 {
    font-synthesis-weight: none;
  }


  ._Fa92 {
    line-height: 1.3;
  }


  .po92 {
    color: light-dark(rgb(19, 19, 19), rgb(242, 242, 242));
  }


  .IG92 {
    margin-inline-start: 2rem;
  }
}

@layer _.b {
  .uch92:lang(ar) {
    font-family: myriad-arabic, ui-sans-serif, system-ui, sans-serif;
  }


  .wfd92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    font-variation-settings: "wght" 700;
  }


  .xfd92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    font-weight: 700;
  }


  ._xfa92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    font-synthesis-weight: none;
  }


  ._Ffb92:lang(ja, ko, zh, zh-Hant, zh-Hans) {
    line-height: 1.5;
  }
}

@layer _.c {
  .udi92:lang(he) {
    font-family: myriad-hebrew, ui-sans-serif, system-ui, sans-serif;
  }
}

@layer _.d {
  .uea92:lang(ja) {
    font-family: adobe-clean-han-japanese, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Osaka, YuGothic, 'Yu Gothic', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  }
}

@layer _.e {
  .ugb92:lang(ko) {
    font-family: adobe-clean-han-korean, source-han-korean, 'Malgun Gothic', 'Apple Gothic', sans-serif;
  }
}

@layer _.f {
  .uhd92:lang(zh) {
    font-family: adobe-clean-han-traditional, source-han-traditional, 'MingLiu', 'Heiti TC Light', sans-serif;
  }
}

@layer _.g {
  .uje92:lang(zh-hant) {
    font-family: adobe-clean-han-traditional, source-han-traditional, 'MingLiu', 'Microsoft JhengHei UI', 'Microsoft JhengHei', 'Heiti TC Light', sans-serif;
  }
}

@layer _.h {
  .uic92:lang(zh-Hans, zh-CN, zh-SG) {
    font-family: adobe-clean-han-simplified-c, source-han-simplified-c, 'SimSun', 'Heiti SC Light', sans-serif;
  }
}

@layer _.b.s {
  @media not ((hover: hover) and (pointer: fine)) {
    .vso92 {
      font-size: 1.9375rem;
    }
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJtYXBwaW5ncyI6IkFBMkQ0QjtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEiLCJzb3VyY2VzIjpbIi4uLy4uL2FwcGxldHMvb25ib2FyZGluZy9zcmMvdmlldy9jb21wb25lbnRzL1NpZGVOYXYvU2lkZU5hdi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBBRE9CRSBDT05GSURFTlRJQUxcbiAqXG4gKiBDb3B5cmlnaHQgMjAyNSBBZG9iZVxuICogQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBOT1RJQ0U6ICBBbGwgaW5mb3JtYXRpb24gY29udGFpbmVkIGhlcmVpbiBpcywgYW5kIHJlbWFpbnNcbiAqIHRoZSBwcm9wZXJ0eSBvZiBBZG9iZSBhbmQgaXRzIHN1cHBsaWVycywgaWYgYW55LiBUaGUgaW50ZWxsZWN0dWFsXG4gKiBhbmQgdGVjaG5pY2FsIGNvbmNlcHRzIGNvbnRhaW5lZCBoZXJlaW4gYXJlIHByb3ByaWV0YXJ5IHRvIEFkb2JlXG4gKiBhbmQgaXRzIHN1cHBsaWVycyBhbmQgYXJlIHByb3RlY3RlZCBieSBhbGwgYXBwbGljYWJsZSBpbnRlbGxlY3R1YWxcbiAqIHByb3BlcnR5IGxhd3MsIGluY2x1ZGluZyB0cmFkZSBzZWNyZXQgYW5kIGNvcHlyaWdodCBsYXdzLlxuICogRGlzc2VtaW5hdGlvbiBvZiB0aGlzIGluZm9ybWF0aW9uIG9yIHJlcHJvZHVjdGlvbiBvZiB0aGlzIG1hdGVyaWFsXG4gKiBpcyBzdHJpY3RseSBmb3JiaWRkZW4gdW5sZXNzIHByaW9yIHdyaXR0ZW4gcGVybWlzc2lvbiBpcyBvYnRhaW5lZFxuICogZnJvbSBBZG9iZS5cbiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG5pbXBvcnQge0hlYWRpbmcsIFRhYiwgVGFiTGlzdCwgVGFic30gZnJvbSAnQHJlYWN0LXNwZWN0cnVtL3MyJztcbmltcG9ydCB7c3R5bGV9IGZyb20gJ0ByZWFjdC1zcGVjdHJ1bS9zMi9zdHlsZScgd2l0aCB7dHlwZTogJ21hY3JvJ307XG5pbXBvcnQgUmVhY3QsIHtLZXl9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7TWVkaWF9IGZyb20gJy4uLy4uLy4uL3V0aWwvdHlwZXMnO1xuXG50eXBlIFNpZGVOYXZQcm9wcyA9IHtcblx0bWVkaWFMaXN0OiBNZWRpYVtdO1xuXHRvblRhYlNlbGVjdGlvbkNoYW5nZTogKGtleTogS2V5KSA9PiB2b2lkO1xuXHRzZWxlY3RlZFRhYjogbnVtYmVyO1xuXHRzdWJUaXRsZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXHR0YWJSZWZzOiBSZWFjdC5NdXRhYmxlUmVmT2JqZWN0PChIVE1MRGl2RWxlbWVudCB8IG51bGwpW10+O1xuXHR0aXRsZTogc3RyaW5nO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gU2lkZU5hdih7XG5cdG1lZGlhTGlzdCxcblx0b25UYWJTZWxlY3Rpb25DaGFuZ2UsXG5cdHNlbGVjdGVkVGFiLFxuXHRzdWJUaXRsZTogc3ViSGVhZGluZyxcblx0dGFiUmVmcyxcblx0dGl0bGUsXG59OiBTaWRlTmF2UHJvcHMpOiBKU1guRWxlbWVudCB7XG5cdHJldHVybiAoXG5cdFx0PGRpdlxuXHRcdFx0Y2xhc3NOYW1lPXtzdHlsZSh7XG5cdFx0XHRcdGRpc3BsYXk6ICdmbGV4Jyxcblx0XHRcdFx0ZmxleERpcmVjdGlvbjogJ2NvbHVtbicsXG5cdFx0XHRcdHJvd0dhcDogMjAsXG5cdFx0XHRcdHBhZGRpbmdUb3A6IDMyLFxuXHRcdFx0XHRwYWRkaW5nU3RhcnQ6IDgsXG5cdFx0XHRcdHBhZGRpbmdFbmQ6IDQwLFxuXHRcdFx0XHR3aWR0aDogMjU2LFxuXHRcdFx0XHRiYWNrZ3JvdW5kQ29sb3I6ICdncmF5LTUwJyxcblx0XHRcdFx0ZmxleFNocmluazogMCxcblx0XHRcdFx0b3ZlcmZsb3dZOiAnYXV0bycsXG5cdFx0XHR9KX1cblx0XHRcdHN0eWxlPXt7b3ZlcmZsb3dXcmFwOiAnYnJlYWstd29yZCd9fVxuXHRcdD5cblx0XHRcdHsvKiBDb250YWluZXIgZm9yIHRoZSB0aXRsZSBhbmQgb3B0aW9uYWwgc3VidGl0bGUgKi99XG5cblx0XHRcdDxkaXYgaWQ9J3NpZGVuYXYtdGl0bGUnPlxuXHRcdFx0XHR7LyogUmVuZGVyIHRoZSBtYWluIHRpdGxlIG9mIHRoZSBTaWRlTmF2ICovfVxuXHRcdFx0XHQ8SGVhZGluZ1xuXHRcdFx0XHRcdHN0eWxlcz17c3R5bGUoe1xuXHRcdFx0XHRcdFx0Zm9udDogJ3RpdGxlLTN4bCcsXG5cdFx0XHRcdFx0XHRtYXJnaW5TdGFydDogMzIsXG5cdFx0XHRcdFx0fSl9XG5cdFx0XHRcdD5cblx0XHRcdFx0XHR7dGl0bGV9XG5cdFx0XHRcdDwvSGVhZGluZz5cblxuXHRcdFx0XHR7LyogQ29uZGl0aW9uYWxseSByZW5kZXIgdGhlIHN1YnRpdGxlIGlmIHByb3ZpZGVkICovfVxuXHRcdFx0XHR7c3ViSGVhZGluZyAmJiAoXG5cdFx0XHRcdFx0PEhlYWRpbmdcblx0XHRcdFx0XHRcdHN0eWxlcz17c3R5bGUoe1xuXHRcdFx0XHRcdFx0XHRjb2xvcjogJ2dyYXktNjAwJyxcblx0XHRcdFx0XHRcdFx0Zm9udFNpemU6ICd0aXRsZS0zeGwnLFxuXHRcdFx0XHRcdFx0XHRtYXJnaW5TdGFydDogMzIsXG5cdFx0XHRcdFx0XHR9KX1cblx0XHRcdFx0XHQ+XG5cdFx0XHRcdFx0XHR7c3ViSGVhZGluZ31cblx0XHRcdFx0XHQ8L0hlYWRpbmc+XG5cdFx0XHRcdCl9XG5cdFx0XHQ8L2Rpdj5cblxuXHRcdFx0ey8qIFJlbmRlciB0aGUgVGFicyBjb21wb25lbnQgd2l0aCB2ZXJ0aWNhbCBvcmllbnRhdGlvbiAqL31cblx0XHRcdHsvKiBIYW5kbGUgdGFiIHNlbGVjdGlvbiBjaGFuZ2VzIHZpYSB0aGUgb25UYWJTZWxlY3Rpb25DaGFuZ2UgY2FsbGJhY2sgKi99XG5cdFx0XHQ8VGFic1xuXHRcdFx0XHRvcmllbnRhdGlvbj0ndmVydGljYWwnXG5cdFx0XHRcdHNlbGVjdGVkS2V5PXtzZWxlY3RlZFRhYn1cblx0XHRcdFx0b25TZWxlY3Rpb25DaGFuZ2U9e29uVGFiU2VsZWN0aW9uQ2hhbmdlfVxuXHRcdFx0XHRkZW5zaXR5PSdyZWd1bGFyJ1xuXHRcdFx0XHRhcmlhLWxhYmVsbGVkYnk9J3NpZGVuYXYtdGl0bGUnXG5cdFx0XHQ+XG5cdFx0XHRcdDxUYWJMaXN0PlxuXHRcdFx0XHRcdHsvKiBNYXAgdGhyb3VnaCB0aGUgbWVkaWFMaXN0IHRvIHJlbmRlciBpbmRpdmlkdWFsIHRhYnMgKi99XG5cdFx0XHRcdFx0ey8qIEVhY2ggdGFiIGNvbnRhaW5zIGEgZGl2IHdpdGggYSByZWYgZm9yIHN0YWJsZSB1cGRhdGVzICovfVxuXHRcdFx0XHRcdHttZWRpYUxpc3QubWFwKCh7c3ViVGl0bGUsIGluQXBwSUR9LCBpbmRleCkgPT4gKFxuXHRcdFx0XHRcdFx0PFRhYlxuXHRcdFx0XHRcdFx0XHRpZD17aW5kZXh9XG5cdFx0XHRcdFx0XHRcdGtleT17YCR7aW5BcHBJRH0tJHtpbmRleH1gfVxuXHRcdFx0XHRcdFx0XHRVTlNBRkVfc3R5bGU9e3tjdXJzb3I6ICdwb2ludGVyJ319XG5cdFx0XHRcdFx0XHQ+XG5cdFx0XHRcdFx0XHRcdDxkaXZcblx0XHRcdFx0XHRcdFx0XHRyZWY9eyhlbCkgPT4ge1xuXHRcdFx0XHRcdFx0XHRcdFx0aWYgKGVsKSB7XG5cdFx0XHRcdFx0XHRcdFx0XHRcdHRhYlJlZnMuY3VycmVudFtpbmRleF0gPSBlbDtcblx0XHRcdFx0XHRcdFx0XHRcdH1cblx0XHRcdFx0XHRcdFx0XHR9fVxuXHRcdFx0XHRcdFx0XHRcdHN0eWxlPXt7XG5cdFx0XHRcdFx0XHRcdFx0XHRkaXNwbGF5OiAnLXdlYmtpdC1ib3gnLFxuXHRcdFx0XHRcdFx0XHRcdFx0V2Via2l0TGluZUNsYW1wOiAyLFxuXHRcdFx0XHRcdFx0XHRcdFx0V2Via2l0Qm94T3JpZW50OiAndmVydGljYWwnLFxuXHRcdFx0XHRcdFx0XHRcdFx0b3ZlcmZsb3c6ICdoaWRkZW4nLFxuXHRcdFx0XHRcdFx0XHRcdFx0dGV4dE92ZXJmbG93OiAnZWxsaXBzaXMnLFxuXHRcdFx0XHRcdFx0XHRcdH19XG5cdFx0XHRcdFx0XHRcdD5cblx0XHRcdFx0XHRcdFx0XHR7c3ViVGl0bGV9XG5cdFx0XHRcdFx0XHRcdDwvZGl2PlxuXHRcdFx0XHRcdFx0PC9UYWI+XG5cdFx0XHRcdFx0KSl9XG5cdFx0XHRcdDwvVGFiTGlzdD5cblx0XHRcdDwvVGFicz5cblx0XHQ8L2Rpdj5cblx0KTtcbn1cbiJdLCJuYW1lcyI6W10sInZlcnNpb24iOjN9 */
@layer _.a, _.b;

@layer _.a {
  .pn92 {
    color: light-dark(rgb(113, 113, 113), rgb(138, 138, 138));
  }


  .vk92 {
    font-size: 1.5625rem;
  }


  .IG92 {
    margin-inline-start: 2rem;
  }
}

@layer _.b.s {
  @media not ((hover: hover) and (pointer: fine)) {
    .vso92 {
      font-size: 1.9375rem;
    }
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJtYXBwaW5ncyI6IkFBc0VnQztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEiLCJzb3VyY2VzIjpbIi4uLy4uL2FwcGxldHMvb25ib2FyZGluZy9zcmMvdmlldy9jb21wb25lbnRzL1NpZGVOYXYvU2lkZU5hdi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gKiBBRE9CRSBDT05GSURFTlRJQUxcbiAqXG4gKiBDb3B5cmlnaHQgMjAyNSBBZG9iZVxuICogQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBOT1RJQ0U6ICBBbGwgaW5mb3JtYXRpb24gY29udGFpbmVkIGhlcmVpbiBpcywgYW5kIHJlbWFpbnNcbiAqIHRoZSBwcm9wZXJ0eSBvZiBBZG9iZSBhbmQgaXRzIHN1cHBsaWVycywgaWYgYW55LiBUaGUgaW50ZWxsZWN0dWFsXG4gKiBhbmQgdGVjaG5pY2FsIGNvbmNlcHRzIGNvbnRhaW5lZCBoZXJlaW4gYXJlIHByb3ByaWV0YXJ5IHRvIEFkb2JlXG4gKiBhbmQgaXRzIHN1cHBsaWVycyBhbmQgYXJlIHByb3RlY3RlZCBieSBhbGwgYXBwbGljYWJsZSBpbnRlbGxlY3R1YWxcbiAqIHByb3BlcnR5IGxhd3MsIGluY2x1ZGluZyB0cmFkZSBzZWNyZXQgYW5kIGNvcHlyaWdodCBsYXdzLlxuICogRGlzc2VtaW5hdGlvbiBvZiB0aGlzIGluZm9ybWF0aW9uIG9yIHJlcHJvZHVjdGlvbiBvZiB0aGlzIG1hdGVyaWFsXG4gKiBpcyBzdHJpY3RseSBmb3JiaWRkZW4gdW5sZXNzIHByaW9yIHdyaXR0ZW4gcGVybWlzc2lvbiBpcyBvYnRhaW5lZFxuICogZnJvbSBBZG9iZS5cbiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG5pbXBvcnQge0hlYWRpbmcsIFRhYiwgVGFiTGlzdCwgVGFic30gZnJvbSAnQHJlYWN0LXNwZWN0cnVtL3MyJztcbmltcG9ydCB7c3R5bGV9IGZyb20gJ0ByZWFjdC1zcGVjdHJ1bS9zMi9zdHlsZScgd2l0aCB7dHlwZTogJ21hY3JvJ307XG5pbXBvcnQgUmVhY3QsIHtLZXl9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7TWVkaWF9IGZyb20gJy4uLy4uLy4uL3V0aWwvdHlwZXMnO1xuXG50eXBlIFNpZGVOYXZQcm9wcyA9IHtcblx0bWVkaWFMaXN0OiBNZWRpYVtdO1xuXHRvblRhYlNlbGVjdGlvbkNoYW5nZTogKGtleTogS2V5KSA9PiB2b2lkO1xuXHRzZWxlY3RlZFRhYjogbnVtYmVyO1xuXHRzdWJUaXRsZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXHR0YWJSZWZzOiBSZWFjdC5NdXRhYmxlUmVmT2JqZWN0PChIVE1MRGl2RWxlbWVudCB8IG51bGwpW10+O1xuXHR0aXRsZTogc3RyaW5nO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gU2lkZU5hdih7XG5cdG1lZGlhTGlzdCxcblx0b25UYWJTZWxlY3Rpb25DaGFuZ2UsXG5cdHNlbGVjdGVkVGFiLFxuXHRzdWJUaXRsZTogc3ViSGVhZGluZyxcblx0dGFiUmVmcyxcblx0dGl0bGUsXG59OiBTaWRlTmF2UHJvcHMpOiBKU1guRWxlbWVudCB7XG5cdHJldHVybiAoXG5cdFx0PGRpdlxuXHRcdFx0Y2xhc3NOYW1lPXtzdHlsZSh7XG5cdFx0XHRcdGRpc3BsYXk6ICdmbGV4Jyxcblx0XHRcdFx0ZmxleERpcmVjdGlvbjogJ2NvbHVtbicsXG5cdFx0XHRcdHJvd0dhcDogMjAsXG5cdFx0XHRcdHBhZGRpbmdUb3A6IDMyLFxuXHRcdFx0XHRwYWRkaW5nU3RhcnQ6IDgsXG5cdFx0XHRcdHBhZGRpbmdFbmQ6IDQwLFxuXHRcdFx0XHR3aWR0aDogMjU2LFxuXHRcdFx0XHRiYWNrZ3JvdW5kQ29sb3I6ICdncmF5LTUwJyxcblx0XHRcdFx0ZmxleFNocmluazogMCxcblx0XHRcdFx0b3ZlcmZsb3dZOiAnYXV0bycsXG5cdFx0XHR9KX1cblx0XHRcdHN0eWxlPXt7b3ZlcmZsb3dXcmFwOiAnYnJlYWstd29yZCd9fVxuXHRcdD5cblx0XHRcdHsvKiBDb250YWluZXIgZm9yIHRoZSB0aXRsZSBhbmQgb3B0aW9uYWwgc3VidGl0bGUgKi99XG5cblx0XHRcdDxkaXYgaWQ9J3NpZGVuYXYtdGl0bGUnPlxuXHRcdFx0XHR7LyogUmVuZGVyIHRoZSBtYWluIHRpdGxlIG9mIHRoZSBTaWRlTmF2ICovfVxuXHRcdFx0XHQ8SGVhZGluZ1xuXHRcdFx0XHRcdHN0eWxlcz17c3R5bGUoe1xuXHRcdFx0XHRcdFx0Zm9udDogJ3RpdGxlLTN4bCcsXG5cdFx0XHRcdFx0XHRtYXJnaW5TdGFydDogMzIsXG5cdFx0XHRcdFx0fSl9XG5cdFx0XHRcdD5cblx0XHRcdFx0XHR7dGl0bGV9XG5cdFx0XHRcdDwvSGVhZGluZz5cblxuXHRcdFx0XHR7LyogQ29uZGl0aW9uYWxseSByZW5kZXIgdGhlIHN1YnRpdGxlIGlmIHByb3ZpZGVkICovfVxuXHRcdFx0XHR7c3ViSGVhZGluZyAmJiAoXG5cdFx0XHRcdFx0PEhlYWRpbmdcblx0XHRcdFx0XHRcdHN0eWxlcz17c3R5bGUoe1xuXHRcdFx0XHRcdFx0XHRjb2xvcjogJ2dyYXktNjAwJyxcblx0XHRcdFx0XHRcdFx0Zm9udFNpemU6ICd0aXRsZS0zeGwnLFxuXHRcdFx0XHRcdFx0XHRtYXJnaW5TdGFydDogMzIsXG5cdFx0XHRcdFx0XHR9KX1cblx0XHRcdFx0XHQ+XG5cdFx0XHRcdFx0XHR7c3ViSGVhZGluZ31cblx0XHRcdFx0XHQ8L0hlYWRpbmc+XG5cdFx0XHRcdCl9XG5cdFx0XHQ8L2Rpdj5cblxuXHRcdFx0ey8qIFJlbmRlciB0aGUgVGFicyBjb21wb25lbnQgd2l0aCB2ZXJ0aWNhbCBvcmllbnRhdGlvbiAqL31cblx0XHRcdHsvKiBIYW5kbGUgdGFiIHNlbGVjdGlvbiBjaGFuZ2VzIHZpYSB0aGUgb25UYWJTZWxlY3Rpb25DaGFuZ2UgY2FsbGJhY2sgKi99XG5cdFx0XHQ8VGFic1xuXHRcdFx0XHRvcmllbnRhdGlvbj0ndmVydGljYWwnXG5cdFx0XHRcdHNlbGVjdGVkS2V5PXtzZWxlY3RlZFRhYn1cblx0XHRcdFx0b25TZWxlY3Rpb25DaGFuZ2U9e29uVGFiU2VsZWN0aW9uQ2hhbmdlfVxuXHRcdFx0XHRkZW5zaXR5PSdyZWd1bGFyJ1xuXHRcdFx0XHRhcmlhLWxhYmVsbGVkYnk9J3NpZGVuYXYtdGl0bGUnXG5cdFx0XHQ+XG5cdFx0XHRcdDxUYWJMaXN0PlxuXHRcdFx0XHRcdHsvKiBNYXAgdGhyb3VnaCB0aGUgbWVkaWFMaXN0IHRvIHJlbmRlciBpbmRpdmlkdWFsIHRhYnMgKi99XG5cdFx0XHRcdFx0ey8qIEVhY2ggdGFiIGNvbnRhaW5zIGEgZGl2IHdpdGggYSByZWYgZm9yIHN0YWJsZSB1cGRhdGVzICovfVxuXHRcdFx0XHRcdHttZWRpYUxpc3QubWFwKCh7c3ViVGl0bGUsIGluQXBwSUR9LCBpbmRleCkgPT4gKFxuXHRcdFx0XHRcdFx0PFRhYlxuXHRcdFx0XHRcdFx0XHRpZD17aW5kZXh9XG5cdFx0XHRcdFx0XHRcdGtleT17YCR7aW5BcHBJRH0tJHtpbmRleH1gfVxuXHRcdFx0XHRcdFx0XHRVTlNBRkVfc3R5bGU9e3tjdXJzb3I6ICdwb2ludGVyJ319XG5cdFx0XHRcdFx0XHQ+XG5cdFx0XHRcdFx0XHRcdDxkaXZcblx0XHRcdFx0XHRcdFx0XHRyZWY9eyhlbCkgPT4ge1xuXHRcdFx0XHRcdFx0XHRcdFx0aWYgKGVsKSB7XG5cdFx0XHRcdFx0XHRcdFx0XHRcdHRhYlJlZnMuY3VycmVudFtpbmRleF0gPSBlbDtcblx0XHRcdFx0XHRcdFx0XHRcdH1cblx0XHRcdFx0XHRcdFx0XHR9fVxuXHRcdFx0XHRcdFx0XHRcdHN0eWxlPXt7XG5cdFx0XHRcdFx0XHRcdFx0XHRkaXNwbGF5OiAnLXdlYmtpdC1ib3gnLFxuXHRcdFx0XHRcdFx0XHRcdFx0V2Via2l0TGluZUNsYW1wOiAyLFxuXHRcdFx0XHRcdFx0XHRcdFx0V2Via2l0Qm94T3JpZW50OiAndmVydGljYWwnLFxuXHRcdFx0XHRcdFx0XHRcdFx0b3ZlcmZsb3c6ICdoaWRkZW4nLFxuXHRcdFx0XHRcdFx0XHRcdFx0dGV4dE92ZXJmbG93OiAnZWxsaXBzaXMnLFxuXHRcdFx0XHRcdFx0XHRcdH19XG5cdFx0XHRcdFx0XHRcdD5cblx0XHRcdFx0XHRcdFx0XHR7c3ViVGl0bGV9XG5cdFx0XHRcdFx0XHRcdDwvZGl2PlxuXHRcdFx0XHRcdFx0PC9UYWI+XG5cdFx0XHRcdFx0KSl9XG5cdFx0XHRcdDwvVGFiTGlzdD5cblx0XHRcdDwvVGFicz5cblx0XHQ8L2Rpdj5cblx0KTtcbn1cbiJdLCJuYW1lcyI6W10sInZlcnNpb24iOjN9 */
@layer _.a;

@layer _.a {
  .LZDjSNb92 {
    max-width: calc(53rem * var(--s2-scale));
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AA6P4B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/Onboarding/Onboarding.tsx"],"sourcesContent":["/*\n *************************************************************************\n *  ADOBE CONFIDENTIAL\n *\n *  Copyright 2025 Adobe\n *  All Rights Reserved.\n *\n *  NOTICE:  All information contained herein is, and remains\n *  the property of Adobe and its suppliers, if any. The intellectual\n *  and technical concepts contained herein are proprietary to Adobe\n *  and its suppliers and are protected by all applicable intellectual\n *  property laws, including trade secret and copyright laws.\n *  Dissemination of this information or reproduction of this material\n *  is strictly forbidden unless prior written permission is obtained\n *  from Adobe.\n *************************************************************************\n */\n\nimport {Action} from '@nest/interface';\nimport {\n\tCloseButton,\n\tCustomDialog,\n\tDialogContainer,\n\tProvider,\n} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {\n\tKey,\n\tuseCallback,\n\tuseEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from 'react';\nimport CardsSection from '../CardsSection';\nimport SideNav from '../SideNav';\nimport {LAYOUTS, VIDEO_SUPPORTED_FORMATS} from '../../../constants';\nimport {\n\tdebounce,\n\tisWhatsNewExperience,\n\tsanitizeOnboardingData,\n} from '../../../util/utils';\nimport {AppsUrl, Card, LayoutData} from '../../../util/types';\n\ntype OnboardingProps = {\n\tcontext: {\n\t\tdata: LayoutData;\n\t\tdataInvalidCallback: () => void;\n\t\tisWindowVisible?: boolean;\n\t\tmuteVideo?: boolean;\n\t\tonAction: (action: AppsUrl, cardID: string) => void;\n\t\tonClose: () => void;\n\t\tonPromotionAction: (action: Action, cardID: string) => void;\n\t\tonRender: (numberOfCards: number, cardID: string) => void;\n\t\tonTabChange: (\n\t\t\tcard: {currentIndex: number; cardID: string} | undefined,\n\t\t) => void;\n\t\tonTabClick: (\n\t\t\tcard: {cardID: string; currentIndex: number} | undefined,\n\t\t) => void;\n\t\tvideoSupportedFormats?: string[];\n\t};\n\tlocale: string;\n\ttheme: 'dark' | 'light';\n};\n\nexport default function Onboarding({\n\tcontext: {\n\t\tdata,\n\t\tdataInvalidCallback,\n\t\tisWindowVisible = true,\n\t\tmuteVideo = false,\n\t\tonAction,\n\t\tonClose,\n\t\tonPromotionAction,\n\t\tonRender,\n\t\tonTabChange,\n\t\tonTabClick,\n\t\tvideoSupportedFormats = VIDEO_SUPPORTED_FORMATS,\n\t},\n\tlocale,\n\ttheme,\n}: OnboardingProps): JSX.Element | null {\n\t// State to track the currently selected tab\n\tconst [selectedKey, setSelectedKey] = useState(0);\n\n\t// Refs to store references to card and tab elements\n\tconst cardRefs = useRef<HTMLDivElement[]>([]);\n\tconst tabRefs = useRef<HTMLDivElement[]>([]);\n\n\t// Ref for the scrollable section containing cards\n\tconst cardScrollableSectionRef = useRef<HTMLDivElement>(null);\n\n\t// State to store the list of cards to be displayed\n\tconst [cardList, setCardList] = useState<Card[]>([]);\n\n\t// State to track the current window width for responsive behavior\n\tconst [currentWindowWidth, setCurrentWindowWidth] = useState(\n\t\twindow.innerWidth,\n\t);\n\n\t// Effect to sanitize and validate the onboarding data\n\tuseEffect(() => {\n\t\tif (!data || !Object.values(LAYOUTS).includes(data.layoutID)) {\n\t\t\tdataInvalidCallback(); // Trigger callback if data is invalid\n\t\t} else {\n\t\t\tconst sanitizedCardList: Card[] = sanitizeOnboardingData(\n\t\t\t\tdata,\n\t\t\t\tvideoSupportedFormats,\n\t\t\t);\n\t\t\tif (sanitizedCardList.length > 0) {\n\t\t\t\tsetCardList(sanitizedCardList); // Set the sanitized card list\n\t\t\t} else {\n\t\t\t\tdataInvalidCallback(); // Trigger callback if no valid cards\n\t\t\t}\n\t\t}\n\t\treturn () => {\n\t\t\tif (cardList.length) {\n\t\t\t\tonClose(); // Close the onboarding dialog when component unmounts\n\t\t\t}\n\t\t};\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, []);\n\n\t// Callback to handle tab selection and scrolling\n\tconst onTabSelectionChange = useCallback(\n\t\t(key: Key, isTabItemClicked: boolean) => {\n\t\t\tconst tabKey = key as number;\n\t\t\t// Scroll to the selected card\n\t\t\tcardRefs.current[tabKey]?.scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tblock: 'start',\n\t\t\t});\n\t\t\tif (selectedKey !== tabKey) {\n\t\t\t\tsetSelectedKey(tabKey); // Update the selected tab\n\t\t\t}\n\n\t\t\tif (cardList[tabKey]) {\n\t\t\t\tif (isTabItemClicked) {\n\t\t\t\t\tonTabClick({\n\t\t\t\t\t\tcardID: cardList[tabKey].id,\n\t\t\t\t\t\tcurrentIndex: tabKey + 1,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tonTabChange({\n\t\t\t\t\tcardID: cardList[tabKey].id,\n\t\t\t\t\tcurrentIndex: tabKey + 1,\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t\t[selectedKey, cardList],\n\t);\n\n\t// Debounced function to handle scrolling and update the selected tab\n\tconst handleScroll = debounce(() => {\n\t\tlet minDiff = Infinity;\n\t\tlet topIndex = 0;\n\n\t\tconst container = cardScrollableSectionRef?.current;\n\t\tconst {top, bottom} = container?.getBoundingClientRect() || {};\n\n\t\tif (top && bottom) {\n\t\t\tcardRefs.current.forEach((el, index) => {\n\t\t\t\tconst rect = el.getBoundingClientRect();\n\t\t\t\tconst diff = Math.abs(rect.top - top);\n\n\t\t\t\t// Check if the last card is fully visible at the bottom\n\t\t\t\tif (index === cardRefs.current.length - 1 && rect.bottom <= bottom) {\n\t\t\t\t\ttopIndex = index;\n\t\t\t\t\treturn; // Prioritize the last card if it's fully visible\n\t\t\t\t}\n\n\t\t\t\tif (diff < minDiff) {\n\t\t\t\t\tminDiff = diff;\n\t\t\t\t\ttopIndex = index;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t// Only update state if the selected key has changed\n\t\t\tif (selectedKey !== topIndex) {\n\t\t\t\tsetSelectedKey(topIndex);\n\t\t\t\tconst {id} = cardList[topIndex] || {};\n\t\t\t\tif (id) {\n\t\t\t\t\tonTabChange({\n\t\t\t\t\t\tcardID: id,\n\t\t\t\t\t\tcurrentIndex: topIndex + 1,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}, 100);\n\n\t// Effect to add and remove scroll event listener\n\tuseEffect(() => {\n\t\tconst container = cardScrollableSectionRef.current;\n\t\tif (container) {\n\t\t\tif (data?.layoutID && isWhatsNewExperience(data.layoutID)) {\n\t\t\t\tcontainer.addEventListener('scroll', handleScroll);\n\t\t\t}\n\t\t}\n\t\treturn () => {\n\t\t\tif (container) {\n\t\t\t\tcontainer.removeEventListener('scroll', handleScroll);\n\t\t\t}\n\t\t};\n\t}, [data?.layoutID, handleScroll]);\n\n\t// Effect to handle window resize and update the current window width\n\tuseEffect(() => {\n\t\tconst debouncedOnResize = debounce(() => {\n\t\t\t// Avoid triggering unnecessary state updates\n\t\t\tconst newWidth = window.innerWidth;\n\t\t\tif (newWidth !== currentWindowWidth) {\n\t\t\t\tsetCurrentWindowWidth(newWidth);\n\t\t\t}\n\t\t}, 100);\n\n\t\tif (cardList.length > 0) {\n\t\t\tonRender(cardList.length, cardList[0]?.id || ''); // Trigger render callback\n\t\t\twindow.addEventListener('resize', debouncedOnResize);\n\t\t}\n\n\t\treturn () => {\n\t\t\twindow.removeEventListener('resize', debouncedOnResize);\n\t\t};\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [cardList.length, currentWindowWidth]);\n\n\t// Determine if the side nav experience should be shown\n\tconst sideNavExperience = useMemo(\n\t\t() => isWhatsNewExperience(data.layoutID) && currentWindowWidth > 520,\n\t\t[currentWindowWidth, data.layoutID],\n\t);\n\n\t// Return null if there are no cards to display\n\tif (cardList.length === 0) {\n\t\treturn null;\n\t}\n\n\tfunction getDialogHeightStyle(): React.CSSProperties {\n\t\tif (sideNavExperience) {\n\t\t\treturn {height: '39.9375rem'};\n\t\t}\n\t\treturn {height: '100%'};\n\t}\n\n\t// Render the onboarding UI\n\treturn (\n\t\t<Provider locale={locale} colorScheme={theme}>\n\t\t\t<DialogContainer onDismiss={onClose}>\n\t\t\t\t<CustomDialog\n\t\t\t\t\tisDismissible\n\t\t\t\t\tstyles={style({maxWidth: 848})}\n\t\t\t\t\tpadding='none'\n\t\t\t\t\taria-label={data.title}\n\t\t\t\t\tUNSAFE_style={getDialogHeightStyle()} // Set the height of the dialog based on layoutID\n\t\t\t\t>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tsize: 'full',\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render the side navigation if applicable */}\n\t\t\t\t\t\t{sideNavExperience && (\n\t\t\t\t\t\t\t<SideNav\n\t\t\t\t\t\t\t\tmediaList={data.mediaList}\n\t\t\t\t\t\t\t\tonTabSelectionChange={(key: Key) => {\n\t\t\t\t\t\t\t\t\tonTabSelectionChange(key, true);\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tselectedTab={selectedKey}\n\t\t\t\t\t\t\t\tsubTitle={data.subtitle}\n\t\t\t\t\t\t\t\ttabRefs={tabRefs}\n\t\t\t\t\t\t\t\ttitle={data.title}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t)}\n\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tstyle={{display: 'flex', flexDirection: 'column', height: '100%'}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{/* Close button - fixed at top */}\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclassName={style({\n\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\tjustifyContent: 'end',\n\t\t\t\t\t\t\t\t\theight: 32,\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<div className={style({paddingTop: 4, paddingEnd: 4})}>\n\t\t\t\t\t\t\t\t\t<CloseButton UNSAFE_style={{cursor: 'pointer'}} />\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t{/* Scrollable cards section */}\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tref={cardScrollableSectionRef}\n\t\t\t\t\t\t\t\tstyle={{flex: 1, overflow: 'auto'}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<CardsSection\n\t\t\t\t\t\t\t\t\tcardList={cardList}\n\t\t\t\t\t\t\t\t\tcardRefs={cardRefs}\n\t\t\t\t\t\t\t\t\theading={data.title}\n\t\t\t\t\t\t\t\t\tsubHeading={data.subtitle}\n\t\t\t\t\t\t\t\t\tisWindowVisible={isWindowVisible}\n\t\t\t\t\t\t\t\t\tlayoutId={data.layoutID}\n\t\t\t\t\t\t\t\t\tmuteVideo={muteVideo}\n\t\t\t\t\t\t\t\t\tnonSideNavExperience={!sideNavExperience}\n\t\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\t\t\tselectedKey={selectedKey}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</CustomDialog>\n\t\t\t</DialogContainer>\n\t\t</Provider>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  .Za92 {
    width: 100%;
  }


  .Fb92 {
    height: 100%;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AAmQmC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/Onboarding/Onboarding.tsx"],"sourcesContent":["/*\n *************************************************************************\n *  ADOBE CONFIDENTIAL\n *\n *  Copyright 2025 Adobe\n *  All Rights Reserved.\n *\n *  NOTICE:  All information contained herein is, and remains\n *  the property of Adobe and its suppliers, if any. The intellectual\n *  and technical concepts contained herein are proprietary to Adobe\n *  and its suppliers and are protected by all applicable intellectual\n *  property laws, including trade secret and copyright laws.\n *  Dissemination of this information or reproduction of this material\n *  is strictly forbidden unless prior written permission is obtained\n *  from Adobe.\n *************************************************************************\n */\n\nimport {Action} from '@nest/interface';\nimport {\n\tCloseButton,\n\tCustomDialog,\n\tDialogContainer,\n\tProvider,\n} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {\n\tKey,\n\tuseCallback,\n\tuseEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from 'react';\nimport CardsSection from '../CardsSection';\nimport SideNav from '../SideNav';\nimport {LAYOUTS, VIDEO_SUPPORTED_FORMATS} from '../../../constants';\nimport {\n\tdebounce,\n\tisWhatsNewExperience,\n\tsanitizeOnboardingData,\n} from '../../../util/utils';\nimport {AppsUrl, Card, LayoutData} from '../../../util/types';\n\ntype OnboardingProps = {\n\tcontext: {\n\t\tdata: LayoutData;\n\t\tdataInvalidCallback: () => void;\n\t\tisWindowVisible?: boolean;\n\t\tmuteVideo?: boolean;\n\t\tonAction: (action: AppsUrl, cardID: string) => void;\n\t\tonClose: () => void;\n\t\tonPromotionAction: (action: Action, cardID: string) => void;\n\t\tonRender: (numberOfCards: number, cardID: string) => void;\n\t\tonTabChange: (\n\t\t\tcard: {currentIndex: number; cardID: string} | undefined,\n\t\t) => void;\n\t\tonTabClick: (\n\t\t\tcard: {cardID: string; currentIndex: number} | undefined,\n\t\t) => void;\n\t\tvideoSupportedFormats?: string[];\n\t};\n\tlocale: string;\n\ttheme: 'dark' | 'light';\n};\n\nexport default function Onboarding({\n\tcontext: {\n\t\tdata,\n\t\tdataInvalidCallback,\n\t\tisWindowVisible = true,\n\t\tmuteVideo = false,\n\t\tonAction,\n\t\tonClose,\n\t\tonPromotionAction,\n\t\tonRender,\n\t\tonTabChange,\n\t\tonTabClick,\n\t\tvideoSupportedFormats = VIDEO_SUPPORTED_FORMATS,\n\t},\n\tlocale,\n\ttheme,\n}: OnboardingProps): JSX.Element | null {\n\t// State to track the currently selected tab\n\tconst [selectedKey, setSelectedKey] = useState(0);\n\n\t// Refs to store references to card and tab elements\n\tconst cardRefs = useRef<HTMLDivElement[]>([]);\n\tconst tabRefs = useRef<HTMLDivElement[]>([]);\n\n\t// Ref for the scrollable section containing cards\n\tconst cardScrollableSectionRef = useRef<HTMLDivElement>(null);\n\n\t// State to store the list of cards to be displayed\n\tconst [cardList, setCardList] = useState<Card[]>([]);\n\n\t// State to track the current window width for responsive behavior\n\tconst [currentWindowWidth, setCurrentWindowWidth] = useState(\n\t\twindow.innerWidth,\n\t);\n\n\t// Effect to sanitize and validate the onboarding data\n\tuseEffect(() => {\n\t\tif (!data || !Object.values(LAYOUTS).includes(data.layoutID)) {\n\t\t\tdataInvalidCallback(); // Trigger callback if data is invalid\n\t\t} else {\n\t\t\tconst sanitizedCardList: Card[] = sanitizeOnboardingData(\n\t\t\t\tdata,\n\t\t\t\tvideoSupportedFormats,\n\t\t\t);\n\t\t\tif (sanitizedCardList.length > 0) {\n\t\t\t\tsetCardList(sanitizedCardList); // Set the sanitized card list\n\t\t\t} else {\n\t\t\t\tdataInvalidCallback(); // Trigger callback if no valid cards\n\t\t\t}\n\t\t}\n\t\treturn () => {\n\t\t\tif (cardList.length) {\n\t\t\t\tonClose(); // Close the onboarding dialog when component unmounts\n\t\t\t}\n\t\t};\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, []);\n\n\t// Callback to handle tab selection and scrolling\n\tconst onTabSelectionChange = useCallback(\n\t\t(key: Key, isTabItemClicked: boolean) => {\n\t\t\tconst tabKey = key as number;\n\t\t\t// Scroll to the selected card\n\t\t\tcardRefs.current[tabKey]?.scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tblock: 'start',\n\t\t\t});\n\t\t\tif (selectedKey !== tabKey) {\n\t\t\t\tsetSelectedKey(tabKey); // Update the selected tab\n\t\t\t}\n\n\t\t\tif (cardList[tabKey]) {\n\t\t\t\tif (isTabItemClicked) {\n\t\t\t\t\tonTabClick({\n\t\t\t\t\t\tcardID: cardList[tabKey].id,\n\t\t\t\t\t\tcurrentIndex: tabKey + 1,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tonTabChange({\n\t\t\t\t\tcardID: cardList[tabKey].id,\n\t\t\t\t\tcurrentIndex: tabKey + 1,\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t\t[selectedKey, cardList],\n\t);\n\n\t// Debounced function to handle scrolling and update the selected tab\n\tconst handleScroll = debounce(() => {\n\t\tlet minDiff = Infinity;\n\t\tlet topIndex = 0;\n\n\t\tconst container = cardScrollableSectionRef?.current;\n\t\tconst {top, bottom} = container?.getBoundingClientRect() || {};\n\n\t\tif (top && bottom) {\n\t\t\tcardRefs.current.forEach((el, index) => {\n\t\t\t\tconst rect = el.getBoundingClientRect();\n\t\t\t\tconst diff = Math.abs(rect.top - top);\n\n\t\t\t\t// Check if the last card is fully visible at the bottom\n\t\t\t\tif (index === cardRefs.current.length - 1 && rect.bottom <= bottom) {\n\t\t\t\t\ttopIndex = index;\n\t\t\t\t\treturn; // Prioritize the last card if it's fully visible\n\t\t\t\t}\n\n\t\t\t\tif (diff < minDiff) {\n\t\t\t\t\tminDiff = diff;\n\t\t\t\t\ttopIndex = index;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t// Only update state if the selected key has changed\n\t\t\tif (selectedKey !== topIndex) {\n\t\t\t\tsetSelectedKey(topIndex);\n\t\t\t\tconst {id} = cardList[topIndex] || {};\n\t\t\t\tif (id) {\n\t\t\t\t\tonTabChange({\n\t\t\t\t\t\tcardID: id,\n\t\t\t\t\t\tcurrentIndex: topIndex + 1,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}, 100);\n\n\t// Effect to add and remove scroll event listener\n\tuseEffect(() => {\n\t\tconst container = cardScrollableSectionRef.current;\n\t\tif (container) {\n\t\t\tif (data?.layoutID && isWhatsNewExperience(data.layoutID)) {\n\t\t\t\tcontainer.addEventListener('scroll', handleScroll);\n\t\t\t}\n\t\t}\n\t\treturn () => {\n\t\t\tif (container) {\n\t\t\t\tcontainer.removeEventListener('scroll', handleScroll);\n\t\t\t}\n\t\t};\n\t}, [data?.layoutID, handleScroll]);\n\n\t// Effect to handle window resize and update the current window width\n\tuseEffect(() => {\n\t\tconst debouncedOnResize = debounce(() => {\n\t\t\t// Avoid triggering unnecessary state updates\n\t\t\tconst newWidth = window.innerWidth;\n\t\t\tif (newWidth !== currentWindowWidth) {\n\t\t\t\tsetCurrentWindowWidth(newWidth);\n\t\t\t}\n\t\t}, 100);\n\n\t\tif (cardList.length > 0) {\n\t\t\tonRender(cardList.length, cardList[0]?.id || ''); // Trigger render callback\n\t\t\twindow.addEventListener('resize', debouncedOnResize);\n\t\t}\n\n\t\treturn () => {\n\t\t\twindow.removeEventListener('resize', debouncedOnResize);\n\t\t};\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [cardList.length, currentWindowWidth]);\n\n\t// Determine if the side nav experience should be shown\n\tconst sideNavExperience = useMemo(\n\t\t() => isWhatsNewExperience(data.layoutID) && currentWindowWidth > 520,\n\t\t[currentWindowWidth, data.layoutID],\n\t);\n\n\t// Return null if there are no cards to display\n\tif (cardList.length === 0) {\n\t\treturn null;\n\t}\n\n\tfunction getDialogHeightStyle(): React.CSSProperties {\n\t\tif (sideNavExperience) {\n\t\t\treturn {height: '39.9375rem'};\n\t\t}\n\t\treturn {height: '100%'};\n\t}\n\n\t// Render the onboarding UI\n\treturn (\n\t\t<Provider locale={locale} colorScheme={theme}>\n\t\t\t<DialogContainer onDismiss={onClose}>\n\t\t\t\t<CustomDialog\n\t\t\t\t\tisDismissible\n\t\t\t\t\tstyles={style({maxWidth: 848})}\n\t\t\t\t\tpadding='none'\n\t\t\t\t\taria-label={data.title}\n\t\t\t\t\tUNSAFE_style={getDialogHeightStyle()} // Set the height of the dialog based on layoutID\n\t\t\t\t>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tsize: 'full',\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render the side navigation if applicable */}\n\t\t\t\t\t\t{sideNavExperience && (\n\t\t\t\t\t\t\t<SideNav\n\t\t\t\t\t\t\t\tmediaList={data.mediaList}\n\t\t\t\t\t\t\t\tonTabSelectionChange={(key: Key) => {\n\t\t\t\t\t\t\t\t\tonTabSelectionChange(key, true);\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tselectedTab={selectedKey}\n\t\t\t\t\t\t\t\tsubTitle={data.subtitle}\n\t\t\t\t\t\t\t\ttabRefs={tabRefs}\n\t\t\t\t\t\t\t\ttitle={data.title}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t)}\n\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tstyle={{display: 'flex', flexDirection: 'column', height: '100%'}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{/* Close button - fixed at top */}\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclassName={style({\n\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\tjustifyContent: 'end',\n\t\t\t\t\t\t\t\t\theight: 32,\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<div className={style({paddingTop: 4, paddingEnd: 4})}>\n\t\t\t\t\t\t\t\t\t<CloseButton UNSAFE_style={{cursor: 'pointer'}} />\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t{/* Scrollable cards section */}\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tref={cardScrollableSectionRef}\n\t\t\t\t\t\t\t\tstyle={{flex: 1, overflow: 'auto'}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<CardsSection\n\t\t\t\t\t\t\t\t\tcardList={cardList}\n\t\t\t\t\t\t\t\t\tcardRefs={cardRefs}\n\t\t\t\t\t\t\t\t\theading={data.title}\n\t\t\t\t\t\t\t\t\tsubHeading={data.subtitle}\n\t\t\t\t\t\t\t\t\tisWindowVisible={isWindowVisible}\n\t\t\t\t\t\t\t\t\tlayoutId={data.layoutID}\n\t\t\t\t\t\t\t\t\tmuteVideo={muteVideo}\n\t\t\t\t\t\t\t\t\tnonSideNavExperience={!sideNavExperience}\n\t\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\t\t\tselectedKey={selectedKey}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</CustomDialog>\n\t\t\t</DialogContainer>\n\t\t</Provider>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .sd92 {
    display: flex;
  }


  ._Cb92 {
    justify-content: end;
  }


  .Fx92 {
    height: calc(2rem * var(--s2-scale));
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AA2R2C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/Onboarding/Onboarding.tsx"],"sourcesContent":["/*\n *************************************************************************\n *  ADOBE CONFIDENTIAL\n *\n *  Copyright 2025 Adobe\n *  All Rights Reserved.\n *\n *  NOTICE:  All information contained herein is, and remains\n *  the property of Adobe and its suppliers, if any. The intellectual\n *  and technical concepts contained herein are proprietary to Adobe\n *  and its suppliers and are protected by all applicable intellectual\n *  property laws, including trade secret and copyright laws.\n *  Dissemination of this information or reproduction of this material\n *  is strictly forbidden unless prior written permission is obtained\n *  from Adobe.\n *************************************************************************\n */\n\nimport {Action} from '@nest/interface';\nimport {\n\tCloseButton,\n\tCustomDialog,\n\tDialogContainer,\n\tProvider,\n} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {\n\tKey,\n\tuseCallback,\n\tuseEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from 'react';\nimport CardsSection from '../CardsSection';\nimport SideNav from '../SideNav';\nimport {LAYOUTS, VIDEO_SUPPORTED_FORMATS} from '../../../constants';\nimport {\n\tdebounce,\n\tisWhatsNewExperience,\n\tsanitizeOnboardingData,\n} from '../../../util/utils';\nimport {AppsUrl, Card, LayoutData} from '../../../util/types';\n\ntype OnboardingProps = {\n\tcontext: {\n\t\tdata: LayoutData;\n\t\tdataInvalidCallback: () => void;\n\t\tisWindowVisible?: boolean;\n\t\tmuteVideo?: boolean;\n\t\tonAction: (action: AppsUrl, cardID: string) => void;\n\t\tonClose: () => void;\n\t\tonPromotionAction: (action: Action, cardID: string) => void;\n\t\tonRender: (numberOfCards: number, cardID: string) => void;\n\t\tonTabChange: (\n\t\t\tcard: {currentIndex: number; cardID: string} | undefined,\n\t\t) => void;\n\t\tonTabClick: (\n\t\t\tcard: {cardID: string; currentIndex: number} | undefined,\n\t\t) => void;\n\t\tvideoSupportedFormats?: string[];\n\t};\n\tlocale: string;\n\ttheme: 'dark' | 'light';\n};\n\nexport default function Onboarding({\n\tcontext: {\n\t\tdata,\n\t\tdataInvalidCallback,\n\t\tisWindowVisible = true,\n\t\tmuteVideo = false,\n\t\tonAction,\n\t\tonClose,\n\t\tonPromotionAction,\n\t\tonRender,\n\t\tonTabChange,\n\t\tonTabClick,\n\t\tvideoSupportedFormats = VIDEO_SUPPORTED_FORMATS,\n\t},\n\tlocale,\n\ttheme,\n}: OnboardingProps): JSX.Element | null {\n\t// State to track the currently selected tab\n\tconst [selectedKey, setSelectedKey] = useState(0);\n\n\t// Refs to store references to card and tab elements\n\tconst cardRefs = useRef<HTMLDivElement[]>([]);\n\tconst tabRefs = useRef<HTMLDivElement[]>([]);\n\n\t// Ref for the scrollable section containing cards\n\tconst cardScrollableSectionRef = useRef<HTMLDivElement>(null);\n\n\t// State to store the list of cards to be displayed\n\tconst [cardList, setCardList] = useState<Card[]>([]);\n\n\t// State to track the current window width for responsive behavior\n\tconst [currentWindowWidth, setCurrentWindowWidth] = useState(\n\t\twindow.innerWidth,\n\t);\n\n\t// Effect to sanitize and validate the onboarding data\n\tuseEffect(() => {\n\t\tif (!data || !Object.values(LAYOUTS).includes(data.layoutID)) {\n\t\t\tdataInvalidCallback(); // Trigger callback if data is invalid\n\t\t} else {\n\t\t\tconst sanitizedCardList: Card[] = sanitizeOnboardingData(\n\t\t\t\tdata,\n\t\t\t\tvideoSupportedFormats,\n\t\t\t);\n\t\t\tif (sanitizedCardList.length > 0) {\n\t\t\t\tsetCardList(sanitizedCardList); // Set the sanitized card list\n\t\t\t} else {\n\t\t\t\tdataInvalidCallback(); // Trigger callback if no valid cards\n\t\t\t}\n\t\t}\n\t\treturn () => {\n\t\t\tif (cardList.length) {\n\t\t\t\tonClose(); // Close the onboarding dialog when component unmounts\n\t\t\t}\n\t\t};\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, []);\n\n\t// Callback to handle tab selection and scrolling\n\tconst onTabSelectionChange = useCallback(\n\t\t(key: Key, isTabItemClicked: boolean) => {\n\t\t\tconst tabKey = key as number;\n\t\t\t// Scroll to the selected card\n\t\t\tcardRefs.current[tabKey]?.scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tblock: 'start',\n\t\t\t});\n\t\t\tif (selectedKey !== tabKey) {\n\t\t\t\tsetSelectedKey(tabKey); // Update the selected tab\n\t\t\t}\n\n\t\t\tif (cardList[tabKey]) {\n\t\t\t\tif (isTabItemClicked) {\n\t\t\t\t\tonTabClick({\n\t\t\t\t\t\tcardID: cardList[tabKey].id,\n\t\t\t\t\t\tcurrentIndex: tabKey + 1,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tonTabChange({\n\t\t\t\t\tcardID: cardList[tabKey].id,\n\t\t\t\t\tcurrentIndex: tabKey + 1,\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t\t[selectedKey, cardList],\n\t);\n\n\t// Debounced function to handle scrolling and update the selected tab\n\tconst handleScroll = debounce(() => {\n\t\tlet minDiff = Infinity;\n\t\tlet topIndex = 0;\n\n\t\tconst container = cardScrollableSectionRef?.current;\n\t\tconst {top, bottom} = container?.getBoundingClientRect() || {};\n\n\t\tif (top && bottom) {\n\t\t\tcardRefs.current.forEach((el, index) => {\n\t\t\t\tconst rect = el.getBoundingClientRect();\n\t\t\t\tconst diff = Math.abs(rect.top - top);\n\n\t\t\t\t// Check if the last card is fully visible at the bottom\n\t\t\t\tif (index === cardRefs.current.length - 1 && rect.bottom <= bottom) {\n\t\t\t\t\ttopIndex = index;\n\t\t\t\t\treturn; // Prioritize the last card if it's fully visible\n\t\t\t\t}\n\n\t\t\t\tif (diff < minDiff) {\n\t\t\t\t\tminDiff = diff;\n\t\t\t\t\ttopIndex = index;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t// Only update state if the selected key has changed\n\t\t\tif (selectedKey !== topIndex) {\n\t\t\t\tsetSelectedKey(topIndex);\n\t\t\t\tconst {id} = cardList[topIndex] || {};\n\t\t\t\tif (id) {\n\t\t\t\t\tonTabChange({\n\t\t\t\t\t\tcardID: id,\n\t\t\t\t\t\tcurrentIndex: topIndex + 1,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}, 100);\n\n\t// Effect to add and remove scroll event listener\n\tuseEffect(() => {\n\t\tconst container = cardScrollableSectionRef.current;\n\t\tif (container) {\n\t\t\tif (data?.layoutID && isWhatsNewExperience(data.layoutID)) {\n\t\t\t\tcontainer.addEventListener('scroll', handleScroll);\n\t\t\t}\n\t\t}\n\t\treturn () => {\n\t\t\tif (container) {\n\t\t\t\tcontainer.removeEventListener('scroll', handleScroll);\n\t\t\t}\n\t\t};\n\t}, [data?.layoutID, handleScroll]);\n\n\t// Effect to handle window resize and update the current window width\n\tuseEffect(() => {\n\t\tconst debouncedOnResize = debounce(() => {\n\t\t\t// Avoid triggering unnecessary state updates\n\t\t\tconst newWidth = window.innerWidth;\n\t\t\tif (newWidth !== currentWindowWidth) {\n\t\t\t\tsetCurrentWindowWidth(newWidth);\n\t\t\t}\n\t\t}, 100);\n\n\t\tif (cardList.length > 0) {\n\t\t\tonRender(cardList.length, cardList[0]?.id || ''); // Trigger render callback\n\t\t\twindow.addEventListener('resize', debouncedOnResize);\n\t\t}\n\n\t\treturn () => {\n\t\t\twindow.removeEventListener('resize', debouncedOnResize);\n\t\t};\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [cardList.length, currentWindowWidth]);\n\n\t// Determine if the side nav experience should be shown\n\tconst sideNavExperience = useMemo(\n\t\t() => isWhatsNewExperience(data.layoutID) && currentWindowWidth > 520,\n\t\t[currentWindowWidth, data.layoutID],\n\t);\n\n\t// Return null if there are no cards to display\n\tif (cardList.length === 0) {\n\t\treturn null;\n\t}\n\n\tfunction getDialogHeightStyle(): React.CSSProperties {\n\t\tif (sideNavExperience) {\n\t\t\treturn {height: '39.9375rem'};\n\t\t}\n\t\treturn {height: '100%'};\n\t}\n\n\t// Render the onboarding UI\n\treturn (\n\t\t<Provider locale={locale} colorScheme={theme}>\n\t\t\t<DialogContainer onDismiss={onClose}>\n\t\t\t\t<CustomDialog\n\t\t\t\t\tisDismissible\n\t\t\t\t\tstyles={style({maxWidth: 848})}\n\t\t\t\t\tpadding='none'\n\t\t\t\t\taria-label={data.title}\n\t\t\t\t\tUNSAFE_style={getDialogHeightStyle()} // Set the height of the dialog based on layoutID\n\t\t\t\t>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tsize: 'full',\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render the side navigation if applicable */}\n\t\t\t\t\t\t{sideNavExperience && (\n\t\t\t\t\t\t\t<SideNav\n\t\t\t\t\t\t\t\tmediaList={data.mediaList}\n\t\t\t\t\t\t\t\tonTabSelectionChange={(key: Key) => {\n\t\t\t\t\t\t\t\t\tonTabSelectionChange(key, true);\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tselectedTab={selectedKey}\n\t\t\t\t\t\t\t\tsubTitle={data.subtitle}\n\t\t\t\t\t\t\t\ttabRefs={tabRefs}\n\t\t\t\t\t\t\t\ttitle={data.title}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t)}\n\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tstyle={{display: 'flex', flexDirection: 'column', height: '100%'}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{/* Close button - fixed at top */}\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclassName={style({\n\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\tjustifyContent: 'end',\n\t\t\t\t\t\t\t\t\theight: 32,\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<div className={style({paddingTop: 4, paddingEnd: 4})}>\n\t\t\t\t\t\t\t\t\t<CloseButton UNSAFE_style={{cursor: 'pointer'}} />\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t{/* Scrollable cards section */}\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tref={cardScrollableSectionRef}\n\t\t\t\t\t\t\t\tstyle={{flex: 1, overflow: 'auto'}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<CardsSection\n\t\t\t\t\t\t\t\t\tcardList={cardList}\n\t\t\t\t\t\t\t\t\tcardRefs={cardRefs}\n\t\t\t\t\t\t\t\t\theading={data.title}\n\t\t\t\t\t\t\t\t\tsubHeading={data.subtitle}\n\t\t\t\t\t\t\t\t\tisWindowVisible={isWindowVisible}\n\t\t\t\t\t\t\t\t\tlayoutId={data.layoutID}\n\t\t\t\t\t\t\t\t\tmuteVideo={muteVideo}\n\t\t\t\t\t\t\t\t\tnonSideNavExperience={!sideNavExperience}\n\t\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\t\t\tselectedKey={selectedKey}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</CustomDialog>\n\t\t\t</DialogContainer>\n\t\t</Provider>\n\t);\n}\n"],"names":[],"version":3} */
@layer _.a;

@layer _.a {
  .Tp92 {
    padding-top: 4px;
  }


  .Rp92 {
    padding-inline-end: 4px;
  }
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"mappings":"AAiSgD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sources":["../../applets/onboarding/src/view/components/Onboarding/Onboarding.tsx"],"sourcesContent":["/*\n *************************************************************************\n *  ADOBE CONFIDENTIAL\n *\n *  Copyright 2025 Adobe\n *  All Rights Reserved.\n *\n *  NOTICE:  All information contained herein is, and remains\n *  the property of Adobe and its suppliers, if any. The intellectual\n *  and technical concepts contained herein are proprietary to Adobe\n *  and its suppliers and are protected by all applicable intellectual\n *  property laws, including trade secret and copyright laws.\n *  Dissemination of this information or reproduction of this material\n *  is strictly forbidden unless prior written permission is obtained\n *  from Adobe.\n *************************************************************************\n */\n\nimport {Action} from '@nest/interface';\nimport {\n\tCloseButton,\n\tCustomDialog,\n\tDialogContainer,\n\tProvider,\n} from '@react-spectrum/s2';\nimport {style} from '@react-spectrum/s2/style' with {type: 'macro'};\nimport React, {\n\tKey,\n\tuseCallback,\n\tuseEffect,\n\tuseMemo,\n\tuseRef,\n\tuseState,\n} from 'react';\nimport CardsSection from '../CardsSection';\nimport SideNav from '../SideNav';\nimport {LAYOUTS, VIDEO_SUPPORTED_FORMATS} from '../../../constants';\nimport {\n\tdebounce,\n\tisWhatsNewExperience,\n\tsanitizeOnboardingData,\n} from '../../../util/utils';\nimport {AppsUrl, Card, LayoutData} from '../../../util/types';\n\ntype OnboardingProps = {\n\tcontext: {\n\t\tdata: LayoutData;\n\t\tdataInvalidCallback: () => void;\n\t\tisWindowVisible?: boolean;\n\t\tmuteVideo?: boolean;\n\t\tonAction: (action: AppsUrl, cardID: string) => void;\n\t\tonClose: () => void;\n\t\tonPromotionAction: (action: Action, cardID: string) => void;\n\t\tonRender: (numberOfCards: number, cardID: string) => void;\n\t\tonTabChange: (\n\t\t\tcard: {currentIndex: number; cardID: string} | undefined,\n\t\t) => void;\n\t\tonTabClick: (\n\t\t\tcard: {cardID: string; currentIndex: number} | undefined,\n\t\t) => void;\n\t\tvideoSupportedFormats?: string[];\n\t};\n\tlocale: string;\n\ttheme: 'dark' | 'light';\n};\n\nexport default function Onboarding({\n\tcontext: {\n\t\tdata,\n\t\tdataInvalidCallback,\n\t\tisWindowVisible = true,\n\t\tmuteVideo = false,\n\t\tonAction,\n\t\tonClose,\n\t\tonPromotionAction,\n\t\tonRender,\n\t\tonTabChange,\n\t\tonTabClick,\n\t\tvideoSupportedFormats = VIDEO_SUPPORTED_FORMATS,\n\t},\n\tlocale,\n\ttheme,\n}: OnboardingProps): JSX.Element | null {\n\t// State to track the currently selected tab\n\tconst [selectedKey, setSelectedKey] = useState(0);\n\n\t// Refs to store references to card and tab elements\n\tconst cardRefs = useRef<HTMLDivElement[]>([]);\n\tconst tabRefs = useRef<HTMLDivElement[]>([]);\n\n\t// Ref for the scrollable section containing cards\n\tconst cardScrollableSectionRef = useRef<HTMLDivElement>(null);\n\n\t// State to store the list of cards to be displayed\n\tconst [cardList, setCardList] = useState<Card[]>([]);\n\n\t// State to track the current window width for responsive behavior\n\tconst [currentWindowWidth, setCurrentWindowWidth] = useState(\n\t\twindow.innerWidth,\n\t);\n\n\t// Effect to sanitize and validate the onboarding data\n\tuseEffect(() => {\n\t\tif (!data || !Object.values(LAYOUTS).includes(data.layoutID)) {\n\t\t\tdataInvalidCallback(); // Trigger callback if data is invalid\n\t\t} else {\n\t\t\tconst sanitizedCardList: Card[] = sanitizeOnboardingData(\n\t\t\t\tdata,\n\t\t\t\tvideoSupportedFormats,\n\t\t\t);\n\t\t\tif (sanitizedCardList.length > 0) {\n\t\t\t\tsetCardList(sanitizedCardList); // Set the sanitized card list\n\t\t\t} else {\n\t\t\t\tdataInvalidCallback(); // Trigger callback if no valid cards\n\t\t\t}\n\t\t}\n\t\treturn () => {\n\t\t\tif (cardList.length) {\n\t\t\t\tonClose(); // Close the onboarding dialog when component unmounts\n\t\t\t}\n\t\t};\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, []);\n\n\t// Callback to handle tab selection and scrolling\n\tconst onTabSelectionChange = useCallback(\n\t\t(key: Key, isTabItemClicked: boolean) => {\n\t\t\tconst tabKey = key as number;\n\t\t\t// Scroll to the selected card\n\t\t\tcardRefs.current[tabKey]?.scrollIntoView({\n\t\t\t\tbehavior: 'smooth',\n\t\t\t\tblock: 'start',\n\t\t\t});\n\t\t\tif (selectedKey !== tabKey) {\n\t\t\t\tsetSelectedKey(tabKey); // Update the selected tab\n\t\t\t}\n\n\t\t\tif (cardList[tabKey]) {\n\t\t\t\tif (isTabItemClicked) {\n\t\t\t\t\tonTabClick({\n\t\t\t\t\t\tcardID: cardList[tabKey].id,\n\t\t\t\t\t\tcurrentIndex: tabKey + 1,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tonTabChange({\n\t\t\t\t\tcardID: cardList[tabKey].id,\n\t\t\t\t\tcurrentIndex: tabKey + 1,\n\t\t\t\t});\n\t\t\t}\n\t\t},\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t\t[selectedKey, cardList],\n\t);\n\n\t// Debounced function to handle scrolling and update the selected tab\n\tconst handleScroll = debounce(() => {\n\t\tlet minDiff = Infinity;\n\t\tlet topIndex = 0;\n\n\t\tconst container = cardScrollableSectionRef?.current;\n\t\tconst {top, bottom} = container?.getBoundingClientRect() || {};\n\n\t\tif (top && bottom) {\n\t\t\tcardRefs.current.forEach((el, index) => {\n\t\t\t\tconst rect = el.getBoundingClientRect();\n\t\t\t\tconst diff = Math.abs(rect.top - top);\n\n\t\t\t\t// Check if the last card is fully visible at the bottom\n\t\t\t\tif (index === cardRefs.current.length - 1 && rect.bottom <= bottom) {\n\t\t\t\t\ttopIndex = index;\n\t\t\t\t\treturn; // Prioritize the last card if it's fully visible\n\t\t\t\t}\n\n\t\t\t\tif (diff < minDiff) {\n\t\t\t\t\tminDiff = diff;\n\t\t\t\t\ttopIndex = index;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t// Only update state if the selected key has changed\n\t\t\tif (selectedKey !== topIndex) {\n\t\t\t\tsetSelectedKey(topIndex);\n\t\t\t\tconst {id} = cardList[topIndex] || {};\n\t\t\t\tif (id) {\n\t\t\t\t\tonTabChange({\n\t\t\t\t\t\tcardID: id,\n\t\t\t\t\t\tcurrentIndex: topIndex + 1,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}, 100);\n\n\t// Effect to add and remove scroll event listener\n\tuseEffect(() => {\n\t\tconst container = cardScrollableSectionRef.current;\n\t\tif (container) {\n\t\t\tif (data?.layoutID && isWhatsNewExperience(data.layoutID)) {\n\t\t\t\tcontainer.addEventListener('scroll', handleScroll);\n\t\t\t}\n\t\t}\n\t\treturn () => {\n\t\t\tif (container) {\n\t\t\t\tcontainer.removeEventListener('scroll', handleScroll);\n\t\t\t}\n\t\t};\n\t}, [data?.layoutID, handleScroll]);\n\n\t// Effect to handle window resize and update the current window width\n\tuseEffect(() => {\n\t\tconst debouncedOnResize = debounce(() => {\n\t\t\t// Avoid triggering unnecessary state updates\n\t\t\tconst newWidth = window.innerWidth;\n\t\t\tif (newWidth !== currentWindowWidth) {\n\t\t\t\tsetCurrentWindowWidth(newWidth);\n\t\t\t}\n\t\t}, 100);\n\n\t\tif (cardList.length > 0) {\n\t\t\tonRender(cardList.length, cardList[0]?.id || ''); // Trigger render callback\n\t\t\twindow.addEventListener('resize', debouncedOnResize);\n\t\t}\n\n\t\treturn () => {\n\t\t\twindow.removeEventListener('resize', debouncedOnResize);\n\t\t};\n\t\t// eslint-disable-next-line react-hooks/exhaustive-deps\n\t}, [cardList.length, currentWindowWidth]);\n\n\t// Determine if the side nav experience should be shown\n\tconst sideNavExperience = useMemo(\n\t\t() => isWhatsNewExperience(data.layoutID) && currentWindowWidth > 520,\n\t\t[currentWindowWidth, data.layoutID],\n\t);\n\n\t// Return null if there are no cards to display\n\tif (cardList.length === 0) {\n\t\treturn null;\n\t}\n\n\tfunction getDialogHeightStyle(): React.CSSProperties {\n\t\tif (sideNavExperience) {\n\t\t\treturn {height: '39.9375rem'};\n\t\t}\n\t\treturn {height: '100%'};\n\t}\n\n\t// Render the onboarding UI\n\treturn (\n\t\t<Provider locale={locale} colorScheme={theme}>\n\t\t\t<DialogContainer onDismiss={onClose}>\n\t\t\t\t<CustomDialog\n\t\t\t\t\tisDismissible\n\t\t\t\t\tstyles={style({maxWidth: 848})}\n\t\t\t\t\tpadding='none'\n\t\t\t\t\taria-label={data.title}\n\t\t\t\t\tUNSAFE_style={getDialogHeightStyle()} // Set the height of the dialog based on layoutID\n\t\t\t\t>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName={style({\n\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\tsize: 'full',\n\t\t\t\t\t\t})}\n\t\t\t\t\t>\n\t\t\t\t\t\t{/* Render the side navigation if applicable */}\n\t\t\t\t\t\t{sideNavExperience && (\n\t\t\t\t\t\t\t<SideNav\n\t\t\t\t\t\t\t\tmediaList={data.mediaList}\n\t\t\t\t\t\t\t\tonTabSelectionChange={(key: Key) => {\n\t\t\t\t\t\t\t\t\tonTabSelectionChange(key, true);\n\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\tselectedTab={selectedKey}\n\t\t\t\t\t\t\t\tsubTitle={data.subtitle}\n\t\t\t\t\t\t\t\ttabRefs={tabRefs}\n\t\t\t\t\t\t\t\ttitle={data.title}\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t)}\n\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\tstyle={{display: 'flex', flexDirection: 'column', height: '100%'}}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{/* Close button - fixed at top */}\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclassName={style({\n\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\tjustifyContent: 'end',\n\t\t\t\t\t\t\t\t\theight: 32,\n\t\t\t\t\t\t\t\t})}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<div className={style({paddingTop: 4, paddingEnd: 4})}>\n\t\t\t\t\t\t\t\t\t<CloseButton UNSAFE_style={{cursor: 'pointer'}} />\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t{/* Scrollable cards section */}\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tref={cardScrollableSectionRef}\n\t\t\t\t\t\t\t\tstyle={{flex: 1, overflow: 'auto'}}\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<CardsSection\n\t\t\t\t\t\t\t\t\tcardList={cardList}\n\t\t\t\t\t\t\t\t\tcardRefs={cardRefs}\n\t\t\t\t\t\t\t\t\theading={data.title}\n\t\t\t\t\t\t\t\t\tsubHeading={data.subtitle}\n\t\t\t\t\t\t\t\t\tisWindowVisible={isWindowVisible}\n\t\t\t\t\t\t\t\t\tlayoutId={data.layoutID}\n\t\t\t\t\t\t\t\t\tmuteVideo={muteVideo}\n\t\t\t\t\t\t\t\t\tnonSideNavExperience={!sideNavExperience}\n\t\t\t\t\t\t\t\t\tonAction={onAction}\n\t\t\t\t\t\t\t\t\tonPromotionAction={onPromotionAction}\n\t\t\t\t\t\t\t\t\tselectedKey={selectedKey}\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</CustomDialog>\n\t\t\t</DialogContainer>\n\t\t</Provider>\n\t);\n}\n"],"names":[],"version":3} */
@keyframes installer-help-popUp-animation{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes installer-help-popUp-animation-fadein-with-bounce{0%,100%{opacity:0;transform:translateY(24px)}8%,12%,50%,54%{transform:translateY(24px)}2%,6%,10%,14%,48%,52%,56%,98%{opacity:1;transform:translateY(0)}}@keyframes installer-activation-help-popUp-animation{from{opacity:0;transform:translateY(24px) rotate(180deg)}to{opacity:1;transform:translateY(0) rotate(180deg)}}@keyframes installer-help-popUp-animation-bottom{from{opacity:0;transform:translateY(-24px)}to{opacity:1;transform:translateY(0)}}@keyframes installer-help-popUp-animation-fadein-with-bounce-bottom{0%{opacity:0;transform:translateY(-24px)}8%,12%,50%,54%{transform:translateY(-24px)}2%,6%,10%,14%,48%,52%,56%,100%{opacity:1;transform:translateY(0)}}@keyframes installer-help-popUp-animation-bounce-bottom{8%,12%,50%,54%{transform:translateY(-24px)}0%,6%,10%,14%,48%,52%,56%,100%{transform:translateY(0)}}@-webkit-keyframes installer-help-popUp-animation{from{opacity:0;-webkit-transform:translateY(24px)}to{opacity:1;-webkit-transform:translateY(0)}}@-webkit-keyframes installer-activation-help-popUp-animation{from{opacity:0;-webkit-transform:translateY(24px) rotate(180deg)}to{opacity:1;-webkit-transform:translateY(0) rotate(180deg)}}@-webkit-keyframes installer-help-popUp-animation-bottom{from{opacity:0;-webkit-transform:translateY(-24px)}to{opacity:1;-webkit-transform:translateY(0)}}@-moz-keyframes installer-help-popUp-animation{from{opacity:0;-moz-transform:translateY(24px)}to{opacity:1;-moz-transform:translateY(0)}}@-moz-keyframes installer-activation-help-popUp-animation{from{opacity:0;-moz-transform:translateY(24px) rotate(180deg)}to{opacity:1;-moz-transform:translateY(0) rotate(180deg)}}@-moz-keyframes installer-help-popUp-animation-bottom{from{opacity:0;-moz-transform:translateY(-24px)}to{opacity:1;-moz-transform:translateY(0)}}.installer-help-popUp-animate-bottom{opacity:0;animation:installer-help-popUp-animation-bottom .25s linear forwards}.installer-help-popUp-animate{opacity:0;animation:installer-help-popUp-animation .25s linear forwards}.installer-help-popUp-animateBounce-fadein{opacity:0;animation:installer-help-popUp-animation-fadein-with-bounce 10s linear forwards}.installer-help-popUp-animateBounce-fadein-bottom{opacity:0;animation:installer-help-popUp-animation-fadein-with-bounce-bottom 10s linear forwards}.installer-help-popUp-animateBounce-bottom{animation:installer-help-popUp-animation-bounce-bottom 10s linear forwards}.installer_help_container_popUp{display:none;padding:1rem;position:fixed;bottom:0rem;left:0rem;background-color:#0d66d0;background-color:var(--blue-600);border-radius:.25rem;margin:1rem}.installer_help_container_popUp .popUp_arrow{margin-right:.5rem;height:1.125rem;width:1.125rem;float:left;margin-top:-2px}.installer_help_container_popUp .popUp_arrow .popUpTriangle{width:0;height:0;border-right:.5625rem solid rgba(0,0,0,0);border-left:.5625rem solid rgba(0,0,0,0);border-bottom:.5625rem solid rgba(0,0,0,0);border-top:.5625rem solid #fff;border-top:.5625rem solid var(--gray-50);border-radius:.125rem}.installer_help_container_popUp .popUp_arrow .popUpRectangle{width:.375rem;height:.5625rem;background-color:var(--gray-50);margin-left:.375rem}.installer_help_container_popUp .popUp_title{font-size:.875rem;font-weight:400;color:var(--gray-50);float:left;line-height:1rem}.installer_help_container_popUp.activationTestIconCoachMark{background-color:rgba(0,0,0,0);color:#0d66d0;color:var(--blue600);margin-left:2.5rem;padding-bottom:0;margin-bottom:0}.installer_help_container_popUp.activationTestIconCoachMark .chevronDownIcon{height:6.25rem;width:6.25rem}.installer_help_container_popUp.updatedTopRightDesignCoachMark{background-color:rgba(0,0,0,0);color:var(--gray-700)}.installer_help_container_popUp.updatedTopRightDesignCoachMark .aliasIcon{float:left;width:3.5625rem;transform:scaleY(-1)}.installer_help_container_popUp.updatedTopRightDesignCoachMark .popUp_title{margin-top:1.5625rem;color:var(--gray-700)}.installer_help_container_popUp.UpArrow{bottom:inherit;left:inherit;top:0rem;right:0rem}.installer_help_container_popUp.UpArrow .popUp_arrow{margin-left:.5rem;margin-right:0;float:right}.installer_help_container_popUp.UpArrow .popUpRectangle{position:relative;bottom:-0.5625rem}.installer_help_container_popUp.UpArrow .popUpTriangle{position:relative;bottom:1.125rem;border-bottom:.5625rem solid #fff;border-bottom:.5625rem solid var(--gray-50);border-top:.5625rem solid rgba(0,0,0,0)}.installer_help_container_popUp.updatedTopRightDesignCoachMark.UpArrow{top:36px;right:36px;padding:0;margin:.5rem}.installer_help_container_popUp.updatedTopRightDesignCoachMark.UpArrow .aliasIcon{float:right;transform:scaleX(-1)}.installer_help_container_popUp.updatedTopRightDesignCoachMark.UpArrow .popUp_title{margin-top:30px}.installer_help_container_popUp.multiAppPlan{margin:.5rem;padding:0}.installer_help_container_popUp.multiAppPlan .multiAppPlanContainer{max-width:20rem}.installer_help_container_popUp.multiAppPlan.Center{left:calc(50vw - 160px)}.installer_help_container_popUp.multiAppPlan.Center .multiAppPlanContainer{max-width:20rem}.installer_help_container_popUp.multiAppPlan.UpArrow{right:0;top:0}.popupElemBounceClass{display:block;z-index:100001}

/*# sourceMappingURL=996.972e05b6fe2071fee01c.css.map*/