@liquidcommerce/elements-sdk 2.6.0-beta.1 → 2.6.0-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -0
- package/dist/index.esm.js +11009 -9677
- package/dist/types/constants/core.constant.d.ts +11 -0
- package/dist/types/enums/cloud.enum.d.ts +326 -0
- package/dist/types/enums/core.enum.d.ts +1 -0
- package/dist/types/interfaces/configs/global.interface.d.ts +1 -0
- package/dist/types/modules/product-list/components/index.d.ts +2 -0
- package/dist/types/modules/product-list/components/product-list-filters-subcomponents/index.d.ts +6 -0
- package/dist/types/modules/product-list/components/product-list-filters-subcomponents/product-list-apply-filter-button.component.d.ts +1 -0
- package/dist/types/modules/product-list/components/product-list-filters-subcomponents/product-list-checkbox-filter.components.d.ts +7 -0
- package/dist/types/modules/product-list/components/product-list-filters-subcomponents/product-list-delivery-options-filter.components.d.ts +16 -0
- package/dist/types/modules/product-list/components/product-list-filters-subcomponents/product-list-price-filter.components.d.ts +22 -0
- package/dist/types/modules/product-list/components/product-list-filters-subcomponents/product-list-search.component.d.ts +16 -0
- package/dist/types/modules/product-list/components/product-list-filters-subcomponents/product-list-toggle-filters.components.d.ts +18 -0
- package/dist/types/modules/product-list/components/product-list-filters.component.d.ts +27 -5
- package/dist/types/modules/product-list/product-list.component.d.ts +14 -5
- package/dist/types/modules/product-list/product-list.interface.d.ts +80 -0
- package/dist/types/static/icon/chevron-up.icon.d.ts +2 -0
- package/dist/types/static/icon/filter.icon.d.ts +2 -0
- package/dist/types/static/icon/index.d.ts +1 -0
- package/docs/THEMING.md +3 -0
- package/package.json +1 -1
- package/umd/elements.js +1 -1
package/umd/elements.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
(function(t,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):(t="undefined"!=typeof globalThis?globalThis:t||self,n(t.LiquidCommerceElements={}))})(this,function(exports){"use strict";function polyfillReplaceChildren(){"undefined"!=typeof Element&&"replaceChildren"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.replaceChildren=function(...t){for(;this.firstChild;)this.removeChild(this.firstChild);for(const n of t)"string"==typeof n?this.appendChild(document.createTextNode(n)):this.appendChild(n)})}function polyfillPrepend(){"undefined"!=typeof Element&&"prepend"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.prepend=function(...t){const n=document.createDocumentFragment();for(const i of t)"string"==typeof i?n.appendChild(document.createTextNode(i)):n.appendChild(i);this.insertBefore(n,this.firstChild)})}function polyfillRemove(){"undefined"!=typeof Element&&"remove"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.remove=function(){this.parentNode&&this.parentNode.removeChild(this)})}function polyfillReplaceWith(){"undefined"!=typeof Element&&"replaceWith"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.replaceWith=function(...t){const n=this.parentNode;if(!n)return;const i=document.createDocumentFragment();for(const o of t)"string"==typeof o?i.appendChild(document.createTextNode(o)):i.appendChild(o);n.replaceChild(i,this)})}function polyfillBefore(){"undefined"!=typeof Element&&"before"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.before=function(...t){const n=this.parentNode;if(!n)return;const i=document.createDocumentFragment();for(const o of t)"string"==typeof o?i.appendChild(document.createTextNode(o)):i.appendChild(o);n.insertBefore(i,this)})}function polyfillAfter(){"undefined"!=typeof Element&&"after"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.after=function(...t){const n=this.parentNode;if(!n)return;const i=document.createDocumentFragment();for(const o of t)"string"==typeof o?i.appendChild(document.createTextNode(o)):i.appendChild(o);n.insertBefore(i,this.nextSibling)})}function polyfillObjectFromEntries(){"undefined"!=typeof Object&&"fromEntries"in Object||"undefined"!=typeof Object&&(Object.fromEntries=t=>{const n={};for(const[i,o]of t)n[i]=o;return n})}function initializeDOMPolyfills(){try{polyfillReplaceChildren(),polyfillPrepend(),polyfillRemove(),polyfillReplaceWith(),polyfillBefore(),polyfillAfter(),polyfillObjectFromEntries()}catch(X){console.warn("DOM polyfills initialization failed:",X)}}function safeReplaceChildren(t,...n){try{if("replaceChildren"in t&&"function"==typeof t.replaceChildren)t.replaceChildren(...n);else{for(;t.firstChild;)t.removeChild(t.firstChild);for(const i of n)"string"==typeof i?t.appendChild(document.createTextNode(i)):t.appendChild(i)}}catch(i){console.error("replaceChildren operation failed:",i),1===n.length&&"string"==typeof n[0]&&(t.innerHTML=n[0])}}class SDKError extends Error{constructor(t,n=![]){super(t),this.name="SDKError",this.isSdk=!![],this.reThrow=n,Error.captureStackTrace&&Error.captureStackTrace(this,SDKError),Object.setPrototypeOf(this,SDKError.prototype)}}function isSDKError(t,n){if((null==t?void 0:t.isSdk)===!![])return t instanceof SDKError&&t.reThrow?![]:!![];if(!t||"object"!=typeof t)return n?isSDKSource(n):![];const i=String((null==t?void 0:t.message)||""),o=/liquidcommerce\s+elements/i.test(i),r=String((null==t?void 0:t.stack)||""),s=(null==t?void 0:t.source)||n||"",a=[/@[/\\](?:core|modules|constants|enums|interfaces|utils|static)[/\\]/,/[./]*[/\\](?:core|modules|constants|enums|interfaces|utils|static)[/\\]/,/node_modules[/\\]@liquidcommerce[/\\]elements-sdk[/\\]/i,/elements-sdk[/\\](?:src[/\\])?(?:core|modules)[/\\]/i,/chunk-[a-z0-9]+.*elements/i],l=[/\bElements\b(?!\w)/,/\bElementsBuilder\b/,/\bLiquidCommerceElements\b/,/BaseComponent/,/Elements(?:Base)?Client/,/(?:Auth|Store|Command|ApiClient|Telemetry|FingerPrint|GoogleTagManager|ClientConfig|ThemeProvider|ComponentFactory|PubSub|SingletonManager|DebugPanel)Service/,/(?:Cart|Product|Checkout|Address|ProductList|UI|Common)Commands/,/(?:Product|Cart|Checkout|Address|ProductList).*Component/],c=[/(?:service|commands|component)\.(?:ts|js)/,/auto-initialize\.(?:ts|js)/,/elements-(?:base-|builder-)?client\.(?:ts|js)/],d=[/elements-sdk[/\\]/i,/modules[/\\](?:cart|product|checkout|address|product-list|theme-provider|ui-components)[/\\]/,/core[/\\](?:auth|store|command|api-client|telemetry|fingerprint|google-tag-manager|client|component-factory|pubsub|singleton-manager|debug-panel)[/\\]/,/@liquidcommerce[/\\]elements-sdk/i],u=isSDKSource(s),h=a.some(t=>t.test(r)),p=l.some(t=>t.test(r)),m=c.some(t=>t.test(r)),f=d.some(t=>t.test(r));return o||u||h||p||m||f}function isSDKSource(t){if(!t||"string"!=typeof t)return![];const n=[/\/elements\.js$/i,/\/index\.esm\.js$/i,/@liquidcommerce\/elements-sdk/i,/node_modules[/\\]@liquidcommerce[/\\]elements-sdk/i,/@liquidcommerce[/\\]elements-sdk[/\\]/i,/\/elements-sdk[/\\]/i,/elements-sdk[/\\]src/i,/elements[-.]?[a-z0-9]*\.js$/i,/chunk.*elements/i,/elements.*chunk/i,/\?.*elements\.js/i,/#.*elements\.js/i];return n.some(n=>n.test(t))}const t={DEVELOPMENT:"development",STAGING:"staging",PRODUCTION:"production"},n={CLIENT_READY:"client_ready",ADDRESS_UPDATED:"address_updated",ADDRESS_CLEARED:"address_cleared",ADDRESS_FAILED:"address_failed",PRODUCT_LOADED:"product_loaded",PRODUCT_QUANTITY_INCREASE:"product_quantity_increase",PRODUCT_QUANTITY_DECREASE:"product_quantity_decrease",PRODUCT_ADD_TO_CART:"product_add_to_cart",PRODUCT_SIZE_CHANGED:"product_size_changed",PRODUCT_FULFILLMENT_TYPE_CHANGED:"product_fulfillment_type_changed",PRODUCT_FULFILLMENT_CHANGED:"product_fulfillment_changed",CART_LOADED:"cart_loaded",CART_CLOSED:"cart_closed",CART_OPENED:"cart_opened",CART_UPDATED:"cart_updated",CART_FAILED:"cart_failed",CART_RESET:"cart_reset",CART_ITEM_ADDED:"cart_item_added",CART_ITEM_REMOVED:"cart_item_removed",CART_ITEM_QUANTITY_INCREASE:"cart_item_quantity_increase",CART_ITEM_QUANTITY_DECREASE:"cart_item_quantity_decrease",CART_ITEM_ENGRAVING_UPDATED:"cart_item_engraving_updated",CART_PROMO_CODE_APPLIED:"cart_promo_code_applied",CART_PROMO_CODE_REMOVED:"cart_promo_code_removed",CART_PROMO_CODE_FAILED:"cart_promo_code_failed",CART_PRODUCT_ADD_SUCCESS:"cart_product_add_success",CART_PRODUCT_ADD_FAILED:"cart_product_add_failed",CHECKOUT_LOADED:"checkout_loaded",CHECKOUT_OPENED:"checkout_opened",CHECKOUT_CLOSED:"checkout_closed",CHECKOUT_FAILED:"checkout_failed",CHECKOUT_IS_GIFT_TOGGLED:"checkout_is_gift_toggled",CHECKOUT_BILLING_SAME_AS_SHIPPING_TOGGLED:"checkout_billing_same_as_shipping_toggled",CHECKOUT_MARKETING_PREFERENCES_TOGGLED:"checkout_marketing_preferences_toggled",CHECKOUT_CUSTOMER_INFORMATION_UPDATED:"checkout_customer_information_updated",CHECKOUT_GIFT_INFORMATION_UPDATED:"checkout_gift_information_updated",CHECKOUT_BILLING_INFORMATION_UPDATED:"checkout_billing_information_updated",CHECKOUT_ITEM_REMOVED:"checkout_item_removed",CHECKOUT_ITEM_QUANTITY_INCREASE:"checkout_item_quantity_increase",CHECKOUT_ITEM_QUANTITY_DECREASE:"checkout_item_quantity_decrease",CHECKOUT_ITEM_ENGRAVING_UPDATED:"checkout_item_engraving_updated",CHECKOUT_TIP_UPDATED:"checkout_tip_updated",CHECKOUT_SUBMIT_STARTED:"checkout_submit_started",CHECKOUT_SUBMIT_COMPLETED:"checkout_submit_completed",CHECKOUT_SUBMIT_FAILED:"checkout_submit_failed",CHECKOUT_PROMO_CODE_APPLIED:"checkout_promo_code_applied",CHECKOUT_PROMO_CODE_REMOVED:"checkout_promo_code_removed",CHECKOUT_PROMO_CODE_FAILED:"checkout_promo_code_failed",CHECKOUT_GIFT_CARD_APPLIED:"checkout_gift_card_applied",CHECKOUT_GIFT_CARD_REMOVED:"checkout_gift_card_removed",CHECKOUT_GIFT_CARD_FAILED:"checkout_gift_card_failed",CHECKOUT_PRODUCT_ADD_SUCCESS:"checkout_product_add_success",CHECKOUT_PRODUCT_ADD_FAILED:"checkout_product_add_failed"},i={CUSTOMER:"customer",GIFT:"gift",BILLING:"billing"},o={DRAWER:"drawer",INPUT:"input",BIRTHDATE_INPUT:"birthdate-input",ENGRAVING_FORM:"engraving-form",ENGRAVING_VIEW:"engraving-view",BUTTONS_CART_OPEN:"buttons-cart-open",POWERED_BY:"powered-by",LCE_ELEMENT:"lce-element",PURCHASE_MIN_ALERT:"purchase-min-alert",ALERT:"alert",PROMO_CODE_TICKER:"promo-code-ticker",ADDRESS:"address",ADDRESS_INPUT:"address-input",ADDRESS_DISPLAY:"address-display",PRODUCT:"product",PRODUCT_IMAGE_CAROUSEL:"product-image-carousel",PRODUCT_OPTIONS:"product-options",PRODUCT_INTERACTIONS:"product-interactions",PRODUCT_DESCRIPTION:"product-description",PRODUCT_RETAILERS:"product-retailers",PRODUCT_RETAILERS_CAROUSEL:"product-retailers-carousel",PRODUCT_RETAILERS_POPUP:"product-retailers-popup",PRODUCT_RETAILERS_POPUP_LIST:"product-retailers-popup-list",PRODUCT_PRICE:"product-price",PRODUCT_ADD_TO_CART_SECTION:"product-add-to-cart-section",PRODUCT_DRAWER:"product-drawer",PRODUCT_LOADING:"product-loading",PRODUCT_LIST:"product-list",PRODUCT_LIST_CARD:"product-list-card",PRODUCT_LIST_FILTERS:"product-list-filters",PRODUCT_LIST_CARD_LOADING:"product-list-card-loading",CART:"cart",CART_RETAILER:"cart-retailer",CART_ITEM:"cart-item",CART_FOOTER:"cart-footer",CART_ITEM_QUANTITY_PRICE:"cart-item-quantity-price",CART_RETAILER_SUBTOTAL:"cart-retailer-subtotal",CART_PROMO_CODE:"cart-promo-code",CART_HEADER:"cart-header",CART_BODY:"cart-body",CART_FULFILLMENT:"cart-fulfillment",CHECKOUT:"checkout",CHECKOUT_INFORMATION:"checkout-information",CHECKOUT_STRIPE_HANDLER:"checkout-stripe-handler",CHECKOUT_STRIPE_FORM:"checkout-stripe-form",CHECKOUT_PAYMENT:"checkout-payment",CHECKOUT_PAYMENT_SUMMARY:"checkout-payment-summary",CHECKOUT_BILLING:"checkout-billing",CHECKOUT_ORDER_SUMMARY:"checkout-order-summary",CHECKOUT_PROMO_CODE:"checkout-promo-code",CHECKOUT_GIFT_CARDS:"checkout-gift-cards",CHECKOUT_AMOUNTS:"checkout-amounts",CHECKOUT_ITEMS:"checkout-items",CHECKOUT_COMPLETED:"checkout-completed",CHECKOUT_DELIVER_TO:"checkout-deliver-to",CHECKOUT_DELIVER_TO_SUMMARY:"checkout-deliver-to-summary",CHECKOUT_BUYER:"checkout-buyer",CHECKOUT_BUYER_SUMMARY:"checkout-buyer-summary",CHECKOUT_TIPS:"checkout-tips",CHECKOUT_PC_GC:"checkout-pc-gc",CHECKOUT_ITEM:"checkout-item",CHECKOUT_ITEM_QUANTITY:"checkout-item-quantity",CHECKOUT_PLACE_ORDER_BUTTON:"checkout-place-order-button",CHECKOUT_HEADER:"checkout-header",CHECKOUT_PRESALE_COUNTDOWN:"checkout-presale-countdown",CHECKOUT_PRESALE_EXPIRED:"checkout-presale-expired",CHECKOUT_SEND_AS_GIFT:"checkout-send-as-gift"},r={ON_DEMAND:"onDemand",SHIPPING:"shipping"},s={NONE:"none",CONSOLE:"console",PANEL:"panel"},a={[t.DEVELOPMENT]:"https://dev-elements.liquidcommerce.us",[t.STAGING]:"https://staging-elements.liquidcommerce.us",[t.PRODUCTION]:"https://elements.liquidcommerce.us"},l={STANDARD:"standard"},c={PERSONALIZATION:"personalization",PRE_ORDER:"pre-order",DELIVERY_OPTIONS:"delivery-options"},d={DRAWER_WRAPPER:2147483640,DRAWER_CONTENT:5952,DRAWER_BACKDROP:5951,ADDRESS_SUGGESTIONS:5850,PRODUCT_DRAWER:5840,CART_LOADING:5750,LOADING_INDICATOR:5730,ERROR_MESSAGE:5650,CAROUSEL_CONTROLS:5580,PROGRESS_BAR:5560,CHECKOUT_HEADER:5920,INDEPENDENT_BUTTON:5910,CART_HEADER:5920,TOGGLE_SLIDER:5150,FORM_CONTROLS:5130,ADDRESS_ACTIONS:5050,SKELETON_WAVE:5040};class SingletonManager{static getInstances(){return"builder"===SingletonManager.currentContext?(SingletonManager.builderClientInstances||(SingletonManager.builderClientInstances=new Map),SingletonManager.builderClientInstances):(SingletonManager.regularClientInstances||(SingletonManager.regularClientInstances=new Map),SingletonManager.regularClientInstances)}constructor(){}static setContext({isBuilder:t}){SingletonManager.currentContext=t?"builder":"regular"}static setClientConstructor(t){SingletonManager.clientConstructor=t}static getClientConstructor(){return SingletonManager.clientConstructor}static getClassInstance(t,n){const i=SingletonManager.getInstances();i.has(t)||i.set(t,n());const o=i.get(t);if(!o)throw new SDKError("ElementsSdk: Instance for class "+t+" could not be created.");return o}static async getClient(t){const n=[t.apiKey,t.env,t.isBuilder,t.debugMode].join("_"),i="LiquidCommerceElementsClient_"+n,o=SingletonManager.getInstances();if(o.has(i))return o.get(i);if(!SingletonManager.clientConstructor)throw new SDKError("LiquidCommerce Elements: Client constructor is not set.");const r=new SingletonManager.clientConstructor(t);return await r.prepare(),o.set(i,r),r}}SingletonManager.clientConstructor=null,SingletonManager.regularClientInstances=null,SingletonManager.builderClientInstances=null,SingletonManager.currentContext="regular";const u="lce",h={identifier:"",id:"",brand:"",category:"",catPath:"",classification:"",type:"",subType:"",salsifyGrouping:"",name:"",description:"",htmlDescription:"",images:[],sizes:{},mainImage:null,region:"",country:"",material:"",abv:"",proof:"",age:"",color:"",flavor:"",variety:"",appellation:"",vintage:"",tastingNotes:"",productHasAvailability:![],fulfillmentHasAvailability:![],quantity:1,selectedFulfillmentType:r.SHIPPING,selectedSizeId:null,selectedFulfillmentId:null,selectedFulfillment:null,loading:![],updating:![],error:null,drawer:{isOpen:![],contentConfig:null},rerender:![]},p={id:null,loading:![],error:null,items:{},retailers:{},totals:{subtotal:0,total:0,shippingFee:0,platformFee:0,engravingFee:0,giftCardTotal:0,deliveryFee:0,discounts:0,quantity:0},promoCode:null,fulfillments:{},rerender:![],shouldReset:![],updatedAt:"",createdAt:"",events:[]},m={token:"",cartId:"",loading:![],updating:![],error:null,warning:[],presale:null,isGift:![],marketingPreferences:{canEmail:![],canSms:![]},customerForm:{data:{firstName:"",lastName:"",email:"",phone:"",birthDate:"",company:""},isEditing:!![],isValid:![],isSaving:![]},giftRecipientForm:{data:{firstName:"",lastName:"",email:"",phone:"",message:""},isEditing:!![],isValid:![],isSaving:![]},paymentForm:{paymentSession:null,paymentMethod:null,data:null,billingSameAsShipping:!![],isEditing:!![],isValid:![],isSaving:![]},shippingAddressTwo:"",promoCode:null,giftCards:[],orderNumber:null,items:{},amounts:{total:0,subtotal:0,shipping:0,discounts:0,delivery:0,platform:0,tax:0,engraving:0,giftCards:0,service:0,tip:0,details:{taxes:{bag:0,bottleDeposits:0,retailDelivery:0,products:0,delivery:0,shipping:0},discounts:{products:0,delivery:0,shipping:0,service:0,engraving:0}}},rerender:![],onDemandFulfillmentTipInfo:{},tipSelection:10,deliveryInstructions:"",giftCardError:null,promoCodeError:null,events:[]},f={drawer:{isOpen:![],contentConfig:null}},b={id:"",formattedAddress:"",address:{one:"",two:"",city:"",state:"",zip:"",country:""},coordinates:{lat:0,long:0}},w={products:{},cart:p,address:b,checkout:m,ui:f};class ClientConfigService{constructor(){this.config=null}static getInstance(){return SingletonManager.getClassInstance("ClientConfigService",()=>new ClientConfigService)}initialize(t,n={}){this.validateInputs(t,n),this.config=Object.freeze(this.buildConfiguration(t,n))}getConfigs(){return{...this.config}}get(t){return this.config[t]}set(t,n){if(!this.config)throw new SDKError("Configuration service is not ready. Please initialize first.");this.config=Object.freeze({...this.config,[t]:n})}isDevelopment(){return this.get("env")===t.DEVELOPMENT}isStaging(){return this.get("env")===t.STAGING}isProduction(){return this.get("env")===t.PRODUCTION}isBuilder(){return this.get("isBuilder")}isDebuggingEnabled(){const t=this.get("debugMode");return t===s.CONSOLE||t===s.PANEL}isDebugPanelEnabled(){return this.get("debugMode")===s.PANEL}debuggingDisabled(){const t=this.get("debugMode");return t===s.NONE}hasCustomTheme(){return null!==this.get("customTheme")}isMobile(){return"mobile"===this.get("deviceType")}isLocalStorageAvailable(){return Boolean(this.get("isLocalStorageAvailable"))}getProxyConfig(){return this.get("proxy")}validateInputs(n,i){if(!(null==n?void 0:n.trim()))throw new SDKError("API key is required. Please provide a valid API key.",!![]);if(i.env&&!Object.values(t).includes(i.env)&&(console.warn('[LiquidCommerce Elements] Invalid environment "'+i.env+'". Using default environment.'),i.env=void 0),void 0!==i.isBuilder&&"boolean"!=typeof i.isBuilder&&(console.warn("[LiquidCommerce Elements] isBuilder must be a boolean. Using default value."),i.isBuilder=void 0),void 0===i.debugMode||Object.values(s).includes(i.debugMode)||(console.warn('[LiquidCommerce Elements] Invalid debugMode "'+i.debugMode+'". Must be one of: '+Object.values(s).join(", ")+". Using default value."),i.debugMode=void 0),i.promoTicker&&"object"!=typeof i.promoTicker&&(console.warn("[LiquidCommerce Elements] promoTicker must be an object. Skipping promoTicker configuration."),i.promoTicker=void 0),i.promoTicker)if(Array.isArray(i.promoTicker)){const t=i.promoTicker.filter((t,n)=>{if("string"!=typeof t.promoCode||!t.promoCode.trim())return console.warn("[LiquidCommerce Elements] promoTicker["+n+"].promoCode is required and must be a non-empty string. Skipping this promo."),![];if(!Array.isArray(t.text)||0===t.text.length||!t.text.every(t=>"string"==typeof t&&t.trim()))return console.warn("[LiquidCommerce Elements] promoTicker["+n+"].text is required and must be a non-empty array of strings. Skipping this promo."),![];if("string"!=typeof t.separator||!t.separator.trim())return console.warn("[LiquidCommerce Elements] promoTicker["+n+"].separator is required and must be a non-empty string. Skipping this promo."),![];if(!t.activeFrom)return console.warn("[LiquidCommerce Elements] promoTicker["+n+"].activeFrom is required. Skipping this promo."),![];const i="string"==typeof t.activeFrom?new Date(t.activeFrom):t.activeFrom;if(!(i instanceof Date)||Number.isNaN(i.getTime()))return console.warn("[LiquidCommerce Elements] promoTicker["+n+"].activeFrom must be a valid Date object or ISO date string. Skipping this promo."),![];if(!t.activeUntil)return console.warn("[LiquidCommerce Elements] promoTicker["+n+"].activeUntil is required. Skipping this promo."),![];const o="string"==typeof t.activeUntil?new Date(t.activeUntil):t.activeUntil;return o instanceof Date&&!Number.isNaN(o.getTime())?i>=o?(console.warn("[LiquidCommerce Elements] promoTicker["+n+"].activeFrom must be earlier than activeUntil. Skipping this promo."),![]):!![]:(console.warn("[LiquidCommerce Elements] promoTicker["+n+"].activeUntil must be a valid Date object or ISO date string. Skipping this promo."),![])});i.promoTicker=t.length>0?t:void 0}else console.warn("[LiquidCommerce Elements] promoTicker must be an array. Skipping promoTicker configuration."),i.promoTicker=void 0;i.proxy&&("object"!=typeof i.proxy?(console.warn("[LiquidCommerce Elements] proxy must be an object. Skipping proxy configuration."),i.proxy=void 0):i.proxy.baseUrl&&"string"==typeof i.proxy.baseUrl?i.proxy.headers&&"object"!=typeof i.proxy.headers&&(console.warn("[LiquidCommerce Elements] proxy.headers must be an object. Skipping proxy configuration."),i.proxy=void 0):(console.warn("[LiquidCommerce Elements] proxy.baseUrl is required and must be a string. Skipping proxy configuration."),i.proxy=void 0))}buildConfiguration(n,i){var o,r,l;const c=i.env||t.PRODUCTION;let d=a[c];const h=c===t.PRODUCTION,p=i.isBuilder||![],m=u+(h?"":"_"+c)+(p?"builder":"");return(null===(o=i.development)||void 0===o?void 0:o.customApiUrl)&&(d=i.development.customApiUrl),{apiKey:n.trim(),env:c,isBuilder:p,debugMode:i.debugMode||s.NONE,baseUrl:d,partnerCode:void 0,partnerName:void 0,customTheme:i.customTheme||null,proxy:i.proxy||null,deviceType:this.detectDeviceType(),userDeviceId:void 0,localStorageKeyPrefix:m,isLocalStorageAvailable:void 0,version:void 0,clientPrepared:![],promoTicker:i.promoTicker||null,paymentMethodId:(null===(r=i.development)||void 0===r?void 0:r.paymentMethodId)||void 0,openShadowDom:h?![]:(null===(l=i.development)||void 0===l?void 0:l.openShadowDom)||![]}}detectDeviceType(){var t,n;if("undefined"==typeof navigator)return"desktop";const i=navigator.userAgent.toLowerCase(),o="ontouchstart"in window||navigator.maxTouchPoints>0,r=(null===(t=window.screen)||void 0===t?void 0:t.width)||0,s=(null===(n=window.screen)||void 0===n?void 0:n.height)||0,a=Math.max(r,s),l=[/ipad/,/android(?!.*mobile)/,/tablet/,/kindle/,/playbook/,/silk/,/gt-p\d{4}/,/nexus (7|9|10)/,/xoom/,/sch-i800/,/galaxy tab/,/surface/,/googletv/,/appletv/,/hbbtv/,/roku/,/smarttv/,/webtv/],c=[/android.*mobile/,/iphone/,/ipod/,/blackberry/,/opera mini/,/opera mobi/,/iemobile/,/mobile/,/webos/,/palm/,/symbian/,/nokia/,/fennec/,/maemo/,/windows phone/,/windows ce/,/htc/,/samsung.*mobile/,/lg.*mobile/,/motorola/,/sony.*mobile/,/watch/,/applewatch/,/wearos/,/tizen/];return l.some(t=>t.test(i))?"tablet":c.some(t=>t.test(i))||o&&a<768?"mobile":o&&a>=768&&a<=1200||o&&/macintosh/i.test(i)&&navigator.maxTouchPoints>1||/android/i.test(i)&&o&&a>=768||/windows nt/i.test(i)&&o&&a>=768?"tablet":(/automotive|carplay|android auto|car browser/i.test(i),"desktop")}}class LoggerService{constructor(t){this.prefix="LiquidCommerce Elements",this.colors={debug:"#9CA3AF",log:"#60A5FA",info:"#22D3EE",warn:"#FB923C",error:"#F87171",prefix:"#C084FC"},this.enableLogging=![],this.telemetryService=null,this.context=t}static getInstance(t){return SingletonManager.getClassInstance("LoggerService_"+t,()=>new LoggerService(t))}setEnableLogging(t){this.enableLogging=t}setTelemetryService(t){this.telemetryService=t}getPrefix(t){if(!this.enableLogging)return[];const n=(new Date).toISOString().slice(11,23);return["%c["+n+"%c "+this.prefix+"%c "+this.context+"%c]","color: "+this.colors[t],"color: "+this.colors.prefix+"; font-weight: bold","color: "+this.colors[t],"color: "+this.colors[t]]}debug(t,n){if(this.sendToTelemetry("debug",t,void 0,n),!this.enableLogging)return;const[i,...o]=this.getPrefix("debug");void 0!==n?console.debug(i,...o,t,n):console.debug(i,...o,t)}info(t,n){if(!this.enableLogging)return;const[i,...o]=this.getPrefix("info");void 0!==n?console.info(i,...o,t,n):console.info(i,...o,t)}warn(t,n){if(this.sendToTelemetry("warn",t,void 0,n),!this.enableLogging)return;const[i,...o]=this.getPrefix("warn");void 0!==n?console.warn(i,...o,t,n):console.warn(i,...o,t)}error(t,n){const i=n instanceof Error,o=i?n:void 0,r=!i&&n?n:void 0;if(this.sendToTelemetry("error",t,o,r),!this.enableLogging)return;const[s,...a]=this.getPrefix("error");void 0!==n?console.error(s,...a,t,n):console.error(s,...a,t)}sendToTelemetry(t,n,i,o){if(this.telemetryService&&this.telemetryService.isEnabled())try{this.telemetryService.captureEvent(t,n,{context:this.context,error:i,data:o})}catch(r){}}}class LoggerFactory{static getInstances(){return LoggerFactory.instances||(LoggerFactory.instances=new Map),LoggerFactory.instances}static get(t){const n=this.getInstances();if(!n.has(t)){const i=LoggerService.getInstance(t);i.setEnableLogging(this.enableLoggingGlobally),this.telemetryService&&i.setTelemetryService(this.telemetryService),n.set(t,i)}return n.get(t)}static setEnableLogging(t){this.enableLoggingGlobally=t;const n=this.getInstances();for(const[,i]of n)i.setEnableLogging(t)}static setTelemetryService(t){this.telemetryService=t;const n=this.getInstances();for(const[,i]of n)i.setTelemetryService(t)}}function componentError({componentType:t,message:n}){const i=document.createElement("div");i.className=t;const o=i.attachShadow({mode:"closed"}),r=document.createElement("style");r.textContent='\n div {\n padding: 10px;\n background-color: #1d4ed81a;\n border-radius: 6px;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;\n }\n\n h3 {\n margin: 0;\n font-size: 16px;\n font-weight: 600;\n color: #d63031;\n line-height: 1.4;\n margin-bottom: 5px;\n }\n\n p {\n margin: 0;\n font-size: 14px;\n font-weight: 400;\n color: #18181B;\n line-height: 1.5;\n max-width: 350px;\n }\n ';const s=document.createElement("div"),a=document.createElement("h3");a.textContent="Component </"+t+">";const l=document.createElement("p");return l.textContent=n,s.appendChild(r),s.appendChild(a),s.appendChild(l),o.appendChild(s),i}function productionComponentError({title:t,message:n,componentType:i}){const o=document.createElement("div");o.setAttribute("data-component-type",i);const r=o.attachShadow({mode:"closed"}),s=document.createElement("style");s.textContent="\n div {\n padding: 20px;\n background-color: #1d4ed81a;\n border-radius: 8px;\n box-sizing: border-box;\n font-family: Poppins, sans-serif;\n max-width: 512px;\n display: block;\n }\n\n h2 {\n color: #18181B;\n margin: 0 0 8px 0;\n font-size: 18px;\n font-style: normal;\n font-weight: 600;\n line-height: 18px;\n text-transform: lowercase;\n }\n\n h2::first-letter {\n text-transform: uppercase;\n }\n\n p {\n color: #18181B;\n font-size: 14px;\n font-style: italic;\n font-weight: 400;\n line-height: 20px;\n margin: 0;\n }\n ";const a=document.createElement("div"),l=document.createElement("h2");l.textContent=t;const c=document.createElement("p");return c.textContent=n,a.appendChild(s),a.appendChild(l),a.appendChild(c),r.appendChild(a),o}LoggerFactory.instances=null,LoggerFactory.enableLoggingGlobally=![],LoggerFactory.telemetryService=null;class ComponentFactoryService{static get logger(){return ComponentFactoryService.t||(ComponentFactoryService.t=LoggerFactory.get("ComponentFactory")),ComponentFactoryService.t}static get clientConfig(){return ComponentFactoryService.i||(ComponentFactoryService.i=ClientConfigService.getInstance()),ComponentFactoryService.i}static getComponentRegistry(){return ComponentFactoryService.componentRegistry||(ComponentFactoryService.componentRegistry=new Map),ComponentFactoryService.componentRegistry}static registerComponent(t,n){ComponentFactoryService.getComponentRegistry().set(t,n)}static createElement(t){try{const n=ComponentFactoryService.getComponentRegistry().get(t.type);if(!n)throw new SDKError("Component type ["+t.type+"] is not registered");const i=ComponentFactoryService.getComponentTagName(t.type);window.customElements.get(i)||window.customElements.define(i,n);const r=document.createElement(i);if(r.initialize){const{type:n,useShadowDom:o,wrapInLceElement:s,...a}=t,l={type:n,tagName:i,useShadowDom:o&&s!==!![]};r.initialize({data:a,config:l})}if(t.wrapInLceElement){const n=ComponentFactoryService.getComponentRegistry().get(o.LCE_ELEMENT),i=ComponentFactoryService.getComponentTagName(o.LCE_ELEMENT);window.customElements.get(i)||window.customElements.define(i,n);const s=document.createElement(i);return s.initialize(t.type,r),s}return r}catch(n){return ComponentFactoryService.logger.error("Failed to create component </"+t.type+">",n),ComponentFactoryService.clientConfig.isProduction()?productionComponentError({title:t.type.replace(/-/g," ")+" is not available.",message:"We're sorry, this element is currently unavailable.",componentType:t.type}):componentError({componentType:t.type,message:(null==n?void 0:n.message)||n})}}static componentError({componentType:t,message:n}){return ComponentFactoryService.logger.error("Component type "+t+" failed to load: "+n),ComponentFactoryService.clientConfig.isProduction()?productionComponentError({title:t.replace(/-/g," ")+" is not available.",message:"We're sorry, this element is currently unavailable.",componentType:t}):componentError({componentType:t,message:n})}static getComponentTagName(t){const n={[o.DRAWER]:"drawer-lc",[o.INPUT]:"input-lc",[o.BIRTHDATE_INPUT]:"birthdate-input-lc",[o.ENGRAVING_FORM]:"engraving-form-lc",[o.ENGRAVING_VIEW]:"engraving-view-lc",[o.BUTTONS_CART_OPEN]:"buttons-cart-open-lc",[o.POWERED_BY]:"powered-by-lc",[o.LCE_ELEMENT]:"lce-element",[o.PURCHASE_MIN_ALERT]:"purchase-min-alert-lc",[o.ALERT]:"alert-lc",[o.PROMO_CODE_TICKER]:"promo-code-ticker-lc",[o.ADDRESS]:"address-lc",[o.ADDRESS_INPUT]:"address-input-lc",[o.ADDRESS_DISPLAY]:"address-display-lc",[o.PRODUCT]:"product-lc",[o.PRODUCT_OPTIONS]:"product-options-lc",[o.PRODUCT_IMAGE_CAROUSEL]:"product-image-carousel-lc",[o.PRODUCT_INTERACTIONS]:"product-interactions-lc",[o.PRODUCT_DESCRIPTION]:"product-description-lc",[o.PRODUCT_ADD_TO_CART_SECTION]:"product-add-to-cart-section-lc",[o.PRODUCT_RETAILERS]:"product-retailers-lc",[o.PRODUCT_RETAILERS_CAROUSEL]:"product-retailers-carousel-lc",[o.PRODUCT_RETAILERS_POPUP]:"product-retailers-popup-lc",[o.PRODUCT_RETAILERS_POPUP_LIST]:"product-retailers-popup-list-lc",[o.PRODUCT_PRICE]:"product-price-lc",[o.PRODUCT_DRAWER]:"product-drawer-lc",[o.PRODUCT_LOADING]:"product-loading-lc",[o.PRODUCT_LIST]:"product-list-lc",[o.PRODUCT_LIST_CARD]:"product-list-card-lc",[o.PRODUCT_LIST_FILTERS]:"product-list-filters-lc",[o.PRODUCT_LIST_CARD_LOADING]:"product-list-card-loading-lc",[o.CART]:"cart-lc",[o.CART_RETAILER]:"cart-retailer-lc",[o.CART_ITEM]:"cart-item-lc",[o.CART_FOOTER]:"cart-footer-lc",[o.CART_ITEM_QUANTITY_PRICE]:"cart-item-quantity-price-lc",[o.CART_RETAILER_SUBTOTAL]:"cart-retailer-subtotal-lc",[o.CART_PROMO_CODE]:"cart-promo-code-lc",[o.CART_HEADER]:"cart-header-lc",[o.CART_BODY]:"cart-body-lc",[o.CART_FULFILLMENT]:"cart-fulfillment-lc",[o.CHECKOUT]:"checkout-lc",[o.CHECKOUT_INFORMATION]:"checkout-information-lc",[o.CHECKOUT_PAYMENT]:"checkout-payment-lc",[o.CHECKOUT_PAYMENT_SUMMARY]:"checkout-payment-summary-lc",[o.CHECKOUT_STRIPE_HANDLER]:"checkout-stripe-handler-lc",[o.CHECKOUT_STRIPE_FORM]:"checkout-stripe-form-lc",[o.CHECKOUT_BILLING]:"checkout-billing-lc",[o.CHECKOUT_ORDER_SUMMARY]:"checkout-order-summary-lc",[o.CHECKOUT_PROMO_CODE]:"checkout-promo-code-lc",[o.CHECKOUT_GIFT_CARDS]:"checkout-gift-cards-lc",[o.CHECKOUT_AMOUNTS]:"checkout-amounts-lc",[o.CHECKOUT_ITEMS]:"checkout-items-lc",[o.CHECKOUT_COMPLETED]:"checkout-completed-lc",[o.CHECKOUT_DELIVER_TO]:"checkout-deliver-to-lc",[o.CHECKOUT_DELIVER_TO_SUMMARY]:"checkout-deliver-to-summary-lc",[o.CHECKOUT_BUYER]:"checkout-buyer-lc",[o.CHECKOUT_BUYER_SUMMARY]:"checkout-buyer-summary-lc",[o.CHECKOUT_TIPS]:"checkout-tips-lc",[o.CHECKOUT_PC_GC]:"checkout-pc-gc-lc",[o.CHECKOUT_ITEM]:"checkout-item-lc",[o.CHECKOUT_ITEM_QUANTITY]:"checkout-item-quantity-lc",[o.CHECKOUT_PLACE_ORDER_BUTTON]:"checkout-place-order-button-lc",[o.CHECKOUT_HEADER]:"checkout-header-lc",[o.CHECKOUT_PRESALE_COUNTDOWN]:"checkout-presale-countdown-lc",[o.CHECKOUT_PRESALE_EXPIRED]:"checkout-presale-expired-lc",[o.CHECKOUT_SEND_AS_GIFT]:"checkout-send-as-gift-lc"};return n[t]||t.toLowerCase()+"-lc"}}ComponentFactoryService.t=null,ComponentFactoryService.i=null,ComponentFactoryService.componentRegistry=null;class PubSubService{constructor(){this.clientReadyEvent=null,this.eventPrefix="lce",this.logger=LoggerFactory.get("PubSub"),this.setupClientReadyBuffering()}static getInstance(){return SingletonManager.getClassInstance("PubSubService",()=>new PubSubService)}publishAction(t,n){this.publishSpecific("actions."+t,n)}publishForm(t,n){this.publishSpecific("forms."+t,n)}publishSpecific(t,n){const[i,o]=t.includes(".")?t.split(".",2):["actions",t];let r=o.split("_")[0];["product","cart","address","checkout"].includes(r)||(r="other");const s=Date.now(),a={eventId:"evt_"+s+"_"+Math.random().toString(36).slice(2,9),namespace:i,event:o,originalEvent:t,actionNamespace:"actions"===i?r:void 0,timestamp:s},l={data:n,metadata:a};this.dispatchNativeEvents(t,l)}dispatchNativeEvents(t,n){const[i]=t.split(".",2);try{"actions.client_ready"===t&&(this.clientReadyEvent=n);const o=new CustomEvent(this.eventPrefix+":"+t,{detail:n,bubbles:!![],cancelable:!![]});window.dispatchEvent(o);const r=new CustomEvent(this.eventPrefix+":"+i,{detail:n,bubbles:!![],cancelable:!![]});window.dispatchEvent(r)}catch(o){this.logger.error("Error dispatching native events for "+t,o)}}setupClientReadyBuffering(){const t=window.addEventListener,n=this.eventPrefix+":actions.client_ready";window.addEventListener=(i,o,r)=>{if(i!==n)return t.call(window,i,o,r);if(!this.clientReadyEvent)return t.call(window,i,o,r);try{const t=new CustomEvent(n,{detail:this.clientReadyEvent,bubbles:!![],cancelable:!![]});"function"==typeof o?o(t):o&&"function"==typeof o.handleEvent&&o.handleEvent(t)}catch(s){this.logger.error("Error replaying CLIENT_READY event",s)}return t.call(window,i,o,r)}}}function centToDollar(t){return t/100}function formatCentToDollarText(t,n=!![]){const i=Math.floor(t/100),o=t%100;let r="$"+i.toString().replace(/\B(?=(\d{3})+(?!\d))/g,",");return(n||o>0)&&(r+=".",r+=o<10?"0"+o:o.toString()),r}function htmlStringToElement(t){const n=document.createElement("template");return n.innerHTML=t.trim(),n.content.firstElementChild}function format24TimeTo12$1(t){const n=t.match(/^(\d{1,2}):(\d{2})$/);if(!n)throw new SDKError("Invalid time format: "+t);const i=Number.parseInt(n[1],10),o=Number.parseInt(n[2],10);if(i<0||i>23||o<0||o>59)throw new SDKError("Invalid time values: "+t);const r=i>=12?"PM":"AM",s=i%12||12;return s+":"+o.toString().padStart(2,"0")+" "+r}function formatISODateToMMDDYYYY(t){if(!t)return"";try{const n=new Date(t);if(Number.isNaN(n.getTime()))return"";const i=(n.getMonth()+1).toString().padStart(2,"0"),o=n.getDate().toString().padStart(2,"0"),r=n.getFullYear().toString();return i+"/"+o+"/"+r}catch(n){return""}}function buildFormattedAddressString(t){const n=[],i=[];t.one&&t.one.trim()&&i.push(t.one.trim()),t.two&&t.two.trim()&&i.push(t.two.trim()),i.length>0&&n.push(i.join(" ")),t.city&&t.city.trim()&&n.push(t.city.trim());const o=[];return t.state&&t.state.trim()&&o.push(t.state.trim()),t.zip&&t.zip.trim()&&o.push(t.zip.trim()),o.length>0&&n.push(o.join(" ")),t.country&&t.country.trim()&&n.push(t.country.trim()),n.join(", ")}function capitalizeFirstLetter(t){return t?t.toLowerCase().split(" ").map(t=>t.charAt(0).toUpperCase()+t.substring(1)).join(" "):t}function splitCategoryPath(t){const n=(null==t?void 0:t.split(" > ").map(t=>capitalizeFirstLetter(t.trim())))||[];return{category:n[0]||"",category2:n[1]||"",category3:n[2]||""}}class ApiClientService{constructor(){this.client=null,this.logger=LoggerFactory.get("ApiClient")}static getInstance(){return SingletonManager.getClassInstance("ApiClientService",()=>new ApiClientService)}async setClient(t){this.client=t}async getAllConfigs(){try{this.ensureClientInitialized();const t=await this.client.get("/configs");if(!this.validResponseData(t))throw this.logger.error("Invalid response data",t),new SDKError("Failed to fetch all configs: Invalid response data");return t.data}catch(t){throw this.logger.error("Error fetching configs",t),t}}async setPersistedStore(t,n){try{if(this.ensureClientInitialized(),!t)return this.logger.error("User device ID is required to set persisted store"),void 0;if(!n||0===Object.keys(n).length)return this.logger.error("No data provided to set persisted store"),void 0;const i=await this.client.post("/configs/store/"+t,{body:n});200!==i.statusCode&&this.logger.error("Failed to set persisted store",i)}catch(i){this.logger.error("Error setting persisted store",i)}}async getPersistedStore(t){try{if(this.ensureClientInitialized(),!t)return this.logger.error("User device ID is required to get persisted store"),null;const n=await this.client.get("/configs/store/"+t);return 200!==n.statusCode?(this.logger.error("Failed to fetch persisted store",n),null):n.data}catch(n){return this.logger.error("Error fetching persisted store",n),null}}async deletePersistedStore(t){try{if(this.ensureClientInitialized(),!t)return this.logger.error("User device ID is required to delete persisted store"),void 0;const n=await this.client.delete("/configs/store/"+t);200!==n.statusCode&&this.logger.error("Failed to delete persisted store",n)}catch(n){this.logger.error("Error deleting persisted store",n)}}async getProductsData(t,n){try{if(this.ensureClientInitialized(),0===t.length)return this.logger.error("No product identifiers provided"),null;const i={upcs:t,ids:t,grouping:t,shouldShowOffHours:!![],isLegacy:!![],loc:n},o=await this.client.post("/cloud/catalog/availability",{body:i});return 200!==o.statusCode?(this.logger.error("Failed to fetch product data",o),null):{products:o.products,retailers:o.retailers}}catch(i){return this.logger.error("Error fetching product data",i),null}}async getCartData(t){try{this.ensureClientInitialized();const n=await this.client.get("/cloud/cart"+(t?"?id="+t:""));if(200!==n.statusCode)throw this.logger.error("Failed to fetch cart data",n),new SDKError("Failed to fetch cart data: "+n.message);return n.cart}catch(n){throw this.logger.error("Error fetching cart data",n),n}}async updateCart(t){try{this.ensureClientInitialized();const n=await this.client.put("/cloud/cart",{body:t});if(200!==n.statusCode)throw this.logger.error("Failed to update cart",n),new SDKError("Failed to update cart: "+n.message);return n.cart}catch(n){throw this.logger.error("Error updating cart",n),n}}async getAddressSuggestions(t){try{if(this.ensureClientInitialized(),!t||0===t.trim().length)return this.logger.error("Query is required to fetch address suggestions"),[];const n=await this.client.get("/cloud/address/autocomplete?input="+encodeURIComponent(t));return 200!==n.statusCode?(this.logger.error("Failed to fetch address suggestions",n),[]):n.data}catch(n){return this.logger.error("Error fetching address suggestions",n),[]}}async getAddressDetails(t){try{if(this.ensureClientInitialized(),!t||0===t.trim().length)throw this.logger.error("Address ID is required to fetch address details"),new SDKError("Address ID is required to fetch address details");const n=await this.client.get("/cloud/address/details/"+t);if(200!==n.statusCode)throw this.logger.error("Failed to fetch address details",n),new SDKError("Failed to fetch address details: "+n.message);return n.data}catch(n){throw this.logger.error("Error fetching address details",n),n}}async prepareCheckout(t){var n;try{this.ensureClientInitialized();const n=await this.client.post("/cloud/checkout/prepare",{body:t});if(200!==n.statusCode)throw this.logger.error("Failed to fetch prepare checkout data",n),new SDKError("Failed to fetch prepare checkout data: "+n.message);return n.checkout}catch(i){throw this.logger.error("Error fetching prepare checkout data:",null!==(n=null==i?void 0:i.message)&&void 0!==n?n:i),i}}async getPaymentSession(t){var n;try{this.ensureClientInitialized();const n=await this.client.post("/cloud/payment/session",{body:t});if(201!==n.statusCode)throw this.logger.error("Failed to get payment session",n),new SDKError("Failed to get payment session: "+n.message);return n.data}catch(i){throw this.logger.error("Error fetching payment session:",null!==(n=null==i?void 0:i.message)&&void 0!==n?n:i),i}}async confirmPaymentSession(t,n){try{this.ensureClientInitialized();const i=await this.client.post("/cloud/payment/confirm",{body:{confirmationTokenId:t,setupIntentId:n}});if(200!==i.statusCode)throw this.logger.error("Failed to confirm payment session",i),new SDKError("Failed to confirm payment session: "+i.message);return i.data}catch(i){throw this.logger.error("Error confirming payment session",i),i}}async checkoutComplete(t){var n;try{this.ensureClientInitialized();const n=await this.client.post("/cloud/checkout/complete",{body:t});if(200!==n.statusCode)throw this.logger.error("Failed to complete checkout",n),new SDKError("Failed to complete checkout: "+n.message);return n.order}catch(i){if(this.logger.error("Error completing checkout:",null!==(n=null==i?void 0:i.message)&&void 0!==n?n:i),null==i?void 0:i.error)throw new SDKError(i.error);throw i}}async catalogSearch(t){var n;try{this.ensureClientInitialized();const n=await this.client.post("/cloud/catalog/search",{body:t});if(200!==n.statusCode)throw this.logger.error("Failed to fetch catalog search data",n),new SDKError("Failed to fetch catalog search data: "+n.message);return{products:n.products,retailers:n.retailers,navigation:n.navigation}}catch(i){return this.logger.error("Error fetching catalog search data:",null!==(n=null==i?void 0:i.message)&&void 0!==n?n:i),{products:[],retailers:[],navigation:void 0}}}validResponseData(t){return t.data&&"object"==typeof t.data&&Object.keys(t.data).length>0}ensureClientInitialized(){if(!this.client)throw new SDKError("API client is not initialized")}}class HttpClientService{constructor(){this.logger=LoggerFactory.get("HttpClient"),this.defaultShouldRetry=(t,n)=>t||n&&n.status>=500&&n.status<600?!![]:![],this.xhrFetch=(t,n)=>new Promise((i,o)=>{const r=new XMLHttpRequest;r.open(n.method||"GET",t);for(const[t,s]of Object.entries(n.headers))r.setRequestHeader(t,s);r.onload=()=>{const t={ok:r.status>=200&&r.status<300,status:r.status,statusText:r.statusText,headers:r.getAllResponseHeaders().split("\r\n").reduce((t,n)=>{const[i,o]=n.split(": ");return i&&o&&(t[i]=o),t},{}),o:r.responseText,json:()=>Promise.resolve(JSON.parse(r.responseText)),text:()=>Promise.resolve(r.responseText)};i(t)},r.onerror=()=>{o(new TypeError("Network request failed"))},r.ontimeout=()=>{o(new TypeError("Network request timed out"))},r.timeout=3e4,r.send(n.body)}),this.fetchImpl=this.getFetchImplementation()}async request(t){var n,i,o;const{url:r,options:s,retryConfig:a}=t,l=null!==(n=null==a?void 0:a.maxRetries)&&void 0!==n?n:3,c=null!==(i=null==a?void 0:a.retryDelay)&&void 0!==i?i:1e3,d=null!==(o=null==a?void 0:a.shouldRetry)&&void 0!==o?o:this.defaultShouldRetry;let u;const h=Date.now();for(let m=0;m<=l;m++){let t=Date.now();try{t=Date.now();const n=await this.fetchImpl(r,s),i=Date.now()-t;if(n.ok)return n;if(await this.logFailedResponse(r,s,n,i,m,l),m<l&&d(null,n)){await this.delay(c*2**m);continue}return n}catch(p){const n=Date.now()-t;if(u=p,this.logNetworkError(r,s,p,n,m,l),m<l&&d(p,void 0)){await this.delay(c*2**m);continue}throw this.enhanceError(p,r,s,Date.now()-h)}}throw this.enhanceError(u,r,s,Date.now()-h)}async logFailedResponse(t,n,i,o,r,s){const a=r<s;let l,c;try{i.o||(i.o=await i.text());try{l=JSON.parse(i.o)}catch(d){l=i.o}}catch(u){l="[Unable to read response body]"}if(n.body)try{c=JSON.parse(n.body)}catch(h){c=n.body}this.logger.error("HTTP request failed",{method:n.method,url:t,status:i.status,statusText:i.statusText,duration:o+"ms",attempt:r+1+"/"+(s+1),willRetry:a,requestHeaders:this.sanitizeHeaders(n.headers),requestBody:c,responseHeaders:this.sanitizeHeaders(i.headers),responseBody:l})}logNetworkError(t,n,i,o,r,s){var a;const l=r<s;this.logger.error("Network request failed",{method:n.method,url:t,error:(null==i?void 0:i.message)||"Unknown error",errorType:(null===(a=null==i?void 0:i.constructor)||void 0===a?void 0:a.name)||typeof i,duration:o+"ms",attempt:r+1+"/"+(s+1),willRetry:l,possibleCauses:this.diagnosePossibleCauses(i)})}diagnosePossibleCauses(t){var n,i,o,r,s;const a=[];return((null===(n=null==t?void 0:t.message)||void 0===n?void 0:n.includes("timeout"))||(null===(i=null==t?void 0:t.message)||void 0===i?void 0:i.includes("timed out")))&&a.push("Request timeout - server took too long to respond"),((null===(o=null==t?void 0:t.message)||void 0===o?void 0:o.includes("Failed to fetch"))||(null===(r=null==t?void 0:t.message)||void 0===r?void 0:r.includes("Network request failed")))&&(a.push("Network connectivity issue"),a.push("CORS policy blocking the request"),a.push("Server is not responding"),a.push("Request was blocked by browser or firewall")),(null===(s=null==t?void 0:t.message)||void 0===s?void 0:s.includes("aborted"))&&a.push("Request was aborted"),0===a.length&&a.push("Unknown network error"),a}enhanceError(t,n,i,o){const r=new Error((null==t?void 0:t.message)||"Network request failed - no response from server");return r.url=n,r.method=i.method,r.totalDuration=o+"ms",r.isNetworkError=!![],r.originalError=t,r.possibleCauses=this.diagnosePossibleCauses(t),r}sanitizeHeaders(t){const n={...t},i=["authorization","x-liquid-api-key","cookie","set-cookie"];for(const o of Object.keys(n))i.includes(o.toLowerCase())&&(n[o]="[REDACTED]");return n}delay(t){return new Promise(n=>setTimeout(n,t))}getFetchImplementation(){return"undefined"!=typeof fetch?this.fetchAdapter(fetch):"undefined"!=typeof global&&global.fetch?this.fetchAdapter(global.fetch):window.fetch?this.fetchAdapter(window.fetch):this.xhrFetch}fetchAdapter(t){return async(n,i)=>{var o;const r=await t(n,i);let s;if("function"==typeof(null===(o=r.headers)||void 0===o?void 0:o.entries))s=Object.fromEntries(r.headers.entries());else{s={};for(const[t,n]of r.headers)s[t]=n}const a={ok:r.ok,status:r.status,statusText:r.statusText,headers:s,json:async()=>(a.o||(a.o=await r.text()),JSON.parse(a.o)),text:async()=>(a.o||(a.o=await r.text()),a.o)};return a}}}class AuthClientService{constructor(t){this.accessToken=null,this.tokenExpiration=null,this.isAuthenticating=![],this.apiKey=t.apiKey,this.baseUrl=t.baseUrl,this.env=t.env,this.httpClient=new HttpClientService,this.logger=LoggerFactory.get("Auth"),this.clientConfig=ClientConfigService.getInstance()}static getInstance(t){return SingletonManager.getClassInstance("AuthService",()=>new AuthClientService(t))}async authenticate(){var t,n;if(this.isAuthenticating)return await new Promise(t=>{const v=()=>{this.isAuthenticating?setTimeout(v,100):t(void 0)};v()}),!!this.accessToken;this.isAuthenticating=!![];try{const i=await this.request("/auth",{method:"GET"},!![]),o=3e5;return this.accessToken=null===(t=null==i?void 0:i.data)||void 0===t?void 0:t.token,this.tokenExpiration=(null===(n=null==i?void 0:i.data)||void 0===n?void 0:n.exp)-o,!![]}catch(i){return this.logger.error("Authentication failed",i),![]}finally{this.isAuthenticating=![]}}isTokenExpired(){return this.tokenExpiration?Date.now()>=this.tokenExpiration:!![]}async request(t,n,i=![]){var o;i||this.accessToken&&!this.isTokenExpired()||await this.authenticate();const r=this.buildUrl(t),s={"Content-Type":"application/json","X-Liquid-Api-Env":this.env,"X-Liquid-Api-Sdk":window.location.href,"X-Liquid-Sdk-Version":this.clientConfig.get("version")||"unknown","X-Liquid-Timestamp":Date.now(),...this.getProxyHeaders(),...n.headers};i?s["X-Liquid-Api-Key"]=this.apiKey:s.Authorization="Bearer "+this.accessToken,this.clientConfig.isBuilder()&&(s["X-Liquid-Api-Builder"]=!![]);const a={method:n.method,headers:s,body:n.body?JSON.stringify(n.body):void 0},L=(t,n)=>{if(t)return!![];if(!i&&n){const t=n.status;if(401===t||403===t)return this.logger.warn("Authorization error detected, will retry with new token"),this.accessToken=null,this.tokenExpiration=null,!![]}return n&&n.status>=500&&n.status<600?!![]:![]};let l,c;try{l=await this.httpClient.request({url:r,options:a,retryConfig:{maxRetries:2,retryDelay:1e3,shouldRetry:L}})}catch(u){throw this.logger.error("Request failed after all retries",{path:t,method:n.method,authType:i?"API Key":"Bearer Token",error:null==u?void 0:u.message,possibleCauses:null==u?void 0:u.possibleCauses}),{status:0,statusCode:0,message:(null==u?void 0:u.message)||"Network error: Unable to connect to the API",url:r,method:n.method,isNetworkError:!![],originalError:u}}if(l.ok)try{return await l.json()}catch(h){const o=await l.text().catch(()=>"Success");return this.logger.error("Failed to parse successful response JSON",{path:t,method:n.method,status:l.status,authType:i?"API Key":"Bearer Token",responsePreview:o,error:null==h?void 0:h.message}),{message:o}}let d="";try{c=await l.json(),d=JSON.stringify(c)}catch(p){d=await l.text().catch(()=>"HTTP error status: "+l.status),c={message:d||"Unknown error"}}throw this.logger.error("API request failed",{path:t,method:n.method,authType:i?"API Key":"Bearer Token",status:l.status,statusText:l.statusText,statusCode:null==c?void 0:c.statusCode,message:null==c?void 0:c.message,requestId:null===(o=null==c?void 0:c.metadata)||void 0===o?void 0:o.requestId,responseBody:d}),{...c,status:l.status,message:(null==c?void 0:c.message)||"Request failed"}}buildUrl(t){const n=this.clientConfig.getProxyConfig();return new URL("api"+t,n?n.baseUrl:this.baseUrl).toString()}getProxyHeaders(){const t=this.clientConfig.getProxyConfig();return t?{"X-Liquid-Proxy":"true","X-Liquid-Proxy-Target":this.baseUrl,...t.headers}:{}}async get(t,n){return this.request(t,{method:"GET",headers:null==n?void 0:n.headers})}async post(t,n){return this.request(t,{method:"POST",body:null==n?void 0:n.body,headers:null==n?void 0:n.headers})}async put(t,n){return this.request(t,{method:"PUT",body:null==n?void 0:n.body,headers:null==n?void 0:n.headers})}async delete(t,n){return this.request(t,{method:"DELETE",headers:null==n?void 0:n.headers})}}const C="@liquidcommerce/elements-sdk",k="LiquidCommerce Elements SDK",S="UNLICENSED",E="LiquidCommerce Team",_="2.6.0-beta.1",D="https://docs.liquidcommerce.co/elements-sdk",P={type:"git",url:"git+https://github.com/liquidcommerce/elements-sdk.git"},F={url:"https://github.com/liquidcommerce/elements-sdk/issues"},A="./dist/index.esm.js",O="./umd/elements.js",N="./dist/types/index.d.ts",R="pnpm@10.0.0",M={".":{types:"./dist/types/index.d.ts",import:"./dist/index.esm.js",browser:"./umd/elements.js",default:"./dist/index.esm.js"},"./package.json":"./package.json"},q=["dist","umd","docs","README.md","LICENSE"],j={access:"public",registry:"https://registry.npmjs.org/"},U="module",V=["dist/index.esm.js","umd/elements.js","src/index.ts","src/index.umd.ts"],K={build:"rollup -c","build:dev":"rollup -c --environment NODE_ENV:development",dev:"rollup -c -w","type-check":"tsc --noEmit",lint:"pnpm biome lint --write",format:"biome format --write",check:"pnpm biome check --write .",fl:"pnpm check && pnpm build:dev",changelog:"conventional-changelog -p angular -i CHANGELOG.md -s",clean:"rm -rf dist umd","clean:hard":"rm -rf dist umd node_modules && pnpm install && pnpm build",prepublishOnly:"pnpm run build","deprecate:old":'npm deprecate @liquidcommerceteam/elements-sdk@"*" "Package moved to @liquidcommerce/elements-sdk"',prepare:"husky"},Y=["liquidcommerce","alcohol","beverage","alcohol tech","elements","custom web components","embeddable components","embeddable web components","embeddable commerce"],W={"@biomejs/biome":"2.3.5","@commitlint/cli":"^20.1.0","@commitlint/config-conventional":"^20.0.0","@rollup/plugin-alias":"^6.0.0","@rollup/plugin-commonjs":"^29.0.0","@rollup/plugin-json":"^6.1.0","@rollup/plugin-node-resolve":"^16.0.3","@rollup/plugin-replace":"^6.0.3","@rollup/plugin-terser":"^0.4.4","@semantic-release/changelog":"^6.0.3","@semantic-release/commit-analyzer":"^13.0.1","@semantic-release/git":"^10.0.1","@semantic-release/github":"^12.0.2","@semantic-release/npm":"^13.1.2","@semantic-release/release-notes-generator":"^14.1.0","@types/core-js":"^2.5.8","@types/node":"^24.10.1","conventional-changelog-cli":"^5.0.0",husky:"^9.1.7",process:"^0.11.10",rollup:"^4.53.3","rollup-obfuscator":"^4.1.1","rollup-plugin-typescript2":"^0.36.0","semantic-release":"^25.0.2","ts-node":"^10.9.2",typescript:"^5.9.3"},Q={node:">=22"},Z={peerDependencyRules:{ignoreMissing:[]},onlyBuiltDependencies:["@biomejs/biome","javascript-obfuscator"],overrides:{"@conventional-changelog/git-client@<2.0.0":">=2.0.0"}},X={name:C,description:k,license:S,author:E,version:_,homepage:D,repository:P,bugs:F,module:A,browser:O,types:N,packageManager:R,exports:M,files:q,publishConfig:j,type:U,sideEffects:V,scripts:K,keywords:Y,devDependencies:W,engines:Q,pnpm:Z};class GoogleTagManagerService{constructor(){this.partnerEnableGaTracking=![],this.liquidCommerceEnableGaTracking=![],this.isInitialized=![],this.isInitializing=![],this.currency="USD",this.eventQueue=[],this.logger=LoggerFactory.get("GoogleTagManager"),this.clientConfigService=ClientConfigService.getInstance()}static getInstance(){return SingletonManager.getClassInstance("GoogleTagManagerService",()=>new GoogleTagManagerService)}waitForDOMReady(){return new Promise(t=>{if("loading"!==document.readyState)return t(),void 0;document.addEventListener("DOMContentLoaded",()=>t())})}isGTMAlreadyLoaded(){return"function"==="object".gtag?!![]:Array.from(document.querySelectorAll('script[src*="googletagmanager.com/gtm.js"]')).length>0}isContainerLoaded(t){const n=Array.from(document.querySelectorAll('script[src*="googletagmanager.com/gtm.js"]'));return n.some(n=>{const i=n.src;return i.includes("id="+t)})}isContainerInitialized(t){return window.dataLayer&&Array.isArray(window.dataLayer)&&this.isContainerLoaded(t)?window.dataLayer.some(t=>t&&"object"==typeof t&&("gtm.start"in t||"gtm.js"===t.event)):![]}async loadGTMScript(t){try{if(this.isContainerInitialized(t))return{success:!![],usingExistingGTM:!![],message:"Container "+t+" already loaded"};if(this.isContainerLoaded(t)){const n=await this.waitForContainerInit(t,1e4);return n?{success:!![],usingExistingGTM:!![],message:"Container "+t+" initialized"}:this.checkFallbackGTM(t)}return await this.injectGTMScript(t),{success:!![],usingExistingGTM:![],message:"Container "+t+" loaded successfully"}}catch(n){return this.checkFallbackGTM(t)}}waitForContainerInit(t,n){return new Promise(i=>{let o;const r=setInterval(()=>{this.isContainerInitialized(t)&&(clearInterval(r),clearTimeout(o),i(!![]))},100);o=setTimeout(()=>{clearInterval(r),i(![])},n)})}injectGTMScript(t){return new Promise((n,i)=>{const o=document.createElement("script");o.src="https://www.googletagmanager.com/gtm.js?id="+t,o.async=!![],o.crossOrigin="anonymous";let r=![];const s=setTimeout(()=>{r||(r=!![],this.isContainerInitialized(t)?n():i(new Error("GTM script timeout")))},15e3);o.onload=()=>{r||setTimeout(()=>{r||(r=!![],clearTimeout(s),this.isContainerInitialized(t)||window.dataLayer&&Array.isArray(window.dataLayer)?n():i(new Error("GTM script loaded but failed to initialize")))},500)},o.onerror=()=>{setTimeout(()=>{r||(r=!![],clearTimeout(s),this.isContainerLoaded(t)&&this.isContainerInitialized(t)?n():i(new Error("GTM script failed to load")))},100)},document.head.appendChild(o)})}checkFallbackGTM(t){if(this.isGTMAlreadyLoaded()&&window.dataLayer&&Array.isArray(window.dataLayer)){if(this.partnerGtmId&&this.isContainerInitialized(this.partnerGtmId))return{success:!![],usingExistingGTM:!![],message:"Using partner GTM container"};const t=window.dataLayer.some(t=>t&&"object"==typeof t&&("gtm.start"in t||"gtm.js"===t.event));if(t)return{success:!![],usingExistingGTM:!![],message:"Using existing GTM container"}}return window.dataLayer&&Array.isArray(window.dataLayer)?{success:!![],usingExistingGTM:!![],message:"Using basic dataLayer for event tracking"}:{success:![],usingExistingGTM:![],message:"Failed to load container "+t+" and no fallback available"}}processEventQueue(){const t=Date.now(),n=this.eventQueue.filter(n=>t-n.timestamp<3e4);for(const o of n)try{const t={event:o.eventName,...o.eventData};window.dataLayer.push(t)}catch(i){this.logger.error("Error processing queued event "+o.methodName,i)}this.eventQueue=[],n.length>0&&this.logger.info("Processed "+n.length+" queued GTM events")}getSendToTargets(){const t=[];return this.liquidCommerceEnableGaTracking&&this.liquidCommerceGtmId&&this.isContainerInitialized(this.liquidCommerceGtmId)&&t.push(this.liquidCommerceGtmId),this.partnerEnableGaTracking&&this.partnerGtmId&&this.isContainerInitialized(this.partnerGtmId)&&t.push(this.partnerGtmId),t}async initialize(t){try{if(this.isInitialized)return Promise.resolve();if(this.isInitializing&&this.initializationPromise)return this.initializationPromise;if(0,this.clientConfigService.isBuilder())return;this.isInitializing=!![],this.initializationPromise=this.doInitialize(t),await this.initializationPromise}catch(n){this.isInitializing=![],this.initializationPromise=void 0,this.logger.error("GTM initialization failed",n)}}async doInitialize(t){if(!(null==t?void 0:t.partnerName)||!(null==t?void 0:t.liquidCommerceGtmId))return;if(!t.liquidCommerceEnableGaTracking&&!t.partnerEnableGaTracking)return this.isInitialized=!![],this.isInitializing=![],this.initializationPromise=void 0,void 0;await this.waitForDOMReady(),this.partnerName=t.partnerName,this.partnerGtmId=t.partnerGtmId,this.liquidCommerceGtmId=t.liquidCommerceGtmId,this.partnerEnableGaTracking=t.partnerEnableGaTracking,this.liquidCommerceEnableGaTracking=t.liquidCommerceEnableGaTracking,window.dataLayer||(window.dataLayer=[]),window.gtag||(window.gtag=(...t)=>window.dataLayer.push(t));const n=t.liquidCommerceEnableGaTracking?await this.loadGTMScript(t.liquidCommerceGtmId):{success:!![],message:"Using partner GTM only"};if(!n.success)throw this.isInitializing=![],this.initializationPromise=void 0,new SDKError("GTM initialization failed: "+n.message);this.isInitialized=!![],this.isInitializing=![],this.initializationPromise=void 0,this.logger.info(n.message),this.processEventQueue()}executeEvent(t,n,i){try{if(this.clientConfigService.isBuilder())return;const o=this.getSendToTargets(),r={...i,...o.length>0&&{send_to:o},tenant_source:X.description+" v"+X.version,tenant_name:this.partnerName};if(!this.isInitialized)return this.eventQueue.length>=100&&this.eventQueue.shift(),this.eventQueue.push({methodName:t,eventName:n,eventData:r,timestamp:Date.now()}),void 0;if(!window.dataLayer||!Array.isArray(window.dataLayer))return;const s={event:n,...r};window.dataLayer.push(s)}catch(o){this.logger.error("GTM "+t+" error",o)}}calculateValue(t){const n=t.reduce((t,n)=>t+(n.price||0)*(n.quantity||1),0);return Number.parseFloat(n.toFixed(2))}viewItem(t){this.executeEvent("viewItem","view_item",{currency:this.currency,value:this.calculateValue([t]),items:[t]})}viewItemList(t,n,i){this.executeEvent("viewItemList","view_item_list",{currency:this.currency,item_list_id:n,item_list_name:i,items:t})}selectItem(t,n,i){this.executeEvent("selectItem","select_item",{item_list_id:n,item_list_name:i,items:[t]})}addToCart(t){this.executeEvent("addToCart","add_to_cart",{currency:this.currency,value:this.calculateValue([t]),quantity:t.quantity||1,items:[t]})}viewCart(t){this.executeEvent("viewCart","view_cart",{currency:this.currency,value:this.calculateValue(t),items:t})}removeFromCart(t){this.executeEvent("removeFromCart","remove_from_cart",{currency:this.currency,value:this.calculateValue([t]),items:[t]})}beginCheckout(t,n){this.executeEvent("beginCheckout","begin_checkout",{currency:this.currency,value:this.calculateValue(t),coupon:n,items:t})}addShippingInfo(t,n){this.executeEvent("addShippingInfo","add_shipping_info",{currency:this.currency,value:this.calculateValue(t),coupon:n,items:t})}addPaymentInfo(t,n,i){this.executeEvent("addPaymentInfo","add_payment_info",{currency:this.currency,value:this.calculateValue(t),payment_type:n,coupon:i,items:t})}purchase(t){this.executeEvent("purchase","purchase",{transaction_id:t.transaction_id,value:t.value,currency:this.currency,tax:t.tax,shipping:t.shipping,coupon:t.coupon,items:t.items,subtotal:t.subtotal,total:t.total_before_discounts,discounts:t.discounts,gift_cards:t.gift_cards,net_total:t.net_total})}promoCodeAttempt(t){this.executeEvent("promoCodeAttempt","promo_code_attempt",{promo_code:t})}promoCodeApplied(t,n){this.executeEvent("promoCodeApplied","promo_code_applied",{promo_code:t,discount_amount:n})}promoCodeFailed(t,n){this.executeEvent("promoCodeFailed","promo_code_failed",{promo_code:t,reason:n})}giftCardAttempt(t){this.executeEvent("giftCardAttempt","gift_card_attempt",{gift_card_code:t})}giftCardApplied(t,n){this.executeEvent("giftCardApplied","gift_card_applied",{gift_card_code:t,applied_amount:n})}giftCardFailed(t,n){this.executeEvent("giftCardFailed","gift_card_failed",{gift_card_code:t,reason:n})}addressUpdated(t){this.executeEvent("addressUpdated","address_updated",{address_id:t.googlePlacesId,formatted_address:t.formattedAddress,address:t.address,coordinates:t.coordinates})}addressFailed(t){this.executeEvent("addressFailed","address_failed",{address_id:t.googlePlacesId,formatted_address:t.formattedAddress,address:t.address,address_error_message:t.error})}productNoAvailability(t){this.executeEvent("productNoAvailability","product_no_availability",{product_id:t.productId,product_name:t.productName,product_brand:t.productBrand,product_category:t.productCategory,product_category2:t.productCategory2,product_category3:t.productCategory3,product_type:t.productType,product_subtype:t.productSubtype,product_price:t.productPrice,upc:t.upc,grouping_id:t.groupingId,address:t.address,availability_reason:t.reason})}productSizeNoAvailability(t){this.executeEvent("productSizeNoAvailability","product_size_no_availability",{product_id:t.productId,product_name:t.productName,product_brand:t.productBrand,product_category:t.productCategory,product_category2:t.productCategory2,product_category3:t.productCategory3,product_type:t.productType,product_subtype:t.productSubtype,product_price:t.productPrice,size_id:t.sizeId,size_name:t.sizeName,upc:t.upc,grouping_id:t.groupingId,address:t.address,availability_reason:t.reason})}productFulfillmentNoAvailability(t){this.executeEvent("productFulfillmentNoAvailability","product_fulfillment_no_availability",{product_id:t.productId,product_name:t.productName,product_brand:t.productBrand,product_category:t.productCategory,product_category2:t.productCategory2,product_category3:t.productCategory3,product_type:t.productType,product_subtype:t.productSubtype,product_price:t.productPrice,size_id:t.sizeId,size_name:t.sizeName,fulfillment_type:t.fulfillmentType,upc:t.upc,grouping_id:t.groupingId,address:t.address,availability_reason:t.reason})}}class StoreService{constructor(){this.middleware=[],this.isLocalStorageAvailable=![],this.loggingMiddleware=({action:t,payload:n,next:i})=>{const o=performance.now();try{const r=i(),s=performance.now()-o;return this.logger.info("🏪 Store "+t+" ✓ "+s.toFixed(3)+"ms",n),r}catch(r){const i=performance.now()-o;throw this.logger.error("🏪 Store "+t+" ✗ "+i.toFixed(3)+"ms",{payload:n,error:r}),r}},this.performanceMiddleware=({action:t,next:n})=>{const i=performance.now(),o=n(),r=performance.now()-i;return r>16&&this.logger.warn('⚠️ Slow store operation "'+t+'": '+r.toFixed(2)+"ms"),o},this.state=w,this.listeners=new Map,this.logger=LoggerFactory.get("Store"),this.clientConfig=ClientConfigService.getInstance(),this.api=ApiClientService.getInstance(),this.setupMiddleware()}static getInstance(){return SingletonManager.getClassInstance("StoreService",()=>new StoreService)}async initialize({userDeviceId:t,isLocalStorageAvailable:n,persistedStore:i}){this.localStorageKey=this.clientConfig.get("localStorageKeyPrefix")+"_"+t,this.isLocalStorageAvailable=n,n?await this.loadPersistedState():i&&await this.loadFromDBPersistence(i),this.logger.info("Store service initialized successfully",{userDeviceId:t,isLocalStorageAvailable:n,hasPersistedState:null!==i,localStorageKey:this.localStorageKey})}get(t){if(!t)return{...this.state};const n=t.split(".");let i=this.state;for(const o of n){if(null==i)return;i=i[o]}return void 0!==i?Array.isArray(i)?[...i]:"object"==typeof i&&null!==i?{...i}:i:void 0}set(t,n){return this.runWithMiddleware("set",{path:t,value:n},()=>{const i=this.get(t);return this.state=this.immutableSet(this.state,t,n),this.notifyListeners(t,n,i),this.isLocalStorageAvailable&&this.debouncedSave(),!![]})}update(t,n){const i=this.get(t),o=n(i);return this.set(t,o)}remove(t){return this.runWithMiddleware("remove",{path:t},()=>{const n=this.get(t);if(void 0===n)return this.logger.warn('No value found at path "'+t+'" to remove.'),![];const i=t.split(".");let o=this.state;const r=i.pop();for(const s of i){if(void 0===o[s])return this.logger.warn('Path "'+t+'" does not exist in the state.'),![];o=o[s]}if(Array.isArray(o))o=o.filter((t,n)=>n!==Number.parseInt(r,10));else{if("object"!=typeof o||null===o)return this.logger.warn('Cannot remove property "'+r+'" from non-object type at path "'+t+'".'),![];{const{[r]:t,...n}=o;o=n}}return this.state=this.immutableSet(this.state,i.join("."),o),this.notifyListeners(t,void 0,n),this.isLocalStorageAvailable&&this.debouncedSave(),!![]})}batch(t){return this.runWithMiddleware("batch",{updates:t},()=>{const n=[];if("function"==typeof t){const i=t(this.state);for(const[t,o]of Object.entries(i)){const i=this.get(t);n.push({path:t,oldValue:i,newValue:o,timestamp:Date.now()}),this.state=this.immutableSet(this.state,t,o)}}else for(const[i,o]of Object.entries(t)){const t=this.get(i);n.push({path:i,oldValue:t,newValue:o,timestamp:Date.now()}),this.state=this.immutableSet(this.state,i,o)}for(const{path:t,oldValue:i,newValue:o}of n)this.notifyListeners(t,o,i);return this.isLocalStorageAvailable&&this.debouncedSave(),!![]})}watch(t,n){const i=t;return this.listeners.has(i)||this.listeners.set(i,new Set),this.listeners.get(i).add(n),()=>{var t;null===(t=this.listeners.get(i))||void 0===t?void 0:t.delete(n)}}watchMany(t,n){const i=[];let o;const r=t.map(t=>this.watch(t,(r,s)=>{i.push({path:t,value:r,oldValue:s}),clearTimeout(o),o=setTimeout(()=>{i.length>0&&(n([...i]),i.length=0)},0)}));return()=>{for(const t of r)t()}}createProductInstance(t){const n="products."+t,i=this.get(n);return i?!![]:this.set(n,h)}removeProductInstance(t){const n=this.get("products"),{[t]:i,...o}=n;return this.set("products",o)}getProductInstances(){return this.get("products")}getState(){return{...this.state}}setupMiddleware(){this.middleware.push(this.loggingMiddleware),this.middleware.push(this.performanceMiddleware)}runWithMiddleware(t,n,i){let o=0;const z=()=>{if(o>=this.middleware.length)return i();const r=this.middleware[o++];return r({action:t,payload:n,state:this.getState(),next:z})};return z()}immutableSet(t,n,i){const o=n.split(".");if(1===o.length){if(Array.isArray(t)){const n=[...t];return n[o[0]]=i,n}return{...t,[o[0]]:i}}const[r,...s]=o,a=t[r],l=Array.isArray(a)?[]:{};if(Array.isArray(t)){const n=[...t];return n[r]=this.immutableSet(a||l,s.join("."),i),n}return{...t,[r]:this.immutableSet(a||l,s.join("."),i)}}notifyListeners(t,n,i){const o=this.listeners.get(t);if(o)for(const l of o)try{l(n,i)}catch(s){this.logger.error('Error in store listener for path "'+t+'"',s)}const r=t.split(".");for(let l=r.length-1;l>0;l--){const t=r.slice(0,l).join("."),n=this.listeners.get(t);if(n){const o=this.get(t),s=r.slice(l).join("."),c=this.immutableSet(o,s,i);for(const i of n)try{i(o,c)}catch(a){this.logger.error('Error in store listener for parent path "'+t+'"',a)}}}}debouncedSave(){this.saveTimeout&&clearTimeout(this.saveTimeout),this.saveTimeout=setTimeout(()=>this.saveStore(),50)}forceSave(){this.saveTimeout&&(clearTimeout(this.saveTimeout),this.saveTimeout=void 0),this.saveStore()}async persist(){var t;const n=this.get("address.id")||"",i=this.get("cart.id")||"";if(!n&&!i)return this.logger.info("No session data to persist (both IDs are empty), skipping"),void 0;if(this.isLocalStorageAvailable)return this.forceSave(),this.logger.info("Session data persisted to localStorage",{addressId:n,cartId:i}),void 0;try{const o=null!==(t=this.clientConfig.get("userDeviceId"))&&void 0!==t?t:"not_defined";await this.api.setPersistedStore(o,{p:n,c:i}),this.logger.info("Session data persisted to DB",{userDeviceId:o,addressId:n,cartId:i})}catch(o){this.logger.error("Failed to persist session data to DB",o)}}clearLocalStorage(){if(!this.isLocalStorageAvailable||!this.localStorageKey)return this.logger.info("localStorage not available or key not set, skipping clear"),void 0;try{localStorage.removeItem(this.localStorageKey),this.logger.info("localStorage entry completely removed",{key:this.localStorageKey})}catch(X){this.logger.error("Failed to clear localStorage entry",X)}}saveStore(){if(this.isLocalStorageAvailable&&this.localStorageKey)try{let t="";if(this.clientConfig.debuggingDisabled()){const n=this.get("address.id")||"",i=this.get("cart.id")||"";(n||i)&&(t=n+":"+i)}else t=this.getState();t&&localStorage.setItem(this.localStorageKey,"string"!=typeof t?JSON.stringify(t):t)}catch(t){this.logger.error("Failed to persist store state",t)}}async loadPersistedState(){if(this.isLocalStorageAvailable&&this.localStorageKey)try{const n=localStorage.getItem(this.localStorageKey);if(!n)return;try{const t=JSON.parse(n);for(const[n,i]of Object.entries(t))this.set(n,i);return}catch(t){if(n.includes(":")){const[t,i]=n.split(":");if(void 0!==t){const n=await this.getAddressDataFromId(t);this.set("address",n)}return void 0!==i&&this.set("cart.id",i||null),void 0}this.logger.warn("Unrecognized localStorage format, skipping load",{saved:n})}}catch(n){this.logger.error("Failed to load persisted state",n),localStorage.removeItem(this.localStorageKey)}}async loadFromDBPersistence(t){try{if(void 0!==t.p){const n=await this.getAddressDataFromId(t.p);this.set("address",n)}void 0!==t.c&&this.set("cart.id",t.c||null),this.logger.info("Session data loaded from DB persistence",{addressId:t.p,cartId:t.c})}catch(n){this.logger.error("Failed to load session data from DB persistence",n)}}async getAddressDataFromId(t){if(!t||""===t.trim())return b;try{const n=await this.api.getAddressDetails(t);return n&&0!==Object.keys(n).length?{id:t,formattedAddress:n.formattedAddress,address:{one:n.address.one,two:n.address.two,city:n.address.city,state:n.address.state,zip:n.address.zip,country:n.address.country||""},coordinates:{lat:n.coords.lat,long:n.coords.long}}:{...b,id:t}}catch(n){return{...b,id:t}}}}const $=[o.PRODUCT,o.PRODUCT_IMAGE_CAROUSEL,o.PRODUCT_OPTIONS,o.PRODUCT_INTERACTIONS,o.PRODUCT_DESCRIPTION,o.PRODUCT_RETAILERS,o.PRODUCT_RETAILERS_CAROUSEL,o.PRODUCT_RETAILERS_POPUP,o.PRODUCT_RETAILERS_POPUP_LIST,o.PRODUCT_PRICE,o.PRODUCT_ADD_TO_CART_SECTION,o.PRODUCT_DRAWER,o.PRODUCT_LOADING,o.ENGRAVING_FORM,o.ENGRAVING_VIEW,o.PRODUCT_LIST,o.PRODUCT_LIST_CARD,o.PRODUCT_LIST_CARD_LOADING,o.PRODUCT_LIST_FILTERS],J=[o.ADDRESS_INPUT,o.ADDRESS_DISPLAY],tt=[o.CART,o.CART_RETAILER,o.CART_ITEM,o.CART_FOOTER,o.CART_ITEM_QUANTITY_PRICE,o.CART_RETAILER_SUBTOTAL,o.CART_PROMO_CODE,o.CART_HEADER,o.CART_BODY,o.CART_FULFILLMENT,o.BUTTONS_CART_OPEN],et=[o.CHECKOUT,o.CHECKOUT_INFORMATION,o.CHECKOUT_STRIPE_HANDLER,o.CHECKOUT_STRIPE_FORM,o.CHECKOUT_PAYMENT,o.CHECKOUT_BILLING,o.CHECKOUT_ORDER_SUMMARY,o.CHECKOUT_PROMO_CODE,o.CHECKOUT_GIFT_CARDS,o.CHECKOUT_AMOUNTS,o.CHECKOUT_ITEMS,o.CHECKOUT_COMPLETED,o.CHECKOUT_DELIVER_TO,o.CHECKOUT_DELIVER_TO_SUMMARY,o.CHECKOUT_BUYER,o.CHECKOUT_TIPS,o.CHECKOUT_PC_GC,o.CHECKOUT_ITEM,o.CHECKOUT_ITEM_QUANTITY,o.CHECKOUT_PLACE_ORDER_BUTTON,o.CHECKOUT_HEADER,o.CHECKOUT_PRESALE_COUNTDOWN,o.CHECKOUT_PRESALE_EXPIRED,o.CHECKOUT_SEND_AS_GIFT];class FontManagerService{constructor(){this.googleFontsUrl="",this.defaultFontFamilies=[{name:"Poppins",weights:[400,500,600,700]}],this.fontsLinkAttribute="data-lce-fonts"}loadGoogleFonts(t,n="swap"){if(!t||0===t.length)return;const i=[...this.defaultFontFamilies,...t],o=i.map(t=>{const n=encodeURIComponent(t.name);return"family="+n+":wght@"+t.weights.join(";")}).join("&"),r="display="+n;this.googleFontsUrl="https://fonts.googleapis.com/css2?"+o+"&"+r,this.injectGoogleFontsResourceHints(),this.injectGoogleFontsLink()}updateGoogleFonts(t,n="swap"){const i=document.querySelector("link["+this.fontsLinkAttribute+"]");this.loadGoogleFonts(t,n),i&&i.remove()}injectGoogleFontsResourceHints(){const t=document.querySelector('link[href="https://fonts.googleapis.com"][rel="preconnect"]'),n=document.querySelector('link[href="https://fonts.gstatic.com"][rel="preconnect"]');if(!t){const t=document.createElement("link");t.rel="preconnect",t.href="https://fonts.googleapis.com",document.head.appendChild(t)}if(!n){const t=document.createElement("link");t.rel="preconnect",t.href="https://fonts.gstatic.com",t.crossOrigin="",document.head.appendChild(t)}}injectGoogleFontsLink(){if(!this.googleFontsUrl)return;const t=document.createElement("link");t.rel="stylesheet",t.href=this.googleFontsUrl,t.setAttribute(this.fontsLinkAttribute,""),document.head.appendChild(t)}}const getProductListStyles=()=>'\n .product-list {\n width: 100%;\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n }\n \n .product-list > *:not(:first-child) {\n margin-left: 24px;\n }\n\n .product-list-filters-container {\n width: 30%;\n height: fit-content;\n position: sticky;\n top: 24px;\n padding: 0;\n }\n\n .product-list-cards__container {\n width: 100%;\n height: 100%;\n display: flex;\n flex-wrap: wrap;\n align-items: flex-start;\n gap: 24px;\n --gap-per-card: calc(24px * (var(--columns, 4) - 1) / var(--columns, 4));\n }\n\n .product-list.has-filters .product-list-cards__container {\n width: 70%;\n }\n\n /* Filters Styles */\n .product-list-filters-header,\n .product-list-filters-personalized,\n .product-list-filters-pre-order,\n .product-list-filters-delivery-options {\n padding: 16px 0 12px 0;\n border-bottom: 1px solid var(--accent-color, #f3f4f6);\n }\n\n .product-list-filters-delivery-options {\n border-bottom: none;\n }\n\n .product-list-filters-title {\n font-size: 18px;\n font-weight: 600;\n color: var(--default-text-color, #111827);\n font-family: var(--paragraph-font-family, Poppins);\n margin: 0;\n }\n\n .product-list-filters-personalized,\n .product-list-filters-pre-order {\n border-bottom: 1px solid var(--accent-color, #f3f4f6);\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n }\n\n .product-list-filters-personalized > *:not(:last-child),\n .product-list-filters-pre-order > *:not(:last-child) {\n margin-right: 12px;\n }\n\n .product-list-filters-personalized-label,\n .product-list-filters-pre-order-label {\n font-size: 15px;\n font-weight: 500;\n color: var(--default-text-color, #374151);\n font-family: var(--paragraph-font-family, Poppins);\n margin: 0;\n cursor: pointer;\n display: flex;\n justify-content: space-between;\n align-items: center;\n line-height: 1.5;\n flex: 1;\n }\n\n .product-list-filters-warning {\n font-size: 12px;\n color: var(--default-text-color-70, #9ca3af);\n font-family: var(--paragraph-font-family, Poppins);\n font-style: normal;\n margin: 0;\n padding: 0;\n }\n\n .product-list-filters-delivery-options-header {\n display: flex;\n align-items: center;\n }\n\n .product-list-filters-delivery-options-label {\n font-size: 18px;\n font-weight: 600;\n color: var(--default-text-color, #111827);\n font-family: var(--heading-font-family, Poppins);\n }\n\n .product-list-filters-delivery-options-list {\n display: flex;\n flex-direction: column;\n }\n\n .product-list-filters-delivery-option {\n display: flex;\n align-items: center;\n padding: 12px 16px;\n border-radius: var(--button-border-radius, 8px);\n cursor: pointer;\n }\n \n .product-list-filters-delivery-option > *:not(:last-child) {\n margin-right: 12px;\n }\n\n .product-list-filters-delivery-option:hover {\n background-color: var(--accent-color-30, #f8fafc);\n }\n\n .product-list-filters-delivery-radio {\n width: 18px;\n height: 18px;\n margin: 0;\n cursor: pointer;\n accent-color: var(--primary-color, #3b82f6);\n }\n\n .product-list-filters-delivery-radio:disabled {\n opacity: 0.4;\n cursor: not-allowed;\n }\n\n .product-list-filters-delivery-radio-label {\n font-size: 15px;\n font-weight: 500;\n color: var(--default-text-color, #374151);\n font-family: var(--paragraph-font-family, Poppins);\n margin: 0;\n cursor: pointer;\n flex: 1;\n }\n\n .product-list-filters-delivery-radio-label.disabled {\n color: var(--default-text-color-70, #9ca3af);\n cursor: not-allowed;\n }\n\n .product-list-filters-delivery-radio:disabled + .product-list-filters-delivery-radio-label {\n color: var(--default-text-color-70, #9ca3af);\n cursor: not-allowed;\n }\n\n input[type="checkbox"].product-list-filters-personalized-switch,\n input[type="checkbox"].product-list-filters-pre-order-switch {\n position: relative;\n width: 52px;\n height: 28px;\n appearance: none;\n background: var(--accent-color, #e5e7eb);\n border-radius: 14px;\n cursor: pointer;\n transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n outline: none;\n border: 2px solid transparent;\n }\n\n input[type="checkbox"].product-list-filters-personalized-switch:checked,\n input[type="checkbox"].product-list-filters-pre-order-switch:checked {\n background: var(--primary-color, #3b82f6);\n border-color: var(--primary-color-30, rgba(59, 130, 246, 0.3));\n }\n\n .product-list-filters-personalized-switch:disabled,\n .product-list-filters-pre-order-switch:disabled {\n background: var(--accent-color-30, #f3f4f6);\n cursor: not-allowed;\n opacity: 0.5;\n }\n\n .product-list-filters-personalized-switch::before,\n .product-list-filters-pre-order-switch::before {\n content: \'\';\n position: absolute;\n top: 2px;\n left: 2px;\n width: 20px;\n height: 20px;\n background: var(--selected-text-color, #ffffff);\n border-radius: 50%;\n transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15), 0 1px 3px rgba(0, 0, 0, 0.1);\n }\n\n .product-list-filters-personalized-switch:checked::before,\n .product-list-filters-pre-order-switch:checked::before {\n transform: translateX(24px);\n }\n\n /* Product List Card Styles */\n .product-list-card.standard {\n height: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n border: 1px solid var(--accent-color, #f3f4f6);\n border-radius: var(--card-border-radius, 0.375rem);\n cursor: pointer;\n overflow: hidden;\n }\n\n .product-list-card.fill {\n background-color: #ffffff;\n }\n\n .product-list-card.standard.not-available {\n cursor: not-allowed;\n }\n\n .product-list-card.standard.not-available:hover {\n cursor: not-allowed;\n }\n\n .product-list-card.standard .plc__image-content {\n width: 100%;\n height: 100%;\n padding: 10px;\n }\n\n .product-list-card.standard .plc__image-wrapper {\n width: 100%;\n height: 14rem;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n border-bottom: 1px solid var(--accent-color, #f3f4f6);\n padding-bottom: 10px;\n }\n\n .product-list-card.standard .plc__image-wrapper .plc__image {\n display: block;\n width: 100%;\n height: 100%;\n object-fit: contain;\n }\n\n .product-list-card.standard .plc__content {\n width: 100%;\n padding: 0 10px;\n display: flex;\n flex-direction: column;\n margin-bottom: 10px;\n }\n\n .product-list-card.standard .plc__content .plc__title {\n width: 100%;\n height: 4.6875rem;\n font-size: 1.125rem;\n font-weight: 600;\n color: var(--default-text-color, #111827);\n font-family: var(--paragraph-font-family, Poppins);\n text-transform: uppercase;\n margin-bottom: 10px;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: auto;\n\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 3;\n overflow: hidden;\n line-height: 1.38;\n word-wrap: break-word;\n word-break: break-word;\n }\n\n .product-list-card.standard .plc__image-link {\n text-decoration: none;\n display: block;\n color: inherit;\n width: 100%;\n }\n\n .product-list-card.standard .plc__image-link:hover {\n text-decoration: none;\n }\n\n .product-list-card.standard .plc__title-link {\n text-decoration: none;\n display: block;\n color: inherit;\n width: 100%;\n }\n\n .product-list-card.standard .plc__title-link:hover {\n text-decoration: underline;\n }\n\n .product-list-card.standard .plc__title-link .plc__title {\n color: var(--default-text-color, #111827);\n }\n\n .plc__size-price-wrapper {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n font-family: var(--paragraph-font-family, Poppins);\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: auto;\n color: var(--default-text-color, #111827);\n }\n\n .plc__size-price-wrapper .plc__size {\n font-size: 10px;\n font-weight: 300;\n }\n\n .plc__size-price-wrapper .plc__size {\n font-size: 1rem;\n font-weight: 600;\n }\n\n .plc__button {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n height: auto;\n white-space: nowrap;\n text-align: center;\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 600;\n text-transform: capitalize;\n color: var(--selected-text-color, #ffffff);\n background-color: var(--primary-color, #3b82f6);\n padding: 0.5rem 0.375rem;\n transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;\n transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n transition-duration: 150ms;\n }\n\n .plc__button:hover {\n background-color: var(--primary-color-70, #3b82f6);\n }\n\n .plc__button:disabled {\n pointer-events: none;\n opacity: 0.5;\n }\n\n /* Infinite Scroll Sentinel Styles */\n .product-list-scroll-sentinel {\n width: 100%;\n flex: 0 0 100%;\n min-height: 80px;\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 24px 16px;\n margin: 16px auto;\n box-sizing: border-box;\n }\n\n .product-list-sentinel-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n }\n \n .product-list-sentinel-container > *:not(:last-child) {\n margin-top: 12px;\n }\n\n .product-list-sentinel-spinner {\n width: 24px;\n height: 24px;\n border: 2px solid var(--primary-color-20, rgba(59, 130, 246, 0.2));\n border-top-color: var(--primary-color, #3b82f6);\n border-radius: 50%;\n animation: product-list-spin 0.8s linear infinite;\n }\n\n @keyframes product-list-spin {\n to {\n transform: rotate(360deg);\n }\n }\n\n .product-list-sentinel-text {\n font-size: 14px;\n color: var(--primary-color, #3b82f6);\n font-weight: 500;\n letter-spacing: 0.3px;\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n }\n\n .product-list-sentinel-icon {\n font-size: 20px;\n color: var(--primary-color-80, rgba(59, 130, 246, 0.8));\n animation: product-list-bounce 2s ease-in-out infinite;\n margin-bottom: 4px;\n }\n\n @keyframes product-list-bounce {\n 0%, 100% {\n transform: translateY(0);\n }\n 50% {\n transform: translateY(4px);\n }\n }\n\n .product-list-sentinel-info-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n }\n\n .product-list-sentinel-container > *:not(:last-child) {\n margin-top: 8px;\n }\n\n .product-list-sentinel-divider {\n width: 60px;\n height: 1px;\n background: var(--primary-color-30, rgba(59, 130, 246, 0.3));\n margin-bottom: 8px;\n }\n\n .product-list-sentinel-info-text {\n font-size: 13px;\n font-weight: 400;\n letter-spacing: 0.2px;\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n color: var(--primary-color, rgba(59, 130, 246, 0.67));\n }\n\n .product-list-sentinel-info-text.no-more {\n color: var(--primary-color, rgba(59, 130, 246, 0.8));\n font-weight: 500;\n }\n\n .product-list-sentinel-error-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n }\n\n .product-list-sentinel-error-container > *:not(:last-child) {\n margin-top: 8px;\n }\n\n .product-list-sentinel-error-icon {\n font-size: 18px;\n color: var(--error-color, #ef4444);\n }\n\n .product-list-sentinel-error-text {\n font-size: 13px;\n color: var(--error-color, #ef4444);\n font-weight: 500;\n letter-spacing: 0.2px;\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n }\n\n /* Responsive Styles */\n\n /* Mobile - 1 column (default, up to 639px) */\n @media (max-width: 639px) {\n .product-list {\n flex-direction: column;\n flex-wrap: wrap;\n }\n\n .product-list-filters-container {\n width: 100%;\n order: 1;\n position: static;\n top: unset;\n }\n\n .product-list-cards__container {\n width: 100%;\n order: 2;\n --columns: 1;\n --gap-per-card: 0px;\n }\n\n .product-list.has-filters .product-list-cards__container {\n width: 100%;\n }\n\n .product-list-card.standard {\n width: 100%;\n flex: 0 0 100%;\n }\n }\n\n /* Small tablets - 2 columns (640px and up) */\n @media (min-width: 640px) and (max-width: 767px) {\n .product-list {\n flex-direction: column;\n flex-wrap: wrap;\n }\n\n .product-list-filters-container {\n width: 100%;\n order: 1;\n position: static;\n top: unset;\n }\n\n .product-list-cards__container {\n width: 100%;\n order: 2;\n --columns: 2;\n --gap-per-card: 12px;\n }\n\n .product-list.has-filters .product-list-cards__container {\n width: 100%;\n }\n\n .product-list-card.standard {\n width: calc(50% - 12px);\n flex: 0 0 calc(50% - 12px);\n }\n }\n\n /* Tablets - 3 columns (768px and up) */\n @media (min-width: 768px) and (max-width: 1023px) {\n .product-list {\n flex-direction: row;\n flex-wrap: nowrap;\n }\n\n .product-list-filters-container {\n width: 30%;\n order: unset;\n position: sticky;\n top: 24px;\n }\n\n .product-list-cards__container {\n width: 100%;\n order: unset;\n --columns: 3;\n --gap-per-card: 16px;\n }\n\n .product-list.has-filters .product-list-cards__container {\n width: 70%;\n }\n\n .product-list-card.standard {\n width: calc(33.333% - 16px);\n flex: 0 0 calc(33.333% - 16px);\n }\n }\n\n /* Desktop - Use configured columns (1024px and up) */\n @media (min-width: 1024px) {\n .product-list {\n flex-direction: row;\n flex-wrap: nowrap;\n }\n\n .product-list-filters-container {\n position: sticky;\n top: 24px;\n }\n\n .product-list-cards__container {\n --gap-per-card: calc(24px * (var(--columns, 4) - 1) / var(--columns, 4));\n }\n\n .product-list-card.standard {\n width: calc(var(--card-width, 25%) - var(--gap-per-card, 18px));\n flex: 0 0 calc(var(--card-width, 25%) - var(--gap-per-card, 18px));\n }\n }\n',getAddressStyles=()=>"\n .address-input-container {\n width: 100%;\n max-width: 100%;\n min-width: 320px;\n height: 100%;\n font-family: var(--heading-font-family, Poppins);\n position: relative;\n display: flex;\n flex-direction: column;\n }\n\n .address-input-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .address-input-container .input-title {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--heading-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n padding-bottom: 8px;\n text-align: left;\n }\n\n .address-input-container .input-section {\n position: relative;\n }\n\n .address-input-container .input-wrapper {\n display: flex;\n flex-direction: row;\n align-items: center;\n align-self: stretch;\n padding: 4px 12px;\n border-radius: var(--card-border-radius, 6px);\n box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.05);\n }\n\n .address-input-container .input-wrapper.filled {\n background-color: var(--accent-color, #E4E4E7);\n }\n\n .address-input-container .input-wrapper.outlined {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .address-input-container .input-icon {\n display: flex;\n margin-left: 4px;\n }\n\n .address-input-container .input-icon svg {\n stroke: var(--default-text-color, #18181B);\n }\n\n /* Remove bottom border radius when suggestions are shown */\n .address-input-container .suggestions-list.show ~ .input-wrapper,\n .address-input-container .input-section.suggestions-expanded .input-wrapper {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n }\n\n /* Alternative approach using a modifier class */\n .address-input-container .input-wrapper.suggestions-expanded {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n }\n\n .address-input-container .input-field {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n width: 100%;\n border: none\n }\n\n .address-input-container .input-field:focus {\n outline: none;\n border: none;\n box-shadow: none;\n }\n\n .address-input-container .suggestions-list {\n position: absolute;\n top: 100%;\n left: 0;\n right: 0;\n z-index: "+d.ADDRESS_SUGGESTIONS+";\n list-style: none;\n overflow-y: auto;\n padding: 4px 0;\n align-self: stretch;\n border-radius: 0 0 6px 6px;\n border-right: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n border-left: 1px solid var(--accent-color, #E4E4E7);\n background: var(--drawer-background-color, #FAFAFA);\n }\n\n .address-input-container .suggestions-list.show {\n border-top-left-radius: 0;\n border-top-right-radius: 0;\n }\n\n .address-input-container .suggestions-list.hide {\n display: none;\n }\n\n .address-input-container .suggestions-list.show {\n display: block;\n }\n\n .address-input-container .suggestion-item {\n display: flex;\n padding: 6px 8px;\n align-items: center;\n align-self: stretch;\n cursor: pointer;\n text-align: left;\n }\n\n .address-input-container .suggestion-item > span {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 1;\n flex: 1 0 0;\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n white-space: nowrap;\n text-overflow: ellipsis;\n max-width: 100%;\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n\n .address-input-container .suggestion-item:hover {\n border-radius: 2px;\n background: linear-gradient(0deg, var(--alpha-50, rgba(254, 254, 254, 0.50)) 0%, var(--alpha-50, rgba(254, 254, 254, 0.50)) 100%), var(--default-text-color-50, #E4E4E7);\n }\n\n .address-input-container .suggestion-item.no-suggestions {\n color: var(--warning-color, #6B7280);\n text-align: center;\n cursor: default;\n }\n\n .address-input-container .suggestion-item.no-suggestions:hover {\n background-color: transparent;\n }\n\n .address-input-container .error-message {\n display: flex;\n align-items: center;\n padding: 12px;\n border: 1px solid var(--error-color, #B91C1C);\n border-radius: var(--card-border-radius, 6px);\n color: var(--error-color, #B91C1C);\n font-size: 14px;\n position: relative;\n z-index: "+d.ERROR_MESSAGE+";\n }\n\n .address-input-container .error-icon {\n font-size: 16px;\n margin-right: 8px;\n }\n\n .address-input-container .error-text {\n flex: 1;\n }\n\n .address-input-container .action-buttons {\n display: flex;\n justify-content: space-between;\n position: relative;\n z-index: "+d.ADDRESS_ACTIONS+";\n }\n\n .address-input-container .action-buttons > button {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 8px 16px;\n border-radius: var(--button-border-radius, 6px);\n transition: all 0.2s ease;\n width: 50%;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .address-input-container .action-buttons > button:not(:first-child) {\n margin-left: 8px;\n }\n\n .address-input-container .action-buttons .secondary-button {\n color: var(--default-text-color, #18181B);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .address-input-container .action-buttons .primary-button {\n color: var(--selected-text-color, #18181B);\n background-color: var(--primary-color, #E4E4E7);\n border: 1px solid transparent;\n }\n\n .privacy-notice {\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 11px;\n font-style: normal;\n font-weight: 400;\n color: var(--default-text-color, #18181B);\n text-align: left;\n }\n\n /* Enhanced fallback for browsers without line-clamp */\n @supports not (-webkit-line-clamp: 1) {\n .address-input-container .suggestion-item > span {\n display: block;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n }\n\n .address-display-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .address-display-container > span {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n margin-bottom: 8px;\n }\n\n .address-display-container > button {\n color: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n text-align: left;\n }\n",getCartStyles=()=>"\n .cart-container {\n display: flex;\n width: 100%;\n height: 100%;\n flex-direction: column;\n align-items: center;\n }\n\n .cart-container.no-header .cart-body {\n padding: 0 0 16px 0;\n }\n\n .cart-container.no-header .cart-footer {\n padding: 16px 0 0 0;\n }\n\n .cart-header {\n width: 100%;\n display: flex;\n flex-direction: column;\n position: sticky;\n top: 0;\n background-color: var(--drawer-background-color, #FFFFFF);\n z-index: "+d.CART_HEADER+";\n }\n\n .cart-header-content {\n width: 100%;\n height: 48px;\n display: flex;\n align-items: center;\n align-self: stretch;\n justify-content: space-between;\n padding: 16px;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .cart-title {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n }\n\n .cart-header-close-btn {\n font-size: 1.4rem;\n font-weight: 300;\n border: none;\n background: none;\n }\n\n .cart-header-close-btn:hover {\n cursor: pointer;\n }\n\n .cart-body {\n position: relative;\n flex: 1;\n display: flex;\n padding: 16px;\n flex-direction: column;\n align-self: stretch;\n }\n\n .cart-body > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .empty-cart-container {\n display: flex;\n align-self: center;\n margin: auto;\n }\n\n .retailer-section {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .section-header-label {\n display: flex;\n justify-content: space-between;\n align-items: center;\n cursor: pointer;\n }\n\n .cart-fulfillment-subtotal {\n color: var(--default-text-color, #18181B);\n }\n\n .section-title {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n }\n\n .cart-retailer-header {\n display: flex;\n flex-direction: column;\n padding: 16px;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .retailer-info {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n width: 100%;\n }\n\n .retailer-body-container {\n display: flex;\n align-items: center;\n align-self: stretch;\n flex-direction: column;\n max-height: 2000px;\n overflow: hidden;\n transition: max-height 0.3s ease;\n }\n\n .retailer-subtotal-container {\n display: flex;\n padding: 16px;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .retailer-subtotal-header {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .retailer-subtotal-amount {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .retailer-fulfillment-container {\n display: flex;\n padding: 16px;\n flex-direction: column;\n align-items: center;\n align-self: stretch;\n max-height: 2000px;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .retailer-fulfillment-container > .cart-item-container {\n margin-top: 16px;\n }\n\n .cart-item-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .cart-item-container > *:not(:first-child) {\n margin-top: 12px;\n }\n\n .cart-item {\n display: flex;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .cart-item > *:not(:first-child) {\n margin-left: 16px;\n }\n\n .item-image {\n display: flex;\n width: 56px;\n height: 70px;\n flex-direction: column;\n align-items: center;\n border-radius: var(--card-border-radius, 6px);\n }\n\n .item-image img {\n max-width: 100%;\n max-height: 100%;\n object-fit: contain;\n }\n\n .item-details {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n flex: 1 0 0;\n align-self: stretch;\n }\n\n .item-details > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .quantity-price {\n display: flex;\n height: 36px;\n align-items: center;\n align-content: center;\n align-self: stretch;\n flex-wrap: wrap;\n justify-content: space-between;\n }\n\n .item-title {\n font-weight: 500;\n font-size: 0.95rem;\n word-break: break-word;\n margin: 0;\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .item-specs {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .item-shipping-container {\n width: 100%;\n display: flex;\n flex-wrap: wrap;\n justify-content: space-between;\n }\n\n .cart-add-personalization-span {\n color: var(--primary-color, #1E40AF);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n .item-shipping {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .item-quantity {\n display: flex;\n width: 106px;\n align-items: center;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-weight: 500;\n }\n\n .quantity-btn-increase {\n display: flex;\n width: 36px;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n flex-shrink: 0;\n border-radius: 0px var(--button-border-radius, 6px) var(--button-border-radius, 6px) 0px;\n background: none;\n cursor: pointer;\n }\n\n .item-quantity.outlined .quantity-btn-increase {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .quantity-btn-decrease {\n display: flex;\n width: 36px;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n flex-shrink: 0;\n border-radius: var(--button-border-radius, 6px) 0px 0px var(--button-border-radius, 6px);\n background: none;\n cursor: pointer;\n }\n\n .item-quantity.outlined .quantity-btn-decrease {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .quantity-btn-decrease:disabled,\n .quantity-btn-increase:disabled,\n .quantity-btn-disabled {\n opacity: 0.7;\n cursor: not-allowed;\n }\n\n .quantity-value {\n display: flex;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n align-self: stretch;\n }\n\n .item-quantity.outlined .quantity-value {\n border-top: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .item-price-container {\n display: flex;\n justify-content: flex-end;\n align-items: center;\n align-content: center;\n flex: 1 0 0;\n flex-wrap: wrap;\n }\n\n .item-price-container > *:not(:first-child) {\n margin-left: 6px;\n }\n\n .item-price {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n }\n\n .item-price-per-unit {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n }\n\n .item-header {\n display: flex;\n align-items: flex-start;\n justify-content: space-between;\n align-self: stretch;\n }\n\n .cart-footer {\n margin-top: auto;\n display: flex;\n min-height: 146px;\n padding: 16px;\n flex-direction: column;\n justify-content: flex-end;\n align-items: flex-start;\n align-self: stretch;\n border-top: 1px solid var(--accent-color, #E4E4E7);\n flex-shrink: 0;\n }\n\n .cart-footer > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .cart-footer-header {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n flex: 1 0 0;\n }\n\n .cart-footer-header > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .cart-footer-header .cart-footer-items-price {\n width: 100%;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n }\n\n .cart-footer-header .subtotal-text {\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 14px;\n }\n\n .cart-footer-header .subtotal-price {\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 14px;\n }\n\n .cart-footer-header .taxes-fees-info {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 14px;\n max-width: 85%;\n }\n\n .promo-input {\n display: flex;\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n font-size: 16px;\n align-self: stretch;\n width: 100%;\n border-radius: var(--button-border-radius, 6px);\n }\n\n .promo-input.outlined {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .promo-input.filled {\n background-color: var(--accent-color, #E4E4E7);\n }\n\n .checkout-button {\n display: flex;\n position: relative;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n border: none;\n cursor: pointer;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #F1F5F9);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .checkout-button.loading::after {\n content: '';\n position: absolute;\n right: 16px;\n top: 50%;\n transform: translateY(-50%);\n z-index: "+d.LOADING_INDICATOR+";\n width: 18px;\n height: 18px;\n border: 2px solid transparent;\n border-top: 2px solid var(--selected-text-color);\n border-radius: 50%;\n animation: spin 1s linear infinite;\n }\n\n .checkout-btn-disabled {\n opacity: 0.7;\n cursor: not-allowed;\n }\n\n /* CSS-only accordions */\n .chevron {\n transition: transform 0.3s ease;\n }\n\n /* Product section accordions */\n .section-toggle {\n display: none;\n }\n\n .section-toggle:checked + .section-header-label .chevron {\n transform: rotate(180deg);\n color: var(--default-text-color, #18181B);\n }\n\n .retailer-section.collapsed .retailer-body-container {\n max-height: 0;\n }\n\n .retailer-section.collapsed .cart-retailer-header {\n border-bottom: none;\n }\n\n .shipping-content {\n max-height: 0;\n overflow: hidden;\n transition: max-height 0.3s ease-out;\n padding-left: 20px;\n }\n\n /** * Loading spinner styles */\n .cart-loading-backdrop {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: var(--drawer-background-color-30, #E4E4E7);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: "+d.CART_LOADING+";\n }\n\n /* Modern browsers with backdrop-filter support */\n @supports (backdrop-filter: blur(1px)) {\n .cart-loading-backdrop {\n background-color: var(--drawer-background-color-30, #E4E4E7);\n backdrop-filter: blur(1px);\n }\n }\n\n .cart-loading-spinner-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n }\n\n .cart-loading-spinner {\n margin-bottom: 16px;\n }\n\n .cart-spinner {\n animation: cart-spinner-rotate 2s linear infinite;\n color: var(--primary-color, #1D4ED8);\n }\n\n .cart-spinner-path {\n stroke-dasharray: 90, 150;\n stroke-dashoffset: 0;\n stroke-linecap: round;\n animation: cart-spinner-dash 1.5s ease-in-out infinite;\n }\n\n @keyframes cart-spinner-rotate {\n 100% {\n transform: rotate(360deg);\n }\n }\n\n @keyframes cart-spinner-dash {\n 0% {\n stroke-dasharray: 1, 150;\n stroke-dashoffset: 0;\n }\n 50% {\n stroke-dasharray: 90, 150;\n stroke-dashoffset: -35;\n }\n 100% {\n stroke-dasharray: 90, 150;\n stroke-dashoffset: -124;\n }\n }\n\n /*PROMO CODE */\n .promo-container {\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n align-self: stretch;\n flex: 1;\n }\n\n .promo-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .promo-container-wrapper {\n display: flex;\n justify-content: space-between;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .promo-code-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .promo-input-wrapper {\n flex: 1;\n }\n\n /* Style the InputComponent container */\n .promo-input-wrapper .custom-input {\n margin: 0;\n width: 100%;\n }\n\n /* Hide label in promo context since we have placeholder */\n .promo-input-wrapper .custom-input label {\n display: none;\n }\n\n /* Style the actual input inside the InputComponent */\n .promo-input-wrapper .promo-input {\n width: 100%;\n padding: 12px 16px;\n border: 1px solid #ddd;\n border-radius: var(--button-border-radius, 6px);\n font-size: 14px;\n transition: border-color 0.2s ease, box-shadow 0.2s ease;\n box-sizing: border-box;\n }\n\n .promo-input-wrapper .promo-input:focus {\n outline: none;\n border-color: var(--primary-color, #1D4ED8);\n }\n\n .promo-input-wrapper .promo-input:disabled {\n background-color: #f8f9fa;\n cursor: not-allowed;\n opacity: 0.6;\n }\n\n .promo-input-wrapper .promo-input.input-error {\n border-color: #dc3545; }\n\n /* Error container styling from InputComponent */\n .promo-input-wrapper .error-container {\n margin-top: 4px;\n min-height: 20px;\n }\n\n .promo-input-wrapper .error-message {\n color: #dc3545;\n font-size: 12px;\n margin: 2px 0;\n display: block;\n }\n\n /* Apply button styling */\n .apply-button {\n display: flex;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .apply-button:hover:not(:disabled) {\n opacity: 0.9;\n }\n\n .apply-button:disabled {\n cursor: not-allowed;\n opacity: 0.7;\n }\n\n /* Applied promo code display - matches the design */\n .promo-applied-container {\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n align-self: stretch;\n align-items: center;\n flex: 1;\n }\n\n .promo-code-pill {\n display: flex;\n height: var(--height-h-9, 36px);\n padding: 4px 12px;\n align-items: center;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px\n }\n\n .promo-remove-btn {\n background: none;\n border: none;\n cursor: pointer;\n border-radius: 4px;\n transition: all 0.2s ease;\n text-decoration: underline;\n color: var(--primary-color, #1D4ED8);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n }\n\n .error-banner {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n color: var(--default-text-color, #18181B);\n padding: 8px 16px;\n flex-grow: 1;\n\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--error-color, #DC2626);\n border: 1px solid var(--error-color, #DC2626);\n border-radius: var(--card-border-radius, 6px) 0 0 var(--card-border-radius, 6px);\n }\n\n .error-banner > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .close-btn {\n border: none;\n font-size: 16px;\n cursor: pointer;\n color: #fff;\n border-radius: 0 var(--button-border-radius, 6px) var(--button-border-radius, 6px) 0;\n padding: 8px 16px;\n\n background: var(--error-color, #DC2626);\n }\n\n /* Mobile responsive */\n .promo-code-pill {\n align-self: flex-start;\n }\n\n .promo-remove-btn {\n align-self: flex-end;\n padding: 4px 8px;\n }\n }\n\n /* Optional: Add loading indicator styles if needed */\n .promo-input-wrapper.loading::after {\n content: '';\n position: absolute;\n right: 12px;\n top: 50%;\n transform: translateY(-50%);\n z-index: "+d.LOADING_INDICATOR+";\n width: 16px;\n height: 16px;\n border: 2px solid var(--accent-color, #E4E4E7);\n border-top: 2px solid var(--accent-color, #E4E4E7);\n border-radius: 50%;\n animation: spin 1s linear infinite;\n }\n\n @keyframes spin {\n 0% { transform: translateY(-50%) rotate(0deg); }\n 100% { transform: translateY(-50%) rotate(360deg); }\n }\n\n .empty-cart-content {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n",getCheckoutStyles=()=>"\n .checkout-container {\n width: 100%;\n height: auto;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n align-self: stretch;\n gap: 24px;\n }\n\n .checkout-container:not(.independent) {\n padding: 24px;\n }\n\n .checkout-container.independent {\n padding: 24px;\n }\n\n .checkout-container.no-header .checkout-information-section,\n .checkout-container.no-header .checkout-summary-section {\n padding: 0;\n }\n\n .checkout-information-section {\n min-width: 320px;\n max-width: 512px;\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n flex-wrap: wrap;\n flex: 1 0 0;\n }\n\n .checkout-information-section > *:not(:first-child) {\n margin-top: 24px;\n padding-top: 24px;\n border-top: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-delivery-information,\n .checkout-buyer-information,\n .checkout-billing-form {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-delivery-information > *:not(:first-child),\n .checkout-buyer-information > *:not(:first-child),\n .checkout-billing-form > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-billing-form {\n margin-top: 24px;\n }\n\n .checkout-payment-form {\n display: flex;\n flex-direction: column;\n align-self: stretch;\n }\n\n .checkout-payment-form > *:not(:last-child) {\n margin-bottom: 24px;\n }\n\n .delivery-header-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n flex-wrap: wrap;\n }\n\n .delivery-title-container {\n display: flex;\n min-width: 200px;\n flex-direction: column;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .delivery-title-container > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .section-title-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .section-title-container > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .delivery-title-container > .delivery-title,\n .section-title-container > .section-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .delivery-title-container > .delivery-subtitle,\n .section-title-container > .section-subtitle {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .gift-toggle-container {\n display: flex;\n padding: 2px 0px;\n align-self: stretch;\n justify-content: space-between;\n align-items: flex-start;\n }\n\n .gift-toggle-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .gift-toggle-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .gift-label-wrapper {\n display: flex;\n flex-direction: column;\n min-width: 200px;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .gift-toggle-description {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n margin-top: 6px;\n }\n\n .toggle-switch {\n position: relative;\n width: 40px;\n height: 20px;\n background-color: var(--primary-color-30, #d1d5db);\n border-radius: 12px;\n cursor: pointer;\n transition: background-color 0.2s ease;\n }\n\n .toggle-switch.active {\n background-color: var(--primary-color, #3b82f6);\n }\n\n .toggle-slider {\n position: absolute;\n top: 2px;\n left: 2px;\n width: 16px;\n z-index: "+d.TOGGLE_SLIDER+";\n height: 16px;\n background-color: var(--accent-color, #ffffff);\n border-radius: 50%;\n transition: transform 0.2s ease;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n }\n\n .toggle-switch.active .toggle-slider {\n transform: translateX(20px);\n }\n\n .section-form-container {\n display: flex;\n flex-direction: column;\n align-self: stretch;\n }\n\n .section-form-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .textarea-message-disclaimer {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n margin-top: 6px;\n }\n\n .checkout-tips-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-tips-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-tip-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-tip-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-tip-distribution-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-tip-distribution-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .retailers-tips-list {\n display: none;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .retailers-tips-list > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .retailers-tips-list.show {\n display: flex;\n }\n\n .checkout-tip-distribution-item {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-tip-fulfillment-input-wrapper {\n display: flex;\n align-items: center;\n }\n\n .checkout-tip-fulfillment-input-wrapper > *:not(:first-child) {\n margin-left: 16px;\n }\n\n .checkout-tip-remove-button {\n color: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n .checkout-tip-distribution-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n cursor: pointer;\n }\n\n .checkout-sub-header {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .checkout-tip-disclaimer {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-tip-config-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-tip-config-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-tip-selection-container {\n display: flex;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-tip-selection-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-tip-button {\n display: flex;\n padding: 8px 16px;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n border-radius: var(--button-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .checkout-tip-button.selected {\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n }\n\n .checkout-tip-button > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .checkout-tip-input-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-tip-input-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-tip-input {\n display: flex;\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-sections-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-sections-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-pc-gc-sub-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-pc-gc-sub-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-pc-gc-applied {\n display: flex;\n width: 100%;\n flex-direction: row;\n align-self: stretch;\n display: flex;\n padding: 0px 12px;\n justify-content: space-between;\n align-items: center;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-pc-gc-applied span {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n text-transform: uppercase;\n }\n\n .checkout-pc-gc-applied button {\n display: flex;\n height: 36px;\n padding: 8px 0px;\n justify-content: center;\n align-items: center;\n border-radius: var(--button-border-radius, 6px);\n color: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .checkout-send-as-gift-toggle-container {\n position: absolute;\n top: 16px;\n right: 16px;\n z-index: "+d.FORM_CONTROLS+";\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: flex-end;\n\n cursor: pointer;\n }\n\n .checkout-two-col-container {\n display: flex;\n align-items: flex-start;\n align-content: flex-start;\n align-self: stretch;\n flex-wrap: wrap;\n margin-right: -16px;\n margin-bottom: -16px;\n }\n\n .checkout-two-col-container > * {\n margin-right: 16px;\n margin-bottom: 16px;\n }\n\n .checkout-three-col-container {\n display: flex;\n flex-direction: row;\n }\n\n .checkout-three-col-container > *:not(:first-child) {\n margin-left: 16px;\n }\n\n .checkout-send-to-form.collapsed {\n display: none;\n }\n\n .checkout-send-to-title,\n .checkout-your-info-title,\n .checkout-billing-title,\n .checkout-payment-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .checkout-send-to-subtitle,\n .checkout-your-info-subtitle,\n .checkout-billing-subtitle,\n .checkout-payment-subtitle {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-summary-section {\n min-width: 320px;\n max-width: 400px;\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n }\n\n .checkout-summary-section > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-disclaimer-title,\n .checkout-summary-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .checkout-disclaimer-subtitle,\n .checkout-summary-subtitle {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-promo-code-container,\n .checkout-gift-cards-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-promo-code-container > *:not(:first-child),\n .checkout-gift-cards-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .input-promo-code-container,\n .input-gift-card-container {\n display: flex;\n flex-direction: row;\n align-self: stretch;\n }\n\n .input-promo-code-container > *:not(:first-child),\n .input-gift-card-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .input-promo-code-container .apply-button,\n .input-gift-card-container .apply-button {\n display: flex;\n padding: 8px 16px;\n justify-content: center;\n align-self: flex-start;\n align-items: center;\n\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .input-promo-code-container .apply-button.disabled,\n .input-gift-card-container .apply-button.disabled {\n background: var(--primary-color-50, #1D4ED8);\n }\n\n .checkout-amounts-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-amounts-container > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .checkout-amount-line {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-amount-line span {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-amount-total {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n\n }\n\n .checkout-amount-total span {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .checkout-separator {\n width: 100%;\n height: 1px;\n margin: 0px;\n background: var(--accent-color, #E4E4E7);\n }\n\n .checkout-place-order-button-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-place-order-button {\n display: flex;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n font-family: var(--paragraph-font-family, Poppins);\n align-self: stretch;\n font-weight: 600;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n transition: all 0.2s ease;\n cursor: pointer;\n position: relative;\n }\n\n .checkout-place-order-button-container .alert-container, .checkout-place-order-button-container .alert-wrapper {\n margin-bottom: 24px;\n }\n\n .checkout-place-order-button.ready {\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n }\n\n .checkout-place-order-button.ready:hover {\n filter: brightness(0.9);\n transform: translateY(-1px);\n }\n\n .checkout-place-order-button.ready:active {\n transform: translateY(0);\n }\n\n /* States when things are missing/wrong - use your opacity variants */\n .checkout-place-order-button.form-invalid,\n .checkout-place-order-button.payment-incomplete,\n .checkout-place-order-button.payment-error {\n background: var(--primary-color-70);\n color: var(--selected-text-color);\n }\n\n .checkout-place-order-button.form-invalid:hover,\n .checkout-place-order-button.payment-incomplete:hover,\n .checkout-place-order-button.payment-error:hover {\n background: var(--primary-color-70);\n }\n\n /* Processing state - keep full primary color to show confidence */\n .checkout-place-order-button.processing {\n cursor: not-allowed;\n pointer-events: none;\n }\n\n .checkout-place-order-button.processing::after {\n content: '';\n position: absolute;\n right: 16px;\n top: 50%;\n transform: translateY(-50%);\n z-index: "+d.LOADING_INDICATOR+';\n width: 18px;\n height: 18px;\n border: 2px solid transparent;\n border-top: 2px solid var(--selected-text-color);\n border-radius: 50%;\n animation: spin 1s linear infinite;\n }\n\n /* Disabled state - very muted */\n .checkout-place-order-button.disabled {\n background: var(--primary-color-70, #D1D5DB);\n cursor: not-allowed;\n }\n\n /* Focus states for accessibility */\n .checkout-place-order-button:focus {\n outline: none;\n box-shadow: 0 0 0 3px var(--primary-color-70);\n }\n\n .checkout-place-order-button.disabled:focus {\n box-shadow: none;\n }\n\n .checkout-marketing-opt-ins-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-marketing-opt-ins-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-billing-same-as-shipping-toggle-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: flex-start;\n cursor: pointer;\n }\n\n .checkout-billing-same-as-shipping-toggle-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-items-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-items-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-items-toggler {\n display: flex;\n height: 14px;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n cursor: pointer;\n }\n\n .checkout-items-toggler-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .checkout-items-list {\n display: none;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-items-list > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-items-list.show {\n display: flex;\n }\n\n .checkout-item-card {\n display: flex;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-item-card > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-item-card-header {\n display: flex;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-item-card-header > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-item-details-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .checkout-item-card-footer {\n display: flex;\n height: 36px;\n align-items: center;\n align-content: center;\n justify-content: space-between;\n align-self: stretch;\n flex-wrap: wrap;\n margin-right: -8px;\n margin-bottom: -8px;\n }\n\n .checkout-item-card-footer > * {\n margin-right: 8px;\n margin-bottom: 8px;\n }\n\n .checkout-item-image {\n display: flex;\n width: 64px;\n height: 70px;\n flex-direction: column;\n align-items: center;\n border-radius: var(--card-border-radius, 6px);\n }\n\n .checkout-item-image img {\n max-width: 100%;\n max-height: 100%;\n object-fit: contain;\n }\n\n .checkout-item-card .checkout-item-subtitle {\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n }\n\n .checkout-item-card .checkout-item-title,\n .checkout-item-card .checkout-item-subtitle > span,\n .checkout-item-price-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n word-break: break-word;\n }\n\n .checkout-item-price-each-text {\n font-weight: 500;\n }\n\n .checkout-item-card .checkout-item-subtitle > span {\n font-weight: 400 !important;\n }\n\n .checkout-item-quantity-container {\n display: flex;\n width: 106px;\n align-items: center;\n }\n\n .billing-checkbox-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n cursor: pointer;\n }\n\n .checkout-item-quantity-container .quantity-decrease,\n .checkout-item-quantity-container .quantity-increase {\n display: flex;\n width: 36px;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n border: 1px solid var(--accent-color, #E4E4E7);\n\n cursor: pointer;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-item-quantity-container .quantity-decrease {\n border-radius: var(--button-border-radius, 6px) 0px 0px var(--button-border-radius, 6px);\n }\n\n .checkout-item-quantity-container .quantity-increase {\n border-radius: 0px var(--button-border-radius, 6px) var(--button-border-radius, 6px) 0px;\n }\n\n .checkout-item-quantity-container .quantity-decrease.disabled,\n .checkout-item-quantity-container .quantity-increase.disabled {\n opacity: 0.7;\n cursor: not-allowed;\n }\n\n .checkout-item-quantity-container .product-count {\n display: flex;\n padding: 6px 8px;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n align-self: stretch;\n\n border-top: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .dollar-input-container {\n display: flex;\n align-items: center;\n border: 1px solid var(--accent-color, #E4E4E7);\n border-radius: var(--button-border-radius, 6px);\n align-self: stretch;\n flex: 1 0 0;\n max-width: 100px;\n\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .dollar-input-container:focus-within {\n outline: none;\n border-color: var(--primary-color, #3b82f6);\n box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);\n }\n\n .dollar-sign {\n font-size: 14px;\n font-weight: 500;\n user-select: none;\n pointer-events: none;\n }\n\n .dollar-input {\n flex: 1;\n border: none;\n outline: none;\n background: transparent;\n }\n\n .dollar-input::placeholder {\n color: var(--default-text-color-70, #18181B);\n }\n\n .dollar-input::-webkit-outer-spin-button,\n .dollar-input::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n .dollar-input[type=number] {\n -moz-appearance: textfield;\n }\n\n .dollar-input:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n\n .dollar-input-container:has(.dollar-input:disabled) {\n opacity: 0.6;\n }\n\n .dollar-input-container:has(.dollar-input:disabled) .dollar-sign {\n color: var(--default-text-color-70, #18181B);\n }\n\n /* Checkout Thank You Page */\n .checkout-completed-container {\n display: flex;\n min-height: 100vh; /* Fallback for browsers that don\'t support dvh */\n min-height: 100dvh;\n min-width: 320px;\n flex-direction: column;\n justify-content: center;\n flex: 1 0 0;\n align-self: stretch;\n }\n\n .checkout-completed-header-container {\n display: flex;\n padding: 24px;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-completed-header-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-completed-header-container img {\n width: 200px;\n height: auto;\n object-fit: contain;\n flex-shrink: 0;\n }\n\n .checkout-completed-sub-section {\n display: flex;\n min-width: 216px;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n flex-shrink: 0;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-completed-sub-section > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-completed-sub-section p {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n }\n\n .checkout-completed-section-container {\n display: flex;\n padding: 24px;\n flex-direction: column;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-completed-section-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-completed-help-section > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-completed-help-section {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 100%;\n text-align: center;\n }\n\n .checkout-completed-section-container button {\n display: flex;\n height: 36px;\n min-width: 182px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n }\n\n .checkout-completed-section-container button svg {\n stroke: var(--selected-text-color, #1D4ED8);\n fill: var(--selected-text-color, #1D4ED8);\n }\n\n .checkout-completed-section-container button span {\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n margin-right: 8px;\n }\n\n .checkout-completed-title-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-completed-title-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-completed-title-section {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n text-align: center;\n }\n\n .checkout-completed-title-section .presale-expired-title {\n font-family: var(--heading-font-family, Poppins);\n font-size: 24px;\n font-weight: 600;\n line-height: 32px;\n }\n\n .checkout-completed-title-section > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .checkout-completed-title-section\n color: var(--default-text-color, #18181B);\n }\n\n .checkout-completed-title-section p:first-child, .checkout-completed-auto-close-seconds {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 24px;\n font-style: normal;\n font-weight: 600;\n line-height: 32px;\n }\n\n .checkout-completed-title-section h3 {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 24px;\n font-style: normal;\n font-weight: 600;\n line-height: 32px;\n }\n\n .checkout-completed-title-section p, .checkout-completed-auto-close-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 24px;\n }\n\n .checkout-completed-line {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-completed-line span {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-completed-line:first-child span {\n font-weight: 600;\n }\n\n .checkout-completed-line h3 {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-payment-form-error {\n color: var(--error-color, #EF4444);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n margin-top: 8px;\n }\n\n .checkout-error-wrapper {\n animation: slideIn 0.2s ease-out;\n display: flex;\n align-self: stretch;\n margin-bottom: 8px;\n }\n\n .checkout-error-wrapper > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-error {\n display: flex;\n padding: 12px 16px;\n }\n\n .checkout-error > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-error\n border-radius: var(--button-border-radius, 6px);\n font-size: 14px;\n line-height: 1.5;\n font-family: var(--body-font-family, inherit);\n flex: 1;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n\n background: var(--error-color-30, #DC2626);\n border: 1px solid var(--error-color, #DC2626);\n }\n\n .checkout-error .icon-error {\n flex-shrink: 0;\n width: 16px;\n height: 16px;\n display: inline-block;\n }\n\n .checkout-error .error-text {\n font-family: var(--body-font-family, inherit);\n }\n\n .checkout-error-wrapper[style*="display: none"] {\n display: none !important;\n }\n\n .checkout-checkbox-container {\n display: flex;\n align-items: flex-start;\n }\n\n .checkout-checkbox-container > *:not(:first-child) {\n margin-left: 12px;\n }\n\n .checkout-checkbox-visual {\n width: 16px;\n height: 16px;\n border: 1px solid var(--primary-color, #1D4ED8);\n border-radius: 2px;\n background: var(--primary-color, #1D4ED8);\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n flex-shrink: 0;\n transition: all 0.2s ease;\n margin-top: 3px;\n }\n\n .checkout-checkbox-visual svg {\n opacity: 1;\n transition: opacity 0.2s ease;\n }\n\n .checkout-checkbox-visual:not(.checked) {\n background: transparent;\n }\n\n .checkout-checkbox-visual:not(.checked) svg {\n opacity: 0;\n }\n\n .checkbox-label {\n cursor: pointer;\n user-select: none;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkbox-label a {\n color: var(--primary-color, #1D4ED8);\n }\n\n .checkbox-label strong {\n font-weight: 600;\n }\n\n .checkbox-label em {\n font-style: italic;\n }\n\n .error-banner-checkout {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n color: var(--default-text-color, #18181B);\n padding: 8px 16px;\n flex-grow: 1;\n align-self: stretch;\n word-break: break-word;\n\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--error-color, #DC2626);\n border: 1px solid var(--error-color, #DC2626);\n border-radius: var(--card-border-radius, 6px);\n }\n\n .error-banner-checkout > *:not(:first-child) {\n margin-left: 8px;\n }\n\n /* It needs background color since it is sticky to cover content behind it\n TODO: for standalone checkout\n */\n .checkout-header-wrapper {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n position: sticky;\n top: 0;\n z-index: '+d.CHECKOUT_HEADER+";\n background-color: var(--drawer-background-color, #F9FAFB);\n }\n\n .checkout-header-container {\n display: flex;\n min-width: 320px;\n flex-direction: row;\n align-items: center;\n align-self: stretch;\n padding: 8px;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-header-button {\n display: flex;\n height: 36px;\n padding: 12px 16px;\n padding-right: 0px;\n justify-content: center;\n align-items: center;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n stroke: var(--default-text-color, #18181B);\n }\n\n .checkout-header-button > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-header-button-close {\n display: flex;\n height: 36px;\n width: 36px;\n padding: 2px 4px;\n justify-content: center;\n align-items: center;\n stroke: var(--default-text-color, #18181B);\n }\n\n .checkout-header-title {\n display: flex;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n align-self: stretch;\n color: var(--default-text-color, #18181B);\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .checkout-presale-countdown-container {\n display: flex;\n min-width: 320px;\n padding: 12px 24px 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n\n &.is-scrolled {\n box-shadow: 0px 6px 10px -2px var(--primary-color-30);\n }\n\n &.time-warning {\n box-shadow: 0px 6px 10px -2px var(--error-color-30, #FDE68A);\n }\n }\n\n .checkout-presale-countdown {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n border-radius: 0;\n overflow: hidden;\n }\n\n .checkout-presale-countdown.time-warning {\n background: var(--error-color-30, #FDE68A);\n border: 1px solid var(--error-color, #E4E4E7);\n }\n\n .checkout-presale-countdown.time-warning {\n background: transparent;\n border: none;\n }\n\n .checkout-presale-countdown.time-warning .checkout-presale-progress-bar {\n background: var(--error-color-70, #FDE68A);\n }\n\n .checkout-presale-countdown.time-warning .checkout-presale-progress-fill {\n background: var(--error-color, #EF4444);\n }\n\n .checkout-presale-text-container {\n display: flex;\n padding: 0px 0px 6px;\n justify-content: flex-end;\n align-self: stretch;\n flex-direction: column;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .checkout-presale-progress-bar {\n display: flex;\n height: 6px;\n align-items: center;\n align-self: stretch;\n border-radius: 40px;\n background: var(--primary-color-50, #E4E4E7);\n position: relative;\n overflow: hidden;\n }\n\n .checkout-presale-progress-fill {\n position: absolute;\n top: 0;\n left: 0;\n height: 100%;\n z-index: "+d.PROGRESS_BAR+';\n background: var(--primary-color, #16a34a);\n transition: width 0.1s linear;\n border-radius: inherit;\n }\n\n .checkout-presale-heading {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n align-self: stretch;\n }\n\n .checkout-presale-timer {\n font-variant-numeric: tabular-nums;\n letter-spacing: 0.02em;\n font-variant-numeric: tabular-nums;\n font-feature-settings: "tnum" 1, "kern" 0;\n min-width: 76px;\n white-space: nowrap;\n\n &.time-warning {\n color: var(--error-color, #EF4444);\n }\n }\n\n .checkout-presale-subtitle {\n transition: opacity 0.3s ease, max-height 0.3s ease;\n opacity: 1;\n max-height: 100px;\n overflow: hidden;\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n\n .checkout-presale-countdown.is-scrolled .checkout-presale-subtitle {\n opacity: 0;\n max-height: 0;\n }\n\n .checkout-completed-container .powered-by-container {\n margin-top: auto;\n padding: 24px;\n }\n\n .checkout-completed-container .checkout-legal-message {\n padding: 0 24px;\n }\n\n .checkout-legal-message {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-weight: 500;\n line-height: 20px;\n text-align: center;\n word-break: break-word;\n margin: 10px 0 !important;\n }\n\n .checkout-legal-message + .checkout-separator {\n margin-top: 0 !important;\n }\n\n .checkout-legal-message a {\n color: var(--primary-color, #1D4ED8);\n }\n\n .checkout-legal-message strong {\n font-weight: 600;\n }\n\n .checkout-legal-message em {\n font-style: italic;\n }\n\n .checkout-amount-due {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-amount-due span:first-child {\n color: var(--default-text-color-70, #18181B);\n }\n\n .checkout-amount-due span:last-child {\n color: var(--default-text-color, #1D4ED8);\n }\n\n .checkout-presale-locked-message {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n align-self: stretch;\n }\n\n .checkout-presale-locked-message > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-presale-locked-message p {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 13px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-presale-locked-message svg {\n width: 16px;\n height: 16px;\n stroke-width: 0.5px;\n stroke: var(--default-text-color, #1D4ED8);\n }\n\n .checkout-zero-amount-container {\n display: flex;\n padding: 0 24px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: italic;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-items-toggler-button .chevron-icon {\n transition: transform 0.3s ease;\n transform-origin: center;\n }\n\n .checkout-items-toggler-button.expanded .chevron-icon {\n transform: rotate(180deg); /* Chevron now points up */\n }\n\n .checkout-summary-form-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-summary-form-header {\n width: 100%;\n display: flex;\n align-items: flex-start;\n justify-content: space-between;\n margin-bottom: 8px;\n }\n\n .checkout-summary-form-header h2 {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n text-align: left;\n }\n\n .checkout-summary-form-header span {\n color: var(--primary-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n cursor: pointer;\n }\n\n .checkout-summary-form-line {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n text-align: left;\n }\n\n .checkout-summary-form-line-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n margin-top: 8px;\n }\n\n .checkout-summary-form-line-container-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n opacity: 0.7;\n }\n\n .save-form-info-button {\n width: 100%;\n display: flex;\n height: 36px;\n justify-content: center;\n align-items: center;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n box-shadow: 0 1.5px 3px 0 rgba(0, 0, 0, 0.10), 0 1px 2px 0 rgba(0, 0, 0, 0.06);\n }\n\n .save-form-info-button:disabled {\n background: var(--primary-color-70, #D1D5DB);\n cursor: not-allowed;\n }\n\n .stripe-summary-container {\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n }\n\n .stripe-summary-container .stripe-summary-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 24px;\n text-align: left;\n }\n\n .stripe-summary-container .change-payment-link {\n color: var(--primary-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n cursor: pointer;\n }\n\n .payment-error-message {\n color: var(--warning-color, #6B7280);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n margin-top: 16px;\n }\n\n .hardcoded-payment-notice {\n background-color: #fff3cd;\n color: #856404;\n font-family: Poppins;\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n border-radius: 4px;\n padding: 16px;\n border: 1px solid #ffc107;\n word-break: break-all;\n }\n ',getGlobalStyles=()=>"\n html, body, div, span, applet, object, iframe,\n h1, h2, h3, h4, h5, h6, p, blockquote, pre,\n a, abbr, acronym, address, big, cite, code,\n del, dfn, em, img, ins, kbd, q, s, samp,\n small, strike, strong, sub, sup, tt, var,\n b, u, i, center,\n dl, dt, dd, ol, ul, li,\n fieldset, form, label, legend,\n table, caption, tbody, tfoot, thead, tr, th, td,\n article, aside, canvas, details, embed,\n figure, figcaption, footer, header, hgroup,\n menu, nav, output, ruby, section, summary,\n time, mark, audio, video {\n margin: 0;\n padding: 0;\n border: 0;\n font-size: 100%;\n font: inherit;\n vertical-align: baseline;\n }\n\n *, :after, :before {\n box-sizing: border-box;\n }\n\n article, aside, details, figcaption, figure,\n footer, header, hgroup, menu, nav, section {\n display: block;\n }\n body {\n line-height: 1;\n }\n ol, ul {\n list-style: none;\n }\n blockquote, q {\n quotes: none;\n }\n blockquote:before, blockquote:after,\n q:before, q:after {\n content: '';\n content: none;\n }\n table {\n border-collapse: collapse;\n border-spacing: 0;\n }\n\n button {\n background: none;\n border: none;\n padding: 0;\n font: inherit;\n color: inherit;\n cursor: pointer;\n }\n\n input,\n textarea {\n background: none;\n border: none;\n padding: 0;\n resize: none;\n }\n\n input[type=\"checkbox\"] {\n /* Add if not using autoprefixer */\n -webkit-appearance: none;\n appearance: none;\n /* For iOS < 15 to remove gradient background */\n background-color: #fff;\n /* Not removed via appearance */\n margin: 0;\n }\n\n .custom-input {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: flex-start;\n align-self: stretch;\n flex: 1 0 0;\n font-family: var(--heading-font-family, Poppins);\n }\n\n .disabled-input {\n opacity: 0.5;\n pointer-events: disable;\n }\n\n .custom-input.birthdate .date-input-container {\n display: flex;\n height: 36px;\n align-items: center;\n align-self: stretch;\n }\n\n .date-input-container .month-field,\n .date-input-container .day-field {\n flex: 0 1 50px;\n max-width: 50px;\n }\n\n .date-input-container .year-field {\n flex: 1 0 70px;\n max-width: 70px;\n }\n\n .date-input-container .date-separator {\n color: var(--accent-color, #18181B);\n font-size: 14px;\n line-height: 24px;\n margin: 0 8px;\n }\n\n .custom-input.birthdate input {\n display: flex;\n flex-direction: column;\n justify-content: flex-end;\n align-items: flex-start;\n font-size: 16px;\n height: 36px;\n font-family: var(--paragraph-font-family, Poppins);\n font-weight: 500;\n padding: 4px 11px;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.05);\n min-width: 53px;\n }\n\n .custom-input.birthdate.outlined input {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .custom-input.birthdate.filled input {\n background-color: var(--accent-color, #E4E4E7);\n }\n\n .custom-input label {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 1;\n color: var(--default-text-color, #18181B);\n text-align: left;\n white-space: nowrap;\n text-overflow: ellipsis;\n max-width: 100%;\n font-family: var(--paragraph-font-family, Poppins);\n text-overflow: ellipsis;\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 14px;\n padding-bottom: 2px;\n margin-bottom: 6px;\n }\n\n /* Enhanced fallback for browsers without line-clamp */\n @supports not (-webkit-line-clamp: 1) {\n .custom-input label {\n display: block;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n }\n\n .custom-input > input,\n .custom-input textarea {\n width: 100%;\n display: flex;\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n font-size: 16px;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-weight: 500;\n }\n\n .custom-input.outlined > input,\n .custom-input.outlined textarea {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .custom-input.filled > input,\n .custom-input.filled textarea {\n background-color: var(--accent-color, #E4E4E7);\n }\n\n .custom-input input:focus,\n .custom-input textarea:focus,\n .custom-input select:focus {\n outline: none;\n border-color: var(--primary-color, #3b82f6);\n }\n\n .custom-input input:disabled,\n .custom-input select:disabled {\n cursor: not-allowed;\n }\n\n .custom-input.textarea textarea {\n height: auto;\n }\n\n .custom-input input.input-error {\n border-color: var(--error-color, #EF4444);\n }\n\n .custom-input .error-container {\n display: none;\n }\n\n .custom-input .error-container.show {\n display: block;\n margin-top: 8px;\n }\n\n .custom-input .error-message {\n color: var(--error-color, #EF4444);\n font-size: 0.875rem;\n margin-bottom: 0.25rem;\n }\n\n p > strong {\n font-weight: 700;\n }\n\n /* Alert Styles\n ** Global styles for alerts\n */\n\n .alert {\n display: flex;\n flex-direction: row;\n padding: 8px 16px;\n align-items: flex-start;\n align-self: stretch;\n border-radius: var(--border-radius-rounded, 6px);\n margin-bottom: 8px;\n }\n\n .alert-warning {\n border: 1px solid var(--warning-color, #EA580C);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--warning-color, #EA580C);\n }\n\n .alert-success {\n border: 1px solid var(--success-color, #10b981);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--success-color, #10b981);\n }\n\n .alert-info {\n border: 1px solid var(--base-blue, #3b82f6);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--base-blue, #3b82f6);\n }\n\n .alert-message {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 13px;\n word-break: break-word;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n flex: 1;\n }\n\n .alert-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 20px;\n height: 20px;\n border-radius: 50%;\n flex-shrink: 0;\n margin-right: 8px;\n }\n\n .alert-icon-warning {\n color: var(--warning-color, #EA580C);\n }\n\n .alert-icon-success {\n color: var(--success-color, #10b981);\n }\n\n .alert-icon-info {\n color: var(--base-blue, #3b82f6);\n }\n\n .alert-icon svg {\n width: 16px;\n height: 16px;\n }\n\n .alert-icon-svg {\n width: 12px;\n height: 12px;\n fill: currentColor;\n }\n\n .alert-details {\n margin-top: 8px;\n padding-left: 24px;\n }\n\n .alert-details-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: var(--typography-base-sizes-small-font-size, 12px);\n font-weight: var(--font-weight-normal, 400);\n opacity: 0.8;\n }\n\n /** Engraving FORM **/\n\n .engraving-form {\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .engraving-form > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .engraving-form .product-info-section,\n .engraving-form .fulfillment-section,\n .engraving-form .engraving-section {\n display: flex;\n padding: 16px 16px;\n align-items: flex-start;\n align-self: stretch;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .engraving-form .product-info-section {\n flex-direction: row;\n align-items: center;\n }\n \n .product-info-section > *:not(:last-child) {\n margin-right: 12px;\n }\n\n .product-details-container {\n width: 100%;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .product-details-container > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .engraving-form .product-info-section .product-image-container {\n display: flex;\n width: 68px;\n height: 68px;\n flex-direction: column;\n align-items: flex-start;\n aspect-ratio: 1/1;\n }\n\n .engraving-form .product-info-section .product-image-container .product-image {\n width: 100%;\n height: 100%;\n object-fit: cover;\n border-radius: var(--card-border-radius, 6px);\n }\n\n .product-details-container .product-header {\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .product-details-container .product-title,\n .product-details-container .product-price {\n color: var(--default-text-color, #18181B);\n font-feature-settings: 'haln' on;\n font-family: var(--heading-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 24px;\n }\n\n .product-details-container .product-price {\n margin-left: 4px;\n white-space: nowrap;\n }\n\n .product-size-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n align-self: stretch;\n text-align: left;\n }\n\n .engraving-fees-disclaimer {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n align-self: stretch;\n text-align: left;\n }\n\n .engraving-form .fulfillment-section .shipping-from-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n margin-bottom: 8px;\n }\n\n .engraving-form .fulfillment-section .shipping-from-text b {\n font-weight: 600;\n }\n\n .engraving-form .fulfillment-section {\n flex-direction: column;\n }\n\n .fulfillment-options-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n max-height: 0;\n overflow: hidden;\n transition: max-height 0.3s ease;\n }\n\n .fulfillment-options-container.expanded {\n max-height: 100%;\n }\n\n .fulfillment-options-container.expanded + .see-more-fulfillments {\n margin-top: 8px;\n }\n\n .fulfillment-options-container .fulfillment-option {\n width: 100%;\n display: flex;\n min-width: 216px;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n cursor: pointer;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n color: var(--default-text-color, #18181B);\n flex-shrink: 0;\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .fulfillment-options-container .fulfillment-option:not(:first-child) {\n margin-top: 8px;\n }\n\n .fulfillment-options-container .fulfillment-option.selected {\n color: var(--selected-text-color, #FAFAFA);\n border-radius: var(--card-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n border: 1px solid transparent;\n box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.06) inset;\n }\n\n .fulfillment-options-container .fulfillment-option .option-row {\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n }\n\n .fulfillment-options-container .fulfillment-option .option-row > *:not(:last-child) {\n margin-right: 8px;\n }\n\n .fulfillment-options-container .fulfillment-option .option-row:first-child span {\n font-weight: 600;\n }\n\n .fulfillment-options-container .fulfillment-option .option-row:last-child {\n margin-top: 8px;\n }\n\n .fulfillment-options-container .fulfillment-option > span {\n width: 50%;\n }\n\n .see-more-fulfillments {\n color: var(--primary-color, #1E40AF);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n .engraving-section {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .engraving-section .engraving-title {\n color: var(--default-text-color, #18181B);\n font-feature-settings: 'haln' on;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .engraving-section .engraving-location-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .engraving-inputs-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n margin-top: 16px;\n }\n \n .engraving-inputs-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .engraving-input-wrapper {\n display: flex;\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);\n }\n \n .engraving-input-wrapper > *:not(:last-child) {\n margin-right: 4px;\n }\n\n .engraving-input-wrapper .engraving-input {\n flex: 1;\n border: none;\n outline: none;\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n text-transform: uppercase;\n }\n\n .engraving-input-wrapper .engraving-char-count {\n color: var(--default-text-color-50, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n white-space: nowrap;\n }\n\n .action-buttons-container {\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n align-content: flex-start;\n align-self: stretch;\n }\n\n .action-buttons-container > *:not(:last-child) {\n margin-right: 16px;\n }\n\n .action-buttons-container .cancel-action-button {\n width: 20%;\n padding: 8px 16px;\n color: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n white-space: nowrap;\n }\n\n .action-buttons-container .add-to-cart-button {\n width: 80%;\n padding: 8px 16px;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0 1.5px 3px 0 rgba(0, 0, 0, 0.10), 0 1px 2px 0 rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n white-space: nowrap;\n }\n\n .action-buttons-container .add-to-cart-button:disabled {\n background: var(--primary-color-70, #E4E4E7);\n cursor: not-allowed;\n }\n\n .engraving-disclaimer {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n }\n\n .engraving-disclaimer b {\n font-weight: 600;\n }\n\n /** Component Error View **/\n .error-view {\n padding: 20px;\n background: #fff5f5;\n border: 1px solid #fed7d7;\n border-radius: 4px;\n color: #c53030;\n text-align: center;\n }\n\n .error-view h3 {\n margin-bottom: 10px;\n }\n\n .error-view p {\n margin-bottom: 20px;\n font-size: 16px;\n font-style: italic;\n }\n\n .error-view button {\n padding: 8px 16px;\n background: #c53030;\n color: white;\n border: none;\n border-radius: 4px;\n cursor: pointer;\n }\n\n .powered-by-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .pb-title-container {\n display: flex;\n justify-content: center;\n align-items: baseline;\n align-self: stretch;\n margin-bottom: 4px;\n padding-bottom: 7px;\n }\n\n .pb-text {\n text-align: center;\n font-family: 'Poppins';\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 100%;\n margin-right: 4px;\n }\n\n .pb-lc {\n font-family: 'Poppins';\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .pb-dot {\n font-family: 'Poppins';\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .light .pb-text,\n .light .pb-lc {\n color: #0F172A;\n }\n\n .light .pb-dot {\n color: #1D4ED8;\n }\n\n .dark .pb-text,\n .dark .pb-lc,\n .dark .pb-dot {\n color: #FAFAFA;\n }\n\n .pb-disclaimer-container {\n align-self: stretch;\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 11px;\n font-style: normal;\n font-weight: 300;\n line-height: 16px;\n word-break: break-word;\n }\n\n .pb-link {\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 11px;\n font-style: normal;\n font-weight: 300;\n line-height: 16px;\n }\n\n .dark .pb-disclaimer-container, .dark .pb-link {\n color: #FAFAFA;;\n }\n\n .light .pb-disclaimer-container{\n color: #0F172A;\n }\n\n .light .pb-link {\n color: #1D4ED8;\n }\n\n .lce-ui-button {\n display: block;\n position: relative;\n cursor: pointer;\n width: 24px;\n height: 24px;\n }\n\n .lce-ui-button.independent {\n position: absolute;\n top: 12px;\n right: 12px;\n z-index: "+d.INDEPENDENT_BUTTON+';\n }\n\n /* Cart Button Components */\n .lce-cart-button-icon {\n display: block;\n }\n\n .lce-cart-button-badge {\n position: absolute;\n top: -6px;\n right: -6px;\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n border-radius: 50%;\n width: 16px;\n height: 16px;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 10px;\n font-weight: bold;\n font-family: var(--heading-font-family, Poppins);\n pointer-events: none;\n z-index: 10;\n line-height: 1;\n }\n\n /* Global Icon Styling - Automatic Accent Color Application */\n svg {\n color: var(--icon-color, var(--accent-color, #E4E4E7));\n }\n\n svg path,\n svg circle,\n svg rect,\n svg line,\n svg polygon,\n svg polyline,\n svg ellipse {\n fill: currentColor;\n stroke: currentColor;\n }\n\n /* Respect explicit fill="none" */\n svg [fill="none"] {\n fill: none !important;\n }\n\n /* Specific icon overrides for semantic colors */\n .checkbox-icon {\n color: var(--icon-color, var(--selected-text-color, #FAFAFA));\n }\n\n .error-info-icon {\n color: var(--icon-color, var(--error-color, #DC2626));\n }\n\n .success-icon {\n color: var(--icon-color, var(--success-color, #10b981));\n }\n\n .warning-icon {\n color: var(--icon-color, var(--warning-color, #EA580C));\n }\n\n .info-icon {\n color: var(--icon-color, var(--accent-color, #E4E4E7));\n }\n\n .search-icon {\n color: var(--icon-color, var(--accent-color, #E4E4E7));\n }\n\n .arrow-right-icon,\n .bag-icon,\n .completed-icon,\n .loading-spinner-icon,\n .trash-icon,\n .chevron-down-icon {\n color: var(--icon-color, var(--accent-color, #E4E4E7));\n }\n\n .chevron-left-icon,\n .close-icon {\n color: var(--icon-color, var(--default-text-color, #18181B));\n }\n\n\n /* Exception for icons that should not inherit color (logos, specific designs) */\n svg[data-no-color-inherit] * {\n fill: initial;\n stroke: initial;\n }\n\n /* Override for stroke-only icons */\n svg[data-stroke-only] * {\n fill: none;\n stroke: currentColor;\n }\n\n /* Override for fill-only icons */\n svg[data-fill-only] * {\n fill: currentColor;\n stroke: none;\n }\n\n /* Tablet and up */\n @media (min-width: 768px) {\n .lce-ui-button.independent {\n top: 16px;\n right: 16px;\n }\n }\n\n /* Desktop */\n @media (min-width: 1024px) {\n .lce-ui-button.independent {\n top: 20px;\n right: 20px;\n }\n }\n\n /** Engraving View Container */\n .engraving-view-container {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n }\n\n .engraving-view-container {\n width: 100%;\n padding: 16px;\n }\n\n .engraving-view-container.outlined {\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .engraving-view-container.filled {\n border-radius: var(--card-border-radius, 6px);\n background: linear-gradient(0deg, var(--alpha-50, rgba(254, 254, 254, 0.50)) 0%, var(--alpha-50, rgba(254, 254, 254, 0.50)) 100%), var(--accent-color, #E4E4E7);\n }\n\n .engraving-view-container .engraving-header {\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n align-content: center;\n }\n\n .engraving-view-container .engraving-header {\n margin-bottom: 16px;\n }\n\n .engraving-view-container .engraving-header h3,\n .engraving-view-container .engraving-header span {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .engraving-view-container .engraving-header span.engraving-fee .engraving-fee-each {\n font-weight: 500;\n }\n\n .engraving-view-container .engraving-body {\n display: flex;\n justify-content: space-between;\n align-items: flex-end;\n align-content: flex-end;\n align-self: stretch;\n flex-wrap: wrap;\n }\n\n .engraving-view-container .engraving-lines {\n display: flex;\n min-width: 136px;\n flex-direction: column;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .engraving-view-container .engraving-lines .engraving-line {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 100%;\n text-transform: uppercase;\n margin-top: 4px;\n }\n\n .engraving-view-container .engraving-lines .engraving-line:not(:first-child) {\n margin-top: 4px;\n }\n\n .engraving-view-container .engraving-actions {\n display: flex;\n align-items: center;\n }\n\n .engraving-view-container .engraving-actions .edit-button {\n margin-left: 16px;\n }\n\n .engraving-view-container .engraving-actions button {\n color: var(--primary-color, #1D4ED8);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n .action-disabled {\n opacity: 0.7;\n cursor: not-allowed;\n }\n\n .disclaimer-header {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 600;\n line-height: 16px;\n }\n\n .disclaimer-description {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n }\n\n /* Alert Container - Simplified version matching existing alert design */\n .alert-container {\n display: flex;\n padding: 8px 16px;\n align-items: flex-start;\n flex-direction: row;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n border: 1px solid var(--error-color, #DC2626);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--error-color, #DC2626);\n }\n\n .alert-wrapper {\n display: flex;\n flex-direction: column;\n align-self: stretch;\n }\n\n .alert-wrapper > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .alert-wrapper.hidden {\n display: none;\n }\n\n .alert-item {\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n }\n\n .alert-container.hidden {\n display: none;\n }\n\n .alert-container.alert-error {\n border-color: var(--error-color, #DC2626);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--error-color, #DC2626);\n }\n\n .alert-container.alert-warning {\n border-color: var(--warning-color, #FBBF24);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--warning-color, #FBBF24);\n }\n\n .alert-container.alert-success {\n border-color: var(--success-color, #4ADE80);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--success-color, #4ADE80);\n }\n\n .alert-container .alert-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 20px;\n height: 20px;\n flex-shrink: 0;\n margin-right: 8px;\n color: var(--error-color, #DC2626);\n }\n\n .alert-container .alert-icon svg {\n width: 16px;\n height: 16px;\n }\n\n .alert-container .alert-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 13px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n flex: 1;\n }\n\n\n /*************************\n Animation\n *************************/\n @keyframes spin {\n 0% {\n transform: translateY(-50%) rotate(0deg);\n }\n 100% {\n transform: translateY(-50%) rotate(360deg);\n }\n }\n\n @keyframes slideIn {\n 0% {\n opacity: 0;\n transform: translateY(-8px);\n max-height: 0;\n }\n 100% {\n opacity: 1;\n transform: translateY(0);\n max-height: 100px;\n }\n }\n\n /*************************\n Accessibility - Focus Visible\n *************************/\n\n /* Remove default focus outline for mouse users */\n *:focus {\n outline: none;\n }\n\n /* Show focus only for keyboard navigation */\n *:focus-visible {\n outline: 1px solid var(--warning-color, #1D4ED8);\n outline-offset: 0px;\n border-radius: var(--button-border-radius, 6px);\n box-shadow: 0 0 0 4px rgba(29, 78, 216, 0.1);\n }\n\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n',getImageCarouselStyle=()=>"\n .product-image-carousel {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n max-width: 100%;\n height: auto;\n min-height: 350px;\n overflow: hidden;\n }\n\n .product-image-carousel.popup {\n max-height: 474px;\n }\n\n .product-image-carousel.carousel {\n max-height: 594px;\n }\n\n .main-image {\n position: relative;\n width: 100%;\n height: 100%;\n display: flex;\n justify-content: center;\n align-items: flex-start;\n border-radius: var(--card-border-radius, 6px);\n overflow: hidden;\n flex: 1;\n background-image: var(--bg-image, none);\n background-position: center center;\n background-size: contain;\n background-repeat: no-repeat;\n }\n\n .carousel-dots {\n position: absolute;\n bottom: 16px;\n left: 50%;\n transform: translateX(-50%);\n z-index: "+d.CAROUSEL_CONTROLS+";\n display: flex;\n border-radius: 20px;\n }\n\n .carousel-dots .carousel-dot {\n margin-left: 10px;\n }\n\n .carousel-dots .carousel-dot:first-child {\n margin-left: 0;\n }\n\n .carousel-dot {\n width: 10px;\n height: 10px;\n border-radius: 50%;\n border: none;\n background: var(--accent-color, #828a97ff);\n cursor: pointer;\n transition: background-color 0.2s ease;\n }\n\n .carousel-dot.active {\n background: var(--primary-color, #3b82f6);\n }\n\n .gallery-viewport {\n display: none;\n overflow: hidden;\n width: 100%;\n height: 80px;\n flex-shrink: 0;\n margin-top: 12px;\n }\n\n .gallery-container {\n display: flex;\n cursor: grab;\n touch-action: pan-y pinch-zoom;\n }\n\n .gallery-container:active {\n cursor: grabbing;\n }\n\n .gallery-container .gallery-image-wrapper {\n margin-left: 8px;\n }\n\n .gallery-container .gallery-image-wrapper:first-child {\n margin-left: 0;\n }\n\n .gallery-image-wrapper {\n flex: 0 0 auto;\n }\n\n .gallery-image {\n width: 60px;\n height: 60px;\n object-fit: cover;\n border: 1px solid transparent;\n border-radius: var(--card-border-radius, 6px);\n cursor: pointer;\n background: var(--accent-color, #3b82f6);\n opacity: 0.5;\n transition: opacity 0.2s ease;\n user-select: none;\n -webkit-user-drag: none;\n }\n\n .gallery-image-wrapper.selected .gallery-image {\n opacity: 1;\n border-color: var(--primary-color, #3b82f6);\n }\n\n /* Small mobile screens */\n @media (min-width: 480px) {\n .carousel-dot {\n width: 8px;\n height: 8px;\n }\n\n .carousel-dots .carousel-dot {\n margin-left: 8px;\n }\n }\n\n /* Tablet and desktop */\n @media (min-width: 769px) {\n .carousel-dots {\n display: none;\n }\n\n .gallery-viewport {\n display: block;\n }\n\n .gallery-image {\n width: 80px;\n height: 80px;\n }\n }\n\n @media (prefers-reduced-motion: reduce) {\n .gallery-image,\n .carousel-dot {\n transition: none;\n }\n }\n",getProductStyles=()=>"\n .product-content-wrapper {\n width: 100%;\n min-width: 320px;\n height: auto;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n }\n\n .product-content-wrapper .product-image-carousel {\n margin-right: 40px;\n }\n\n .product-content {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n position: relative;\n overflow: hidden;\n }\n\n .product-content > .product-title + .product-options:not(.hide-content) {\n margin-top: 24px;\n }\n\n @media (min-width: 769px) {\n .product-content-wrapper {\n flex-direction: row;\n align-items: stretch;\n }\n\n .product-content-wrapper.has-images .product-image-carousel {\n width: 45%;\n }\n\n .product-content-wrapper.has-images .product-content {\n width: 55%;\n }\n }\n\n .product-interactions {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .product-interactions > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .size-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .size-container .size-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n margin-bottom: 8px;\n }\n\n .size-container .size-buttons-container {\n display: flex;\n align-items: flex-start;\n align-content: flex-start;\n align-self: stretch;\n flex-wrap: wrap;\n margin-bottom: -8px;\n }\n\n .size-container .size-buttons-container .size-button {\n display: flex;\n padding: 8px 16px;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n border-radius: var(--button-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .size-container .size-buttons-container > * {\n margin-right: 8px;\n margin-bottom: 8px;\n }\n\n .size-container .size-buttons-container > *:last-child {\n margin-right: 0;\n }\n\n .size-container .size-buttons-container .size-button.selected {\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n border: 1px solid transparent;\n }\n\n .price-personalization-container {\n display: flex;\n align-items: center;\n justify-content: space-between;\n flex-wrap: wrap;\n width: 100%;\n }\n\n .add-personalization-span {\n color: var(--primary-color, #1E40AF);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight:400;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n /** Product Add to Cart Container */\n .add-to-cart-container {\n display: flex;\n align-items: flex-start;\n align-content: flex-start;\n align-self: stretch;\n flex-wrap: wrap;\n }\n\n .add-to-cart-container > *:not(:first-child) {\n margin-left: 16px;\n }\n\n .add-to-cart-container .quantity-container {\n display: flex;\n width: 106px;\n align-items: center;\n }\n\n .add-to-cart-container .quantity-container .quantity-decrease,\n .add-to-cart-container .quantity-container .quantity-increase {\n display: flex;\n width: 36px;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n\n cursor: pointer;\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .add-to-cart-container .quantity-container.outlined .quantity-decrease,\n .add-to-cart-container .quantity-container.outlined .quantity-increase {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .add-to-cart-container .quantity-container.outlined .quantity-decrease.disabled,\n .add-to-cart-container .quantity-container.outlined .quantity-increase.disabled {\n cursor: not-allowed;\n }\n\n .add-to-cart-container .quantity-container .quantity-decrease {\n border-radius: var(--button-border-radius, 6px) 0px 0px var(--button-border-radius, 6px);\n }\n\n .add-to-cart-container .quantity-container .quantity-increase {\n border-radius: 0px var(--button-border-radius, 6px) var(--button-border-radius, 6px) 0px;\n }\n\n .add-to-cart-container .quantity-container .product-count {\n display: flex;\n padding: 6px 8px;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n align-self: stretch;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n\n .add-to-cart-container .quantity-container.outlined .product-count {\n border-top: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .add-to-cart-container .add-to-cart-button {\n display: flex;\n min-width: 182px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n outline: none;\n cursor: pointer;\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n position: relative;\n }\n\n .add-to-cart-container .add-to-cart-button.loading::after {\n content: '';\n position: absolute;\n right: 16px;\n top: 50%;\n transform: translateY(-50%);\n z-index: "+d.LOADING_INDICATOR+";\n width: 18px;\n height: 18px;\n border: 2px solid transparent;\n border-top: 2px solid var(--selected-text-color);\n border-radius: 50%;\n animation: spin 1s linear infinite;\n }\n\n .add-to-cart-container .add-to-cart-button.processing {\n cursor: not-allowed;\n pointer-events: none;\n }\n\n .add-to-cart-container .add-to-cart-button.disabled {\n background: var(--primary-color-70, #E4E4E7);\n cursor: not-allowed;\n }\n\n .product-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 24px;\n font-style: normal;\n font-weight: 600;\n line-height: 32px;\n transform: translateX(0);\n transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n visibility: visible;\n height: auto;\n }\n\n .product-title.hide {\n transform: translateX(-100%);\n visibility: hidden;\n height: 0;\n }\n\n .main-product-price {\n display: inline-block;\n width: fit-content;\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 30px;\n font-style: normal;\n font-weight: 600;\n line-height: 36px;\n }\n\n .product-presale-notice {\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n text-align: left;\n }\n\n .product-description {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .product-description > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .product-description .title {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .product-description .content {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n align-self: stretch;\n\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n text-align: left;\n }\n\n .product-description .content.collapsed {\n /* Modern browsers with line-clamp support */\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 3;\n overflow: hidden;\n\n /* Fallback for older browsers */\n max-height: 4.5em; /* 3 lines * 1.5 line-height */\n line-height: 1.5;\n word-wrap: break-word;\n\n /* Additional fallback properties */\n text-overflow: ellipsis;\n white-space: normal;\n }\n\n /* Fallback for browsers without line-clamp support */\n @supports not (-webkit-line-clamp: 3) {\n .product-description .content.collapsed {\n display: block;\n max-height: 4.5em;\n overflow: hidden;\n position: relative;\n }\n\n .product-description .content.collapsed::after {\n content: '...';\n position: absolute;\n right: 0;\n bottom: 0;\n background: linear-gradient(to right, transparent, var(--default-background-color, white) 50%);\n padding-left: 20px;\n }\n }\n\n .product-description .collapse-button {\n border-radius: var(--button-border-radius, 6px);\n cursor: pointer;\n color: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n /* Product Drawer container */\n .product-drawer-container {\n width: 100%;\n height: 0;\n z-index: "+d.PRODUCT_DRAWER+";\n transform: translateX(100%);\n transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n }\n\n /* Opened drawer state */\n .product-drawer-container.open {\n transform: translateX(0);\n height: 100%;\n }\n\n /* Expanded drawer state when address suggestions are shown */\n .product-drawer-container.open:has(.suggestions-expanded) {\n height: 230px;\n }\n\n /* Content area - fills the remaining space */\n .product-drawer-content {\n position: relative;\n display: block;\n width: 100%;\n height: 100%;\n box-sizing: border-box;\n overflow-y: auto;\n }\n\n .product-options {\n width: 100%;\n min-width: 320px;\n transform: translateX(0);\n transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n visibility: visible;\n height: auto;\n }\n\n .product-options.hide-content {\n transform: translateX(-100%);\n visibility: hidden;\n height: 0;\n }\n\n .product-no-availability-message {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n\n .product-options-open-address-button {\n width: 100%;\n display: flex;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n",getProductRetailersStyles=()=>"\n .product-retailers {\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n }\n\n .retailers-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .retailers-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n /** Fulfillment Tab Container **/\n .fulfillment-tabs-container {\n display: flex;\n width: 100%;\n align-items: flex-end;\n flex-shrink: 0;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .fulfillment-tabs-container .fulfillment-tab {\n display: flex;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n }\n\n .fulfillment-tabs-container .fulfillment-tab.selected {\n border-bottom: 2px solid var(--primary-color, #1D4ED8);\n margin-bottom: -1px;\n }\n\n .fulfillment-tabs-container .fulfillment-tab .fulfillment-tab-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .fulfillment-tabs-container .fulfillment-tab .fulfillment-tab-label.selected {\n font-weight: 600;\n }\n\n /** Carousel Mode **/\n .retailers-container .carousel-fulfillment-list-container {\n display: flex;\n flex-direction: row;\n align-self: stretch;\n touch-action: pan-y pinch-zoom;\n cursor: grab;\n }\n\n .retailers-container .carousel-fulfillment-list-container.active {\n cursor: grabbing;\n }\n\n .carousel-fulfillment-list-viewport {\n overflow: hidden;\n width: 100%;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card {\n display: flex;\n width: 200px;\n min-height: 200px;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n justify-content: space-between;\n flex-shrink: 0;\n transition: all 0.2s ease;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n color: var(--default-text-color, #18181B);\n cursor: pointer;\n scroll-snap-align: center;\n\n -webkit-touch-callout:none;\n -webkit-user-select:none;\n -moz-user-select:none;\n -ms-user-select:none;\n user-select:none;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card:not(:first-child) {\n margin-left: 8px;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card.closed {\n opacity: 0.7;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card.selected {\n color: var(--selected-text-color, #FAFAFA);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.06) inset;\n border: 1px solid transparent;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-header .name {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 2;\n overflow: hidden;\n text-overflow: ellipsis;\n align-self: stretch;\n /* Cross-browser fallback */\n max-height: 2.8em;\n line-height: 1.4;\n word-wrap: break-word;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-weight: 500;\n font-style: normal;\n line-height: 20px;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card.selected .retailer-header .name {\n font-weight: 600;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-header .address {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 2;\n overflow: hidden;\n font-weight: 400;\n text-overflow: ellipsis;\n /* Cross-browser fallback */\n max-height: 2.8em;\n line-height: 1.4;\n word-wrap: break-word;\n align-self: stretch;\n font-family: var(--heading-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n line-height: 14px;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body .product-price {\n font-family: var(--heading-font-family, Poppins);\n font-size: 24px;\n font-style: normal;\n font-weight: 500;\n line-height: 32px;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card.selected .retailer-body .product-price {\n font-weight: 600;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body .shipping-price,\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body .expectation {\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n\n /************************* Popup Mode *************************/\n .retailers-container .header {\n display: flex;\n height: 36px;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .retailers-container .header .header-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .retailers-container .header .delivery-options {\n color: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n /** Popup Fulfillment List Container **/\n .retailers-popup-list-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .retailers-popup-list-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .retailers-popup-list-container .popup-retailers-section-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .popup-fulfillment-list-container {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n overflow-y: auto;\n align-self: stretch;\n max-height: 350px;\n }\n\n .drawer-content .popup-fulfillment-list-container {\n max-height: 100%;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card {\n width: 100%;\n display: flex;\n min-width: 216px;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n cursor: pointer;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n color: var(--default-text-color, #18181B);\n flex-shrink: 0;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card:not(:first-child) {\n margin-top: 16px;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card.closed {\n opacity: 0.7;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card.selected {\n color: var(--selected-text-color, #FAFAFA);\n border-radius: var(--card-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n border: 1px solid transparent;\n box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.06) inset;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card .row {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card .name,\n .popup-fulfillment-list-container .popup-retailer-card .price,\n .popup-fulfillment-list-container .popup-retailer-card .expectation,\n .popup-fulfillment-list-container .popup-retailer-card .fee,\n .popup-fulfillment-list-container .popup-retailer-card .address {\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card .name,\n .popup-fulfillment-list-container .popup-retailer-card .price {\n font-weight: 600;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card .name,\n .popup-fulfillment-list-container .popup-retailer-card .expectation,\n .popup-fulfillment-list-container .popup-retailer-card .address {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 1;\n overflow: hidden;\n /* Cross-browser single-line fallback */\n white-space: nowrap;\n text-overflow: ellipsis;\n max-width: 100%;\n }\n\n /* Enhanced fallback for browsers without line-clamp */\n @supports not (-webkit-line-clamp: 1) {\n .popup-fulfillment-list-container .popup-retailer-card .name,\n .popup-fulfillment-list-container .popup-retailer-card .expectation,\n .popup-fulfillment-list-container .popup-retailer-card .address {\n display: block;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n }\n\n .fulfillments-no-availability-message {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n";function getDrawerStyles(){return"\n /* Drawer wrapper container */\n .drawer-wrapper {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: "+d.DRAWER_WRAPPER+";\n pointer-events: none;\n }\n\n .drawer-wrapper.open {\n pointer-events: auto;\n }\n\n /* Backdrop overlay */\n .drawer-backdrop {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background-color: rgba(0, 0, 0, 0.4);\n z-index: "+d.DRAWER_BACKDROP+";\n opacity: 0;\n visibility: hidden;\n transition: opacity 0.3s ease, visibility 0.3s ease;\n pointer-events: none;\n }\n\n .drawer-backdrop.visible {\n opacity: 1;\n visibility: visible;\n pointer-events: auto;\n }\n\n /* Main drawer */\n .drawer {\n position: absolute;\n top: 0;\n right: 0;\n width: 400px;\n height: 100vh; /* Fallback for browsers that don't support dvh */\n height: 100dvh;\n z-index: "+d.DRAWER_CONTENT+";\n background-color: #ffffff;\n overflow: hidden;\n transform: translateX(100%);\n transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n box-shadow: -2px 0 8px rgba(0, 0, 0, 0.1);\n pointer-events: auto;\n }\n\n /* Opened drawer state */\n .drawer.open {\n transform: translateX(0);\n }\n\n .drawer.address-input .drawer-content,\n .drawer.engraving-form .drawer-content,\n .drawer.product-retailers-popup-list .drawer-content {\n padding: 16px;\n }\n\n /* Content area - fills the remaining space */\n .drawer-content {\n position: relative;\n width: 100%;\n height: 100%;\n box-sizing: border-box;\n overflow-y: auto;\n background-color: var(--drawer-background-color, #FAFAFA);\n }\n\n /* Content swap animation classes */\n .drawer-content-fade-out {\n opacity: 1;\n transition: opacity 150ms ease-out;\n }\n\n .drawer-content-fade-out.fading {\n opacity: 0;\n }\n\n .drawer-content-fade-in {\n opacity: 0;\n transition: opacity 150ms ease-in;\n }\n\n .drawer-content-fade-in.visible {\n opacity: 1;\n }\n\n /* Mobile adjustments */\n @media (max-width: 576px) {\n .drawer {\n width: 100%;\n }\n }\n\n /* Accessibility - respect user's motion preferences */\n @media (prefers-reduced-motion: reduce) {\n .drawer,\n .drawer-backdrop,\n .drawer-content-fade-out,\n .drawer-content-fade-in {\n transition: none;\n }\n }\n "}const getProductLoadingStyles=()=>"\n .skeleton-container {\n min-width: 320px;\n width: 100%;\n height: auto;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n }\n\n .skeleton-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .skeleton-container .wave {\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .skeleton-container .wave::before {\n content: '';\n position: absolute;\n top: 0;\n left: -100%;\n width: 100%;\n height: 100%;\n background: linear-gradient(\n 90deg,\n transparent 0%,\n rgba(255, 255, 255, 0.8) 50%,\n transparent 100%\n );\n animation: wave 1.8s infinite ease-in-out;\n z-index: "+d.SKELETON_WAVE+";\n }\n\n .sc-title {\n height: 32px;\n width: 100%;\n }\n\n .sc-sizes {\n height: 36px;\n width: 100%;\n display: flex;\n }\n\n .sc-size-button {\n height: 36px;\n width: 30%;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .sc-size-button:not(:first-child) {\n margin-left: 8px;\n }\n\n .sc-row {\n display: flex;\n background: none !important;\n height: auto;\n }\n\n .sc-row > *:not(:first-child) {\n margin-left: 12px;\n }\n\n .sc-price {\n height: 36px;\n width: 30%;\n }\n\n .sc-personalization {\n height: 36px;\n width: 40%;\n margin-right: 0;\n margin-left: auto;\n }\n\n .sc-deliver-to {\n height: 16px;\n width: 25%;\n margin-bottom: -16px;\n }\n\n .sc-address {\n height: 16px;\n width: 75%;\n }\n\n .sc-retailers {\n height: 140px;\n width: 100%;\n }\n\n .sc-quantity {\n height: 36px;\n width: 30%;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .sc-add-to-cart {\n height: 36px;\n flex: 1;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .sc-description-title {\n height: 16px;\n width: 45%;\n margin-bottom: -12px;\n }\n\n .sc-description-line {\n height: 16px;\n width: 100%;\n margin-bottom: -20px;\n }\n\n .sc-description-more {\n height: 16px;\n width: 30%;\n margin-top: 8px;\n }\n\n .sc-title::before { animation-delay: 0s; }\n .sc-price::before { animation-delay: 0.1s; }\n .sc-size-button::before { animation-delay: 0.2s; }\n .sc-price::before { animation-delay: 0.3s; }\n .sc-personalization::before { animation-delay: 0.4s; }\n .sc-deliver-to::before { animation-delay: 0.5s; }\n .sc-address::before { animation-delay: 0.6s; }\n .sc-retailers::before { animation-delay: 0.7s; }\n .sc-quantity::before { animation-delay: 0.8s; }\n .sc-add-to-cart::before { animation-delay: 0.9s; }\n .sc-description-title::before { animation-delay: 1.0s; }\n .sc-description-line:nth-child(10)::before { animation-delay: 1.1s; }\n .sc-description-line:nth-child(11)::before { animation-delay: 1.2s; }\n .sc-description-line:nth-child(12)::before { animation-delay: 1.3s; }\n .sc-description-more::before { animation-delay: 1.4s; }\n\n .sc-main-image {\n width: 100%;\n height: 350px;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n flex: 1;\n }\n\n .sc-carousel-dot {\n width: 10px;\n height: 10px;\n border-radius: 50%;\n background-color: #c4d1e0;\n margin-right: 10px;\n }\n\n .sc-carousel-dot:last-child {\n margin-right: 0;\n }\n\n .sc-gallery-thumbnail {\n width: 60px;\n height: 60px;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .sc-main-image::before { animation-delay: 1.5s; }\n .sc-carousel-dot::before { animation-delay: 1.6s; }\n .sc-gallery-thumbnail::before { animation-delay: 1.7s; }\n\n @media (min-width: 480px) {\n .sc-carousel-dot {\n width: 8px;\n height: 8px;\n margin-right: 8px;\n }\n }\n\n @media (min-width: 769px) {\n .sc-gallery-thumbnail {\n width: 80px;\n height: 80px;\n }\n\n .sc-main-image {\n height: 474px;\n }\n }\n\n @keyframes wave {\n 0% {\n left: -100%;\n }\n 100% {\n left: 100%;\n }\n }\n",getProductListCardLoadingStyles=()=>"\n .product-list-card-loading__container {\n width: 100%;\n height: 100%;\n display: flex;\n flex-wrap: wrap;\n align-items: flex-start;\n gap: 24px;\n --gap-per-card: calc(24px * (var(--columns, 4) - 1) / var(--columns, 4));\n }\n\n .slc__card {\n width: calc(var(--card-width, 25%) - var(--gap-per-card, 18px));\n flex: 0 0 calc(var(--card-width, 25%) - var(--gap-per-card, 18px));\n pointer-events: none;\n background-color: transparent;\n border: none;\n border-radius: var(--card-border-radius, 0.375rem);\n overflow: hidden;\n cursor: default;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n height: 100%;\n }\n\n .slc__card .wave {\n background-color: #c4d1e0;\n position: relative;\n overflow: hidden;\n }\n\n .slc__card .wave::before {\n content: '';\n position: absolute;\n top: 0;\n left: -100%;\n width: 100%;\n height: 100%;\n background: linear-gradient(\n 90deg,\n transparent 0%,\n rgba(255, 255, 255, 0.8) 50%,\n transparent 100%\n );\n animation: wave 1.8s infinite ease-in-out;\n z-index: "+d.SKELETON_WAVE+";\n }\n\n .slc__image-content {\n width: 100%;\n height: 100%;\n padding: 10px 0;\n }\n\n .slc__image-wrapper {\n width: 100%;\n height: 14rem;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n border-bottom: none;\n padding-bottom: 10px;\n }\n\n .slc__image {\n width: 100%;\n height: 14rem;\n background-color: #c4d1e0;\n }\n\n .slc__content {\n width: 100%;\n display: flex;\n flex-direction: column;\n margin-bottom: 10px;\n }\n\n .slc__title-container {\n display: flex;\n flex-direction: column;\n margin-bottom: 20px;\n width: 100%;\n }\n\n .slc__title-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .slc__title {\n height: 18px;\n background-color: #c4d1e0;\n }\n\n .slc__title-line-1 {\n width: 90%;\n }\n\n .slc__title-line-2 {\n width: 75%;\n }\n\n .slc__price {\n width: 60px;\n height: 20px;\n background-color: #c4d1e0;\n }\n\n .slc__size-price-wrapper {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n }\n\n .slc__size {\n width: 45px;\n height: 20px;\n background-color: #c4d1e0;\n }\n\n .slc__button {\n width: 100%;\n height: 42px;\n margin-top: 10px;\n background-color: var(--primary-color, #3b82f6);\n opacity: 0.7;\n }\n\n .slc__card:nth-child(1) .slc__image::before { animation-delay: 0s; }\n .slc__card:nth-child(1) .slc__title-line-1::before { animation-delay: 0.05s; }\n .slc__card:nth-child(1) .slc__title-line-2::before { animation-delay: 0.1s; }\n .slc__card:nth-child(1) .slc__price::before { animation-delay: 0.2s; }\n .slc__card:nth-child(1) .slc__size::before { animation-delay: 0.2s; }\n .slc__card:nth-child(1) .slc__button::before { animation-delay: 0.25s; }\n\n .slc__card:nth-child(2) .slc__image::before { animation-delay: 0.05s; }\n .slc__card:nth-child(2) .slc__title-line-1::before { animation-delay: 0.1s; }\n .slc__card:nth-child(2) .slc__title-line-2::before { animation-delay: 0.15s; }\n .slc__card:nth-child(2) .slc__price::before { animation-delay: 0.25s; }\n .slc__card:nth-child(2) .slc__size::before { animation-delay: 0.25s; }\n .slc__card:nth-child(2) .slc__button::before { animation-delay: 0.3s; }\n\n .slc__card:nth-child(3) .slc__image::before { animation-delay: 0.1s; }\n .slc__card:nth-child(3) .slc__title-line-1::before { animation-delay: 0.15s; }\n .slc__card:nth-child(3) .slc__title-line-2::before { animation-delay: 0.2s; }\n .slc__card:nth-child(3) .slc__price::before { animation-delay: 0.3s; }\n .slc__card:nth-child(3) .slc__size::before { animation-delay: 0.3s; }\n .slc__card:nth-child(3) .slc__button::before { animation-delay: 0.35s; }\n\n .slc__card:nth-child(4) .slc__image::before { animation-delay: 0.15s; }\n .slc__card:nth-child(4) .slc__title-line-1::before { animation-delay: 0.2s; }\n .slc__card:nth-child(4) .slc__title-line-2::before { animation-delay: 0.25s; }\n .slc__card:nth-child(4) .slc__price::before { animation-delay: 0.35s; }\n .slc__card:nth-child(4) .slc__size::before { animation-delay: 0.35s; }\n .slc__card:nth-child(4) .slc__button::before { animation-delay: 0.4s; }\n\n .slc__card:nth-child(n+5) .slc__image::before { animation-delay: 0.2s; }\n .slc__card:nth-child(n+5) .slc__title-line-1::before { animation-delay: 0.25s; }\n .slc__card:nth-child(n+5) .slc__title-line-2::before { animation-delay: 0.3s; }\n .slc__card:nth-child(n+5) .slc__price::before { animation-delay: 0.4s; }\n .slc__card:nth-child(n+5) .slc__size::before { animation-delay: 0.4s; }\n .slc__card:nth-child(n+5) .slc__button::before { animation-delay: 0.45s; }\n";function getPromoCodeTickerStyles(){return"\n .promo-ticker {\n display: flex;\n align-items: stretch;\n width: 100%;\n height: 30px;\n background: var(--accent-color-70, #fff);\n position: relative;\n overflow: hidden;\n }\n\n .promo-ticker__content {\n width: calc(100% - 55px);\n display: flex;\n align-items: center;\n overflow: hidden;\n position: relative;\n border-top: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n transition: width 0.3s ease;\n }\n\n .promo-ticker:has(.promo-ticker__cta:disabled) .promo-ticker__content {\n width: calc(100% - 60px);\n }\n\n .promo-ticker__content::before,\n .promo-ticker__content::after {\n content: '';\n position: absolute;\n top: 0;\n width: 60px;\n height: 100%;\n z-index: 2;\n pointer-events: none;\n }\n\n .promo-ticker__content::before {\n left: 0;\n background: linear-gradient(90deg, var(--accent-color-70, #fff) 0%, transparent 100%);\n }\n\n .promo-ticker__content::after {\n right: 0;\n background: linear-gradient(90deg, transparent 0%, var(--accent-color-70, #fff) 100%);\n }\n\n .promo-ticker__track {\n display: flex;\n animation: promo-scroll 30s linear infinite;\n will-change: transform;\n }\n\n .promo-ticker__content:hover .promo-ticker__track {\n animation-play-state: paused;\n }\n\n .promo-ticker__text-group {\n display: flex;\n align-items: center;\n color: var(--default-text-color, #fff);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-weight: 500;\n white-space: nowrap;\n letter-spacing: 0.5px;\n text-transform: uppercase;\n }\n\n .promo-ticker__text-item {\n display: inline-flex;\n align-items: center;\n }\n\n .promo-ticker__separator {\n margin: 0 16px;\n color: var(--default-text-color, #fff);\n font-size: 12px;\n }\n\n @keyframes promo-scroll {\n 0% { transform: translateX(0); }\n 100% { transform: translateX(-50%); }\n }\n\n .promo-ticker__cta {\n width: 55px;\n height: 100%;\n background-color: var(--primary-color, #FF5733);\n color: var(--selected-text-color, #fff);\n font-family: var(--heading-font-family, Poppins);\n font-size: 12px;\n font-weight: 600;\n text-transform: uppercase;\n user-select: none;\n position: absolute;\n right: 0;\n top: 0;\n transition: width 0.3s ease;\n }\n\n .promo-ticker__cta:disabled {\n width: 60px;\n background-color: var(--primary-color-70, #FF5733);\n cursor: not-allowed;\n }\n "}const nt={"headingFont.name":"--heading-font-family","paragraphFont.name":"--paragraph-font-family",buttonCornerRadius:"--button-border-radius",cardCornerRadius:"--card-border-radius",primaryColor:"--primary-color",accentColor:"--accent-color",defaultTextColor:"--default-text-color",selectedTextColor:"--selected-text-color",errorColor:"--error-color",warningColor:"--warning-color",successColor:"--success-color",drawerBackgroundColor:"--drawer-background-color"},it={backgroundColor:"--product-background-color"},ot={backgroundColor:"--cart-background-color"},rt={backgroundColor:"--address-background-color"},st={backgroundColor:"--checkout-background-color"},at={global:nt,product:it,cart:ot,address:rt,checkout:st};function getCSSVariableMapping(t){return at[t]||{}}class CssVariableProcessorService{constructor(){this.opacityLevels=[{suffix:"30",value:.3},{suffix:"50",value:.5},{suffix:"70",value:.7},{suffix:"90",value:.9}],this.logger=LoggerFactory.get("CssVariableProcessor")}extractVariablesFromTheme(t,n){const i={},o=getCSSVariableMapping(n);for(const[r,s]of Object.entries(o)){const n=this.getValueByPath(t,r);void 0!==n&&this.isCSSValue(n)&&(i[s]=n,this.isColorVariable(s,n)&&this.generateOpacityVariants(i,s,n))}return i}extractVariablesFromPartialTheme(t,n){const i={},o=getCSSVariableMapping(n);for(const[r,s]of Object.entries(o))if(this.hasValueAtPath(t,r)){const n=this.getValueByPath(t,r);void 0!==n&&this.isCSSValue(n)&&(i[s]=n,this.isColorVariable(s,n)&&this.generateOpacityVariants(i,s,n))}return i}generateCSSVariablesString(t){return Object.entries(t).map(([t,n])=>" "+t+": "+n+";").join("\n")}updateCSSVariablesInStylesheet(t,n){if(0!==Object.keys(n).length)try{const i=this.findOrCreateRule(t);for(const[t,o]of Object.entries(n))i.style.setProperty(t,String(o))}catch(i){this.logger.warn("Failed to update CSS variables")}}getValueByPath(t,n){return n.split(".").reduce((t,n)=>t&&void 0!==t[n]?t[n]:void 0,t)}hasValueAtPath(t,n){const i=n.split(".");let o=t;for(const r of i){if(null==o||!(r in o))return![];o=o[r]}return!![]}findOrCreateRule(t){const n=":host";for(const o of Array.from(t.cssRules))if(o instanceof CSSStyleRule&&o.selectorText===n)return o;const i=t.insertRule(n+" {}");return t.cssRules[i]}isCSSValue(t){if("string"==typeof t){if(""===t.trim())return![];if(/^(#[0-9a-f]{3,8}|rgb|rgba|hsl|hsla|\d+px|\d+%|\d+rem|\d+em|auto|none|inherit|initial|unset|rounded|squared)/.test(t.toLowerCase()))return!![];if(/^[a-zA-Z0-9\s\-'"]+$/.test(t))return!![];if(/^[a-z-]+$/.test(t))return!![]}return"number"==typeof t}generateOpacityVariants(t,n,i){for(const o of this.opacityLevels){const r=n+"-"+o.suffix,s=this.addOpacityToHexColor(i,o.value);s&&(t[r]=s)}}isColorVariable(t,n){if("string"!=typeof n)return![];const i=t.toLowerCase().includes("color"),o=/^#[0-9a-f]{3,8}$/i.test(n);return i&&o}addOpacityToHexColor(t,n){if(!t.startsWith("#"))return null;let i=t.slice(1);if(3===i.length&&(i=i.split("").map(t=>t+t).join("")),6!==i.length)return null;const o=Math.round(255*n),r=o.toString(16).padStart(2,"0");return"#"+i+r}}class StylesheetGeneratorService{constructor(){this.cssProcessor=new CssVariableProcessorService,this.styleSheets=new Map}getStylesheet(t){return this.styleSheets.get(t)}generateSpecificStylesheet(t,n){const i=this.cssProcessor.extractVariablesFromTheme(n,t),o=this.cssProcessor.generateCSSVariablesString(i),r=this.getStylesheetStyles(t).join("\n\n"),s=0===o.length?"":":host { "+o+" }",a=("\n "+s+"\n\n "+r+"\n ").trim();this.createStylesheet(t,a)}createStylesheet(t,n){try{if(this.isCSSStyleSheetSupported()){const i=new CSSStyleSheet;i.replaceSync(n),this.styleSheets.set(t,i)}else this.styleSheets.set(t,n)}catch(X){this.styleSheets.set(t,n)}}isCSSStyleSheetSupported(){try{if("undefined"==typeof CSSStyleSheet)return![];if("function"!=typeof CSSStyleSheet.prototype.replaceSync)return![];const t=new CSSStyleSheet;return t.replaceSync("/* test */"),!![]}catch(t){return![]}}updateVariablesInStylesheet(t,n,i){const o=this.styleSheets.get(t);if(o&&"string"!=typeof o){const t=this.cssProcessor.extractVariablesFromPartialTheme(n,i);this.cssProcessor.updateCSSVariablesInStylesheet(o,t)}}getStylesheetStyles(t){switch(t){case"global":return[getGlobalStyles()];case"ui":return[getDrawerStyles(),getProductLoadingStyles(),getProductListCardLoadingStyles(),getPromoCodeTickerStyles()];case"product":return[getProductStyles(),getImageCarouselStyle(),getAddressStyles(),getProductRetailersStyles(),getProductListStyles()];case"address":return[getAddressStyles()];case"cart":return[getCartStyles()];case"checkout":return[getCheckoutStyles()];default:return[]}}}class ThemeProviderService{constructor(){this.logger=LoggerFactory.get("ThemeProvider"),this.stylesheetGenerator=new StylesheetGeneratorService,this.fontManager=new FontManagerService}static getInstance(){return SingletonManager.getClassInstance("ThemeProviderService",()=>new ThemeProviderService)}async initialize(t){this.data=t,this.fontManager.loadGoogleFonts([this.data.global.theme.headingFont,this.data.global.theme.paragraphFont]),this.stylesheetGenerator.generateSpecificStylesheet("global",this.data.global.theme),this.stylesheetGenerator.generateSpecificStylesheet("ui",{}),this.stylesheetGenerator.generateSpecificStylesheet("product",this.data.product.theme),this.stylesheetGenerator.generateSpecificStylesheet("cart",this.data.cart.theme),this.stylesheetGenerator.generateSpecificStylesheet("checkout",this.data.checkout.theme),this.stylesheetGenerator.generateSpecificStylesheet("address",this.data.address.theme)}updateComponentGlobalConfigs(t){var n,i;const o=this.data.global.layout.showPoweredBy;this.data.global=this.deepMerge(this.getConfigs("global"),t),this.data.global.layout.showPoweredBy=o,((null===(n=t.theme)||void 0===n?void 0:n.headingFont)||(null===(i=t.theme)||void 0===i?void 0:i.paragraphFont))&&this.fontManager.updateGoogleFonts([this.data.global.theme.headingFont,this.data.global.theme.paragraphFont]),t.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("global",t.theme,"global")}updateProductComponent(t){this.data.product=this.deepMerge(this.getConfigs("product"),t),t.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("product",t.theme,"product")}updateAddressComponent(t){this.data.address=this.deepMerge(this.getConfigs("address"),t),t.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("address",t.theme,"address")}updateCartComponent(t){this.data.cart=this.deepMerge(this.getConfigs("cart"),t),t.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("cart",t.theme,"cart")}updateCheckoutComponent(t){this.data.checkout=this.deepMerge(this.getConfigs("checkout"),t),t.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("checkout",t.theme,"checkout")}getConfigs(t){return"all"===t?this.data:this.data[t]}getComponentConfig(t){return-1!==$.indexOf(t)?this.getConfigs("product"):-1!==J.indexOf(t)?this.getConfigs("address"):-1!==tt.indexOf(t)?this.getConfigs("cart"):-1!==et.indexOf(t)?this.getConfigs("checkout"):void 0}getStylesheet(t){const n=this.getBaseStylesheets();if(t===o.DRAWER){const t=[...n],i=this.stylesheetGenerator.getStylesheet("product"),o=this.stylesheetGenerator.getStylesheet("cart"),r=this.stylesheetGenerator.getStylesheet("checkout"),s=this.stylesheetGenerator.getStylesheet("address");return i&&t.push(i),o&&t.push(o),r&&t.push(r),s&&t.push(s),t}let i;if(J.includes(t)||t===o.ADDRESS)i="address";else if($.includes(t)||t===o.PRODUCT)i="product";else if(tt.includes(t)||t===o.CART)i="cart";else{if(!et.includes(t)&&t!==o.CHECKOUT)return this.logger.warn("No stylesheets found for component type: "+t+", returning base stylesheets only."),n;i="checkout"}const r=this.stylesheetGenerator.getStylesheet(i);return r?[...n,r]:n}getBaseStylesheets(){const t=[],n=this.stylesheetGenerator.getStylesheet("global"),i=this.stylesheetGenerator.getStylesheet("ui");return n&&t.push(n),i&&t.push(i),t}deepMerge(t,n){const i={...t};for(const o in n)null!==n[o]&&void 0!==n[o]&&("object"!=typeof n[o]||Array.isArray(n[o])||"object"!=typeof t[o]||Array.isArray(t[o])?i[o]=n[o]:i[o]=this.deepMerge(t[o],n[o]));return i}}class BaseCommand{constructor(){this.store=StoreService.getInstance(),this.api=ApiClientService.getInstance(),this.logger=LoggerFactory.get("BaseCommand"),this.pubSub=PubSubService.getInstance(),this.googleTagManager=GoogleTagManagerService.getInstance(),this.clientConfig=ClientConfigService.getInstance(),this.themeProvider=ThemeProviderService.getInstance()}getLocation(){const t=this.store.get("address");if(t.address.one&&t.coordinates.long&&t.coordinates.lat)return{coords:t.coordinates,address:t.address}}}const includeCartEvents=(t,n)=>t.filter(t=>n.includes(t.type)),excludeCartEvents=(t,n)=>t.filter(t=>!n.includes(t.type)),eventsForCart=t=>excludeCartEvents(t,["NewCart","ItemsRemoved","CartError","NoId","InvalidId","NoItemsInCart","RemovedExistingCartItems","PartnerProductConfigs","RetailerMinNotMet","AddressChange"]),hasCartAnyPromoCodeEvents=t=>{const n=["CouponProcessingError","CouponNotFound","CouponExpired","NoApplicableDiscount","CouponNotStarted","MinimumOrderValueNotMet","MinimumOrderUnitsNotMet","MinimumDistinctItemsNotMet","QuotaExceeded","UserLimitExceeded","NotFirstPurchase","InvalidCoupon","InvalidMembership","InvalidDomain","InvalidRequirements","InvalidOrganization","ProductNotEligible","NotEnoughPreviousOrders","RetailerDoesNotAllowPromos","RetailersDoNotAllowPromos"],i=includeCartEvents(t,n);return i.length>0},includeCheckoutEvents=(t,n)=>t.filter(t=>n.includes(t.type)),eventsForCheckout=t=>includeCheckoutEvents(t,["RetailerOnDemandHoursNotAvailable","ItemQuantityChange","MaxQuantityPerOrderExceeded"]),promoCodeCheckoutEvents=t=>includeCheckoutEvents(t,["RetailerDoesNotAllowPromos","RetailersDoNotAllowPromos"]),giftCardCheckoutEvents=t=>includeCheckoutEvents(t,["ErrorProcessingGiftCards","InvalidGiftCardCodes","InvalidGiftCardPartner","InactiveGiftCard","GiftCardAlreadyInUse","GiftCardExpired","GiftCardBalanceDepleted","RetailerDoesNotAllowGiftCards","RetailersDoNotAllowGiftCards"]),hasAnyRetailerGiftCardRestriction=t=>{const n=["RetailerDoesNotAllowGiftCards","RetailersDoNotAllowGiftCards"];return t.some(t=>n.includes(t.type))},lt={OutOfStock:"error",ItemsNotAdded:"warning",ItemsRequestedNotAdded:"warning",ItemEngravingError:"error",AddressChange:"warning",LocationAvailability:"warning",PartnerProductConfigs:"warning",RemovedExistingCartItems:"warning",RetailerMinNotMet:"warning",NoItemsInCart:"warning",InvalidId:"warning",NoId:"warning",CartCheckoutProcessed:"success",NewCart:"warning",CartError:"error",ItemQuantityChange:"warning",ItemIdNotFound:"error",ItemsRemoved:"warning",CouponProcessingError:"error",CouponNotFound:"error",CouponExpired:"error",NoApplicableDiscount:"warning",CouponNotStarted:"error",MinimumOrderValueNotMet:"warning",MinimumOrderUnitsNotMet:"warning",MinimumDistinctItemsNotMet:"warning",QuotaExceeded:"error",UserLimitExceeded:"error",NotFirstPurchase:"warning",InvalidCoupon:"error",InvalidMembership:"error",InvalidDomain:"error",InvalidRequirements:"error",InvalidOrganization:"error",ProductNotEligible:"warning",NotEnoughPreviousOrders:"warning",PresaleItemsNotAllowed:"error",PresaleLimitExceeded:"error",PresaleNotStarted:"error",PresaleExpired:"error",PresaleMixedCart:"error",RetailerDoesNotAllowPromos:"warning",RetailersDoNotAllowPromos:"warning"},ct={ErrorProcessingGiftCards:"error",InvalidGiftCardCodes:"error",InvalidGiftCardPartner:"error",InactiveGiftCard:"error",GiftCardAlreadyInUse:"error",GiftCardExpired:"error",GiftCardBalanceDepleted:"error",RetailerOnDemandHoursNotAvailable:"warning",ItemQuantityChange:"warning",MaxQuantityPerOrderExceeded:"warning",RetailerDoesNotAllowPromos:"warning",RetailersDoNotAllowPromos:"warning",RetailerDoesNotAllowGiftCards:"warning",RetailersDoNotAllowGiftCards:"warning"},transformCartEventsRaw=t=>t.map(t=>({type:t.type,message:t.message,level:lt[t.type]||"error"})),transformCheckoutEventsRaw=t=>t.map(t=>({type:t.type,message:t.message,level:ct[t.type]||"error"})),transformEventsForCart=t=>{const n=eventsForCart(t);return transformCartEventsRaw(n)},transformEventsForCheckout=t=>{const n=eventsForCheckout(t);return transformCheckoutEventsRaw(n)},transformPromoCodeCheckoutEvents=t=>{const n=promoCodeCheckoutEvents(t);return transformCheckoutEventsRaw(n)},transformGiftCardCheckoutEvents=t=>{const n=giftCardCheckoutEvents(t);return transformCheckoutEventsRaw(n)};function buildCartItemStore(t){return{id:t.id,variantId:t.variantId,liquidId:t.liquidId,retailerId:t.retailerId,partNumber:t.partNumber,fulfillmentId:t.fulfillmentId,upc:t.upc,sku:t.sku,salsifyGrouping:t.salsifyGrouping,catPath:t.catPath,volume:t.volume,uom:t.uom,pack:t.pack,packDesc:t.packDesc,container:t.container,containerType:t.containerType,name:t.name,brand:t.brand,size:t.size,price:t.price,quantity:t.quantity,maxQuantity:t.maxQuantity,unitPrice:t.unitPrice,mainImage:t.mainImage,attributes:t.attributes,loading:![],updating:![],error:null}}function buildCartTotals(t){return{subtotal:t.subtotal||0,total:t.total||0,shippingFee:t.shippingFee||0,platformFee:t.platformFee||0,giftCardTotal:t.giftCardTotal||0,engravingFee:t.engravingFee||0,deliveryFee:t.deliveryFee||0,discounts:t.discounts||0,quantity:t.quantity||0}}function buildRetailerStore(t){var n;return{id:t.id,name:t.name,platformFee:t.platformFee||0,shippingFee:t.shippingFee||0,subtotal:t.subtotal||0,address:t.address,total:t.total||0,deliveryFee:t.deliveryFee||0,engravingFee:t.engravingFee||0,fulfillments:(null===(n=t.fulfillments)||void 0===n?void 0:n.map(t=>t.id))||[]}}function buildFulfillmentStore(t,n){return{id:t.id,canEngrave:t.canEngrave||![],type:t.type,fees:t.fees,expectation:t.expectation,shippingFee:t.shippingFee||0,subtotal:t.subtotal||0,engravingFee:t.engravingFee||0,deliveryFee:t.deliveryFee||0,items:t.items||[],retailerId:n.id,loading:![],error:null,updating:![]}}function cartDataForEventFromStore(t,n){var i;const o=n.formattedAddress?n:{id:"",address:{one:"",two:"",city:"",state:"",zip:"",country:""},coordinates:{lat:0,long:0}},r={};for(const s in t.items||{}){const n=t.items[s];r[s]={id:n.id,variantId:n.variantId,liquidId:n.liquidId,retailerId:n.retailerId,partNumber:n.partNumber,fulfillmentId:n.fulfillmentId,upc:n.upc,sku:n.sku,salsifyGrouping:n.salsifyGrouping,catPath:n.catPath,volume:n.volume,uom:n.uom,pack:n.pack,packDesc:n.packDesc,container:n.container,containerType:n.containerType,name:n.name,brand:n.brand,size:n.size,price:n.price||0,quantity:n.quantity||0,maxQuantity:n.maxQuantity||0,unitPrice:n.unitPrice||0,mainImage:n.mainImage||"",attributes:n.attributes||{}}}return{id:t.id,promoCode:(null===(i=t.promoCode)||void 0===i?void 0:i.code)||"",items:r,location:{placesId:o.id,address:{one:o.address.one,two:o.address.two,city:o.address.city,state:o.address.state,zip:o.address.zip,country:o.address.country},coordinates:{latitude:o.coordinates.lat,longitude:o.coordinates.long}},amounts:{deliveryFee:t.totals.deliveryFee,discounts:t.totals.discounts,engravingFee:t.totals.engravingFee,giftCardTotal:0,platformFee:t.totals.platformFee,shippingFee:t.totals.shippingFee,subtotal:t.totals.subtotal,total:t.totals.total},itemCount:Object.values(r||{}).reduce((t,n)=>t+(n.quantity||0),0),updatedAt:t.updatedAt,createdAt:t.createdAt}}class CommonCommands extends BaseCommand{static getInstance(){return SingletonManager.getClassInstance("CommonCommands",()=>new CommonCommands)}syncCartFromResponse(t,i=![]){var o,r,s,a,l,c;const d=this.store.get("cart");for(const n of Object.keys(d.items||{}))this.store.remove("cart.items."+n);for(const n of Object.keys(d.retailers||{}))this.store.remove("cart.retailers."+n);for(const n of Object.keys(d.fulfillments||{}))this.store.remove("cart.fulfillments."+n);const u={"cart.id":t.id,"cart.error":null,"cart.totals":buildCartTotals(t),"cart.updatedAt":t.updatedAt||(new Date).toISOString(),"cart.createdAt":t.createdAt||(new Date).toISOString(),"cart.events":[],"cart.promoCode":(null===(r=null===(o=t.attributes)||void 0===o?void 0:o.promoCode)||void 0===r?void 0:r.value)?{code:t.attributes.promoCode.value.toUpperCase(),discountAmount:t.attributes.promoCode.discount||0,error:null}:null};if((null===(s=t.items)||void 0===s?void 0:s.length)>0)for(const n of t.items)u["cart.items."+n.id]=buildCartItemStore(n);if((null===(a=t.retailers)||void 0===a?void 0:a.length)>0)for(const n of t.retailers)if(u["cart.retailers."+n.id]=buildRetailerStore(n),(null===(l=n.fulfillments)||void 0===l?void 0:l.length)>0)for(const t of n.fulfillments)u["cart.fulfillments."+t.id]=buildFulfillmentStore(t,n);if((null===(c=t.events)||void 0===c?void 0:c.length)>0&&(u["cart.events"]=transformEventsForCart(t.events||[])),this.store.batch(u),i){const t=this.store.get("cart"),i=this.store.get("address");this.pubSub.publishAction(n.CART_LOADED,cartDataForEventFromStore(t,i))}}async loadCart(){try{this.store.set("cart.loading",!![]);const t=this.store.get("cart"),n=await this.api.getCartData(t.id);this.syncCartFromResponse(n,!![]),n.id!==t.id&&await this.store.persist()}catch(t){const i=(null==t?void 0:t.message)||"Failed to load cart";this.store.set("cart.error",i),this.pubSub.publishAction(n.CART_FAILED,{message:i}),this.logger.error("Load cart failed",t)}finally{this.store.set("cart.loading",![])}}}class UICommands extends BaseCommand{static getInstance(){return SingletonManager.getClassInstance("UICommands",()=>new UICommands)}openDrawer(t,i){const r={type:t,data:i||{}};this.store.set("ui.drawer",{isOpen:!![],contentConfig:r}),t===o.CART&&this.pubSub.publishAction(n.CART_OPENED,!![]),t===o.CHECKOUT&&this.pubSub.publishAction(n.CHECKOUT_OPENED,!![])}closeDrawer(){this.store.set("ui.drawer.isOpen",![]);const t=this.store.get("ui.drawer.contentConfig");(null==t?void 0:t.type)===o.CART&&this.pubSub.publishAction(n.CART_CLOSED,!![]),(null==t?void 0:t.type)===o.CHECKOUT&&this.pubSub.publishAction(n.CHECKOUT_CLOSED,!![])}}class CheckoutCommands extends BaseCommand{constructor(){super(),this.uiCommands=UICommands.getInstance(),this.commonCommands=CommonCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("CheckoutCommands",()=>new CheckoutCommands)}async loadCheckout(t){var i,o,s,a,l,c,d,u,h,p,m,f;try{this.store.set("checkout.loading",!![]);const b=t||this.store.get("cart.id"),w=this.store.get("cart");if(0===(null===(i=Object.values(w.items||{}))||void 0===i?void 0:i.length)&&!t)return;const C=this.themeProvider.getConfigs("checkout"),k={canEmail:C.layout.emailOptIn.checked,canSms:C.layout.smsOptIn.checked};if(!b)return this.store.set("checkout.error","Cart ID is not provided"),void 0;const S={"checkout.error":null,"checkout.onDemandFulfillmentTipInfo":{},"checkout.giftCardError":null,"checkout.promoCodeError":null,"checkout.presale":null,"checkout.updating":![]},E=await this.api.prepareCheckout({cartId:b,marketingPreferences:k});if((null===(o=E.retailers)||void 0===o?void 0:o.length)>0)for(const t of E.retailers)for(const n of t.fulfillments)n.type===r.ON_DEMAND&&(S["checkout.onDemandFulfillmentTipInfo."+n.id]={retailerId:t.id,retailerName:t.name,fulfillmentId:n.id,tip:n.tip,subtotal:n.subtotal});if((null===(s=E.items)||void 0===s?void 0:s.length)>0){this.store.remove("checkout.items");for(const t of E.items){const n=E.retailers.find(n=>n.id===t.retailerId),i=n.fulfillments.find(n=>n.id===t.fulfillmentId);S["checkout.items."+t.cartItemId]=this.buildCheckoutItemStore(t,n,i)}}E.isPresaleLocked&&E.presaleExpiresAt&&(S["checkout.presale"]={isLocked:E.isPresaleLocked,expiresAt:E.presaleExpiresAt}),S["checkout.token"]=E.token,S["checkout.cartId"]=E.cartId,S["checkout.isGift"]=E.isGift,S["checkout.giftRecipientForm.data"]={firstName:((null===(l=null===(a=E.giftOptions)||void 0===a?void 0:a.recipient)||void 0===l?void 0:l.name)||"").split(" ")[0],lastName:((null===(d=null===(c=E.giftOptions)||void 0===c?void 0:c.recipient)||void 0===d?void 0:d.name)||"").split(" ")[1],email:(null===(h=null===(u=E.giftOptions)||void 0===u?void 0:u.recipient)||void 0===h?void 0:h.email)||"",phone:(null===(m=null===(p=E.giftOptions)||void 0===p?void 0:p.recipient)||void 0===m?void 0:m.phone)||"",message:(null===(f=E.giftOptions)||void 0===f?void 0:f.message)||""},S["checkout.paymentForm.billingSameAsShipping"]=E.billingSameAsShipping,S["checkout.marketingPreferences"]=E.marketingPreferences,S["checkout.giftCards"]=E.giftCards.map(t=>({code:t.code,discountAmount:t.applied})),S["checkout.promoCode"]=E.promoCode.value?{code:E.promoCode.value,discountAmount:E.promoCode.discount}:null,S["checkout.amounts"]=E.amounts,S["checkout.events"]=E.events||[],this.store.batch(S),this.pubSub.publishAction(n.CHECKOUT_LOADED,{cartId:E.cartId})}catch(b){this.store.set("checkout.error",b.message),this.pubSub.publishAction(n.CHECKOUT_FAILED,{message:b.message})}finally{this.store.set("checkout.loading",![])}}async toggleIsGift(t){const i=this.store.get("checkout.isGift"),o=null!=t?t:!i,r={firstName:"",lastName:"",email:"",phone:"",message:""};this.store.batch({"checkout.isGift":o,"checkout.customerForm.isEditing":!![],"checkout.giftRecipientForm.isEditing":!![],"checkout.giftRecipientForm.isValid":![],"checkout.giftRecipientForm.data":r}),this.pubSub.publishAction(n.CHECKOUT_IS_GIFT_TOGGLED,{isActive:o})}async toggleBillingSameAsShipping(t){const i=this.store.get("checkout.paymentForm.billingSameAsShipping"),o=null!=t?t:!i;this.store.set("checkout.paymentForm.billingSameAsShipping",o),this.pubSub.publishAction(n.CHECKOUT_BILLING_SAME_AS_SHIPPING_TOGGLED,{isActive:o})}async toggleMarketingPreferences(t,i){const o=this.store.get("checkout.marketingPreferences."+t),r=null!=i?i:!o,s=this.store.get("checkout.marketingPreferences"),a=this.dataForCheckoutPrepare({marketingPreferences:{...s,[t]:r}}),l=await this.api.prepareCheckout(a);this.store.set("checkout.marketingPreferences",l.marketingPreferences),this.pubSub.publishAction(n.CHECKOUT_MARKETING_PREFERENCES_TOGGLED,{fieldName:t,isActive:r})}async getPaymentSession(){try{const t=this.store.get("cart.id"),n=await this.api.getPaymentSession({cartId:t});this.store.batch({"checkout.paymentForm.paymentSession":{key:n.key,secret:n.secret},"checkout.paymentForm.paymentMethod":null})}catch(t){throw this.store.batch({"checkout.error":t.message,"checkout.loading":![]}),t}}async confirmPaymentSession(t,n){var i,o,r,s;try{if(this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId"))return{id:this.clientConfig.get("paymentMethodId"),card:{brand:"visa",last4:"1111",expMonth:"03",expYear:"2035"}};const a=await this.api.confirmPaymentSession(t,n);return a&&a.id&&a.card&&a.card.brand&&a.card.last4&&a.card.expMonth&&a.card.expYear?{id:a.id,card:{brand:null===(i=a.card)||void 0===i?void 0:i.brand,last4:null===(o=a.card)||void 0===o?void 0:o.last4.toString(),expMonth:null===(r=a.card)||void 0===r?void 0:r.expMonth.toString(),expYear:null===(s=a.card)||void 0===s?void 0:s.expYear.toString()}}:(this.store.set("checkout.error","Invalid payment method information received."),null)}catch(a){return this.store.set("checkout.error","Failed to confirm payment method. Please try again."),null}}async applyPromoCode(t){var i;try{this.googleTagManager.promoCodeAttempt(t);const o=this.dataForCheckoutPrepare({}),r=await this.api.prepareCheckout({...o,promoCode:t}),s=0!==r.amounts.discounts,a=null===(i=transformPromoCodeCheckoutEvents(r.events||[]))||void 0===i?void 0:i[0];if(!s)return this.store.set("checkout.promoCodeError",a?a.message:'Code "'+t+'" does not exist'),this.pubSub.publishAction(n.CHECKOUT_PROMO_CODE_FAILED,{error:(null==a?void 0:a.message)||'Code "'+t+'" does not exist'}),this.googleTagManager.promoCodeFailed(t,(null==a?void 0:a.message)||"not_applied"),void 0;this.pubSub.publishAction(n.CHECKOUT_PROMO_CODE_APPLIED,{discountAmount:r.amounts.discounts,newTotal:r.amounts.total}),this.googleTagManager.promoCodeApplied(t,r.amounts.discounts),await this.partialLoadCheckout({response:r})}catch(o){const i=(null==o?void 0:o.message)||"Failed to apply promo code. Please try again.";throw this.store.set("checkout.error",i),this.pubSub.publishAction(n.CHECKOUT_PROMO_CODE_FAILED,{error:i}),this.googleTagManager.promoCodeFailed(t,i),o}}async removePromoCode(){var t,i;try{const o=this.dataForCheckoutPrepare({}),r=(null===(i=null===(t=this.store.get("checkout"))||void 0===t?void 0:t.promoCode)||void 0===i?void 0:i.code)||"",s=await this.api.prepareCheckout({...o,promoCode:""});if(0!==s.amounts.discounts)return this.store.set("checkout.promoCodeError","Failed to remove promo code"),void 0;this.pubSub.publishAction(n.CHECKOUT_PROMO_CODE_REMOVED,{newTotal:s.amounts.total}),this.googleTagManager.promoCodeApplied(r,0),await this.partialLoadCheckout({response:s})}catch(o){const t=(null==o?void 0:o.message)||"Failed to remove promo code. Please try again.";this.store.set("checkout.error",t);const i=this.store.get("checkout.promoCode.code")||"";throw this.pubSub.publishAction(n.CHECKOUT_PROMO_CODE_FAILED,{error:t}),i&&this.googleTagManager.promoCodeFailed(i,t),o}}async clearPromoCodeError(){try{this.store.set("checkout.promoCodeError",null)}catch(X){const n=X.message||"Failed to clear promo code error. Please try again.";throw this.store.set("checkout.error",n),X}}async applyGiftCard(t){var i;const o=t.trim().toUpperCase();try{this.googleTagManager.giftCardAttempt(o);const t=this.dataForCheckoutPrepare({}),r=t.giftCards||[],s=await this.api.prepareCheckout({...t,giftCards:[...r,o]}),a=null===(i=transformGiftCardCheckoutEvents(s.events||[]))||void 0===i?void 0:i[0],l=hasAnyRetailerGiftCardRestriction(s.events||[]);if(a&&(this.store.set("checkout.giftCardError",a.message),!l))return;const c=s.giftCards.find(t=>t.code.toLowerCase()===o.toLowerCase());if(!c)return this.store.set("checkout.giftCardError","Gift card could not be applied"),this.pubSub.publishAction(n.CHECKOUT_GIFT_CARD_FAILED,{error:(null==a?void 0:a.message)||"Gift card could not be applied"}),this.googleTagManager.giftCardFailed(o,(null==a?void 0:a.message)||"not_applied"),void 0;this.pubSub.publishAction(n.CHECKOUT_GIFT_CARD_APPLIED,{newTotal:s.amounts.total}),this.googleTagManager.giftCardApplied(o,c.applied),await this.partialLoadCheckout({response:s})}catch(r){const t=(null==r?void 0:r.message)||"Failed to apply gift card. Please try again.";throw this.store.set("checkout.error",t),this.pubSub.publishAction(n.CHECKOUT_GIFT_CARD_FAILED,{error:t}),this.googleTagManager.giftCardFailed(o,t),r}}async removeGiftCard(t){var i;const o=t.trim().toUpperCase();try{const t=this.dataForCheckoutPrepare({}),r=(null===(i=t.giftCards)||void 0===i?void 0:i.filter(t=>t.toLowerCase()!==o.toLowerCase()))||[],s=await this.api.prepareCheckout({...t,giftCards:r}),a=s.giftCards.find(t=>t.code.toLowerCase()===o.toLowerCase());if(a)return this.store.set("checkout.giftCardError","Failed to remove gift card: "+o),void 0;this.pubSub.publishAction(n.CHECKOUT_GIFT_CARD_REMOVED,{newTotal:s.amounts.total}),this.googleTagManager.giftCardApplied(o,0),await this.partialLoadCheckout({response:s})}catch(r){const t=(null==r?void 0:r.message)||"Failed to remove gift card. Please try again.";throw this.store.set("checkout.error",t),this.pubSub.publishAction(n.CHECKOUT_GIFT_CARD_FAILED,{error:t}),this.googleTagManager.giftCardFailed(o,t),r}}async clearGiftCardError(){try{this.store.set("checkout.giftCardError",null)}catch(X){throw this.store.set("checkout.error",(null==X?void 0:X.message)||"Failed to clear gift card error. Please try again."),X}}openPresaleExpiredDrawer(){this.uiCommands.openDrawer(o.CHECKOUT_PRESALE_EXPIRED)}rerenderCheckout(){this.store.set("checkout.rerender",!![])}async updateCheckoutItemQuantity(t,i){var o,r,s;try{this.store.set("checkout.items."+t+".updating",!![]);const a=this.store.get("checkout.cartId"),l=this.store.get("checkout.items."+t);if(!l)throw new SDKError("Item not found");const c=l.quantity,d=l.quantity+i;if(d<1)return this.removeItem(t,!![]);const u={id:l.cartItemId,fulfillmentId:l.fulfillmentId,partNumber:l.partNumber,quantity:d},h=(null===(s=null===(r=null===(o=l.attributes)||void 0===o?void 0:o.engraving)||void 0===r?void 0:r.lines)||void 0===s?void 0:s.filter(t=>""!==t.trim()))||[];h.length>0&&(u.engravingLines=h);const p=await this.api.updateCart({id:a,items:[u],loc:this.getLocation()});this.pubSub.publishAction(i>0?n.CHECKOUT_ITEM_QUANTITY_INCREASE:n.CHECKOUT_ITEM_QUANTITY_DECREASE,{cartItemId:l.cartItemId,quantity:d,previousQuantity:c});const m=splitCategoryPath(l.catPath),f={item_id:l.liquidId,item_name:l.name,item_brand:l.brand,item_size:l.size,item_category:m.category,item_category2:m.category2,item_category3:m.category3,quantity:Math.abs(i),price:centToDollar(l.unitPrice||0),upc:l.upc,grouping_id:l.salsifyGrouping,product_id:l.liquidId};i<0?this.googleTagManager.removeFromCart(f):i>0&&this.googleTagManager.addToCart(f),await this.partialLoadCheckout({cartResponse:p})}catch(a){throw this.store.set("checkout.items."+t+".error",a.message),a}finally{this.store.set("checkout.items."+t+".updating",![])}}async removeItemEngraving(t){var i,o,r;try{const s=this.store.get("checkout.items."+t);if(!s)throw new SDKError("Item not found in checkout");if(!(null===(i=s.attributes)||void 0===i?void 0:i.engraving))return this.logger.warn("No engraving found for checkout item",{productItemId:t}),void 0;const a=(null===(r=null===(o=s.attributes)||void 0===o?void 0:o.engraving)||void 0===r?void 0:r.lines)||[],l={id:s.cartItemId,fulfillmentId:s.fulfillmentId,partNumber:s.partNumber,quantity:s.quantity,engravingLines:[]},c=this.store.get("checkout.cartId"),d=await this.api.updateCart({id:c,items:[l],loc:this.getLocation()});this.pubSub.publishAction(n.CHECKOUT_ITEM_ENGRAVING_UPDATED,{cartItemId:s.cartItemId,engravingLines:[],previousEngravingLines:a}),await this.partialLoadCheckout({cartResponse:d})}catch(s){throw this.store.set("checkout.items."+t+".error",s.message),this.logger.error("Failed to remove engraving from checkout item",{productItemId:t,error:s.message}),s}}async removeItem(t,i){var o,r,s;try{if(this.clientConfig.isBuilder())return this.logger.warn("Remove item is not available in builder mode"),void 0;i||this.store.set("checkout.items."+t+".updating",!![]);const a=this.store.get("checkout.cartId"),l=this.store.get("checkout.items."+t);if(!l)throw new SDKError("Item not found");const c={id:l.cartItemId,fulfillmentId:l.fulfillmentId,partNumber:l.partNumber,quantity:0},d=(null===(s=null===(r=null===(o=l.attributes)||void 0===o?void 0:o.engraving)||void 0===r?void 0:r.lines)||void 0===s?void 0:s.filter(t=>""!==t.trim()))||[];d.length>0&&(c.engravingLines=d);const u=await this.api.updateCart({id:a,items:[c],loc:this.getLocation()});this.store.remove("checkout.items."+t),this.pubSub.publishAction(n.CHECKOUT_ITEM_REMOVED,{cartItemId:l.cartItemId}),await this.partialLoadCheckout({cartResponse:u})}catch(a){throw this.store.set("checkout.items."+t+".error",a.message),a}}async updateTips(t){try{this.store.set("checkout.updating",!![]),this.store.set("checkout.tipSelection",t);const i=this.store.get("checkout.onDemandFulfillmentTipInfo"),o=Object.values(i||{}).map(n=>{const i=Math.round(n.subtotal*t/100);return{fulfillmentId:n.fulfillmentId,tip:i}}),r=await this.api.prepareCheckout(this.dataForCheckoutPrepare({deliveryTips:o}));this.updateStoreFromCheckoutResponse(r),this.pubSub.publishAction(n.CHECKOUT_TIP_UPDATED,{deliveryTips:o})}catch(i){throw this.store.set("checkout.error",(null==i?void 0:i.message)||"Failed to update tips. Please try again."),i}finally{this.store.set("checkout.updating",![])}}async updateFulfillmentTip(t,i){try{this.store.set("checkout.updating",!![]);const o=this.store.get("checkout.onDemandFulfillmentTipInfo"),r=Object.values(o||{}).map(n=>({fulfillmentId:n.fulfillmentId,tip:n.fulfillmentId===t?i:n.tip})),s=await this.api.prepareCheckout(this.dataForCheckoutPrepare({deliveryTips:r}));this.updateStoreFromCheckoutResponse(s),this.pubSub.publishAction(n.CHECKOUT_TIP_UPDATED,{deliveryTips:r})}catch(o){throw this.store.set("checkout.error",(null==o?void 0:o.message)||"Failed to update fulfillment tip. Please try again."),o}finally{this.store.set("checkout.updating",![])}}async removeFulfillmentTip(t){try{this.store.set("checkout.updating",!![]);const i=this.store.get("checkout.onDemandFulfillmentTipInfo"),o=Object.values(i||{}).map(n=>({fulfillmentId:n.fulfillmentId,tip:n.fulfillmentId===t?0:n.tip})),r=await this.api.prepareCheckout(this.dataForCheckoutPrepare({deliveryTips:o}));this.updateStoreFromCheckoutResponse(r),this.pubSub.publishAction(n.CHECKOUT_TIP_UPDATED,{deliveryTips:o})}catch(i){throw this.store.set("checkout.error",(null==i?void 0:i.message)||"Failed to remove fulfillment tip. Please try again."),i}finally{this.store.set("checkout.updating",![])}}async clearCheckoutError(){this.store.set("checkout.error",null)}async editCustomerForm(){this.store.set("checkout.customerForm.isEditing",!![])}async saveCustomerForm({shippingAddressTwo:t,deliveryInstructions:i,customerData:o}){var r,s,a,l,c,d,u,h,p;try{this.store.set("checkout.customerForm.isSaving",!![]);const m=this.store.get("checkout.customerForm.data"),f=this.store.get("checkout.isGift"),b=this.dataForCheckoutPrepare({shippingAddressTwo:t,deliveryInstructions:i||void 0,customer:{...m,...o},isGift:f}),w=await this.api.prepareCheckout(b),C={id:(null===(r=w.customer)||void 0===r?void 0:r.id)||"",firstName:(null===(s=w.customer)||void 0===s?void 0:s.firstName)||"",lastName:(null===(a=w.customer)||void 0===a?void 0:a.lastName)||"",email:(null===(l=w.customer)||void 0===l?void 0:l.email)||"",phone:(null===(c=w.customer)||void 0===c?void 0:c.phone)||"",birthDate:(null===(u=null===(d=w.customer)||void 0===d?void 0:d.birthDate)||void 0===u?void 0:u.slice(0,10))||"",company:(null===(h=w.customer)||void 0===h?void 0:h.company)||""};this.store.batch({"checkout.customerForm.data":C,"checkout.customerForm.isEditing":![],"checkout.customerForm.isValid":!![],"checkout.shippingAddressTwo":w.shippingAddress.two,"checkout.deliveryInstructions":i}),this.pubSub.publishAction(n.CHECKOUT_CUSTOMER_INFORMATION_UPDATED,!![]);const k=this.store.get("checkout");this.googleTagManager.addShippingInfo([...Object.values(k.items||{}).map(t=>{const n=splitCategoryPath(t.catPath);return{item_id:t.liquidId,item_name:t.name,item_brand:t.brand,item_size:t.size,item_category:n.category,item_category2:n.category2,item_category3:n.category3,quantity:t.quantity,price:centToDollar(t.unitPrice||0),upc:t.upc,grouping_id:t.salsifyGrouping,product_id:t.liquidId}})],(null===(p=k.promoCode)||void 0===p?void 0:p.code)||void 0)}finally{this.store.set("checkout.customerForm.isSaving",![])}}async editGiftRecipientForm(){this.store.set("checkout.giftRecipientForm.isEditing",!![])}async saveGiftRecipientForm({shippingAddressTwo:t,deliveryInstructions:i,...o}){var r,s,a,l,c,d;try{this.store.set("checkout.giftRecipientForm.isSaving",!![]);const u=this.dataForCheckoutPrepare({shippingAddressTwo:t,deliveryInstructions:i||void 0,isGift:!![],giftRecipient:o}),h=await this.api.prepareCheckout(u),p={firstName:(null==o?void 0:o.firstName)||"",lastName:(null==o?void 0:o.lastName)||"",email:(null===(s=null===(r=h.giftOptions)||void 0===r?void 0:r.recipient)||void 0===s?void 0:s.email)||"",phone:(null===(l=null===(a=h.giftOptions)||void 0===a?void 0:a.recipient)||void 0===l?void 0:l.phone)||"",message:(null===(c=h.giftOptions)||void 0===c?void 0:c.message)||""};this.store.batch({"checkout.giftRecipientForm.data":p,"checkout.giftRecipientForm.isEditing":![],"checkout.giftRecipientForm.isValid":!![],"checkout.shippingAddressTwo":h.shippingAddress.two,"checkout.deliveryInstructions":i}),this.pubSub.publishAction(n.CHECKOUT_GIFT_INFORMATION_UPDATED,!![]);const m=this.store.get("checkout");this.googleTagManager.addShippingInfo([...Object.values(m.items||{}).map(t=>{const n=splitCategoryPath(t.catPath);return{item_id:t.liquidId,item_name:t.name,item_brand:t.brand,item_size:t.size,item_category:n.category,item_category2:n.category2,item_category3:n.category3,quantity:t.quantity,price:centToDollar(t.unitPrice||0),upc:t.upc,grouping_id:t.salsifyGrouping,product_id:t.liquidId}})],(null===(d=m.promoCode)||void 0===d?void 0:d.code)||void 0)}finally{this.store.set("checkout.giftRecipientForm.isSaving",![])}}async editPaymentForm(){this.store.set("checkout.paymentForm.isEditing",!![])}async savePaymentForm({billingFormData:t,paymentSession:i}){var o,r,s;try{this.store.set("checkout.paymentForm.isSaving",!![]);const a=this.store.get("checkout"),l={},c=this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId");let d=null,u=null;if(c||i){const t=await this.confirmPaymentSession((null==i?void 0:i.confirmationTokenId)||"",(null==i?void 0:i.setupIntentId)||"");if(!t)throw new Error("Failed to confirm payment method");d=t.card,u=t.id}const h=this.dataForCheckoutPrepare({billingData:t,paymentMethodId:u||void 0}),p=await this.api.prepareCheckout(h);p.payment&&d&&(l["checkout.paymentForm.paymentMethod"]={id:p.payment,card:d}),t&&p.billingAddress&&(l["checkout.paymentForm.data"]={firstName:p.billingAddress.firstName||"",lastName:p.billingAddress.lastName||"",email:p.billingAddress.email||"",phone:p.billingAddress.phone||"",company:p.billingAddress.company||"",addressOne:p.billingAddress.one||"",addressTwo:p.billingAddress.two||"",city:p.billingAddress.city||"",state:p.billingAddress.state||"",zipCode:p.billingAddress.zip||""},this.pubSub.publishAction(n.CHECKOUT_BILLING_INFORMATION_UPDATED,!![])),l["checkout.paymentForm.isEditing"]=![],l["checkout.paymentForm.isValid"]=!![],this.store.batch(l);const m=l["checkout.paymentForm.paymentMethod"]||(null===(o=a.paymentForm)||void 0===o?void 0:o.paymentMethod),f=(null===(r=null==m?void 0:m.card)||void 0===r?void 0:r.brand)?m.card.brand+" ****"+m.card.last4:"card";this.googleTagManager.addPaymentInfo(Object.values(a.items||{}).map(t=>{const n=splitCategoryPath(t.catPath);return{item_id:t.liquidId,item_name:t.name,item_brand:t.brand,item_size:t.size,item_category:n.category,item_category2:n.category2,item_category3:n.category3,quantity:t.quantity,price:centToDollar(t.unitPrice||0),upc:t.upc,grouping_id:t.salsifyGrouping,product_id:t.liquidId}}),f,(null===(s=a.promoCode)||void 0===s?void 0:s.code)||void 0)}catch(a){throw this.logger.error("Failed to save payment form",a),this.store.set("checkout.error",a.message),a}finally{this.store.set("checkout.paymentForm.isSaving",![])}}async checkoutComplete(){var t,i,r,s,a,l;try{this.store.set("checkout.loading",!![]),this.pubSub.publishAction(n.CHECKOUT_SUBMIT_STARTED,{started:!![]});const c=this.store.get("checkout"),d=await this.api.checkoutComplete({token:c.token}),u=d.legacyOrderNumber||d.referenceId||"N/A";c.presale||this.store.set("cart.shouldReset",!![]),this.uiCommands.openDrawer(o.CHECKOUT_COMPLETED,{orderNumber:u,orderTotal:c.amounts.total,cardLast4:null===(r=null===(i=null===(t=null==c?void 0:c.paymentForm)||void 0===t?void 0:t.paymentMethod)||void 0===i?void 0:i.card)||void 0===r?void 0:r.last4,customerEmail:c.customerForm.data.email,giftRecipientEmail:(null===(a=null===(s=null==c?void 0:c.giftRecipientForm)||void 0===s?void 0:s.data)||void 0===a?void 0:a.email)||null}),this.pubSub.publishAction(n.CHECKOUT_SUBMIT_COMPLETED,{orderNumber:u,orderTotal:c.amounts.total}),this.googleTagManager.purchase({transaction_id:u,tax:centToDollar(c.amounts.tax||0),shipping:centToDollar(c.amounts.shipping||0),coupon:(null===(l=c.promoCode)||void 0===l?void 0:l.code)||void 0,items:[...Object.values(c.items||{}).map(t=>{const n=splitCategoryPath(t.catPath);return{item_id:t.liquidId,item_name:t.name,item_brand:t.brand,item_size:t.size,item_category:n.category,item_category2:n.category2,item_category3:n.category3,quantity:t.quantity,price:centToDollar(t.unitPrice||0),upc:t.upc,grouping_id:t.salsifyGrouping,product_id:t.liquidId}})],value:centToDollar(c.amounts.total),subtotal:centToDollar(c.amounts.subtotal),total_before_discounts:centToDollar(c.amounts.subtotal+c.amounts.tax+c.amounts.shipping+c.amounts.delivery+c.amounts.platform+c.amounts.service),discounts:centToDollar(c.amounts.discounts),gift_cards:centToDollar(c.amounts.giftCards||0),net_total:centToDollar(c.amounts.total)})}catch(c){const t=(null==c?void 0:c.message)||"Checkout complete failed";this.store.batch({"checkout.error":t}),this.pubSub.publishAction(n.CHECKOUT_SUBMIT_FAILED,{message:t})}finally{this.store.set("checkout.loading",![])}}updateStoreFromCheckoutResponse(t){var n;const i={"checkout.amounts":t.amounts,"checkout.warning":t.warning,"checkout.events":transformEventsForCheckout(t.events||[]),"checkout.error":null};if((null===(n=t.retailers)||void 0===n?void 0:n.length)>0)for(const o of t.retailers)for(const t of o.fulfillments)t.type===r.ON_DEMAND&&(i["checkout.onDemandFulfillmentTipInfo."+t.id]={retailerId:o.id,retailerName:o.name,fulfillmentId:t.id,tip:t.tip,subtotal:t.subtotal});this.store.batch(i)}async partialLoadCheckout(t){var i,o,s,a,l;try{let n;if(this.store.set("checkout.updating",!![]),(null==t?void 0:t.cartResponse)?this.commonCommands.syncCartFromResponse(t.cartResponse):await this.commonCommands.loadCart(),null==t?void 0:t.response)n=t.response;else{const o=null!==(i=null==t?void 0:t.cartId)&&void 0!==i?i:this.store.get("checkout.cartId");if(!o)return this.store.set("checkout.error","Cart ID is not provided"),void 0;const r=this.dataForCheckoutPrepare({});n=await this.api.prepareCheckout({...r,cartId:o})}const c={"checkout.token":n.token,"checkout.events":transformEventsForCheckout(n.events||[]),"checkout.amounts":n.amounts,"checkout.error":null,"checkout.promoCodeError":null,"checkout.giftCardError":null,"checkout.giftCards":n.giftCards.map(t=>({code:t.code,discountAmount:t.applied})),"checkout.promoCode":(null===(s=null===(o=null==n?void 0:n.promoCode)||void 0===o?void 0:o.value)||void 0===s?void 0:s.trim())?{code:n.promoCode.value,discountAmount:n.promoCode.discount}:null};if((null===(a=n.retailers)||void 0===a?void 0:a.length)>0){this.store.remove("checkout.onDemandFulfillmentTipInfo");for(const t of n.retailers)for(const n of t.fulfillments)n.type===r.ON_DEMAND&&(c["checkout.onDemandFulfillmentTipInfo."+n.id]={retailerId:t.id,retailerName:t.name,fulfillmentId:n.id,tip:n.tip,subtotal:n.subtotal})}if((null===(l=n.items)||void 0===l?void 0:l.length)>0){this.store.remove("checkout.items");for(const t of n.items){const i=n.retailers.find(n=>n.id===t.retailerId),o=i.fulfillments.find(n=>n.id===t.fulfillmentId);c["checkout.items."+t.cartItemId]=this.buildCheckoutItemStore(t,i,o)}}this.store.batch(c)}catch(c){const t=(null==c?void 0:c.message)||"Failed to load checkout data. Please try again.";throw this.store.set("checkout.error",t),this.pubSub.publishAction(n.CHECKOUT_FAILED,{message:t}),c}finally{this.store.set("checkout.updating",![])}}dataForCheckoutPrepare({customer:t,giftRecipient:n,billingData:i,marketingPreferences:o,shippingAddressTwo:r,deliveryInstructions:s,deliveryTips:a,paymentMethodId:l,isGift:c}){var d,u,h,p,m,f,b,w,C,k,S,E,_,D,P,F,A,O,N,R,M,q,j,U,V,K;const Y=this.store.get("checkout"),W=null!==(u=null===(d=Y.paymentForm)||void 0===d?void 0:d.billingSameAsShipping)&&void 0!==u?u:!![],Q=void 0!==c?c:Y.isGift,Z=n?!![]:null!==(p=null===(h=Y.giftRecipientForm)||void 0===h?void 0:h.isValid)&&void 0!==p?p:![],X=Q&&Z,$={cartId:Y.cartId,acceptedAccountCreation:![],hasSubstitutionPolicy:![],hasAgeVerify:!![],shippingAddressTwo:r,billingSameAsShipping:W,marketingPreferences:o||Y.marketingPreferences,promoCode:(null===(m=Y.promoCode)||void 0===m?void 0:m.code)||void 0,isGift:X,giftCards:(null===(f=null==Y?void 0:Y.giftCards)||void 0===f?void 0:f.map(t=>t.code))||[],deliveryTips:a||Object.values(Y.onDemandFulfillmentTipInfo||{}).map(t=>({fulfillmentId:t.fulfillmentId,tip:t.tip}))};l?$.payment=l:(null===(w=null===(b=Y.paymentForm)||void 0===b?void 0:b.paymentMethod)||void 0===w?void 0:w.id)&&($.payment=Y.paymentForm.paymentMethod.id);const J=s||Y.deliveryInstructions;if(J&&($.deliveryInstructions=Object.values(Y.items||{}).map(t=>({fulfillmentId:t.fulfillmentId,instructions:J}))),$.customer=t?{...t,id:(null==t?void 0:t.id)||void 0}:(null===(k=null===(C=null==Y?void 0:Y.customerForm)||void 0===C?void 0:C.data)||void 0===k?void 0:k.email)?{id:(null===(E=null===(S=Y.customerForm)||void 0===S?void 0:S.data)||void 0===E?void 0:E.id)||void 0,firstName:null===(D=null===(_=Y.customerForm)||void 0===_?void 0:_.data)||void 0===D?void 0:D.firstName,lastName:null===(F=null===(P=Y.customerForm)||void 0===P?void 0:P.data)||void 0===F?void 0:F.lastName,email:null===(O=null===(A=Y.customerForm)||void 0===A?void 0:A.data)||void 0===O?void 0:O.email,phone:null===(R=null===(N=Y.customerForm)||void 0===N?void 0:N.data)||void 0===R?void 0:R.phone,birthDate:null===(q=null===(M=Y.customerForm)||void 0===M?void 0:M.data)||void 0===q?void 0:q.birthDate,company:null===(U=null===(j=Y.customerForm)||void 0===j?void 0:j.data)||void 0===U?void 0:U.company}:void 0,X){const t=n||(null===(V=Y.giftRecipientForm)||void 0===V?void 0:V.data);t&&($.giftOptions={recipient:{name:(t.firstName||"")+" "+(t.lastName||""),email:t.email||"",phone:t.phone||""},message:t.message||""})}if(!W)if(i)$.billingAddress={firstName:i.firstName,lastName:i.lastName,email:i.email,phone:i.phone,company:i.company,one:i.addressOne,two:i.addressTwo,city:i.city,state:i.state,zip:i.zipCode,country:"US"};else{const t=null===(K=Y.paymentForm)||void 0===K?void 0:K.data;$.billingAddress={firstName:null==t?void 0:t.firstName,lastName:null==t?void 0:t.lastName,email:null==t?void 0:t.email,phone:null==t?void 0:t.phone,company:null==t?void 0:t.company,one:null==t?void 0:t.addressOne,two:null==t?void 0:t.addressTwo,city:null==t?void 0:t.city,state:null==t?void 0:t.state,zip:null==t?void 0:t.zipCode,country:"US"}}return $}buildCheckoutItemStore(t,n,i){return{liquidId:t.liquidId,variantId:t.variantId,cartItemId:t.cartItemId,retailerId:t.retailerId,fulfillmentId:t.fulfillmentId,salsifyGrouping:t.salsifyGrouping,name:t.name,catPath:t.catPath,volume:t.volume,uom:t.uom,proof:t.proof,abv:t.abv,containerType:t.containerType,container:t.container,size:t.size,pack:t.pack,packDesc:t.packDesc,mainImage:t.mainImage,brand:t.brand,partNumber:t.partNumber,upc:t.upc,sku:t.sku,price:t.price,unitPrice:t.unitPrice,quantity:t.quantity,unitTax:t.unitTax,bottleDeposits:t.bottleDeposits,attributes:t.attributes,retailerName:n.name,expectationDetail:i.expectation.detail,loading:![],updating:![],error:null}}}class CartCommands extends BaseCommand{constructor(){super(),this.uiCommands=UICommands.getInstance(),this.checkoutCommands=CheckoutCommands.getInstance(),this.commonCommands=CommonCommands.getInstance(),this.store.watch("cart.shouldReset",async t=>{t===!![]&&await this.resetCart()})}static getInstance(){return SingletonManager.getClassInstance("CartCommands",()=>new CartCommands)}async updateItemQuantity(t,i){try{this.store.set("cart.items."+t+".updating",!![]);const o=this.store.get("cart.id"),r=this.store.get("cart.items."+t);if(!r)throw this.logger.error("Cart item not found: "+t+" - cannot update quantity by "+i),new SDKError("Item not found");const s=r.quantity+i;if(s<1)return this.removeItem(t,!![]);const a=this.buildItemUpdate(r,s),l=await this.api.updateCart({id:o,items:[a],loc:this.getLocation()});this.syncItemsFromApiResponse(l,[t]),this.updateFulfillment(r.fulfillmentId,l),this.syncRetailersFromApiResponse(l),this.syncCartMetaFromApiResponse(l),this.pubSub.publishAction(i<0?n.CART_ITEM_QUANTITY_DECREASE:n.CART_ITEM_QUANTITY_INCREASE,{id:r.id,quantity:s,previousQuantity:r.quantity});const c=splitCategoryPath(r.catPath),d={item_id:r.liquidId,item_name:r.name,item_brand:r.brand,item_size:r.size,item_category:c.category,item_category2:c.category2,item_category3:c.category3,quantity:Math.abs(i),price:centToDollar(r.unitPrice||0),upc:r.upc,grouping_id:r.salsifyGrouping,product_id:r.liquidId};i<0?this.googleTagManager.removeFromCart(d):i>0&&this.googleTagManager.addToCart(d)}catch(o){throw this.store.set("cart.items."+t+".error",o.message),this.logger.error("Failed to update item quantity",o),o}finally{this.store.set("cart.items."+t+".updating",![])}}async removeItem(t,i){try{if(this.clientConfig.isBuilder())return this.logger.warn("Remove item is not available in builder mode"),void 0;i||this.store.set("cart.items."+t+".updating",!![]);const o=this.store.get("cart.id"),r=this.store.get("cart.items."+t);if(!r)throw new SDKError("Item not found");const s={itemId:r.id,fulfillmentId:r.fulfillmentId,retailerId:r.retailerId},a=this.buildItemUpdate(r,0),l=await this.api.updateCart({id:o,items:[a],loc:this.getLocation()});this.syncItemsFromApiResponse(l,[]),this.cleanupAfterItemRemoval(s,l),this.syncCartMetaFromApiResponse(l),this.pubSub.publishAction(n.CART_ITEM_REMOVED,{id:r.id});const c=splitCategoryPath(r.catPath);this.googleTagManager.removeFromCart({item_id:r.liquidId,item_name:r.name,item_brand:r.brand,item_size:r.size,item_category:c.category,item_category2:c.category2,item_category3:c.category3,quantity:r.quantity,price:centToDollar(r.unitPrice||0),upc:r.upc,grouping_id:r.salsifyGrouping,product_id:r.liquidId})}catch(o){throw this.store.set("cart.items."+t+".error",o.message),this.logger.error("Failed to remove item",o),o}}async updateItemEngraving(t,i){var o,r,s;try{const a=this.store.get("cart"),l=null===(o=a.items)||void 0===o?void 0:o[t];if(!l)throw new SDKError("Item not found");this.store.set("cart.items."+t+".updating",!![]);const c={id:l.id,fulfillmentId:l.fulfillmentId,partNumber:l.partNumber,quantity:l.quantity,engravingLines:i},d=await this.api.updateCart({id:a.id||"",items:[c],loc:this.getLocation()});this.syncItemsFromApiResponse(d,[t]),this.syncRetailersFromApiResponse(d),this.syncCartMetaFromApiResponse(d);const u=this.store.get("cart"),h=this.store.get("address");this.pubSub.publishAction(n.CART_UPDATED,{previous:cartDataForEventFromStore(a,h),current:cartDataForEventFromStore(u,h)}),this.pubSub.publishAction(n.CART_ITEM_ENGRAVING_UPDATED,{id:l.id,engravingLines:i,previousEngravingLines:(null===(s=null===(r=l.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.lines)||[]})}catch(a){throw this.store.set("cart.items."+t+".error",a.message),this.logger.error("Failed to update item engraving",a),a}finally{this.store.set("cart.items."+t+".updating",![])}}async addItem(t){var i,o;try{this.store.set("cart.loading",!![]);const r=this.store.get("cart"),s={...r},a=(null===(i=t.engravingLines)||void 0===i?void 0:i.filter(t=>""!==t.trim()))||[],l=a.length>0,c=Object.values(r.items||{}).find(n=>{var i,o,r,s,c;const d=n.fulfillmentId===t.fulfillmentId&&n.partNumber===t.partNumber;if(!d)return![];if(l){const t=(null===(o=null===(i=n.attributes)||void 0===i?void 0:i.engraving)||void 0===o?void 0:o.lines)||[];return a.join(",")===t.join(",")}return!(null===(c=null===(s=null===(r=n.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.lines)||void 0===c?void 0:c.length)}),d={upc:t.upc,fulfillmentId:t.fulfillmentId,partNumber:t.partNumber,quantity:c?t.quantity+c.quantity:t.quantity};l&&(d.engravingLines=a);const u=await this.api.updateCart({id:r.id||"",items:[d],loc:this.getLocation()}),h=null===(o=u.items)||void 0===o?void 0:o.find(t=>t.fulfillmentId===d.fulfillmentId&&t.partNumber===d.partNumber&&t.upc===d.upc);if(!h)throw new SDKError("Added item not found in cart response");this.syncItemsFromApiResponse(u,[]);const p=this.store.get("cart.fulfillments."+t.fulfillmentId);p?this.updateFulfillment(t.fulfillmentId,u):this.addNewFulfillmentAndRetailer(t.fulfillmentId,u),this.syncRetailersFromApiResponse(u),this.syncCartMetaFromApiResponse(u);const m=this.store.get("cart"),f=this.store.get("address");this.pubSub.publishAction(n.PRODUCT_ADD_TO_CART,{...t}),this.pubSub.publishAction(n.CART_ITEM_ADDED,{id:h.id,upc:t.upc,fulfillmentId:t.fulfillmentId,partNumber:t.partNumber,quantity:t.quantity,engravingLines:t.engravingLines}),this.pubSub.publishAction(n.CART_UPDATED,{previous:cartDataForEventFromStore(s,f),current:cartDataForEventFromStore(m,f)});const b=splitCategoryPath(h.catPath);this.googleTagManager.addToCart({item_id:h.liquidId,item_name:h.name,item_brand:h.brand,item_size:h.size,item_category:b.category,item_category2:b.category2,item_category3:b.category3,item_type:h.type,item_subtype:h.subType,quantity:h.quantity,price:centToDollar(h.unitPrice||0),upc:h.upc,grouping_id:h.salsifyGrouping,product_id:h.liquidId})}catch(r){this.store.set("cart.error",r.message),this.logger.error("Failed to add item to cart",r)}finally{this.store.set("cart.loading",![])}}async addPresaleItem(t){var n;try{const i={upc:t.upc,fulfillmentId:t.fulfillmentId,partNumber:t.partNumber,quantity:t.quantity};(null==t?void 0:t.engravingLines)&&(null===(n=null==t?void 0:t.engravingLines)||void 0===n?void 0:n.length)>0&&(i.engravingLines=t.engravingLines);const o=await this.api.updateCart({id:"",items:[i],loc:this.getLocation()});await this.checkoutCommands.loadCheckout(o.id)}catch(i){throw this.store.set("cart.error",i.message),this.logger.error("Failed to add presale item to cart",i),i}}async handleGoToCheckout(){var t;try{this.store.set("cart.loading",!![]),await this.checkoutCommands.loadCheckout(),this.uiCommands.openDrawer(o.CHECKOUT);const n=this.store.get("cart"),i=(null===(t=n.promoCode)||void 0===t?void 0:t.code)||void 0;this.googleTagManager.beginCheckout([...Object.values(n.items||{}).map(t=>{const n=splitCategoryPath(t.catPath);return{item_id:t.liquidId,item_name:t.name,item_brand:t.brand,item_size:t.size,item_category:n.category,item_category2:n.category2,item_category3:n.category3,quantity:t.quantity,price:centToDollar(t.unitPrice||0),upc:t.upc,grouping_id:t.salsifyGrouping,product_id:t.liquidId}})],i)}catch(n){throw this.store.set("cart.error",n.message),this.logger.error("Failed to proceed to checkout",n),n}finally{this.store.set("cart.loading",![])}}async applyPromoCode(t){var i,o,r;if(!(null==t?void 0:t.trim()))throw new SDKError("Promo code is required");const s=t.trim().toUpperCase();try{const t=this.store.get("cart.id");this.googleTagManager.promoCodeAttempt(s);const a=await this.api.updateCart({id:t,items:[],promoCode:s,loc:this.getLocation()});this.store.set("cart.totals",buildCartTotals(a)),this.store.set("cart.events",transformEventsForCart(a.events||[]));const l=(null===(r=null===(o=null===(i=a.attributes)||void 0===i?void 0:i.promoCode)||void 0===o?void 0:o.value)||void 0===r?void 0:r.toLowerCase())===s.toLowerCase();l?(this.store.set("cart.promoCode",{code:s,discountAmount:a.discounts||0}),this.pubSub.publishAction(n.CART_PROMO_CODE_APPLIED,{discountAmount:a.discounts||0,newTotal:a.total||0}),this.googleTagManager.promoCodeApplied(s,a.discounts||0)):(this.store.set("cart.promoCode",null),this.pubSub.publishAction(n.CART_PROMO_CODE_FAILED,{error:'Code "'+s+'" does not exist'}),this.googleTagManager.promoCodeFailed(s,'Code "'+s+'" does not exist'))}catch(a){const t=(null==a?void 0:a.message)||"Failed to apply promo code. Please try again.";throw this.store.set("cart.error",t),this.pubSub.publishAction(n.CART_PROMO_CODE_FAILED,{error:t}),this.googleTagManager.promoCodeFailed(s,t),this.logger.error("Failed to apply promo code",a),a}}async removePromoCode(){try{const t=this.store.get("cart.id"),i=await this.api.updateCart({id:t,items:[],promoCode:"",loc:this.getLocation()});this.store.batch({"cart.totals":buildCartTotals(i),"cart.promoCode":null}),this.pubSub.publishAction(n.CART_PROMO_CODE_REMOVED,{newTotal:i.total||0}),this.googleTagManager.promoCodeApplied("",0)}catch(t){const i=(null==t?void 0:t.message)||"Failed to remove promo code. Please try again.";this.store.set("cart.error",i);const o=this.store.get("cart.promoCode");throw this.pubSub.publishAction(n.CART_PROMO_CODE_FAILED,{error:i}),(null==o?void 0:o.code)&&this.googleTagManager.promoCodeFailed(o.code,i),this.logger.error("Failed to remove promo code",t),t}}rerenderCart(){this.store.set("cart.rerender",!![])}async resetCart(){this.store.set("checkout",{...m,rerender:!![]}),this.store.set("cart",{...p,rerender:!![]}),await this.commonCommands.loadCart(),this.pubSub.publishAction(n.CART_RESET,!![])}getDetails(){var t;const n=this.store.get("cart"),i=this.store.get("address"),o=i.id?i:{id:"",address:{one:"",two:"",city:"",state:"",zip:"",country:""},coordinates:{lat:0,long:0}},r={};for(const s in n.items||{}){const t=n.items[s];r[s]={id:t.id,variantId:t.variantId,liquidId:t.liquidId,salsifyGrouping:t.salsifyGrouping,retailerId:t.retailerId,partNumber:t.partNumber,fulfillmentId:t.fulfillmentId,upc:t.upc,sku:t.sku,catPath:t.catPath,volume:t.volume,uom:t.uom,pack:t.pack,packDesc:t.packDesc,container:t.container,containerType:t.containerType,name:t.name,brand:t.brand,size:t.size,price:t.price||0,quantity:t.quantity||0,maxQuantity:t.maxQuantity||0,unitPrice:t.unitPrice||0,mainImage:t.mainImage||"",attributes:t.attributes||{}}}return{id:n.id,promoCode:(null===(t=n.promoCode)||void 0===t?void 0:t.code)||"",items:r,location:{placesId:o.id,address:{one:o.address.one,two:o.address.two,city:o.address.city,state:o.address.state,zip:o.address.zip,country:o.address.country},coordinates:{latitude:o.coordinates.lat,longitude:o.coordinates.long}},amounts:{deliveryFee:n.totals.deliveryFee,discounts:n.totals.discounts,engravingFee:n.totals.engravingFee,giftCardTotal:n.totals.giftCardTotal,platformFee:n.totals.platformFee,shippingFee:n.totals.shippingFee,subtotal:n.totals.subtotal,total:n.totals.total},itemCount:Object.values(r||{}).reduce((t,n)=>t+(n.quantity||0),0),updatedAt:n.updatedAt,createdAt:n.createdAt}}buildItemUpdate(t,n){var i,o,r;const s={id:t.id,fulfillmentId:t.fulfillmentId,partNumber:t.partNumber,quantity:n},a=(null===(r=null===(o=null===(i=t.attributes)||void 0===i?void 0:i.engraving)||void 0===o?void 0:o.lines)||void 0===r?void 0:r.filter(t=>""!==t.trim()))||[];return a.length>0&&(s.engravingLines=a),s}syncItemsFromApiResponse(t,n=[]){var i;const o=this.store.get("cart.items")||{},r=new Set((null===(i=t.items)||void 0===i?void 0:i.map(t=>t.id))||[]);for(const a of Object.keys(o))r.has(a)||this.store.remove("cart.items."+a);const s={};for(const a of t.items)0!==n.length&&!n.includes(a.id)&&o[a.id]||(s["cart.items."+a.id]=buildCartItemStore(a));Object.keys(s).length>0&&this.store.batch(s)}syncCartMetaFromApiResponse(t){var n,i;const o={"cart.totals":buildCartTotals(t),"cart.error":null,"cart.updatedAt":t.updatedAt||(new Date).toISOString(),"cart.createdAt":t.createdAt||(new Date).toISOString(),"cart.events":transformEventsForCart(t.events||[])},r=null===(i=null===(n=t.attributes)||void 0===n?void 0:n.promoCode)||void 0===i?void 0:i.value;if(r)o["cart.promoCode"]={code:r.toUpperCase(),discountAmount:t.discounts||0};else{const t=this.store.get("cart.promoCode");(null==t?void 0:t.code)&&(o["cart.promoCode"]=null)}this.store.batch(o)}syncRetailersFromApiResponse(t){var n;if((null===(n=t.retailers)||void 0===n?void 0:n.length)>0){const n={};for(const i of t.retailers)n["cart.retailers."+i.id]=buildRetailerStore(i);this.store.batch(n)}}updateFulfillment(t,n){var i,o;const r=null===(i=n.retailers)||void 0===i?void 0:i.find(n=>{var i;return null===(i=n.fulfillments)||void 0===i?void 0:i.some(n=>n.id===t)}),s=null===(o=null==r?void 0:r.fulfillments)||void 0===o?void 0:o.find(n=>n.id===t);s&&r&&this.store.set("cart.fulfillments."+t,buildFulfillmentStore(s,r))}addNewFulfillmentAndRetailer(t,n){var i,o;const r=null===(i=n.retailers)||void 0===i?void 0:i.find(n=>{var i;return null===(i=n.fulfillments)||void 0===i?void 0:i.some(n=>n.id===t)}),s=null===(o=null==r?void 0:r.fulfillments)||void 0===o?void 0:o.find(n=>n.id===t);if(s&&r){const n={["cart.fulfillments."+t]:buildFulfillmentStore(s,r),["cart.retailers."+r.id]:buildRetailerStore(r)};this.store.batch(n)}}cleanupAfterItemRemoval(t,n){var i,o,r,s;const a=this.store.get("cart.fulfillments."+t.fulfillmentId),l=this.store.get("cart.retailers."+t.retailerId);if(!a||!l)return;const c=null===(i=n.retailers)||void 0===i?void 0:i.some(n=>{var i;return null===(i=n.fulfillments)||void 0===i?void 0:i.some(n=>n.id===t.fulfillmentId)}),d=null===(o=n.retailers)||void 0===o?void 0:o.some(n=>n.id===t.retailerId);if(c){this.updateFulfillment(t.fulfillmentId,n);const i=null===(s=n.retailers)||void 0===s?void 0:s.find(n=>n.id===t.retailerId);i&&this.store.set("cart.retailers."+t.retailerId,buildRetailerStore(i))}else if(this.store.remove("cart.fulfillments."+t.fulfillmentId),d){const i=null===(r=n.retailers)||void 0===r?void 0:r.find(n=>n.id===t.retailerId);i&&this.store.set("cart.retailers."+t.retailerId,buildRetailerStore(i))}else this.store.remove("cart.retailers."+t.retailerId)}}const dt=["sunday","monday","tuesday","wednesday","thursday","friday","saturday"],ut=1440;function timeToMinutes(t){const n=t.match(/^(\d{1,2}):(\d{2})$/);if(!n)throw new SDKError("Invalid time format: "+t);const i=Number.parseInt(n[1],10),o=Number.parseInt(n[2],10);if(i<0||i>47||o<0||o>59)throw new SDKError("Invalid time values: "+t);return 60*i+o}function getCurrentTimeInTimezone$1(t){var n,i,o;const r=new Date,s={timeZone:t,weekday:"long",hour:"2-digit",minute:"2-digit",hour12:![]};try{const t=new Intl.DateTimeFormat("en-US",s),a=t.formatToParts(r),l=(null===(n=a.find(t=>"weekday"===t.type))||void 0===n?void 0:n.value.toLowerCase())||"",c=(null===(i=a.find(t=>"hour"===t.type))||void 0===i?void 0:i.value)||"0",d=(null===(o=a.find(t=>"minute"===t.type))||void 0===o?void 0:o.value)||"0",u=60*Number.parseInt(c,10)+Number.parseInt(d,10);return{weekday:l,timeInMinutes:u}}catch(a){throw new SDKError("Invalid timezone: "+t)}}function format24TimeTo12(t){const n=t.match(/^(\d{1,2}):(\d{2})$/);if(!n||"object"==typeof n)return t;let i=Number.parseInt(n[1],10);const o=n[2];i>=24&&(i-=24);const r=i>=12?"PM":"AM",s=0===i?12:i>12?i-12:i;return s+":"+o+" "+r}function isWithinTimeSlot(t,n){try{const i=timeToMinutes(n.startsAt),o=timeToMinutes(n.endsAt);if(o>ut){if(t>=i||t<o-ut)return"during"}else if(o<i){if(t>=i||t<o)return"during"}else if(t>=i&&t<o)return"during";return t<i?"before":"after"}catch(i){return"after"}}function getNextOpeningTime(t,n,i=7){var o,r;const s=dt.indexOf(n);for(let l=1;l<=i;l++){const n=(s+l)%7,i=dt[n],c=t[i];if((null==c?void 0:c.active)&&c.times&&c.times.length>0)try{const t=1===l?"tomorrow":i;return"Opens "+t+" at "+format24TimeTo12(null!==(r=null===(o=null==c?void 0:c.times[0])||void 0===o?void 0:o.startsAt)&&void 0!==r?r:"")}catch(a){}}return null}function validateFulfillmentData(t){return t&&"object"==typeof t&&t.hours&&t.timezone?"string"!=typeof t.timezone?![]:!![]:![]}function getRetailerOffHours(t){var n;if(!(null==t?void 0:t.type)||(null==t?void 0:t.type)!==r.ON_DEMAND)return{message:null,isOpen:!![],isClosed:![]};if(!validateFulfillmentData(t))return{message:null,isOpen:![],isClosed:!![]};try{const{weekday:i,timeInMinutes:o}=getCurrentTimeInTimezone$1(t.timezone),r=t.hours[i];if(!(null==r?void 0:r.active)||!(null===(n=r.times)||void 0===n?void 0:n.length)){const n=getNextOpeningTime(t.hours,i);return{message:n,isOpen:![],isClosed:!![]}}for(const t of r.times){const n=isWithinTimeSlot(o,t);switch(n){case"before":return{message:"Opens at "+format24TimeTo12(t.startsAt),isOpen:![],isClosed:!![],openTime:t.startsAt,closeTime:t.endsAt};case"during":{let n=t.endsAt;const i=timeToMinutes(n);if(i>ut){const t=Math.floor(i/60)-24,o=i%60;n=t.toString().padStart(2,"0")+":"+o.toString().padStart(2,"0")}return{message:"Closes at "+format24TimeTo12(n),isOpen:!![],isClosed:![],openTime:t.startsAt,closeTime:t.endsAt}}}}const s=getNextOpeningTime(t.hours,i);return{message:s,isOpen:![],isClosed:!![]}}catch(i){return{message:null,isOpen:![],isClosed:!![]}}}class ProductCommands extends BaseCommand{constructor(){super(),this.uiCommands=UICommands.getInstance(),this.cartCommands=CartCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("ProductCommands",()=>new ProductCommands)}async createProductInstance(t,n=![]){this.store.createProductInstance(t),n&&this.store.set("products."+t+".loading",!![])}async loadMultipleProducts(t){var n;if(!Array.isArray(t)||0===t.length)return this.logger.warn("No product IDs provided for loading multiple products."),void 0;this.store.batch(t.reduce((t,n)=>(t["products."+n+".loading"]=!![],t["products."+n+".error"]=null,t),{}));const i=await this.api.getProductsData(t,this.getLocation());if(!i||!i.products||0===i.products.length)return this.logger.warn("No product data found for the provided product IDs."),this.store.batch(t.reduce((t,n)=>(t["products."+n+".loading"]=![],t["products."+n+".error"]=!![],t),{})),void 0;const o=[];for(const s of i.products){const r=s.sizes.filter(n=>t.some(t=>t===(n.upc||n.id||s.salsifyGrouping))),a=t.find(t=>r.some(n=>t===n.upc||t===n.id)||t===s.salsifyGrouping),l=a||(null===(n=null==r?void 0:r[0])||void 0===n?void 0:n.upc);await this.loadProduct(l,{products:[s],retailers:i.retailers}),o.push(l)}const r=t.filter(t=>-1===o.indexOf(t));this.store.batch(r.reduce((t,n)=>(t["products."+n+".loading"]=![],t["products."+n+".error"]="Product data not found",t),{}))}async loadProduct(t,i=null){var o,r;try{const s=this.store.get("products."+t);s.loading||this.store.set("products."+t+".loading",!![]);let a=null;if(i&&(a=i),i||(a=await this.api.getProductsData([t],this.getLocation())),!a||!(null===(o=null==a?void 0:a.products)||void 0===o?void 0:o[0]))return this.store.set("products."+t+".error","Product data not found"),void 0;const l=this.loadProductStoreUpdate(a);if(!l)return this.store.set("products."+t+".error","Failed to process product data"),void 0;this.store.set("products."+t,{...l,identifier:t}),this.pubSub.publishAction(n.PRODUCT_LOADED,this.productDataForEventFromStore(t));const c=a.products[0],d=l.sizes[l.selectedSizeId||""],u=Boolean(this.getLocation()),h=l.selectedFulfillment,p=u&&(null==h?void 0:h.price)?h.price:(null===(r=l.priceInfo)||void 0===r?void 0:r.avg)||0,m=splitCategoryPath(c.catPath);this.googleTagManager.viewItem({item_id:null==d?void 0:d.id,item_name:c.name,item_brand:c.brand,item_size:null==d?void 0:d.size,item_category:m.category,item_category2:m.category2,item_category3:m.category3,price:centToDollar(p),item_type:c.type,item_subtype:c.subType,upc:null==d?void 0:d.upc,grouping_id:c.salsifyGrouping,product_id:null==d?void 0:d.id})}catch(s){this.store.set("products."+t+".error",s.message),this.logger.error("Failed to load product data for ID "+t,s)}finally{this.store.set("products."+t+".loading",![])}}async selectSize(t,i){var o,s,a,l,c,d,u;const h=this.store.get("products."+t);let p=h.selectedFulfillmentType;const m=null===(o=h.sizes[i])||void 0===o?void 0:o.shippingFulfillments,f=null===(s=h.sizes[i])||void 0===s?void 0:s.onDemandFulfillments;let b=null,w=null;if(p!==r.SHIPPING||Object.values(m).length)if(p!==r.ON_DEMAND||Object.values(f).length){const t=p===r.SHIPPING?m:f,n=Object.values(t);b=n[0]||null,w=(null==b?void 0:b.fulfillmentId)||null}else{p=r.SHIPPING;const t=Object.values(m);b=t[0]||null,w=(null==b?void 0:b.fulfillmentId)||null}else{p=r.ON_DEMAND;const t=Object.values(f);b=t[0]||null,w=(null==b?void 0:b.fulfillmentId)||null}const C=p===r.SHIPPING?m:f,k=h.sizes[i],S=splitCategoryPath(h.catPath),E=(null==b?void 0:b.price)||(null===(a=h.priceInfo)||void 0===a?void 0:a.avg)||0;this.googleTagManager.viewItem({item_id:null==k?void 0:k.id,item_name:h.name,item_brand:h.brand,item_size:null==k?void 0:k.size,item_category:S.category,item_category2:S.category2,item_category3:S.category3,price:centToDollar(E),item_type:h.type,item_subtype:h.subType,upc:null==k?void 0:k.upc,grouping_id:h.salsifyGrouping,product_id:null==k?void 0:k.id});const _=Object.keys(m).length>0,D=Object.keys(f).length>0,P=_||D;if(!P){const t=this.store.get("address");this.googleTagManager.productSizeNoAvailability({productId:null==k?void 0:k.id,productName:h.name,productBrand:h.brand,productCategory:S.category,productCategory2:S.category2,productCategory3:S.category3,productType:h.type,productSubtype:h.subType,productPrice:(null===(l=h.priceInfo)||void 0===l?void 0:l.avg)||0,sizeId:i,sizeName:null==k?void 0:k.size,upc:null==k?void 0:k.upc,groupingId:h.salsifyGrouping,address:(null==t?void 0:t.address)?{one:t.address.one,two:t.address.two,city:t.address.city,state:t.address.state,zip:t.address.zip,country:t.address.country||""}:void 0,reason:"No fulfillments available for this size"})}this.pubSub.publishAction(n.PRODUCT_SIZE_CHANGED,{identifier:t,selectedSizeId:i,size:(null===(c=h.sizes[i])||void 0===c?void 0:c.size)||"",previousSizeId:h.selectedSizeId||"",previousSize:(null===(d=h.sizes[h.selectedSizeId])||void 0===d?void 0:d.size)||""}),this.store.batch({["products."+t+".selectedSizeId"]:i,["products."+t+".mainImage"]:(null===(u=h.sizes[i])||void 0===u?void 0:u.image)||null,["products."+t+".productHasAvailability"]:Object.keys(m).length+Object.keys(f).length>0,["products."+t+".fulfillmentHasAvailability"]:Boolean(Object.keys(C).length),["products."+t+".selectedFulfillmentType"]:p,["products."+t+".selectedFulfillment"]:b,["products."+t+".selectedFulfillmentId"]:w})}async selectFulfillment(t,i){var o,s,a;const l=this.store.get("products."+t),c=null===(o=l.sizes[l.selectedSizeId])||void 0===o?void 0:o.shippingFulfillments,d=null===(s=l.sizes[l.selectedSizeId])||void 0===s?void 0:s.onDemandFulfillments,u=l.selectedFulfillmentType===r.SHIPPING?c:d,h=u[i];this.pubSub.publishAction(n.PRODUCT_FULFILLMENT_CHANGED,{identifier:t,selectedFulfillmentId:i,selectedFulfillmentType:l.selectedFulfillmentType,previousFulfillmentId:l.selectedFulfillmentId||"",previousFulfillmentType:l.selectedFulfillmentType});const p=l.sizes[l.selectedSizeId||""],m=splitCategoryPath(l.catPath),f=(null==h?void 0:h.price)||(null===(a=l.priceInfo)||void 0===a?void 0:a.avg)||0;this.googleTagManager.viewItem({item_id:null==p?void 0:p.id,item_name:l.name,item_brand:l.brand,item_size:null==p?void 0:p.size,item_category:m.category,item_category2:m.category2,item_category3:m.category3,price:centToDollar(f),item_type:l.type,item_subtype:l.subType,upc:null==p?void 0:p.upc,grouping_id:l.salsifyGrouping,product_id:null==p?void 0:p.id}),this.store.batch({["products."+t+".selectedFulfillment"]:h,["products."+t+".selectedFulfillmentId"]:i,["products."+t+".quantity"]:1})}async updateQuantity(t,i){var o;const r=this.store.get("products."+t),s=r.quantity,a=s+i,l=1,c=(null===(o=null==r?void 0:r.selectedFulfillment)||void 0===o?void 0:o.stock)||5,d=Math.max(l,Math.min(c,a));this.pubSub.publishAction(i<0?n.PRODUCT_QUANTITY_DECREASE:n.PRODUCT_QUANTITY_INCREASE,{identifier:t,quantity:d,previousQuantity:s}),this.store.set("products."+t+".quantity",d)}async changeFulfillmentType(t,i){var o,s,a;const l=this.store.get("products."+t),{shippingFulfillments:c,onDemandFulfillments:d}=l.sizes[l.selectedSizeId],u=i===r.SHIPPING?c:d,h=Object.values(u);if(0===h.length){const t=this.store.get("address"),n=l.sizes[l.selectedSizeId],r=splitCategoryPath(l.catPath);return this.googleTagManager.productFulfillmentNoAvailability({productId:null==n?void 0:n.id,productName:l.name,productBrand:l.brand,productCategory:r.category,productCategory2:r.category2,productCategory3:r.category3,productType:l.type,productSubtype:l.subType,productPrice:(null===(o=l.priceInfo)||void 0===o?void 0:o.avg)||0,sizeId:null!==(s=l.selectedSizeId)&&void 0!==s?s:void 0,sizeName:null==n?void 0:n.size,fulfillmentType:i,upc:null==n?void 0:n.upc,groupingId:l.salsifyGrouping,address:(null==t?void 0:t.address)?{one:t.address.one,two:t.address.two,city:t.address.city,state:t.address.state,zip:t.address.zip,country:t.address.country||""}:void 0,reason:"No "+i+" fulfillments available for selected size"}),void 0}const p=h[0]||null,m=(null==p?void 0:p.fulfillmentId)||null;this.pubSub.publishAction(n.PRODUCT_FULFILLMENT_TYPE_CHANGED,{identifier:t,selectedFulfillmentType:i,selectedFulfillmentId:m,previousFulfillmentType:l.selectedFulfillmentType,previousFulfillmentId:l.selectedFulfillmentId,fulfillmentHasAvailability:h.length>0});const f=l.sizes[l.selectedSizeId||""],b=splitCategoryPath(l.catPath),w=(null==p?void 0:p.price)||(null===(a=l.priceInfo)||void 0===a?void 0:a.avg)||0;this.googleTagManager.viewItem({item_id:null==f?void 0:f.id,item_name:l.name,item_brand:l.brand,item_size:null==f?void 0:f.size,item_category:b.category,item_category2:b.category2,item_category3:b.category3,price:centToDollar(w),item_type:l.type,item_subtype:l.subType,upc:null==f?void 0:f.upc,grouping_id:l.salsifyGrouping,product_id:null==f?void 0:f.id}),this.store.batch({["products."+t+".selectedFulfillmentType"]:i,["products."+t+".selectedFulfillment"]:p,["products."+t+".selectedFulfillmentId"]:m,["products."+t+".fulfillmentHasAvailability"]:h.length>0})}async removeProduct(t){this.store.removeProductInstance(t)}async openProductDrawer(t,n,i){const o={type:n,data:i||{}};this.store.batch({["products."+t+".drawer.isOpen"]:!![],["products."+t+".drawer.contentConfig"]:o})}async closeProductDrawer(t){this.store.set("products."+t+".drawer.isOpen",![])}async rerenderAllProducts(){const t=this.store.getProductInstances(),n=Object.keys(t);for(const i of n)this.store.set("products."+i+".rerender",!![])}async addToCart(t,n){try{this.store.set("products."+t+".updating",!![]),this.uiCommands.openDrawer(o.CART),await this.cartCommands.addItem(n),this.store.batch({["products."+t+".quantity"]:1,["products."+t+".updating"]:![]});const i=this.store.get("cart");this.googleTagManager.viewCart([...Object.values(i.items||{}).map(t=>{const n=splitCategoryPath(t.catPath);return{item_id:t.liquidId,item_name:t.name,item_brand:t.brand,item_size:t.size,item_category:n.category,item_category2:n.category2,item_category3:n.category3,quantity:t.quantity,price:centToDollar(t.unitPrice||0),upc:t.upc,grouping_id:t.salsifyGrouping,product_id:t.liquidId}})])}catch(i){this.logger.error("Error adding to cart",i),this.store.set("products."+t+".updating",![])}}async addPresaleToCart(t,n){try{this.store.set("products."+t+".updating",!![]),await this.cartCommands.addPresaleItem(n),this.clientConfig.isBuilder()||this.uiCommands.openDrawer(o.CHECKOUT),this.store.batch({["products."+t+".quantity"]:1,["products."+t+".updating"]:![]})}catch(i){this.logger.error("Error adding to cart",i),this.store.set("products."+t+".updating",![])}}productDataForEventFromStore(t){const n=this.store.get("products."+t),i={},fulfillmentEventData=t=>{const n={};for(const i in t){const o=t[i];n[i]={retailerId:o.retailerId,retailerName:o.retailerName,retailerAddress:o.retailerAddress,retailerTimezone:o.timezone,price:o.price,partNumber:o.partNumber,stock:o.stock,isEngravable:o.isVariantEngravable,fulfillmentId:o.fulfillmentId,fulfillmentType:o.fulfillmentType,modalities:o.modalities||[]}}return n};for(const o in n.sizes||{}){const t=n.sizes[o];i[o]={id:t.id,upc:t.upc,size:t.size,pack:t.pack,packDesc:t.packDesc||"",container:t.container,containerType:t.containerType,maxQuantityPerOrder:t.attributes.maxQuantityPerOrder||0,image:t.image,uom:t.uom,volume:t.volume,attributes:{engraving:t.attributes.engraving||void 0,presale:t.attributes.presale||void 0},shippingFulfillments:fulfillmentEventData(t.shippingFulfillments||{}),onDemandFulfillments:fulfillmentEventData(t.onDemandFulfillments||{})}}return{identifier:t,selectedSizeId:n.selectedSizeId||null,selectedFulfillmentId:n.selectedFulfillmentId||null,selectedFulfillmentType:n.selectedFulfillmentType,id:n.id,name:n.name,brand:n.brand,catPath:n.catPath,category:n.category,classification:n.classification,type:n.type,salsifyGrouping:n.salsifyGrouping,subType:n.subType,mainImage:n.mainImage||null,images:n.images||[],region:n.region,country:n.country,material:n.material,abv:n.abv,proof:n.proof,age:n.age,color:n.color,flavor:n.flavor,variety:n.variety,appellation:n.appellation,vintage:n.vintage,description:n.description,htmlDescription:n.htmlDescription,tastingNotes:n.tastingNotes,priceInfo:n.priceInfo||null,sizes:i}}findFirstAvailableSize(t){const n=Object.values(t);for(const i of n){const t=i.shippingFulfillments||{},n=i.onDemandFulfillments||{},o=Object.values(t).length,r=Object.values(n).length;if(o+r>0)return i.id}return null}loadProductStoreUpdate(t){var n,i,o,s,a,l,c,d,u,h,p;try{const{products:[m,...f],retailers:b}=t,w=this.themeProvider.getConfigs("product"),C={};let k=![],S=![],E="",_=null,D=w.layout.enableShippingFulfillment?r.SHIPPING:r.ON_DEMAND,P=null,F=null;const A={};if(b&&Array.isArray(b)&&b.length>0)for(const t of b)for(const n of t.fulfillments){const i={retailerName:t.name,retailerAddress:t.address||null,type:n.type,timezone:n.timezone||"",canEngrave:n.canEngrave||![],expectation:n.expectation,fees:n.fees,hours:n.hours,retailerId:t.id,fulfillmentId:n.id,fulfillmentType:n.type,isVariantEngravable:![],stock:0,price:0,partNumber:"",modalities:[]},o=getRetailerOffHours(i);o.isClosed&&!w.layout.showOffHours||(A[n.id]=i)}if(m.sizes&&Array.isArray(m.sizes)&&m.sizes.length>0)for(const t of m.sizes){const a={},l={};for(const c of t.variants){if((null===(n=null==c?void 0:c.fulfillmentTypes)||void 0===n?void 0:n.onDemand)&&""!==c.fulfillmentTypes.onDemand){const t=c.fulfillmentTypes.onDemand,n=A[t];n?l[t]={...n,isVariantEngravable:c.isEngravable,stock:c.stock,price:c.price,retailerId:c.retailerId,fulfillmentId:t,fulfillmentType:r.ON_DEMAND,modalities:[...n.modalities,...null!==(i=null==c?void 0:c.modalities)&&void 0!==i?i:[]],partNumber:c.partNumber}:this.logger.warn("No retailer info found for onDemand fulfillmentId "+t)}if((null===(o=null==c?void 0:c.fulfillmentTypes)||void 0===o?void 0:o.shipping)&&""!==c.fulfillmentTypes.shipping){const t=c.fulfillmentTypes.shipping,n=A[t];n?a[t]={...n,isVariantEngravable:c.isEngravable,stock:c.stock,price:c.price,retailerId:c.retailerId,fulfillmentId:t,fulfillmentType:r.SHIPPING,modalities:[...n.modalities,...null!==(s=null==c?void 0:c.modalities)&&void 0!==s?s:[]],partNumber:c.partNumber}:this.logger.warn("No retailer info found for shipping fulfillmentId "+t)}}C[t.id]={id:t.id,upc:t.upc,size:t.size,pack:t.pack,packDesc:t.packDesc,container:t.container,containerType:t.containerType,maxQuantityPerOrder:t.attributes.maxQuantityPerOrder||0,image:t.image,uom:t.uom,volume:t.volume,attributes:t.attributes,loading:![],error:null,shippingFulfillments:a,onDemandFulfillments:l}}const O=Object.values(C),N=this.findFirstAvailableSize(C);E=N||O[0]&&O[0].id||"",_=(null===(a=C[E])||void 0===a?void 0:a.image)||null;const R=(null===(l=C[E])||void 0===l?void 0:l.shippingFulfillments)||{},M=(null===(c=C[E])||void 0===c?void 0:c.onDemandFulfillments)||{},q=Object.values(R).length,j=Object.values(M).length;k=q+j>0;const U=D===r.SHIPPING?Object.values(R):Object.values(M);if(S=U.length>0,F=U[0]||null,P=(null==F?void 0:F.fulfillmentId)||null,!S){const t=D===r.SHIPPING?r.ON_DEMAND:r.SHIPPING,n=t===r.SHIPPING?Object.values(R):Object.values(M);n.length>0&&(D=t,F=n[0],P=(null==F?void 0:F.fulfillmentId)||null,S=!![])}if(!k){const t=this.store.get("address"),n=splitCategoryPath(m.catPath),i=C[E];this.googleTagManager.productNoAvailability({productId:null==i?void 0:i.id,productName:m.name,productBrand:m.brand,productCategory:n.category,productCategory2:n.category2,productCategory3:n.category3,productType:m.type,productSubtype:m.subType,productPrice:(null===(d=m.priceInfo)||void 0===d?void 0:d.average)||0,upc:null==i?void 0:i.upc,groupingId:m.salsifyGrouping,address:(null==t?void 0:t.address)?{one:t.address.one,two:t.address.two,city:t.address.city,state:t.address.state,zip:t.address.zip,country:t.address.country||""}:void 0,reason:"No fulfillments available for any size"})}return{identifier:"",id:m.id||"",name:m.name,description:m.description,htmlDescription:m.htmlDescription,images:m.images,priceInfo:{min:(null===(u=m.priceInfo)||void 0===u?void 0:u.minimum)||0,max:(null===(h=m.priceInfo)||void 0===h?void 0:h.maximum)||0,avg:(null===(p=m.priceInfo)||void 0===p?void 0:p.average)||0},brand:m.brand,region:m.region||"",country:m.country||"",material:m.material||"",abv:m.abv||"",proof:m.proof||"",age:m.age||"",color:m.color||"",flavor:m.flavor||"",variety:m.variety||"",appellation:m.appellation||"",vintage:m.vintage||"",tastingNotes:m.tastingNotes||"",catPath:m.catPath,category:m.category,classification:m.classification,type:m.type,subType:m.subType,salsifyGrouping:m.salsifyGrouping,sizes:C,productHasAvailability:k,fulfillmentHasAvailability:S,selectedSizeId:E,mainImage:_,selectedFulfillmentType:D,selectedFulfillmentId:P,selectedFulfillment:F,drawer:{isOpen:![],contentConfig:null},error:null,loading:![],updating:![],quantity:1,rerender:![]}}catch(m){throw this.logger.error("Product data processing error",m),m}}}class AddressCommands extends BaseCommand{constructor(){super(),this.productCommands=ProductCommands.getInstance(),this.cartCommands=CartCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("AddressCommands",()=>new AddressCommands)}async searchAddresses(t){return!t||t.length<3?[]:await this.api.getAddressSuggestions(t)}async getAddressDetails(t){return await this.api.getAddressDetails(t)}async setSelectedAddress(t){try{this.store.batch({"address.id":t.id,"address.formattedAddress":t.formattedAddress,"address.address":t.address,"address.coordinates":t.coordinates});const n=this.store.get("products");await this.productCommands.loadMultipleProducts(Object.keys(n)),await this.cartCommands.resetCart(),await this.store.persist()}catch(i){throw this.googleTagManager.addressFailed({googlePlacesId:t.id,formattedAddress:t.formattedAddress,address:{one:t.address.one,two:t.address.two,city:t.address.city,state:t.address.state,zip:t.address.zip,country:t.address.country||""},error:(null==i?void 0:i.message)||"Failed to update downstream state after address change"}),this.pubSub.publishAction(n.ADDRESS_FAILED,{googlePlacesId:t.id,formattedAddress:t.formattedAddress,address:t.address,coordinates:t.coordinates,error:(null==i?void 0:i.message)||"Failed to update downstream state after address change"}),i}this.googleTagManager.addressUpdated({googlePlacesId:t.id,formattedAddress:t.formattedAddress,address:{one:t.address.one,two:t.address.two,city:t.address.city,state:t.address.state,zip:t.address.zip,country:t.address.country||""},coordinates:t.coordinates}),this.pubSub.publishAction(n.ADDRESS_UPDATED,{googlePlacesId:t.id,address:{one:t.address.one,two:t.address.two,city:t.address.city,state:t.address.state,zip:t.address.zip,country:t.address.country||""},coordinates:t.coordinates,formattedAddress:t.formattedAddress})}async setAddressManually(t,i){try{const n=buildFormattedAddressString(t),o={id:"",formattedAddress:n,address:t,coordinates:i};await this.setSelectedAddress(o)}catch(o){throw this.googleTagManager.addressFailed({googlePlacesId:"",formattedAddress:buildFormattedAddressString(t),address:{one:t.one,two:t.two,city:t.city,state:t.state,zip:t.zip,country:t.country||""},error:(null==o?void 0:o.message)||"Failed to set manual address"}),this.pubSub.publishAction(n.ADDRESS_FAILED,{googlePlacesId:"",formattedAddress:buildFormattedAddressString(t),address:t,coordinates:i,error:(null==o?void 0:o.message)||"Failed to set manual address"}),o}}async clearSelectedAddress(){this.store.set("address",b),this.pubSub.publishAction(n.ADDRESS_CLEARED,!![]),await this.cartCommands.resetCart();const t=this.clientConfig.get("userDeviceId");await this.api.deletePersistedStore(t),this.store.clearLocalStorage()}getDetails(){const t=this.store.get("address");return t.id?{id:t.id,formattedAddress:t.formattedAddress,address:t.address,coordinates:t.coordinates}:null}}class ProductListCommands extends BaseCommand{constructor(){super(),this.uiCommands=UICommands.getInstance(),this.cartCommands=CartCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("ProductListCommands",()=>new ProductListCommands)}async getProductList(t){var n,i;const o=t,r=this.clientConfig.getConfigs();o.entity=null!==(i=null!==(n=window.location.hostname)&&void 0!==n?n:r.partnerName)&&void 0!==i?i:void 0,o.visitorId=r.userDeviceId,o.loc=this.getLocation(),o.isLegacy=!![];const s=await this.api.catalogSearch(o);return s.products&&s.products.length>0&&this.trackViewItemList(s.products),s}async addToCart(t){try{this.uiCommands.openDrawer(o.CART),await this.cartCommands.addItem(t)}catch(n){throw this.logger.error("Error adding product to cart from product list",n),n}}async addPresaleToCart(t){try{await this.cartCommands.addPresaleItem(t),this.clientConfig.isBuilder()||this.uiCommands.openDrawer(o.CHECKOUT)}catch(n){throw this.logger.error("Error adding presale product to cart from product list",n),n}}trackViewItemList(t){if(0!==t.length)try{const n=t.map((t,n)=>({...this.convertProductToBaseItem(t),index:n+1}));this.googleTagManager.viewItemList(n,"product_list","Product List")}catch(n){this.logger.error("Error tracking view_item_list event",n)}}trackSelectItem(t){try{const n=this.convertProductToBaseItem(t);this.googleTagManager.selectItem(n,"product_list","Product List")}catch(n){this.logger.error("Error tracking select_item event",n)}}convertProductToBaseItem(t){var n,i,o;const r=null===(n=t.sizes)||void 0===n?void 0:n[0],s=null===(i=null==r?void 0:r.variants)||void 0===i?void 0:i[0],a=splitCategoryPath(t.catPath);return{item_id:null==r?void 0:r.id,item_name:t.name,item_brand:t.brand,item_size:null==r?void 0:r.size,item_category:a.category,item_category2:a.category2,item_category3:a.category3,price:(null==s?void 0:s.price)?centToDollar(s.price):(null===(o=t.priceInfo)||void 0===o?void 0:o.average)?centToDollar(t.priceInfo.average):void 0,item_type:t.type,item_subtype:t.subType,upc:null==r?void 0:r.upc,grouping_id:t.salsifyGrouping,product_id:null==r?void 0:r.id,item_list_id:"product_list",item_list_name:"Product List"}}}class CommandService{constructor(){this.ui=UICommands.getInstance(),this.address=AddressCommands.getInstance(),this.product=ProductCommands.getInstance(),this.productList=ProductListCommands.getInstance(),this.cart=CartCommands.getInstance(),this.checkout=CheckoutCommands.getInstance(),this.common=CommonCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("CommandService",()=>new CommandService)}}class ClientActionService{constructor(){this.pendingCartParams=null,this.pendingCartOpenFlag=![],this.productActions={getDetails:t=>this.command.product.productDataForEventFromStore(t)},this.addressActions={setAddressByPlacesId:async t=>{try{if(!t||""===t.trim())throw new SDKError("Valid Google Places ID is required. Received empty or invalid value.",!![]);const n=await this.command.address.getAddressDetails(t);await this.command.address.setSelectedAddress({id:t,address:n.address,coordinates:n.coords,formattedAddress:n.formattedAddress})}catch(n){throw this.logger.error("Error setting address by placesId:",n),n}},setAddressManually:async(t,n)=>{try{if(!t||!n)throw new SDKError("Both address and coordinates are required.",!![]);if(!(t.one&&t.city&&t.state&&t.zip))throw new SDKError("Address must include street, city, state, and zip code.",!![]);if("number"!=typeof n.lat||"number"!=typeof n.long)throw new SDKError("Coordinates must have numeric latitude and longitude. Received lat: "+typeof n.lat+", long: "+typeof n.long,!![]);if(n.lat<-90||n.lat>90)throw new SDKError("Latitude must be between -90 and 90. Received: "+n.lat,!![]);if(n.long<-180||n.long>180)throw new SDKError("Longitude must be between -180 and 180. Received: "+n.long,!![]);await this.command.address.setAddressManually(t,n)}catch(i){throw this.logger.error("Error setting manual address:",i),i}},clear:async()=>{await this.command.address.clearSelectedAddress()},getDetails:()=>this.command.address.getDetails()},this.cartActions={openCart:()=>{this.command.ui.openDrawer(o.CART)},closeCart:()=>{this.command.ui.closeDrawer()},toggleCart:()=>{const t=this.store.get("ui.drawer.isOpen");t?this.command.ui.closeDrawer():this.command.ui.openDrawer(o.CART)},addProduct:async(t,i)=>{var s,a;try{if(!t||0===t.length)return this.logger.warn("No products provided to add to cart"),void 0;const l=this.getLocation();if(void 0===l)return this.pendingCartParams=t,this.pendingCartOpenFlag=null!=i?i:![],this.logger.info("Location not available, opening address drawer before adding to cart"),this.command.ui.openDrawer(o.ADDRESS_INPUT,{isIndependentComponent:!![]}),void 0;i===!![]&&this.command.ui.openDrawer(o.CART);const c=[...new Set(t.map(t=>t.identifier))],d=await this.api.getProductsData(c,l);if(!d||!d.products||0===d.products.length)return this.logger.warn("No product data found for the provided identifiers"),this.pubSub.publishAction(n.CART_PRODUCT_ADD_FAILED,{identifiers:[],error:"No products provided"}),void 0;for(const n of t){let t=null;for(let r=0;r<d.products.length;r++){const i=d.products[r];let o=![];for(let t=0;t<i.sizes.length;t++){const r=i.sizes[t];if(r.upc===n.identifier||r.id===n.identifier||i.salsifyGrouping===n.identifier){o=!![];break}}if(o){t=i;break}}if(!t){this.logger.warn("No product found for identifier: "+n.identifier);continue}const i=t.sizes[0];if(!i){this.logger.warn("No sizes found for product: "+n.identifier);continue}if((null===(a=null===(s=null==i?void 0:i.attributes)||void 0===s?void 0:s.presale)||void 0===a?void 0:a.isActive)===!![]){this.logger.warn("Product is a presale item and cannot be added to cart: "+n.identifier),this.store.set("cart.error","Presale products cannot be added to cart");continue}let o=null;for(let s=0;s<i.variants.length;s++){const t=i.variants[s];let a=![];if(n.fulfillmentType===r.ON_DEMAND&&(a=!(!t.fulfillmentTypes||!t.fulfillmentTypes.onDemand||""===t.fulfillmentTypes.onDemand)),n.fulfillmentType===r.SHIPPING&&(a=!(!t.fulfillmentTypes||!t.fulfillmentTypes.shipping||""===t.fulfillmentTypes.shipping)),a){o=t;break}}if(!o){this.logger.warn("No supported variant found for product: "+n.identifier+" with fulfillment type: "+n.fulfillmentType),this.store.set("cart.error","Product has no availability");continue}const l=n.fulfillmentType===r.ON_DEMAND?o.fulfillmentTypes.onDemand:o.fulfillmentTypes.shipping;await this.command.cart.addItem({upc:i.upc,fulfillmentId:l,partNumber:o.partNumber,quantity:n.quantity,identifier:n.identifier})}this.clearPendingCartOperation(),this.pubSub.publishAction(n.CART_PRODUCT_ADD_SUCCESS,{itemsAdded:t.length,identifiers:c}),this.logger.info("Products added to cart successfully:",c)}catch(l){throw this.logger.error("Error adding products to cart:",l),this.clearPendingCartOperation(),this.pubSub.publishAction(n.CART_PRODUCT_ADD_FAILED,{identifiers:t.map(t=>t.identifier),error:l.message||"Failed to add products to cart"}),l}},applyPromoCode:async t=>{try{if(!t||""===t.trim())return this.logger.warn("Invalid promo code provided"),this.store.set("cart.error","Invalid promo code provided"),void 0;const i=t.trim().toUpperCase(),o=this.themeProvider.getConfigs("global"),r=o.layout.allowPromoCodes;if(!r)return this.logger.warn("Promo codes are not allowed"),this.store.set("cart.error","Promo codes are not allowed"),void 0;const s=this.store.get("cart.promoCode");if(s&&s.code===i)return this.logger.info("Promo code is already applied"),void 0;await this.command.cart.applyPromoCode(i);const a=this.command.cart.getDetails();this.pubSub.publishAction(n.CART_PROMO_CODE_APPLIED,{discountAmount:a.amounts.discounts,newTotal:a.amounts.total}),this.logger.info("Promo code applied successfully")}catch(i){throw this.logger.error("Failed to apply promo code:",i),this.pubSub.publishAction(n.CART_PROMO_CODE_FAILED,{error:"Promo code could not be applied"}),i}},removePromoCode:async()=>{try{const t=this.themeProvider.getConfigs("global"),i=t.layout.allowPromoCodes;if(!i)return this.logger.warn("Promo codes are not allowed"),this.store.set("cart.error","Promo codes are not allowed"),void 0;await this.command.cart.removePromoCode();const o=this.command.cart.getDetails();this.pubSub.publishAction(n.CART_PROMO_CODE_REMOVED,{newTotal:o.amounts.total}),this.logger.info("Promo code removed successfully")}catch(t){throw this.logger.error("Failed to remove promo code:",t),t}},resetCart:async()=>{await this.command.cart.resetCart(),this.pubSub.publishAction(n.CART_RESET,!![])},getDetails:()=>this.command.cart.getDetails()},this.checkoutActions={openCheckout:()=>{this.command.ui.openDrawer(o.CHECKOUT)},closeCheckout:()=>{this.command.ui.closeDrawer()},toggleCheckout:()=>{const t=this.store.get("ui.drawer.isOpen");t?this.command.ui.closeDrawer():this.command.ui.openDrawer(o.CHECKOUT)},addProduct:async(t,i)=>{try{if(!t||0===t.length)return this.logger.warn("No products provided to add to checkout"),void 0;i===!![]&&this.command.ui.openDrawer(o.CHECKOUT);const r=t.map(t=>t.identifier);await this.cartActions.addProduct(t),await this.command.checkout.loadCheckout(),this.pubSub.publishAction(n.CHECKOUT_PRODUCT_ADD_SUCCESS,{itemsAdded:t.length,identifiers:r}),this.logger.info("Products added to checkout successfully:",r)}catch(r){throw this.logger.error("Error adding products to checkout:",r),this.pubSub.publishAction(n.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:t.map(t=>t.identifier),error:r.message||"Failed to add products to checkout"}),r}},addPresaleProduct:async t=>{var i,s;try{if(!t||"object"!=typeof t||!t.identifier)return this.logger.warn("No presale product provided to add to checkout"),void 0;const a=this.getLocation();if(void 0===a)return this.logger.info("Location not available, opening address drawer before adding presale product to checkout"),this.command.ui.openDrawer(o.ADDRESS_INPUT,{isIndependentComponent:!![]}),void 0;const l=await this.api.getProductsData([t.identifier],a);if(!l||!l.products||0===l.products.length)return this.logger.warn("No product data found for the provided presale identifier"),this.pubSub.publishAction(n.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[t.identifier],error:"No product found",isPresale:!![]}),void 0;const c=l.products[0],d=c.sizes[0];if(!d)return this.logger.warn("No sizes found for presale product: "+t.identifier),this.pubSub.publishAction(n.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[t.identifier],error:"No sizes found for product",isPresale:!![]}),void 0;if((null===(s=null===(i=null==d?void 0:d.attributes)||void 0===i?void 0:i.presale)||void 0===s?void 0:s.isActive)!==!![])return this.logger.warn("Product is not a presale item: "+t.identifier),this.store.set("checkout.error","Product is not available for presale"),this.pubSub.publishAction(n.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[t.identifier],error:"Product is not available for presale",isPresale:!![]}),void 0;let u=null;for(let n=0;n<d.variants.length;n++){const i=d.variants[n];let o=![];if(t.fulfillmentType===r.ON_DEMAND&&(o=!(!i.fulfillmentTypes||!i.fulfillmentTypes.onDemand||""===i.fulfillmentTypes.onDemand)),t.fulfillmentType===r.SHIPPING&&(o=!(!i.fulfillmentTypes||!i.fulfillmentTypes.shipping||""===i.fulfillmentTypes.shipping)),o){u=i;break}}if(!u)return this.logger.warn("No supported variant found for presale product: "+t.identifier+" with fulfillment type: "+t.fulfillmentType),this.store.set("checkout.error","Presale product has no availability"),this.pubSub.publishAction(n.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[t.identifier],error:"Presale product has no availability",isPresale:!![]}),void 0;const h=t.fulfillmentType===r.ON_DEMAND?u.fulfillmentTypes.onDemand:u.fulfillmentTypes.shipping;await this.command.cart.addPresaleItem({upc:d.upc,fulfillmentId:h,partNumber:u.partNumber,quantity:t.quantity,engravingLines:[],identifier:t.identifier}),this.command.ui.openDrawer(o.CHECKOUT),this.pubSub.publishAction(n.CHECKOUT_PRODUCT_ADD_SUCCESS,{itemsAdded:1,identifiers:[t.identifier],isPresale:!![]}),this.logger.info("Presale product added to checkout successfully: "+t.identifier)}catch(a){throw this.logger.error("Error adding presale product to checkout:",a),this.pubSub.publishAction(n.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[t.identifier],error:a.message||"Failed to add presale product to checkout",isPresale:!![]}),a}},applyPromoCode:async t=>{var i;try{if(!t||""===t.trim())return this.logger.warn("Invalid promo code provided"),this.store.set("checkout.error","Invalid promo code provided"),void 0;const o=t.trim().toUpperCase(),r=this.themeProvider.getConfigs("global"),s=r.layout.allowPromoCodes;if(!s)return this.logger.warn("Promo codes are not allowed"),this.store.set("checkout.error","Promo codes are not allowed"),void 0;const a=this.store.get("checkout.promoCode");if(a&&a.code===o)return this.logger.info("Promo code is already applied"),void 0;await this.command.checkout.applyPromoCode(t);const l=this.store.get("checkout"),c=null==l?void 0:l.promoCode;this.pubSub.publishAction(n.CHECKOUT_PROMO_CODE_APPLIED,{discountAmount:(null==c?void 0:c.discountAmount)||0,newTotal:(null===(i=null==l?void 0:l.amounts)||void 0===i?void 0:i.total)||0}),this.logger.info("Checkout promo code applied successfully")}catch(o){throw this.logger.error("Failed to apply checkout promo code:",o),this.pubSub.publishAction(n.CHECKOUT_PROMO_CODE_FAILED,{error:"Promo code could not be applied"}),o}},removePromoCode:async()=>{var t;try{const i=this.themeProvider.getConfigs("global"),o=i.layout.allowPromoCodes;if(!o)return this.logger.warn("Promo codes are not allowed"),this.store.set("checkout.error","Promo codes are not allowed"),void 0;await this.command.checkout.removePromoCode();const r=this.store.get("checkout");this.pubSub.publishAction(n.CHECKOUT_PROMO_CODE_REMOVED,{newTotal:(null===(t=null==r?void 0:r.amounts)||void 0===t?void 0:t.total)||0}),this.logger.info("Checkout promo code removed successfully")}catch(i){throw this.logger.error("Failed to remove checkout promo code:",i),i}},applyGiftCard:async t=>{var i;try{const o=this.themeProvider.getConfigs("checkout"),r=o.layout.allowGiftCards;if(!r)return this.logger.warn("Gift cards are not allowed"),this.store.set("checkout.error","Gift cards are not allowed"),void 0;await this.command.checkout.applyGiftCard(t);const s=this.store.get("checkout");this.pubSub.publishAction(n.CHECKOUT_GIFT_CARD_APPLIED,{newTotal:(null===(i=null==s?void 0:s.amounts)||void 0===i?void 0:i.total)||0}),this.logger.info("Gift card applied successfully")}catch(o){throw this.logger.error("Failed to apply gift card:",o),this.pubSub.publishAction(n.CHECKOUT_GIFT_CARD_FAILED,{error:"Gift card could not be applied"}),o}},removeGiftCard:async t=>{var i;try{const o=this.themeProvider.getConfigs("checkout"),r=o.layout.allowGiftCards;if(!r)return this.logger.warn("Gift cards are not allowed"),this.store.set("checkout.error","Gift cards are not allowed"),void 0;await this.command.checkout.removeGiftCard(t);const s=this.store.get("checkout");this.pubSub.publishAction(n.CHECKOUT_GIFT_CARD_REMOVED,{newTotal:(null===(i=null==s?void 0:s.amounts)||void 0===i?void 0:i.total)||0}),this.logger.info("Gift card removed successfully")}catch(o){throw this.logger.error("Failed to remove gift card:",o),this.pubSub.publishAction(n.CHECKOUT_GIFT_CARD_FAILED,{error:"Gift card could not be removed"}),o}},toggleIsGift:async t=>{await this.command.checkout.toggleIsGift(t)},toggleBillingSameAsShipping:async t=>{await this.command.checkout.toggleBillingSameAsShipping(t)},toggleMarketingPreferences:(t,n)=>{this.command.checkout.toggleMarketingPreferences(t,n)},getDetails:()=>{var t,n,i;const o=this.store.get("checkout"),r=o.items||{},s={};for(const[a,l]of Object.entries(r))s[a]={liquidId:l.liquidId,variantId:l.variantId,cartItemId:a,retailerId:l.retailerId,fulfillmentId:l.fulfillmentId,salsifyGrouping:l.salsifyGrouping,name:l.name,catPath:l.catPath,volume:l.volume,uom:l.uom,proof:l.proof,abv:l.abv,containerType:l.containerType,container:l.container,size:l.size,pack:l.pack,packDesc:l.packDesc,mainImage:l.mainImage,brand:l.brand,partNumber:l.partNumber,upc:l.upc,sku:l.sku,price:l.price,unitPrice:l.unitPrice,quantity:l.quantity,unitTax:l.unitTax,bottleDeposits:l.bottleDeposits,attributes:l.attributes,retailerName:l.retailerName,expectationDetail:l.expectationDetail};return{cartId:o.cartId||"",isGift:o.isGift||![],billingSameAsShipping:o.paymentForm.billingSameAsShipping,marketingPreferences:{canEmail:(null===(t=o.marketingPreferences)||void 0===t?void 0:t.canEmail)||![],canSms:(null===(n=o.marketingPreferences)||void 0===n?void 0:n.canSms)||![]},hasPromoCode:!!(null===(i=o.promoCode)||void 0===i?void 0:i.code),hasGiftCards:Array.isArray(o.giftCards)&&o.giftCards.length>0,itemCount:Object.values(s||{}).reduce((t,n)=>t+(n.quantity||0),0),amounts:o.amounts,items:s}}},this.actions={product:this.productActions,address:this.addressActions,cart:this.cartActions,checkout:this.checkoutActions},this.store=StoreService.getInstance(),this.command=CommandService.getInstance(),this.api=ApiClientService.getInstance(),this.pubSub=PubSubService.getInstance(),this.themeProvider=ThemeProviderService.getInstance(),this.logger=LoggerFactory.get("ClientAction"),this.setupAddressUpdateListener()}static getInstance(){return SingletonManager.getClassInstance("ClientActionService",()=>new ClientActionService)}setupAddressUpdateListener(){const T=async()=>{this.pendingCartParams&&(this.logger.info("Address updated, retrying pending cart operation"),await this.retryPendingCartOperation())};window.addEventListener("lce:actions."+n.ADDRESS_UPDATED,T)}async retryPendingCartOperation(){if(this.pendingCartParams)try{const t=this.pendingCartParams,n=this.pendingCartOpenFlag;this.clearPendingCartOperation(),await this.cartActions.addProduct(t,n)}catch(t){this.logger.error("Failed to retry cart operation after address update",t)}}clearPendingCartOperation(){this.pendingCartParams=null,this.pendingCartOpenFlag=![]}getLocation(){const t=this.store.get("address");if(t.address.one&&t.coordinates.long&&t.coordinates.lat)return{coords:t.coordinates,address:t.address}}}const ht="\n :host {\n position: fixed;\n z-index: 2147483647;\n display: block;\n }\n\n .panel {\n position: relative;\n background: rgba(15, 23, 42, 0.95);\n backdrop-filter: blur(10px);\n border: 1px solid rgba(148, 163, 184, 0.2);\n border-radius: 12px;\n box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);\n font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace;\n font-size: 12px;\n color: #e2e8f0;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n user-select: none;\n transition: all 0.2s ease;\n width: 100%;\n height: 100%;\n }\n\n .panel:hover {\n border-color: rgba(148, 163, 184, 0.4);\n box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.4);\n }\n\n .header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n padding: 12px 16px;\n border-bottom: 1px solid rgba(148, 163, 184, 0.2);\n background: rgba(30, 41, 59, 0.5);\n cursor: move;\n }\n\n .icon {\n font-size: 14px;\n display: flex;\n align-items: center;\n justify-content: center;\n min-width: 20px;\n }\n\n .title-container {\n display: flex;\n flex-direction: column;\n flex: 1;\n margin: 0 12px;\n }\n \n .title-container > *:not(:first-child) {\n margin-top: 2px;\n }\n\n .title {\n font-weight: 600;\n color: #f1f5f9;\n font-size: 13px;\n }\n\n\n .subtitle {\n font-size: 10px;\n color: #94a3b8;\n }\n\n .minimize {\n background: none;\n border: none;\n color: #94a3b8;\n font-size: 18px;\n cursor: pointer;\n padding: 4px;\n border-radius: 4px;\n transition: all 0.2s ease;\n line-height: 1;\n font-weight: bold;\n }\n\n .minimize:hover {\n background: rgba(148, 163, 184, 0.1);\n color: #cbd5e1;\n }\n\n .toggles {\n display: flex;\n padding: 8px 16px;\n border-bottom: 1px solid rgba(148, 163, 184, 0.2);\n background: rgba(30, 41, 59, 0.3);\n align-items: center;\n }\n\n .toggles > *:not(:last-child) {\n margin-right: 12px;\n }\n\n .toggle {\n display: flex;\n align-items: center;\n cursor: pointer;\n font-size: 11px;\n color: #cbd5e1;\n transition: color 0.2s ease;\n }\n \n .toggle > *:not(:last-child) {\n margin-right: 6px;\n }\n\n .toggle:hover {\n color: #f1f5f9;\n }\n\n .toggle input[type=\"checkbox\"] {\n width: 12px;\n height: 12px;\n accent-color: #3b82f6;\n cursor: pointer;\n }\n\n .clear-btn {\n background: none;\n border: none;\n color: #ef4444;\n font-size: 14px;\n padding: 0;\n cursor: pointer;\n transition: all 0.2s ease;\n margin-left: auto;\n min-width: 20px;\n height: 20px;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n .clear-btn:hover {\n transform: scale(1.1);\n color: #dc2626;\n }\n\n .logs {\n flex: 1;\n overflow-y: auto;\n overflow-x: hidden;\n padding: 8px;\n background: rgba(15, 23, 42, 0.8);\n min-height: 0;\n max-height: 100%;\n }\n\n .log-entry {\n display: flex;\n align-items: flex-start;\n padding: 8px 12px;\n margin-bottom: 2px;\n border-radius: 6px;\n font-size: 11px;\n line-height: 1.4;\n transition: background-color 0.2s ease;\n user-select: text;\n }\n \n .log-entry > *:not(:last-child) {\n margin-right: 8px;\n }\n\n .log-entry:hover {\n background-color: rgba(148, 163, 184, 0.1);\n }\n\n /* Event type background colors */\n .log-entry.event {\n background: rgba(59, 130, 246, 0.1);\n }\n\n .log-entry.action {\n background: rgba(16, 185, 129, 0.1);\n }\n\n .log-entry.gtm {\n background: rgba(245, 158, 11, 0.1);\n }\n\n .log-entry.logger {\n background: rgba(139, 92, 246, 0.1);\n }\n\n\n .log-meta {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n min-width: 50px;\n }\n \n .log-meta > *:not(:first-child) {\n margin-top: 2px;\n }\n\n .log-type {\n font-weight: 600;\n font-size: 9px;\n padding: 2px 0;\n border-radius: 3px;\n white-space: nowrap;\n text-align: center;\n line-height: 1;\n font-weight: bold;\n letter-spacing: 0.5px;\n }\n\n .log-timestamp {\n color: #64748b;\n font-size: 9px;\n white-space: nowrap;\n line-height: 1;\n }\n\n .log-type.event {\n background: rgba(59, 130, 246, 0.2);\n color: #60a5fa;\n }\n\n .log-type.action {\n color: #34d399;\n }\n\n .log-type.gtm {\n color: #fbbf24;\n }\n\n .log-type.logger {\n color: #a78bfa;\n }\n\n .log-message {\n flex: 1;\n word-break: break-word;\n user-select: text;\n }\n\n .log-context {\n color: #94a3b8;\n font-size: 10px;\n margin-top: 2px;\n font-style: italic;\n }\n\n .log-data {\n background: rgba(30, 41, 59, 0.6);\n border: 1px solid rgba(148, 163, 184, 0.2);\n border-radius: 4px;\n padding: 8px;\n margin-top: 6px;\n font-size: 10px;\n color: #cbd5e1;\n max-height: 120px;\n overflow-y: auto;\n font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace;\n user-select: text;\n }\n\n .log-data pre {\n margin: 0;\n white-space: pre-wrap;\n word-break: break-word;\n }\n\n .resize-handle {\n position: absolute;\n bottom: 0;\n right: 0;\n width: 12px;\n height: 12px;\n background: linear-gradient(-45deg, transparent 30%, rgba(148, 163, 184, 0.3) 30%, rgba(148, 163, 184, 0.3) 70%, transparent 70%);\n cursor: nw-resize;\n border-radius: 0 0 12px 0;\n }\n\n .resize-handle:hover {\n background: linear-gradient(-45deg, transparent 30%, rgba(148, 163, 184, 0.7) 30%, rgba(148, 163, 184, 0.7) 70%, transparent 70%);\n transform: scale(1.1);\n }\n\n .resize-handle:active {\n background: linear-gradient(-45deg, transparent 30%, rgba(148, 163, 184, 0.9) 30%, rgba(148, 163, 184, 0.9) 70%, transparent 70%);\n }\n\n /* Scrollbar styling */\n .logs::-webkit-scrollbar {\n width: 6px;\n }\n\n .logs::-webkit-scrollbar-track {\n background: rgba(30, 41, 59, 0.3);\n border-radius: 3px;\n }\n\n .logs::-webkit-scrollbar-thumb {\n background: rgba(148, 163, 184, 0.3);\n border-radius: 3px;\n }\n\n .logs::-webkit-scrollbar-thumb:hover {\n background: rgba(148, 163, 184, 0.5);\n }\n\n .log-data::-webkit-scrollbar {\n width: 4px;\n }\n\n .log-data::-webkit-scrollbar-track {\n background: rgba(30, 41, 59, 0.3);\n border-radius: 2px;\n }\n\n .log-data::-webkit-scrollbar-thumb {\n background: rgba(148, 163, 184, 0.3);\n border-radius: 2px;\n }\n\n .log-data::-webkit-scrollbar-thumb:hover {\n background: rgba(148, 163, 184, 0.5);\n }\n\n /* Floating button styles */\n .floating-btn {\n position: absolute;\n top: 20px;\n left: 20px;\n width: 40px;\n height: 40px;\n background: rgba(15, 23, 42, 0.95);\n border: 1px solid rgba(148, 163, 184, 0.2);\n border-radius: 50%;\n display: none;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n font-size: 18px;\n user-select: none;\n z-index: 1;\n }\n\n .floating-btn:hover {\n background: rgba(30, 41, 59, 0.95);\n border-color: rgba(148, 163, 184, 0.4);\n }\n\n /* Mobile Responsiveness */\n @media (max-width: 768px) {\n .panel {\n font-size: 11px;\n border-radius: 8px;\n }\n\n .header {\n padding: 8px 12px;\n }\n\n .title {\n font-size: 12px;\n }\n\n .subtitle {\n font-size: 9px;\n }\n\n .toggles {\n padding: 6px 12px;\n flex-wrap: wrap;\n }\n \n .toggles > *:not(:last-child) {\n margin-right: 8px;\n }\n\n .toggle {\n font-size: 10px;\n }\n\n .toggle input[type=\"checkbox\"] {\n width: 10px;\n height: 10px;\n }\n\n .logs {\n padding: 6px;\n }\n\n .log-entry {\n padding: 6px 8px;\n font-size: 10px;\n }\n\n .log-type {\n font-size: 8px;\n }\n\n .log-timestamp {\n font-size: 8px;\n }\n\n .log-data {\n font-size: 9px;\n padding: 6px;\n max-height: 80px;\n }\n\n .floating-btn {\n width: 36px;\n height: 36px;\n font-size: 16px;\n top: 15px;\n left: 15px;\n }\n }\n\n @media (max-width: 480px) {\n .panel {\n font-size: 10px;\n border-radius: 6px;\n }\n\n .header {\n padding: 6px 10px;\n }\n\n .title {\n font-size: 11px;\n }\n\n .subtitle {\n font-size: 8px;\n }\n\n .toggles {\n padding: 4px 10px;\n }\n \n .toggles > *:not(:first-child) {\n margin-right: 6px;\n }\n\n .toggle {\n font-size: 9px;\n }\n\n .logs {\n padding: 4px;\n }\n\n .log-entry {\n padding: 4px 6px;\n font-size: 9px;\n }\n \n .log-entry > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .log-meta {\n min-width: 40px;\n }\n\n .log-type {\n font-size: 7px;\n }\n\n .log-timestamp {\n font-size: 7px;\n }\n\n .log-data {\n font-size: 8px;\n padding: 4px;\n max-height: 60px;\n }\n\n .floating-btn {\n width: 32px;\n height: 32px;\n font-size: 14px;\n top: 10px;\n left: 10px;\n }\n }\n",pt="lce-debug-panel";class DebugPanelService{constructor(){this.panelElement=null,this.panelContainer=null,this.floatingButton=null,this.logContainer=null,this.logs=[],this.isVisible=![],this.showEvents=!![],this.showGtmEvents=!![],this.showLogs=![]}static getInstance(){return SingletonManager.getClassInstance("DebugPanelService",()=>new DebugPanelService)}initialize(){this.createPanel(),this.interceptLoggerService(),this.interceptPubSubEvents(),this.interceptGtmEvents()}toggleVisibility(){if(!this.panelElement)return this.createPanel(),void 0;this.isVisible=!this.isVisible,this.isVisible?this.showPanelContent():this.hidePanelContent()}destroy(){this.panelElement&&(this.panelElement.remove(),this.panelElement=null),this.panelContainer=null,this.floatingButton=null,this.logs=[],this.isVisible=![]}interceptLoggerService(){const t=LoggerFactory,n=t.instances;if(n)for(const[o,r]of n)this.interceptLoggerInstance(r,o);const i=LoggerFactory.get.bind(LoggerFactory);LoggerFactory.get=t=>{const n=i(t);return this.interceptLoggerInstance(n,t),n}}interceptLoggerInstance(t,n){if(t.l)return;const i=t.debug.bind(t),o=t.info.bind(t),r=t.warn.bind(t),s=t.error.bind(t),g=(t,i,o)=>({id:"logger_"+Date.now()+"_"+Math.random().toString(36).slice(2,9),timestamp:Date.now(),type:"logger",level:t,message:i,data:o,context:n});t.debug=(t,n)=>{i(t,n),this.addLogEntry(g("debug",t,n))},t.info=(t,n)=>{o(t,n),this.addLogEntry(g("info",t,n))},t.warn=(t,n)=>{r(t,n),this.addLogEntry(g("warn",t,n))},t.error=(t,n)=>{s(t,n),this.addLogEntry(g("error",t,n))},t.l=!![]}interceptPubSubEvents(){const t=PubSubService.getInstance(),n=t.publishAction.bind(t);t.publishAction=(t,i)=>{n(t,i),this.addLogEntry({id:"action_"+Date.now()+"_"+Math.random().toString(36).slice(2,9),timestamp:Date.now(),type:"event",level:"info",message:"Action: "+t,data:i,context:"PubSub"})};const i=t.publishForm.bind(t);t.publishForm=(t,n)=>{i(t,n),this.addLogEntry({id:"event_"+Date.now()+"_"+Math.random().toString(36).slice(2,9),timestamp:Date.now(),type:"event",level:"info",message:"Form Event: "+t,data:n,context:"PubSub"})}}interceptGtmEvents(){const t=GoogleTagManagerService.getInstance(),n=t.executeEvent.bind(t);t.executeEvent=(t,i,o)=>{n(t,i,o),this.addLogEntry({id:"gtm_"+Date.now()+"_"+Math.random().toString(36).slice(2,9),timestamp:Date.now(),type:"gtm",level:"info",message:"GTM Event: "+i,data:o,context:"GTM."+t})}}addLogEntry(t){this.logs.push(t),this.logs.length>100&&(this.logs=this.logs.slice(-100)),this.renderLogs()}renderLogs(){if(!this.logContainer)return;const t=this.logs.filter(t=>{switch(t.type){case"event":return this.showEvents;case"gtm":return this.showGtmEvents;case"logger":return this.showLogs;default:return!![]}});this.logContainer.innerHTML="",t.forEach(t=>{const n=this.createLogElement(t);this.logContainer.appendChild(n)}),this.logContainer.scrollTop=this.logContainer.scrollHeight}clearLogs(){this.logs=[],this.renderLogs()}createPanel(){const t=document.querySelector(pt);t&&t.remove(),this.panelElement=document.createElement(pt);const n=window.innerWidth<=768,i=window.innerWidth<=480;i?(this.panelElement.style.top="10px",this.panelElement.style.left="10px",this.panelElement.style.width="calc(100vw - 20px)",this.panelElement.style.height="40vh"):n?(this.panelElement.style.top="15px",this.panelElement.style.left="15px",this.panelElement.style.width="calc(100vw - 30px)",this.panelElement.style.height="40vh"):(this.panelElement.style.top="20px",this.panelElement.style.left="20px",this.panelElement.style.width="500px",this.panelElement.style.height="600px"),this.createPanelContent(),document.body.appendChild(this.panelElement),this.isVisible=!![]}createPanelContent(){if(!this.panelElement)return;const t=this.panelElement.attachShadow({mode:"closed"}),n=document.createElement("style");n.textContent=ht,t.appendChild(n),this.floatingButton=this.createFloatingButton(),t.appendChild(this.floatingButton),this.panelContainer=document.createElement("div"),this.panelContainer.className="panel";const i=this.createHeader();this.panelContainer.appendChild(i);const o=this.createToggles();this.panelContainer.appendChild(o),this.logContainer=document.createElement("div"),this.logContainer.className="logs",this.logContainer.title="Debug logs - scroll to see more",this.panelContainer.appendChild(this.logContainer);const r=this.createResizeHandle();this.panelContainer.appendChild(r),t.appendChild(this.panelContainer),this.setupShadowEventListeners(t)}createHeader(){const t=document.createElement("div");t.className="header",t.title="Drag to move panel";const n=document.createElement("div");n.className="icon",n.innerHTML="🔍",n.title="Elements Debug Console",n.style.cursor="help";const i=document.createElement("div");i.className="title-container";const o=document.createElement("div");o.className="title",o.textContent="Elements Debug Console";const r=document.createElement("div");r.className="subtitle",r.textContent="Live SDK logs, events & GTM tracking",i.appendChild(o),i.appendChild(r);const s=document.createElement("button");return s.className="minimize",s.innerHTML="−",s.title="Minimize debug panel",s.addEventListener("click",()=>this.toggleVisibility()),t.appendChild(n),t.appendChild(i),t.appendChild(s),t}createToggles(){const t=document.createElement("div");t.className="toggles";const n=[{key:"showLogs",label:"Logs",description:"SDK internal logs and debug messages",color:"#8b5cf6"},{key:"showEvents",label:"Events",description:"User actions and form interactions",color:"#10b981"},{key:"showGtmEvents",label:"GTM Events",description:"Google Tag Manager tracking events",color:"#f59e0b"}];n.forEach(({key:n,label:i,description:o,color:r})=>{const s=document.createElement("label");s.className="toggle",s.title=o;const a=document.createElement("input");a.type="checkbox",a.checked="showLogs"!==n,a.addEventListener("change",t=>{const i=t.target;"showEvents"===n&&(this.showEvents=i.checked),"showGtmEvents"===n&&(this.showGtmEvents=i.checked),"showLogs"===n&&(this.showLogs=i.checked),this.renderLogs()});const l=document.createElement("span");l.textContent=i,l.style.color=r,s.appendChild(a),s.appendChild(l),t.appendChild(s)});const i=document.createElement("button");return i.className="clear-btn",i.innerHTML="🗑️",i.title="Clear all logs",i.addEventListener("click",()=>this.clearLogs()),t.appendChild(i),t}createResizeHandle(){const t=document.createElement("div");t.className="resize-handle",t.title="Drag to resize panel",t.style.cursor="nw-resize";let n=![],i=0,o=0,r=0,s=0;t.addEventListener("mousedown",t=>{n=!![],i=t.clientX,o=t.clientY,r=Number.parseInt(this.panelElement.style.width,10)||500,s=Number.parseInt(this.panelElement.style.height,10)||300,document.addEventListener("mousemove",L),document.addEventListener("mouseup",y),t.preventDefault()});const L=t=>{if(!n||!this.panelElement)return;const a=t.clientX-i,l=t.clientY-o,c=window.innerWidth<=768,d=window.innerWidth<=480;let u,h,p,m;d?(u=280,h=window.innerWidth-20,p=200,m=.4*window.innerHeight):c?(u=300,h=window.innerWidth-30,p=200,m=.4*window.innerHeight):(u=300,h=800,p=200,m=600);const f=Math.max(u,Math.min(h,r+a)),b=Math.max(p,Math.min(m,s+l));this.panelElement.style.width=f+"px",this.panelElement.style.height=b+"px"},y=()=>{n=![],document.removeEventListener("mousemove",L),document.removeEventListener("mouseup",y)};return t}setupShadowEventListeners(t){if(!this.panelElement)return;const n=t.querySelector(".header");if(n){let t=![],i=0,o=0,r=0,s=0;n.addEventListener("mousedown",n=>{if(n.target.classList.contains("minimize"))return;t=!![],i=n.clientX,o=n.clientY;const a=this.panelElement.getBoundingClientRect();r=a.left,s=a.top,document.addEventListener("mousemove",L),document.addEventListener("mouseup",y),n.preventDefault()});const L=n=>{if(!t||!this.panelElement)return;const a=n.clientX-i,l=n.clientY-o;this.panelElement.style.left=r+a+"px",this.panelElement.style.top=s+l+"px",this.panelElement.style.right="auto",this.panelElement.style.bottom="auto"},y=()=>{t=![],document.removeEventListener("mousemove",L),document.removeEventListener("mouseup",y)}}}createFloatingButton(){const t=document.createElement("div");return t.className="floating-btn",t.innerHTML="⚙️",t.title="Open Elements Debug Console",t.style.display="none",t.addEventListener("click",()=>{this.toggleVisibility()}),t}showPanelContent(){this.panelContainer&&(this.panelContainer.style.display="flex"),this.floatingButton&&(this.floatingButton.style.display="none")}hidePanelContent(){this.panelContainer&&(this.panelContainer.style.display="none"),this.floatingButton&&(this.floatingButton.style.display="flex")}createLogElement(t){const n=document.createElement("div");n.className="log-entry "+t.type+" "+t.level;const i=new Date(t.timestamp).toLocaleTimeString();return n.innerHTML='\n <div class="log-meta">\n <div class="log-type '+t.type+'">'+t.type.toUpperCase()+'</div>\n <div class="log-timestamp">'+i+'</div>\n </div>\n <div class="log-message">\n '+this.escapeHtml(t.message)+"\n "+(t.context?'<div class="log-context">'+this.escapeHtml(t.context)+"</div>":"")+"\n "+(t.data?'<div class="log-data"><pre>'+this.formatJsonData(t.data)+"</pre></div>":"")+"\n </div>\n ",n}formatJsonData(t){try{return"object"==typeof t&&null!==t?JSON.stringify(t,null,2):String(t)}catch(n){return String(t)}}escapeHtml(t){const n=document.createElement("div");return n.textContent=t,n.innerHTML}}class FingerPrintService{constructor(){this.isLocalStorageAvailable=null,this.cachedFingerprint=null,this.clientConfig=ClientConfigService.getInstance()}static getInstance(){return SingletonManager.getClassInstance("FingerPrintService",()=>new FingerPrintService)}async getId(t){if(this.u()){const n=this.h(t);if(n)return this.m(t,n)}return this.cachedFingerprint||(this.cachedFingerprint=this.v()),this.m(t,this.cachedFingerprint)}getFingerprintData(){return{screen:this.C(),browser:this.k(),timezone:this.S()}}isLocalStorageWebApiAvailable(){return this.u()}m(t,n){return(t+"_"+n).toLowerCase()}u(){if(null!==this.isLocalStorageAvailable)return this.isLocalStorageAvailable;try{0;const t=window.localStorage,n="__localStorage_test_"+Date.now()+"__",i="test";t.setItem(n,i);const o=t.getItem(n);return o!==i?(this.isLocalStorageAvailable=![],![]):(t.removeItem(n),this.isLocalStorageAvailable=!![],!![])}catch(t){const i=t instanceof DOMException&&(22===t.code||1014===t.code||"QuotaExceededError"===t.name||"NS_ERROR_DOM_QUOTA_REACHED"===t.name);if(i)try{const t=window.localStorage;return t&&t.length>0?(this._()&&console.warn("localStorage is full in webview environment - consider data cleanup"),this.isLocalStorageAvailable=!![],!![]):(console.warn("localStorage reports zero quota - likely Safari private mode or similar restriction"),this.isLocalStorageAvailable=![],![])}catch(n){return this.isLocalStorageAvailable=![],![]}if(this.isLocalStorageAvailable=![],t instanceof DOMException){const n={SecurityError:"Access denied due to security policies (third-party cookies, Firefox cookie settings, or iframe restrictions)",InvalidStateError:"Invalid state error",InvalidAccessError:"Invalid access to storage",NotFoundError:"Storage not found"},i=n[t.name]||"Storage error: "+t.name,o=this._()?"webview":"browser";console.warn("localStorage unavailable in "+o+": "+i)}else console.warn("localStorage unavailable:",t.message||"Unknown error");return![]}}h(t){try{const n=this.clientConfig.get("localStorageKeyPrefix")+"_"+t.toLowerCase()+"_";for(let t=0;t<localStorage.length;t++){const i=localStorage.key(t);if(null==i?void 0:i.startsWith(n)){const t=i.substring(n.length);if(t&&/^[a-f0-9]+$/.test(t))return t}}return null}catch(n){return null}}v(){const t=this.getFingerprintData(),n=Object.keys(t).sort().map(n=>n+":"+t[n]).join("|");return this.D(n)}C(){try{const t=screen,n=t.colorDepth||24,i=t.pixelDepth||n,o=this.T(),r=Math.round(100*(window.devicePixelRatio||1));return n+"|"+i+"|"+o+"|"+r}catch(t){return"24|24|srgb|100"}}T(){try{if(window.matchMedia&&"function"==="object".matchMedia){if(window.matchMedia("(color-gamut: rec2020)").matches)return"rec2020";if(window.matchMedia("(color-gamut: p3)").matches)return"p3";if(window.matchMedia("(color-gamut: srgb)").matches)return"srgb"}}catch(X){}return"srgb"}k(){var t;try{const n=navigator,i=[],o=((null===(t=n.languages)||void 0===t?void 0:t[0])||n.language||"en").substring(0,2);i.push(o),i.push(n.hardwareConcurrency||4);const r=(n.platform||"unknown").toLowerCase().replace(/\s+/g,"_").substring(0,10);i.push(r),i.push(n.cookieEnabled?"1":"0"),i.push(n.maxTouchPoints||0),i.push(n.deviceMemory||0),i.push(this.P()),i.push(this._()?"webview":"browser");const s=["bluetooth"in n?"1":"0","usb"in n?"1":"0","mediaDevices"in n?"1":"0","permissions"in n?"1":"0","credentials"in n?"1":"0","storage"in n?"1":"0","ServiceWorker"in window?"1":"0","PushManager"in window?"1":"0"];return i.push(s.join("")),i.join("|")}catch(n){return"en|4|unknown|1|0|0|unknown|webview|00000000"}}P(){try{const t=navigator.userAgent.toLowerCase();return t.includes("instagram")?"ig_webview":t.includes("fban")||t.includes("fbav")?"fb_webview":t.includes("tiktok")?"tiktok_webview":t.includes("linkedin")?"linkedin_webview":t.includes("snapchat")?"snapchat_webview":t.includes("twitter")?"twitter_webview":t.includes("line/")?"line_webview":t.includes("micromessenger")?"wechat_webview":t.includes("firefox")?"gecko":t.includes("edg/")?"edge":t.includes("opr/")||t.includes("opera")?"opera":t.includes("chrome")&&!t.includes("edg")?"blink":t.includes("safari")&&!t.includes("chrome")?"webkit":"unknown"}catch(t){return"unknown"}}_(){try{const t=navigator.userAgent.toLowerCase(),n=navigator,i=["wv","instagram","fban","fbav","tiktok","linkedin","snapchat","twitter","line/","micromessenger","kakaotalk","telegram"];return i.some(n=>t.includes(n))?!![]:void 0===n.standalone||n.standalone?window.self!==window.top?!![]:![]:!![]}catch(t){return![]}}S(){try{const t=Intl.DateTimeFormat().resolvedOptions().timeZone||"UTC";return t.replace(/\//g,"_").substring(0,30)}catch(t){return"UTC"}}D(t){const n=16777619;let i=2166136261,o=2166136261,r=2166136261,s=2166136261;for(let a=0;a<t.length;a++){const l=t.charCodeAt(a);i^=l,i=Math.imul(i,n),o^=l<<1,o=Math.imul(o,n),r^=l<<2,r=Math.imul(r,n),s^=l<<3,s=Math.imul(s,n)}return i=Math.abs(i),o=Math.abs(o),r=Math.abs(r),s=Math.abs(s),i.toString(16)+o.toString(16)+r.toString(16)+s.toString(16)}}class TelemetryService{constructor(){this.eventQueue=[],this.batchTimer=null,this.stats={totalEvents:0,eventsByLevel:{debug:0,log:0,info:0,warn:0,error:0,fatal:0},batchesSent:0,failedBatches:0,queuedEvents:0,droppedEvents:0},this.isShuttingDown=![],this.clientConfig=ClientConfigService.getInstance(),this.store=StoreService.getInstance();const n=this.clientConfig.get("env"),i=new URL("/api/telemetry",this.clientConfig.get("baseUrl")).toString();this.config={enabled:!![],endpoint:i,batchSize:n===t.PRODUCTION?5:10,batchInterval:n===t.PRODUCTION?5e3:3e3,includeDebugLogs:![],includeWarnings:!![],includeErrors:!![],maxQueueSize:50},window.addEventListener("beforeunload",()=>this.shutdown()),window.addEventListener("pagehide",()=>this.shutdown()),this.config.enabled&&this.startBatchTimer()}static getInstance(){return SingletonManager.getClassInstance("TelemetryService",()=>new TelemetryService)}isEnabled(){return this.config.enabled}captureEvent(t,n,i={}){if(!this.isEnabled()||this.isShuttingDown)return;if(!this.shouldCapture(t))return;const o=Date.now();try{const r={eventId:"event_"+o,timestamp:o,level:t,message:n,context:i.context,error:i.error?this.buildErrorContext(i.error):void 0,component:i.component,data:i.data,metadata:{sdk:this.buildSDKContext(),user:this.buildUserContext(),browser:this.buildBrowserContext()}};this.addToQueue(r)}catch(r){this.handleInternalError(r)}}buildErrorContext(t){return{name:t.name,message:t.message,stack:this.truncateStackTrace(t.stack),code:t.code,statusCode:t.status||t.statusCode}}buildSDKContext(){return{version:this.clientConfig.get("version")||"unknown",env:this.clientConfig.get("env"),isBuilder:this.clientConfig.get("isBuilder"),partnerCode:this.clientConfig.get("partnerCode")}}buildUserContext(){const t=this.store.get("address.formattedAddress");return{deviceId:this.clientConfig.get("userDeviceId")||"not_defined",isLocalStorageAvailable:this.clientConfig.get("isLocalStorageAvailable")||![],selectedAddress:t||void 0}}buildBrowserContext(){return{userAgent:navigator.userAgent,deviceType:this.clientConfig.get("deviceType"),url:window.location.href,referrer:document.referrer||void 0,timezone:Intl.DateTimeFormat().resolvedOptions().timeZone}}shouldCapture(t){switch(t){case"debug":case"log":case"info":return this.config.includeDebugLogs;case"warn":return this.config.includeWarnings;case"error":case"fatal":return this.config.includeErrors;default:return![]}}addToQueue(t){this.eventQueue.length>=this.config.maxQueueSize&&(this.eventQueue.shift(),this.stats.droppedEvents++),this.eventQueue.push(t),this.stats.totalEvents++,this.stats.eventsByLevel[t.level]++,this.stats.queuedEvents=this.eventQueue.length,this.eventQueue.length>=this.config.batchSize&&this.flushQueue()}startBatchTimer(){this.batchTimer&&clearInterval(this.batchTimer),this.batchTimer=setInterval(()=>{this.eventQueue.length>0&&this.flushQueue()},this.config.batchInterval)}flushQueue(){var t;if(0===this.eventQueue.length||!(null===(t=this.config)||void 0===t?void 0:t.endpoint))return;const n=this.eventQueue.splice(0,this.config.batchSize);this.stats.queuedEvents=this.eventQueue.length;const i=this.createBatch(n);try{this.sendBatch(i),this.stats.batchesSent++}catch(o){this.stats.failedBatches++,this.handleInternalError(o),this.eventQueue.unshift(...n),this.stats.queuedEvents=this.eventQueue.length}}createBatch(t){const n=Date.now();return{batchId:"batch_"+n,timestamp:n,events:t}}sendBatch(t){if("undefined"!=typeof navigator&&navigator.sendBeacon)try{const n=new Blob([JSON.stringify(t)],{type:"text/plain"}),i=navigator.sendBeacon(this.config.endpoint,n);if(i)return}catch(n){return this.sendBatchViaXHR(t),void 0}this.sendBatchViaXHR(t)}sendBatchViaXHR(t){try{const n=new XMLHttpRequest;if(n.open("POST",this.config.endpoint,![]),n.setRequestHeader("Content-Type","text/plain"),n.send(JSON.stringify(t)),n.status<200||n.status>=300)throw new SDKError("XHR request failed with status: "+n.status)}catch(n){throw new SDKError("Both sendBeacon and XHR failed: "+n.message)}}truncateStackTrace(t){if(t)return t.split("\n").slice(0,10).join("\n")}handleInternalError(t){this.clientConfig.isProduction()&&!this.clientConfig.isDebuggingEnabled()||console.error("[LiquidCommerce Elements][Telemetry Internal Error]",t)}shutdown(){var t;if(!this.isShuttingDown&&(this.isShuttingDown=!![],this.batchTimer&&(clearInterval(this.batchTimer),this.batchTimer=null),this.eventQueue.length>0&&(null===(t=this.config)||void 0===t?void 0:t.endpoint))){const t=this.createBatch(this.eventQueue);this.eventQueue=[];try{this.sendBatch(t),this.stats.batchesSent++}catch(n){this.stats.failedBatches++}}}}class BaseComponent extends HTMLElement{get hostClasses(){return[]}get hostAttributes(){return{}}constructor(t={}){super(),this.initialized=![],this.isDestroyed=![],this.renderScheduled=![],this.unsubscribers=[],this.lastRenderTrigger="initial",this.renderCount=0,this.store=StoreService.getInstance(),this.commands=CommandService.getInstance(),this.themeProvider=ThemeProviderService.getInstance(),this.pubSub=PubSubService.getInstance(),this.logger=LoggerFactory.get("BaseComponent"),this.clientConfig=ClientConfigService.getInstance(),this.telemetry=TelemetryService.getInstance(),this.reactiveOptions={watchStorePaths:[],watchOnlyStorePaths:[],autoDestroy:![],autoDestroyDelay:0,...t}}initialize({data:t,config:n}){var i;this.I=Object.freeze(t),this.F=Object.freeze({type:n.type,tagName:this.tagName.toLowerCase(),useShadowDom:null!==(i=null==n?void 0:n.useShadowDom)&&void 0!==i?i:![]}),this.initialized&&(this.setup(),this.triggerRender("initialize"))}interpolateStorePaths(t){return t.map(t=>this.interpolatePath(t))}interpolatePath(t){if("string"!=typeof t)return t;const n=/\{([^}]+)}/g;return t.replace(n,(n,i)=>{const o=this.I[i];return null==o?(this.logger.warn('Parameter "'+i+'" not found in component params for path "'+t+'"'),n):String(o)})}connectedCallback(){var t,n;try{if(this.isDestroyed)return;this.initialized=!![],this.container=this.F.useShadowDom?this.attachShadow({mode:this.clientConfig.get("openShadowDom")?"open":"closed"}):this,this.setup(),this.triggerRender("connected"),null===(t=this.connected)||void 0===t||t.call(this)}catch(i){this.logger.error("Component connectedCallback error in "+((null===(n=this.F)||void 0===n?void 0:n.tagName)||"unknown"),i),i instanceof Error&&this.captureComponentError(i,"connectedCallback")}}disconnectedCallback(){var t,n;try{this.cleanup(),null===(t=this.disconnected)||void 0===t||t.call(this)}catch(i){this.logger.error("Component disconnectedCallback error in "+((null===(n=this.F)||void 0===n?void 0:n.tagName)||"unknown"),i),i instanceof Error&&this.captureComponentError(i,"disconnectedCallback")}}setup(){var t,n,i;try{this.updateHostClasses(),this.updateHostAttributes(),null===(t=this.beforeSetupStoreWatchers)||void 0===t||t.call(this),this.setupStoreWatchers(),this.setupNonRenderingWatchers(),this.setupAutoDestroy(),null===(n=this.beforeConnected)||void 0===n||n.call(this)}catch(o){this.logger.error("Component setup error in "+((null===(i=this.F)||void 0===i?void 0:i.tagName)||"unknown"),o),o instanceof Error&&this.captureComponentError(o,"setup")}}cleanup(){this.isDestroyed=!![],this.renderTimeout&&cancelAnimationFrame(this.renderTimeout),this.autoDestroyTimeout&&clearTimeout(this.autoDestroyTimeout);for(const n of this.unsubscribers)try{n()}catch(t){this.logger.error("Cleanup error during component destruction",t),t instanceof Error&&this.captureComponentError(t,"cleanup")}this.unsubscribers=[]}setupAutoDestroy(){var t;if(!this.reactiveOptions.autoDestroy)return;let n=this.reactiveOptions.autoDestroyPath;if(!n&&(null===(t=this.reactiveOptions.watchStorePaths)||void 0===t?void 0:t.length)&&(n=this.reactiveOptions.watchStorePaths[0]),!n)return this.logger.warn("AutoDestroy enabled but no path specified and no watchStorePaths found"),void 0;const i=this.interpolatePath(n),o=this.store.watch(i,(t,n)=>{this.isDestroyed||void 0===t&&void 0!==n&&this.handleAutoDestroy(i)});this.unsubscribers.push(o)}handleAutoDestroy(t){var n;if(this.isDestroyed)return;null===(n=this.beforeAutoDestroy)||void 0===n?void 0:n.call(this,t);const i=this.reactiveOptions.autoDestroyDelay||0;i>0?this.autoDestroyTimeout=setTimeout(()=>{this.destroyComponent()},i):this.destroyComponent()}destroyComponent(){var t;if(!this.isDestroyed)try{null===(t=this.onAutoDestroy)||void 0===t?void 0:t.call(this),this.remove()}catch(n){this.logger.error("Error during auto-destroy of "+this.F.tagName,n),n instanceof Error&&this.captureComponentError(n,"auto-destroy")}}setupStoreWatchers(){var t;try{let t=this.reactiveOptions.watchStorePaths;if(!(null==t?void 0:t.length)||!this.I)return;t=this.interpolateStorePaths(t);const n=this.store.watchMany(t,t=>{var n,i;try{if(this.isDestroyed)return;const i=t.map(t=>t.path).join(", "),o="store:["+i+"]",r=null===(n=this.onStoreChanged)||void 0===n?void 0:n.call(this,t);r!==![]&&this.triggerRender(o)}catch(o){this.logger.error("Store watcher callback error in "+((null===(i=this.F)||void 0===i?void 0:i.tagName)||"unknown"),o),o instanceof Error&&this.captureComponentError(o,"storeWatcher")}});this.unsubscribers.push(n)}catch(n){this.logger.error("Store watchers setup error in "+((null===(t=this.F)||void 0===t?void 0:t.tagName)||"unknown"),n),n instanceof Error&&this.captureComponentError(n,"setupStoreWatchers")}}setupNonRenderingWatchers(){var t;try{let t=this.reactiveOptions.watchOnlyStorePaths;if(!(null==t?void 0:t.length)||!this.I)return;t=this.interpolateStorePaths(t);const n=this.store.watchMany(t,t=>{var n,i;try{if(this.isDestroyed)return;null===(n=this.onStoreWatch)||void 0===n?void 0:n.call(this,t)}catch(o){this.logger.error("Non-rendering watcher callback error in "+((null===(i=this.F)||void 0===i?void 0:i.tagName)||"unknown"),o),o instanceof Error&&this.captureComponentError(o,"nonRenderingWatcher")}});this.unsubscribers.push(n)}catch(n){this.logger.error("Non-rendering watchers setup error in "+((null===(t=this.F)||void 0===t?void 0:t.tagName)||"unknown"),n),n instanceof Error&&this.captureComponentError(n,"setupNonRenderingWatchers")}}triggerRender(t){this.lastRenderTrigger=t,this.scheduleRender()}scheduleRender(){this.renderScheduled||this.isDestroyed||(this.renderScheduled=!![],this.renderTimeout=requestAnimationFrame(()=>{this.render(),this.renderScheduled=![]}))}render(){var t,n;if(!this.initialized||this.isDestroyed)return;const i=performance.now();this.renderCount++;try{const n=this.template();"string"==typeof n&&(this.container.innerHTML=n),n instanceof HTMLElement&&safeReplaceChildren(this.container,n),Array.isArray(n)&&safeReplaceChildren(this.container,...n);const r=performance.now()-i;this.logRenderInfo(r);try{null===(t=this.afterRender)||void 0===t?void 0:t.call(this)}catch(o){this.logger.error("❌ afterRender hook error in "+this.F.tagName,o),o instanceof Error&&this.captureComponentError(o,"afterRender")}}catch(r){const t=performance.now()-i;this.logger.error("❌ Component render error in "+this.F.tagName,r),this.captureComponentError(r,"render",t),safeReplaceChildren(this.container,ComponentFactoryService.componentError({componentType:this.F.type,message:r instanceof Error?r.message:String(r)}));try{null===(n=this.onError)||void 0===n?void 0:n.call(this,r,"render")}catch(s){this.logger.error("❌ onError hook error in "+this.F.tagName,s)}}}logRenderInfo(t){const n=this.F.type,i=this.F.tagName,o=t>16?"🐌":t>8?"⚡":"🚀";this.logger.debug("Rendered "+o+" "+n+" </"+i+"> | #"+this.renderCount+" | "+t.toFixed(2)+"ms | "+this.lastRenderTrigger),t>16&&(this.logger.warn("⚠️ Slow render in "+n+"("+i+"): "+t.toFixed(2)+"ms triggered by "+this.lastRenderTrigger,{duration:t,threshold:16,componentType:n,tagName:i,renderTrigger:this.lastRenderTrigger,renderCount:this.renderCount}),this.telemetry.captureEvent("warn","Slow render: "+t.toFixed(2)+"ms",{context:"Component:"+i+":performance",component:{type:n,tagName:i,renderCount:this.renderCount,renderTrigger:this.lastRenderTrigger,renderDuration:t,useShadowDom:this.F.useShadowDom}}))}rerender(t){this.triggerRender(t?"manual:rerender:"+t:"manual:rerender()")}captureComponentError(t,n,i){if(this.telemetry.isEnabled())try{this.telemetry.captureEvent("error",t.message,{context:"Component:"+this.F.tagName+":"+n,component:{type:this.F.type,tagName:this.F.tagName,renderCount:this.renderCount,renderTrigger:this.lastRenderTrigger,renderDuration:i,useShadowDom:this.F.useShadowDom}})}catch(o){}}updateHostClasses(){const t=this.hostClasses;if(t.length>0){const n=t.filter(t=>t&&"string"==typeof t&&t.trim());n.length>0&&this.classList.add(...n)}}addHostClasses(...t){const n=t.filter(t=>t&&"string"==typeof t&&t.trim());n.length>0&&this.classList.add(...n)}removeHostClasses(...t){const n=t.filter(t=>t&&"string"==typeof t&&t.trim());n.length>0&&this.classList.remove(...n)}toggleHostClasses(...t){const n=t.filter(t=>t&&"string"==typeof t&&t.trim());for(const i of n)this.classList.toggle(i)}addHostAttribute(t,n){t&&"string"==typeof t&&n&&"string"==typeof n&&(this.setAttribute(t,String(n)),this.hostAttributes[t]=String(n))}removeHostAttribute(t){t&&"string"==typeof t&&(this.removeAttribute(t),delete this.hostAttributes[t])}updateHostAttributes(){const t=this.hostAttributes;for(const[n,i]of Object.entries(t))n&&"string"==typeof n&&i&&"string"==typeof i&&this.setAttribute(n,String(i))}get params(){return this.I}get config(){return this.themeProvider.getComponentConfig(this.F.type)}get elementConfig(){return this.F}getConfigs(t){return this.themeProvider.getConfigs(t)}getStoreValue(t){return this.store.get(t)}setStoreValue(t,n){return this.store.set(t,n)}watchStore(t,n){const i=this.store.watch(t,n);return this.unsubscribers.push(i),i}}class AddressComponent extends BaseComponent{constructor(){super({watchOnlyStorePaths:["address"]})}template(){var t;const n=null!==(t=this.params.options)&&void 0!==t?t:{};return ComponentFactoryService.createElement({type:o.ADDRESS_DISPLAY,isIndependentComponent:!![],options:n})}}class AddressDisplayComponent extends BaseComponent{get hostClasses(){return["address-display-container"]}constructor(){super({watchStorePaths:["address"]})}template(){var t,n,i,r;const s=this.getStoreValue("address"),a=null!==(t=this.params.isIndependentComponent)&&void 0!==t?t:![],l=null!==(n=this.params.productId)&&void 0!==n?n:"",c=null!==(i=this.params.options)&&void 0!==i?i:{},d=null!==(r=c.showLabel)&&void 0!==r?r:!![],u=[];if(d){const t=document.createElement("span");t.textContent="Delivers to:",u.push(t)}const h=document.createElement("button");h.type="button",h.textContent=s.formattedAddress||"Select an address";const p=s.formattedAddress?"Change delivery address, currently set to "+s.formattedAddress:"Select delivery address";return h.setAttribute("aria-label",p),h.addEventListener("click",async()=>{if(a)return this.commands.ui.openDrawer(o.ADDRESS_INPUT,{productId:l,isIndependentComponent:!![]}),void 0;!a&&l&&(this.clientConfig.isMobile()&&this.commands.ui.openDrawer(o.ADDRESS_INPUT,{productId:l}),this.clientConfig.isMobile()||await this.commands.product.openProductDrawer(l,o.ADDRESS_INPUT,{productId:l}))}),u.push(h),u}}const ArrowRightIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="arrow-right-icon '+i+'" style="'+r+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M7.52794 2.86225C7.78829 2.6019 8.2104 2.6019 8.47075 2.86225L13.1374 7.52892C13.3978 7.78927 13.3978 8.21138 13.1374 8.47173L8.47075 13.1384C8.2104 13.3987 7.78829 13.3987 7.52794 13.1384C7.26759 12.878 7.26759 12.4559 7.52794 12.1956L11.0565 8.66699H3.33268C2.96449 8.66699 2.66602 8.36851 2.66602 8.00033C2.66602 7.63214 2.96449 7.33366 3.33268 7.33366H11.0565L7.52794 3.80506C7.26759 3.54471 7.26759 3.1226 7.52794 2.86225Z"/>\n </svg>\n '},BagIcon=({width:t=24,height:n=24,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 489 489" class="bag-icon '+i+'" style="'+r+'" data-fill-only>\n <path d="M440.1,422.7l-28-315.3c-0.6-7-6.5-12.3-13.4-12.3h-57.6C340.3,42.5,297.3,0,244.5,0s-95.8,42.5-96.6,95.1H90.3 c-7,0-12.8,5.3-13.4,12.3l-28,315.3c0,0.4-0.1,0.8-0.1,1.2c0,35.9,32.9,65.1,73.4,65.1h244.6c40.5,0,73.4-29.2,73.4-65.1 C440.2,423.5,440.2,423.1,440.1,422.7z M244.5,27c37.9,0,68.8,30.4,69.6,68.1H174.9C175.7,57.4,206.6,27,244.5,27z M366.8,462 H122.2c-25.4,0-46-16.8-46.4-37.5l26.8-302.3h45.2v41c0,7.5,6,13.5,13.5,13.5s13.5-6,13.5-13.5v-41h139.3v41 c0,7.5,6,13.5,13.5,13.5s13.5-6,13.5-13.5v-41h45.2l26.9,302.3C412.8,445.2,392.1,462,366.8,462z"/>\n </svg>\n'},CheckboxIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="checkbox-icon '+i+'" style="'+r+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M13.8047 3.52885C14.0651 3.7892 14.0651 4.21131 13.8047 4.47166L6.4714 11.805C6.21106 12.0653 5.78894 12.0653 5.5286 11.805L2.19526 8.47166C1.93491 8.21131 1.93491 7.7892 2.19526 7.52885C2.45561 7.2685 2.87772 7.2685 3.13807 7.52885L6 10.3908L12.8619 3.52885C13.1223 3.2685 13.5444 3.2685 13.8047 3.52885Z"/>\n </svg>\n '},ChevronDownIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="'+i+'" style="'+r+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M3.52827 5.52876C3.78862 5.26841 4.21073 5.26841 4.47108 5.52876L7.99967 9.05735L11.5283 5.52876C11.7886 5.26841 12.2107 5.26841 12.4711 5.52876C12.7314 5.78911 12.7314 6.21122 12.4711 6.47157L8.47108 10.4716C8.21073 10.7319 7.78862 10.7319 7.52827 10.4716L3.52827 6.47157C3.26792 6.21122 3.26792 5.78911 3.52827 5.52876Z" fill="#18181B"/>\n </svg>\n '},ChevronLeftIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="chevron-left-icon '+i+'" style="'+r+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M10.4721 3.52864C10.7324 3.78899 10.7324 4.2111 10.4721 4.47145L6.94346 8.00004L10.4721 11.5286C10.7324 11.789 10.7324 12.2111 10.4721 12.4714C10.2117 12.7318 9.7896 12.7318 9.52925 12.4714L5.52925 8.47145C5.2689 8.2111 5.2689 7.78899 5.52925 7.52864L9.52925 3.52864C9.7896 3.26829 10.2117 3.26829 10.4721 3.52864Z"/>\n </svg>\n '},CloseIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="close-icon '+i+'" style="'+r+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M3.52925 3.52864C3.7896 3.26829 4.21171 3.26829 4.47206 3.52864L8.00065 7.05723L11.5292 3.52864C11.7896 3.26829 12.2117 3.26829 12.4721 3.52864C12.7324 3.78899 12.7324 4.2111 12.4721 4.47145L8.94346 8.00004L12.4721 11.5286C12.7324 11.789 12.7324 12.2111 12.4721 12.4714C12.2117 12.7318 11.7896 12.7318 11.5292 12.4714L8.00065 8.94285L4.47206 12.4714C4.21171 12.7318 3.7896 12.7318 3.52925 12.4714C3.2689 12.2111 3.2689 11.789 3.52925 11.5286L7.05784 8.00004L3.52925 4.47145C3.2689 4.2111 3.2689 3.78899 3.52925 3.52864Z"/>\n </svg>\n '},ErrorInfoIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'<svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="error-info-icon '+i+'" style="'+r+'" data-fill-only>\n<path fill-rule="evenodd" clip-rule="evenodd" d="M8.00033 1.99996C4.68662 1.99996 2.00033 4.68625 2.00033 7.99996C2.00033 11.3137 4.68662 14 8.00033 14C11.314 14 14.0003 11.3137 14.0003 7.99996C14.0003 4.68625 11.314 1.99996 8.00033 1.99996ZM0.666992 7.99996C0.666992 3.94987 3.95024 0.666626 8.00033 0.666626C12.0504 0.666626 15.3337 3.94987 15.3337 7.99996C15.3337 12.05 12.0504 15.3333 8.00033 15.3333C3.95024 15.3333 0.666992 12.05 0.666992 7.99996ZM8.00033 4.66663C8.36852 4.66663 8.66699 4.9651 8.66699 5.33329V7.99996C8.66699 8.36815 8.36852 8.66663 8.00033 8.66663C7.63213 8.66663 7.33366 8.36815 7.33366 7.99996V5.33329C7.33366 4.9651 7.63213 4.66663 8.00033 4.66663ZM7.33366 10.6666C7.33366 10.2984 7.63213 9.99996 8.00033 9.99996H8.00699C8.37518 9.99996 8.67366 10.2984 8.67366 10.6666C8.67366 11.0348 8.37518 11.3333 8.00699 11.3333H8.00033C7.63213 11.3333 7.33366 11.0348 7.33366 10.6666Z"/>\n</svg>'},InfoIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="info-icon '+i+'" style="'+r+'" data-fill-only>\n <path d="M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z"/>\n <path d="m8.93 6.588-2.29.287-.082.38.45.083c.294.07.352.176.288.469l-.738 3.468c-.194.897.105 1.319.808 1.319.545 0 1.178-.252 1.465-.598l.088-.416c-.2.176-.492.246-.686.246-.275 0-.375-.193-.304-.533L8.93 6.588zM9 4.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0z"/>\n </svg>\n '},SearchIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o||"currentColor";return'<svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="search-icon '+i+'">\n <path d="M14.0001 14L11.1335 11.1333M12.6667 7.33333C12.6667 10.2789 10.2789 12.6667 7.33333 12.6667C4.38781 12.6667 2 10.2789 2 7.33333C2 4.38781 4.38781 2 7.33333 2C10.2789 2 12.6667 4.38781 12.6667 7.33333Z" fill="none" stroke="'+r+'" stroke-width="1.33" stroke-linecap="round" stroke-linejoin="round"/>\n</svg>'},SuccessIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="success-icon '+i+'" style="'+r+'" data-fill-only>\n <path d="M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z"/>\n </svg>\n '},TrashIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="trash-icon '+i+'" style="'+r+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M6.22157 2.22161C6.06513 2.37804 6.00016 2.55036 6.00016 2.66687V3.33354H10.0002V2.66687C10.0002 2.55036 9.93519 2.37804 9.77876 2.22161C9.62232 2.06517 9.45001 2.0002 9.3335 2.0002H6.66683C6.55032 2.0002 6.378 2.06517 6.22157 2.22161ZM11.3335 3.33354V2.66687C11.3335 2.11672 11.0651 1.62236 10.7216 1.2788C10.378 0.935235 9.88365 0.66687 9.3335 0.66687H6.66683C6.11668 0.66687 5.62232 0.935235 5.27876 1.2788C4.93519 1.62236 4.66683 2.11672 4.66683 2.66687V3.33354H2.00016C1.63197 3.33354 1.3335 3.63201 1.3335 4.0002C1.3335 4.36839 1.63197 4.66687 2.00016 4.66687H2.66683V13.3335C2.66683 13.8837 2.93519 14.378 3.27876 14.7216C3.62232 15.0652 4.11668 15.3335 4.66683 15.3335H11.3335C11.8837 15.3335 12.378 15.0652 12.7216 14.7216C13.0651 14.378 13.3335 13.8837 13.3335 13.3335V4.66687H14.0002C14.3684 4.66687 14.6668 4.36839 14.6668 4.0002C14.6668 3.63201 14.3684 3.33354 14.0002 3.33354H11.3335ZM4.00016 4.66687V13.3335C4.00016 13.45 4.06513 13.6224 4.22157 13.7788C4.378 13.9352 4.55032 14.0002 4.66683 14.0002H11.3335C11.45 14.0002 11.6223 13.9352 11.7788 13.7788C11.9352 13.6224 12.0002 13.45 12.0002 13.3335V4.66687H4.00016ZM6.66683 6.66687C7.03502 6.66687 7.3335 6.96535 7.3335 7.33354V11.3335C7.3335 11.7017 7.03502 12.0002 6.66683 12.0002C6.29864 12.0002 6.00016 11.7017 6.00016 11.3335V7.33354C6.00016 6.96535 6.29864 6.66687 6.66683 6.66687ZM9.3335 6.66687C9.70169 6.66687 10.0002 6.96535 10.0002 7.33354V11.3335C10.0002 11.7017 9.70169 12.0002 9.3335 12.0002C8.96531 12.0002 8.66683 11.7017 8.66683 11.3335V7.33354C8.66683 6.96535 8.96531 6.66687 9.3335 6.66687Z"/>\n </svg>\n '},WarningIcon=({width:t=16,height:n=16,className:i="",color:o=null})=>{const r=o?"--icon-color: "+o:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+t+'" height="'+n+'" viewBox="0 0 16 16" class="warning-icon '+i+'" style="'+r+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M7.99984 2.00033C4.68613 2.00033 1.99984 4.68662 1.99984 8.00033C1.99984 11.314 4.68613 14.0003 7.99984 14.0003C11.3135 14.0003 13.9998 11.314 13.9998 8.00033C13.9998 4.68662 11.3135 2.00033 7.99984 2.00033ZM0.666504 8.00033C0.666504 3.95024 3.94975 0.666992 7.99984 0.666992C12.0499 0.666992 15.3332 3.95024 15.3332 8.00033C15.3332 12.0504 12.0499 15.3337 7.99984 15.3337C3.94975 15.3337 0.666504 12.0504 0.666504 8.00033ZM7.99984 4.66699C8.36803 4.66699 8.6665 4.96547 8.6665 5.33366V8.00033C8.6665 8.36852 8.36803 8.66699 7.99984 8.66699C7.63165 8.66699 7.33317 8.36852 7.33317 8.00033V5.33366C7.33317 4.96547 7.63165 4.66699 7.99984 4.66699ZM7.33317 10.667C7.33317 10.2988 7.63165 10.0003 7.99984 10.0003H8.0065C8.37469 10.0003 8.67317 10.2988 8.67317 10.667C8.67317 11.0352 8.37469 11.3337 8.0065 11.3337H7.99984C7.63165 11.3337 7.33317 11.0352 7.33317 10.667Z"/>\n </svg>\n '};class AddressInputComponent extends BaseComponent{constructor(){super({watchStorePaths:["address"]}),this.suggestions=[],this.error=null,this.selectedAddress=null,this.minSearchLength=3,this.isIndependentComponent=()=>{var t;return null!==(t=this.params.isIndependentComponent)&&void 0!==t?t:![]},this.handleInputChange=t=>{const n=t.target,i=n.value.replace(/[^a-zA-Z0-9\s\-.,#'/]/g,"");n.value=i;const o=i.trim();this.searchTimeout&&clearTimeout(this.searchTimeout),this.selectedAddress=null,this.error=null,this.updateErrorDisplay();const r=/^\d/.test(o);if(o.length<this.minSearchLength||!r)return this.suggestions=[],this.hideSuggestions(),void 0;this.searchTimeout=setTimeout(async()=>{await this.searchAddresses(o)},300)},this.closeDrawer=async()=>{const t=this.params.productId,n=this.clientConfig.isMobile(),i=this.isIndependentComponent();(n||i)&&this.commands.ui.closeDrawer(),!n&&t&&await this.commands.product.closeProductDrawer(t)},this.handleCancel=async()=>{try{await this.closeDrawer(),this.suggestions=[],this.error=null,this.hideSuggestions(),this.updateErrorDisplay()}catch(X){this.logger.error("Address edit cancellation failed",X)}},this.handleCheckAvailability=async()=>{if(!this.selectedAddress)return this.error="Please select a valid address first",this.updateErrorDisplay(),this.showSuggestions(),void 0;try{this.error=null,this.updateErrorDisplay();const t=this.getStoreValue("address"),n=(null==t?void 0:t.coordinates.lat)!==this.selectedAddress.coordinates.lat||(null==t?void 0:t.coordinates.long)!==this.selectedAddress.coordinates.long;n&&await this.commands.address.setSelectedAddress(this.selectedAddress),await this.closeDrawer()}catch(t){this.logger.error("Address selection and availability check failed",t),this.error="Failed to update address. Please try again.",this.updateErrorDisplay()}},this.handleSuggestionClick=async t=>{const n=t.currentTarget.dataset.suggestionId;if(n)try{this.error=null,this.updateErrorDisplay();const t=await this.commands.address.getAddressDetails(n);if(0===Object.keys(t).length)return this.error="No details found for the selected address.",this.updateErrorDisplay(),void 0;this.selectedAddress={id:n,address:t.address,coordinates:t.coords,formattedAddress:t.formattedAddress},this.inputElement.value=this.selectedAddress.formattedAddress,this.hideSuggestions()}catch(i){this.logger.error("Address details retrieval failed",i),this.error="Failed to get address details. Please try again.",this.updateErrorDisplay()}},this.handleDocumentClick=t=>{this.container.contains(t.target)||this.hideSuggestions()}}get hostClasses(){return["address-input-container"]}beforeConnected(){const t=this.getStoreValue("address");(null==t?void 0:t.formattedAddress)&&(this.selectedAddress=t)}async searchAddresses(t){try{this.error=null,this.updateErrorDisplay(),this.showSuggestions();const n=await this.commands.address.searchAddresses(t);this.suggestions=n.slice(0,5),this.updateSuggestionsDisplay(),this.showSuggestions()}catch(n){this.logger.error("Address search operation failed",n),this.error="Failed to search addresses. Please try again.",this.suggestions=[],this.updateErrorDisplay(),this.updateSuggestionsDisplay()}}updateErrorDisplay(){if(!this.errorContainer)return;if(!this.error)return this.errorContainer.style.display="none",void 0;this.errorContainer.style.display="block";const t=this.errorContainer.querySelector(".error-text");t&&(t.textContent=this.error)}updateSuggestionsDisplay(){if(this.suggestionsContainer){if(this.suggestionsContainer.innerHTML="",0===this.suggestions.length){const t=this.createElement("li",{className:"suggestion-item no-suggestions",textContent:"No matching address found."});return this.suggestionsContainer.appendChild(t),void 0}for(const t of this.suggestions){const n=this.createElement("li",{className:"suggestion-item"}),i=this.createElement("span",{textContent:t.description});n.appendChild(i),n.setAttribute("data-suggestion-id",t.id),n.setAttribute("role","option"),n.setAttribute("aria-label","Select address: "+t.description),n.setAttribute("tabindex","0"),n.addEventListener("click",this.handleSuggestionClick),n.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),n.click())}),this.suggestionsContainer.appendChild(n)}}}showSuggestions(){this.suggestionsContainer&&(this.suggestionsContainer.classList.remove("hide"),this.suggestionsContainer.classList.add("show")),this.inputElement&&this.inputElement.setAttribute("aria-expanded","true"),this.inputContainer&&this.inputContainer.classList.add("suggestions-expanded")}hideSuggestions(){this.suggestionsContainer&&(this.suggestionsContainer.classList.remove("show"),this.suggestionsContainer.classList.add("hide")),this.inputElement&&this.inputElement.setAttribute("aria-expanded","false"),this.inputContainer&&this.inputContainer.classList.remove("suggestions-expanded")}createElement(t,n){const i=document.createElement(t);return n&&Object.assign(i,n),i}createErrorContainer(){const t=this.createElement("div",{className:"error-message"});t.style.display="none",t.setAttribute("role","alert"),t.setAttribute("aria-live","assertive"),t.setAttribute("aria-atomic","true");const n=this.createElement("span",{className:"error-icon",textContent:"⚠️"}),i=this.createElement("span",{className:"error-text"});return t.appendChild(n),t.appendChild(i),t}createCheckButton(){const t=this.createElement("button",{type:"button",className:"primary-button",textContent:"Save"});return t.setAttribute("aria-label","Save and check address availability"),t.addEventListener("click",this.handleCheckAvailability),t}createCancelButton(){const t=this.createElement("button",{type:"button",className:"secondary-button",textContent:"Cancel"});return t.setAttribute("aria-label","Cancel address selection"),t.addEventListener("click",this.handleCancel),t}template(){var t,n,i;const o=this.getConfigs("global"),r=null!==(t=this.params.options)&&void 0!==t?t:{},s=null!==(n=r.showLabel)&&void 0!==n?n:!![];if(this.inputContainer=this.createElement("div",{className:"input-section"}),s){const t=this.createElement("h2",{className:"input-title",textContent:"Enter delivery address"});this.inputContainer.appendChild(t)}const a=this.createElement("div",{className:"input-wrapper "+o.layout.inputFieldStyle});this.inputElement=this.createElement("input",{type:"text",id:"address-input",className:"input-field",value:(null===(i=this.selectedAddress)||void 0===i?void 0:i.formattedAddress)||"",autocomplete:"off",placeholder:"Enter an address"}),this.inputElement.setAttribute("role","combobox"),this.inputElement.setAttribute("aria-label","Enter delivery address"),this.inputElement.setAttribute("aria-autocomplete","list"),this.inputElement.setAttribute("aria-controls","address-suggestions"),this.inputElement.setAttribute("aria-expanded","false"),this.inputElement.setAttribute("aria-haspopup","listbox"),this.inputElement.addEventListener("input",this.handleInputChange),a.appendChild(this.inputElement);const l=this.createElement("span");l.className="input-icon",l.innerHTML=SearchIcon({width:16,height:16,className:""}),a.appendChild(l),this.inputContainer.appendChild(a),this.suggestionsContainer=this.createElement("ul",{className:"suggestions-list hide"}),this.suggestionsContainer.setAttribute("id","address-suggestions"),this.suggestionsContainer.setAttribute("role","listbox"),this.suggestionsContainer.setAttribute("aria-label","Address suggestions"),this.inputContainer.appendChild(this.suggestionsContainer),this.errorContainer=this.createErrorContainer();const c=this.createElement("span",{className:"privacy-notice",textContent:"This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply."}),d=[this.inputContainer,c,this.errorContainer],u=this.createElement("div",{className:"action-buttons"}),h=this.createCancelButton();u.appendChild(h);const p=this.createCheckButton();return u.appendChild(p),d.push(u),document.addEventListener("click",this.handleDocumentClick),d}disconnected(){this.searchTimeout&&clearTimeout(this.searchTimeout),document.removeEventListener("click",this.handleDocumentClick)}}class CartComponent extends BaseComponent{get hostClasses(){const t=["cart-container"];return this.params.isIndependentComponent&&!this.clientConfig.isBuilder()&&t.push("cart-no-header"),this.params.isIndependentComponent&&t.push("independent"),t}constructor(){super({watchStorePaths:["cart.rerender"]})}template(){const t=[],n=this.params.isIndependentComponent&&!this.clientConfig.isBuilder();if(!n){const n=ComponentFactoryService.createElement({type:o.CART_HEADER});t.push(n)}const i=ComponentFactoryService.createElement({type:o.CART_BODY});t.push(i);const r=ComponentFactoryService.createElement({type:o.CART_FOOTER});return t.push(r),t}}class CartBodyComponent extends BaseComponent{get hostClasses(){return["cart-body"]}constructor(){super({watchStorePaths:["cart.retailers","cart.loading"]})}createEmptyCartElement(){const t=document.createElement("div");t.className="empty-cart-container";const n=document.createElement("h3");return n.className="empty-cart-content",n.textContent="Your cart is empty",t.appendChild(n),t}createLoadingElement(){const t=document.createElement("div");return t.setAttribute("data-component-type","cart-body-loading"),t.innerHTML=this.loadingTemplate(),t}loadingTemplate(){return'\n <div class="cart-loading-backdrop">\n <div class="cart-loading-spinner-container">\n <div class="cart-loading-spinner">\n <svg class="cart-spinner" width="50" height="50" viewBox="0 0 50 50">\n <circle\n class="cart-spinner-path"\n cx="25"\n cy="25"\n r="20"\n fill="none"\n stroke-width="3"\n stroke-linecap="round"\n stroke-dasharray="31.416"\n stroke-dashoffset="31.416"\n />\n </svg>\n </div>\n </div>\n </div>\n '}createRetailerElement(t){try{return ComponentFactoryService.createElement({type:o.CART_RETAILER,retailerId:t.id})}catch(n){return this.logger.error("Cart retailer component creation failed",n),document.createElement("div")}}getRetailerElementById(t){return this.container.querySelector('[data-retailer-id="'+t+'"]')}getLoadingElement(){return this.container.querySelector('[data-component-type="cart-body-loading"]')}showEmptyCartState(){this.container.innerHTML="";const t=this.createEmptyCartElement();this.container.appendChild(t),this.setupEmptyCartListeners()}addLoadingOverlay(){const t=this.getLoadingElement();if(!t){const t=this.createLoadingElement();this.container.appendChild(t)}}removeLoadingOverlay(){const t=this.getLoadingElement();t&&t.remove()}setupEmptyCartListeners(){const t=this.container.querySelector('[data-action="continue-shopping"]');t&&t.addEventListener("click",()=>{this.commands.ui.closeDrawer()})}addRetailerElement(t,n){const i=this.createRetailerElement(n);i.setAttribute("data-retailer-id",t),this.container.appendChild(i)}removeRetailerElement(t){const n=this.getRetailerElementById(t);n&&n.remove()}updateRetailerElement(t,n){const i=this.getRetailerElementById(t);if(i){const o=this.createRetailerElement(n);o.setAttribute("data-retailer-id",t),i.replaceWith(o)}}hasRetailerDataChanged(t,n){return t?![]:!![]}getValidRetailers(t){if(!t)return{};const n={};for(const[i,o]of Object.entries(t))o&&"object"==typeof o&&o.id&&(n[i]=o);return n}getValidRetailerIds(t){const n=this.getValidRetailers(t);return new Set(Object.keys(n))}onStoreChanged(t){const n=t.find(t=>"cart.retailers"===t.path),i=t.find(t=>"cart.loading"===t.path);if(n){const t=this.getValidRetailers(n.oldValue),i=this.getValidRetailers(n.value),o=this.getValidRetailerIds(n.oldValue),r=this.getValidRetailerIds(n.value),s=o.size,a=r.size,l=this.getValidRetailers(this.getStoreValue("cart.retailers")),c=Object.keys(l).length;if(a>0&&0===c)return this.showEmptyCartState(),![];if(this.removeLoadingOverlay(),0===s&&a>0){this.container.innerHTML="";for(const[t,n]of Object.entries(i))this.addRetailerElement(t,n)}else if(s>0&&0===a)this.showEmptyCartState();else if(a>0){for(const t of o)r.has(t)||this.removeRetailerElement(t);for(const n of r){const r=i[n],s=t[n];o.has(n)?this.hasRetailerDataChanged(s,r)&&this.updateRetailerElement(n,r):this.addRetailerElement(n,r)}}else 0===s&&0===a&&this.showEmptyCartState()}if(i){const t=i.value,n=i.oldValue;t!==n&&(t?this.addLoadingOverlay():this.removeLoadingOverlay())}return i||n,![]}afterRender(){this.setupEmptyCartListeners();const t=this.getStoreValue("cart.loading");t&&this.addLoadingOverlay()}template(){const t=this.getStoreValue("cart.retailers")||{},n=Object.values(t);if(0===n.length)return this.createEmptyCartElement();const i=[];for(const o of n){const t=this.createRetailerElement(o);t.setAttribute("data-retailer-id",o.id),i.push(t)}return i}}class CartFooterComponent extends BaseComponent{get hostClasses(){return["cart-footer"]}constructor(){super({watchOnlyStorePaths:["cart.items","cart.totals","cart.fulfillments","cart.loading","cart.retailers"]})}onStoreWatch(t){const n=t.some(t=>t.path.includes("cart.items")),i=t.some(t=>t.path.includes("cart.totals")),o=t.some(t=>t.path.includes("cart.fulfillments")),r=t.some(t=>"cart.loading"===t.path),s=t.some(t=>t.path.includes("cart.retailers"));if(n&&this.updateSubtotalItemsCount(),i&&this.subtotalPrice){const t=this.getStoreValue("cart.totals");this.subtotalPrice.textContent=""+formatCentToDollarText(t.subtotal+t.engravingFee-t.discounts)}(o||i||r||n||s)&&this.updateCheckoutButtonState()}afterRender(){this.updateSubtotalItemsCount(),this.updateCheckoutButtonState()}isAnythingLoading(){const t=this.getStoreValue("cart.loading");if(t)return!![];const n=this.getStoreValue("cart.items")||{},i=Object.values(n).some(t=>t.updating);if(i)return!![];const o=this.getStoreValue("cart.fulfillments")||{},r=Object.values(o).some(t=>t.updating);if(r)return!![];const s=this.getStoreValue("cart.retailers")||{},a=Object.values(s).some(t=>t.updating);return a?!![]:![]}hasUnmetMinimum(t){var n;const i=t.subtotal;if(t.type===r.SHIPPING){const o=t.fees;if((null===(n=o.individual)||void 0===n?void 0:n.active)&&o.individual.min>0&&i<o.individual.min)return!![]}if(t.type===r.ON_DEMAND){const n=t.fees;if(n.min>0&&i<n.min)return!![]}return![]}shouldDisableCheckout(){const t=this.getStoreValue("cart.fulfillments")||{};return Object.values(t).some(t=>this.hasUnmetMinimum(t))}updateCheckoutButtonState(){const t=this.getStoreValue("cart.items")||{},n=Object.keys(t).length>0;if(this.checkoutButton){const t=this.isAnythingLoading(),i=this.shouldDisableCheckout(),o=t||i||!n;this.checkoutButton.disabled=o,this.checkoutButton.classList.toggle("checkout-btn-disabled",o),this.checkoutButton.classList.toggle("loading",t)}}updateSubtotalItemsCount(){const t=this.getStoreValue("cart.items"),n=Object.values(t).reduce((t,n)=>t+n.quantity,0);this.subtotalText&&(this.subtotalText.textContent="Subtotal ("+n+" item"+(1!==n?"s":"")+"):")}async handleCheckout(t){return this.clientConfig.isBuilder()?(t.preventDefault(),this.logger.info("Cart Go To Checkout Button Is Disabled In Builder Mode"),void 0):this.isAnythingLoading()||this.shouldDisableCheckout()?(t.preventDefault(),void 0):(await this.commands.cart.handleGoToCheckout(),void 0)}template(){const t=this.getConfigs("global"),n=this.getStoreValue("cart.totals"),i=[],r=document.createElement("div");r.className="cart-footer-header";const s=document.createElement("div");s.className="cart-footer-items-price",this.subtotalText=document.createElement("span"),this.subtotalText.className="subtotal-text",this.subtotalText.textContent="Subtotal (0 items):",s.appendChild(this.subtotalText),this.subtotalPrice=document.createElement("span"),this.subtotalPrice.className="subtotal-price",this.subtotalPrice.textContent=formatCentToDollarText(n.subtotal+n.engravingFee-n.discounts),s.appendChild(this.subtotalPrice);const a=document.createElement("p");if(a.textContent="Taxes & fees will be calculated at checkout",a.className="taxes-fees-info",r.appendChild(s),r.appendChild(a),i.push(r),t.layout.allowPromoCodes){const t=ComponentFactoryService.createElement({type:o.CART_PROMO_CODE});i.push(t)}const l=ComponentFactoryService.createElement({type:o.ALERT,errorStorePath:"cart.events",fromEvents:!![],showFirstEvent:![]});if(i.push(l),this.checkoutButton=document.createElement("button"),this.checkoutButton.type="button",this.checkoutButton.className="checkout-button",this.checkoutButton.setAttribute("aria-label","Go to checkout"),this.checkoutButton.textContent=this.config.layout.goToCheckoutButtonText||"Go to Checkout",this.checkoutButton.addEventListener("click",async t=>{t.preventDefault(),await this.handleCheckout(t)}),this.checkoutButton.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await this.handleCheckout(t))}),i.push(this.checkoutButton),t.layout.showPoweredBy){const t=ComponentFactoryService.createElement({type:o.POWERED_BY,context:"general"});i.push(t)}return i}}const shouldShowMinimumPurchaseAlert=(t,n=![])=>{var i,o;if(!t)return![];const s=t.subtotal;if(t.type===r.SHIPPING){const r=t.fees;if(n&&(null===(i=r.pack)||void 0===i?void 0:i.active)&&r.pack.min>0&&s<r.pack.min)return!![];if(!n&&(null===(o=r.individual)||void 0===o?void 0:o.active)&&r.individual.min>0&&s<r.individual.min)return!![]}else if(t.type===r.ON_DEMAND){const n=t.fees;if(n.min>0&&s<n.min)return!![]}return![]},getMinimumPurchaseMessage=(t,n=![])=>{var i,o;if(!t)return{message:"",type:"warning"};const s=t.subtotal;if(t.type===r.SHIPPING){const r=t.fees;let a=0;if(n&&(null===(i=r.pack)||void 0===i?void 0:i.active)&&r.pack.min>0?a=r.pack.min:(null===(o=r.individual)||void 0===o?void 0:o.active)&&r.individual.min>0&&(a=r.individual.min),a>0&&s<a)return{message:"+"+formatCentToDollarText(a-s)+" needed for order minimum",type:"warning"}}if(t.type===r.ON_DEMAND){const n=t.fees,i=n.min>0?n.min:0;if(i>0&&s<i)return{message:"+"+formatCentToDollarText(i-s)+" needed for order minimum",type:"warning"}}return{message:"",type:"warning"}},hasUnmetMinimum=(t,n=![])=>{var i,o;if(!t)return![];const s=t.subtotal;if(t.type===r.SHIPPING){const r=t.fees;if(n&&(null===(i=r.pack)||void 0===i?void 0:i.active)&&r.pack.min>0&&s<r.pack.min)return!![];if(!n&&(null===(o=r.individual)||void 0===o?void 0:o.active)&&r.individual.min>0&&s<r.individual.min)return!![]}if(t.type===r.ON_DEMAND){const n=t.fees;if(n.min>0&&s<n.min)return!![]}return![]};class PurchaseMinAlertComponent extends BaseComponent{get hostClasses(){return["alert","alert-"+this.params.messageType]}getIconElement(){const t=this.config||{};if(t.showIcon===![])return null;const n={warning:"warning",success:"success",info:"info"},i={warning:WarningIcon,success:SuccessIcon,info:InfoIcon},o=n[this.params.messageType]||"warning",r=document.createElement("div");return r.className="alert-icon alert-icon-"+this.params.messageType,r.appendChild(htmlStringToElement(i[o]({width:16,height:16,className:"alert-icon-svg"}))),r}template(){var t;const n=[],i=this.getIconElement();i&&n.push(i);const o=document.createElement("span");if(o.className="alert-message",o.textContent=this.params.message,n.push(o),"detailed"===(null===(t=this.config)||void 0===t?void 0:t.alertType)&&this.params.currentTotal){const t=document.createElement("div");t.className="alert-details";const i=document.createElement("small");i.className="alert-details-text",i.textContent="Current subtotal: "+formatCentToDollarText(this.params.currentTotal),t.appendChild(i),n.push(t)}return n}}class CartFulfillmentComponent extends BaseComponent{get hostClasses(){return["retailer-fulfillment-container"]}constructor(){super({watchStorePaths:["cart.fulfillments.{fulfillmentId}","cart.items"],autoDestroy:!![],autoDestroyPath:"cart.fulfillments.{fulfillmentId}"})}getFulfillmentId(){return this.params.fulfillmentId}getProductStore(){const t=this.getFulfillmentId(),n=this.getStoreValue("cart.fulfillments."+t+".items")||{};return Object.values(n).find(n=>n.fulfillmentId===t)}handleItemsUpdate(t,n){const i=new Set(t||[]),r=new Set(n||[]);for(const o of i)if(!r.has(o)){const t=this.container.querySelector('[data-item-id="'+o+'"]');t&&t.remove()}for(const s of r)if(!i.has(s)){const t=ComponentFactoryService.createElement({type:o.CART_ITEM,itemId:s});t.setAttribute("data-item-id",s),this.container.appendChild(t)}}setupItemElements(){const t=this.getFulfillmentId(),n=this.getStoreValue("cart.fulfillments."+t+".items")||[],i=this.container.querySelectorAll("[data-item-id]");for(const o of i)o.remove();for(const r of n){const t=ComponentFactoryService.createElement({type:o.CART_ITEM,itemId:r});t.setAttribute("data-item-id",r),this.container.appendChild(t)}}setupMinimumPurchaseAlert(){var t;const n=this.getFulfillmentId(),i=(null===(t=this.getProductStore())||void 0===t?void 0:t.pack)||![],r=this.getStoreValue("cart.fulfillments."+n),s=this.container.querySelector('[data-component-type="cart-retailer-alert"]');if(s&&s.remove(),r&&shouldShowMinimumPurchaseAlert(r,i)){const t=getMinimumPurchaseMessage(r,i),n=ComponentFactoryService.createElement({type:o.PURCHASE_MIN_ALERT,message:t.message,messageType:t.type,currentTotal:r.subtotal,config:{showIcon:!![],alertType:"minimal"}});n.setAttribute("data-component-type","cart-retailer-alert"),this.container.prepend(n)}}createLoadingOverlay(){const t=document.createElement("div");t.className="cart-loading-backdrop",t.setAttribute("data-loading-id","fulfillment-loading-overlay");const n=document.createElement("div");n.className="cart-loading-spinner-container";const i=document.createElement("div");return i.className="cart-loading-spinner",i.innerHTML='\n <svg class="cart-spinner" width="32" height="32" viewBox="0 0 50 50">\n <circle\n class="cart-spinner-path"\n cx="25"\n cy="25"\n r="20"\n fill="none"\n stroke-width="3"\n stroke-linecap="round"\n stroke-dasharray="31.416"\n stroke-dashoffset="31.416"\n />\n </svg>\n ',n.appendChild(i),t.appendChild(n),t}hasLoadingOverlay(){return!!this.container.querySelector('[data-loading-id="fulfillment-loading-overlay"]')}showLoadingOverlay(){if(this.hasLoadingOverlay())return;const t=this.createLoadingOverlay();this.container.appendChild(t),this.container instanceof HTMLElement&&(this.container.style.position="relative")}hideLoadingOverlay(){const t=this.container.querySelector('[data-loading-id="fulfillment-loading-overlay"]');t&&(t.remove(),this.container instanceof HTMLElement&&(this.container.style.position=""))}isAnyItemUpdating(){var t;const n=this.getFulfillmentId(),i=this.getStoreValue("cart.fulfillments."+n);return(null===(t=null==i?void 0:i.items)||void 0===t?void 0:t.length)?i.items.some(t=>{const n=this.getStoreValue("cart.items."+t);return(null==n?void 0:n.updating)===!![]}):![]}checkAndUpdateLoadingState(){const t=this.isAnyItemUpdating(),n=this.hasLoadingOverlay();t&&!n?this.showLoadingOverlay():!t&&n&&this.hideLoadingOverlay()}onStoreChanged(t){const n=this.getFulfillmentId(),i="cart.fulfillments."+n,o=t.find(t=>t.path===i),r=t.filter(t=>"cart.items"===t.path||t.path.startsWith("cart.items."));if(r.length>0&&this.checkAndUpdateLoadingState(),o){const t=o.oldValue,n=o.value,i=(null==t?void 0:t.items)||[],r=(null==n?void 0:n.items)||[],s=JSON.stringify(i)!==JSON.stringify(r);s&&(this.handleItemsUpdate(i,r),this.checkAndUpdateLoadingState());const a=this.hasFulfillmentFeesChanged(t,n),l=this.hasFulfillmentDataChanged(t,n,["items","updating"]);if(a&&!l&&this.setupMinimumPurchaseAlert(),!l)return![]}return![]}hasFulfillmentFeesChanged(t,n){return t?t.subtotal!==n.subtotal||t.shippingFee!==n.shippingFee||t.deliveryFee!==n.deliveryFee||JSON.stringify(t.fees)!==JSON.stringify(n.fees):!![]}hasFulfillmentDataChanged(t,n,i=[]){if(!t)return!![];const o=["type","canEngrave","retailerId"];for(const r of o)if(!i.includes(r)&&t[r]!==n[r])return!![];return![]}afterRender(){this.setupItemElements(),this.setupMinimumPurchaseAlert(),this.checkAndUpdateLoadingState()}disconnected(){this.hideLoadingOverlay()}template(){return[]}}const mt={CT:"America/New_York",DE:"America/New_York",FL:"America/New_York",GA:"America/New_York",IN:"America/New_York",KY:"America/New_York",ME:"America/New_York",MD:"America/New_York",MA:"America/New_York",MI:"America/New_York",NH:"America/New_York",NJ:"America/New_York",NY:"America/New_York",NC:"America/New_York",OH:"America/New_York",PA:"America/New_York",RI:"America/New_York",SC:"America/New_York",TN:"America/New_York",VT:"America/New_York",VA:"America/New_York",WV:"America/New_York",AL:"America/Chicago",AR:"America/Chicago",IL:"America/Chicago",IA:"America/Chicago",KS:"America/Chicago",LA:"America/Chicago",MN:"America/Chicago",MS:"America/Chicago",MO:"America/Chicago",NE:"America/Chicago",ND:"America/Chicago",OK:"America/Chicago",SD:"America/Chicago",TX:"America/Chicago",WI:"America/Chicago",AZ:"America/Phoenix",CO:"America/Denver",ID:"America/Denver",MT:"America/Denver",NV:"America/Los_Angeles",NM:"America/Denver",UT:"America/Denver",WY:"America/Denver",CA:"America/Los_Angeles",OR:"America/Los_Angeles",WA:"America/Los_Angeles",AK:"America/Anchorage",HI:"Pacific/Honolulu"},ft="America/New_York";function detectUserTimezone(t){try{if(t){const n=t.toUpperCase(),i=mt[n];return i||ft}return Intl.DateTimeFormat().resolvedOptions().timeZone}catch(n){return ft}}function getCurrentTimeInTimezone(t){try{const n=new Date,i=n.getTime(),o=6e4*n.getTimezoneOffset(),r=new Date(i+o),s=new Date(r.toLocaleString("en-US",{timeZone:t})),a=r.getTime()-s.getTime();return new Date(i+a)}catch(n){return new Date}}function getCurrentTimeInUserTimezone(t){const n=detectUserTimezone(t);return getCurrentTimeInTimezone(n)}function isDateTimeInRange(t){const{startDate:n,endDate:i,addressState:o}=t;try{const t=getCurrentTimeInUserTimezone(o),r=!n||t>=new Date(n),s=!i||t<=new Date(i);return r&&s}catch(r){return![]}}function filterActiveItems(t,n){return t.filter(t=>isDateTimeInRange({startDate:t.activeFrom,endDate:t.activeUntil,addressState:n}))}function hasActiveItems(t,n){return filterActiveItems(t,n).length>0}class CartHeaderComponent extends BaseComponent{get hostClasses(){return["cart-header"]}template(){var t,n,i;const r=this.config.layout.drawerHeaderText,s=this.getConfigs("global"),a=document.createElement("div");a.className="cart-header-content";const l=document.createElement("h2");l.className="cart-title",l.textContent=r,a.appendChild(l);const c=document.createElement("button");c.type="button",c.className="cart-header-close-btn",c.innerHTML=CloseIcon({width:16,height:16}),c.setAttribute("aria-label","Close cart drawer"),c.addEventListener("click",()=>{this.commands.ui.closeDrawer()}),a.appendChild(c);const d=this.clientConfig.get("promoTicker"),u=null!==(n=null===(t=null==s?void 0:s.experienceFeatures)||void 0===t?void 0:t.promoTicker)&&void 0!==n?n:[],h=null!=d?d:u,p=this.store.get("address"),m=hasActiveItems(h,null===(i=null==p?void 0:p.address)||void 0===i?void 0:i.state);if(!h.length||!m)return[a];const f=ComponentFactoryService.createElement({context:"cart",type:o.PROMO_CODE_TICKER,tickers:h});return[a,f]}}class CartItemComponent extends BaseComponent{get hostClasses(){return["cart-item-container"]}get hostAttributes(){return{"data-item-id":this.params.itemId}}constructor(){super({watchStorePaths:["cart.items.{itemId}"],autoDestroy:!![],autoDestroyPath:"cart.items.{itemId}"})}handleOpenEngravingForm(t,n){var i,r,s,a,l,c,d,u,h,p;this.commands.ui.openDrawer(o.ENGRAVING_FORM,{identifier:t,context:"cart",lines:(null===(r=null===(i=n.attributes)||void 0===i?void 0:i.engraving)||void 0===r?void 0:r.lines)||[],maxLines:(null===(a=null===(s=n.attributes)||void 0===s?void 0:s.engraving)||void 0===a?void 0:a.maxLines)||1,maxCharsPerLine:(null===(c=null===(l=n.attributes)||void 0===l?void 0:l.engraving)||void 0===c?void 0:c.maxCharsPerLine)||16,fee:(null===(u=null===(d=n.attributes)||void 0===d?void 0:d.engraving)||void 0===u?void 0:u.fee)||0,location:null===(p=null===(h=n.attributes)||void 0===h?void 0:h.engraving)||void 0===p?void 0:p.location})}template(){var t,n,i,r,s,a,l,c,d;const u=this.params.itemId,h=this.getStoreValue("cart.items."+u),p=this.getConfigs("global"),m=this.getStoreValue("cart.fulfillments."+h.fulfillmentId),f=h.attributes.engraving.hasEngraving?"Ships in 10 days":(null===(t=null==m?void 0:m.expectation)||void 0===t?void 0:t.detail)||"",b=document.createElement("article");b.className="cart-item";const w=document.createElement("div");w.className="item-image";const C=document.createElement("img");C.src=h.mainImage,C.alt=h.name,w.appendChild(C);const k=document.createElement("div");k.className="item-details";const S=document.createElement("div");S.className="item-header";const E=document.createElement("h3");E.className="item-title",E.textContent=h.name;const _=document.createElement("button");_.className="item-delete",_.innerHTML=TrashIcon({}),_.setAttribute("role","button"),_.setAttribute("tabindex","0"),_.setAttribute("aria-label","Remove "+h.name+" from cart"),_.setAttribute("aria-expanded","true"),_.addEventListener("click",async()=>{await this.commands.cart.removeItem(u)}),_.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),this.commands.cart.removeItem(u))}),S.appendChild(E),S.appendChild(_);const D=document.createElement("div");D.className="item-specs",D.textContent=h.size+", "+h.container;const P=document.createElement("div");P.className="item-shipping-container";const F=document.createElement("div");if(F.className="item-shipping",F.textContent=f,P.appendChild(F),p.layout.enablePersonalization&&(null===(i=null===(n=null==h?void 0:h.attributes)||void 0===n?void 0:n.engraving)||void 0===i?void 0:i.isEngravable)&&(null===(s=null===(r=null==h?void 0:h.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.hasEngraving)===![]&&m.canEngrave){const t=document.createElement("span");t.className="cart-add-personalization-span",t.textContent=p.layout.personalizationText+" +"+formatCentToDollarText((null===(l=null===(a=h.attributes)||void 0===a?void 0:a.engraving)||void 0===l?void 0:l.fee)||0,![]),t.setAttribute("role","button"),t.setAttribute("tabindex","0"),t.setAttribute("aria-label","Add personalization to "+h.name),t.addEventListener("click",()=>this.handleOpenEngravingForm(u,h)),t.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),this.handleOpenEngravingForm(u,h))}),P.appendChild(t)}k.appendChild(S),k.appendChild(D),k.appendChild(P),b.appendChild(w),b.appendChild(k);const A=[b],O=ComponentFactoryService.createElement({type:o.CART_ITEM_QUANTITY_PRICE,itemId:u});if((null===(d=null===(c=null==h?void 0:h.attributes)||void 0===c?void 0:c.engraving)||void 0===d?void 0:d.hasEngraving)===!![]){const t=ComponentFactoryService.createElement({type:o.ENGRAVING_VIEW,identifier:u,context:"cart"});A.push(t)}return A.push(O),A}}class CartItemQuantityPriceComponent extends BaseComponent{get hostClasses(){return["quantity-price"]}constructor(){super({watchStorePaths:["cart.items.{itemId}"],watchOnlyStorePaths:["cart.items"]})}onStoreWatch(t){const n=t.find(t=>"cart.items"===t.path);if(n){const t=this.calculateQuantityLimits();this.updateButtonStates(t)}}getItemStore(){const t=this.params.itemId,n=this.getStoreValue("cart.items."+t);return n||null}calculateQuantityLimits(){const t=this.getItemStore();if(!t)return{currentQuantity:0,availableQuantity:0,canIncrease:![],canDecrease:!![]};const n=t.quantity,i=this.getAvailableQuantity(),o=i>0;return{currentQuantity:n,availableQuantity:i,canIncrease:o,canDecrease:!![]}}getAvailableQuantity(){var t,n,i,o;const r=this.getItemStore();if(!r)return 0;const s=r.partNumber,a=r.fulfillmentId,l=this.getStoreValue("cart.items")||{},c=Object.values(l).filter(t=>t.partNumber===s&&t.fulfillmentId===a),d=c.reduce((t,n)=>t+n.quantity,0),u=this.getStoreValue("products."+r.upc)||this.getStoreValue("products."+r.salsifyGrouping);if(!u)return r.maxQuantity-d;const h=null!==(o=null===(i=null===(n=null===(t=null==u?void 0:u.sizes)||void 0===t?void 0:t[r.liquidId])||void 0===n?void 0:n.attributes)||void 0===i?void 0:i.maxQuantityPerOrder)&&void 0!==o?o:0;return!h||h<=0?r.maxQuantity-d:h-d}updateButtonStates(t){this.qtyDecreaseButton&&(this.qtyDecreaseButton.disabled=!t.canDecrease,this.qtyDecreaseButton.classList.toggle("quantity-btn-disabled",!t.canDecrease)),this.qtyIncreaseButton&&(this.qtyIncreaseButton.disabled=!t.canIncrease,this.qtyIncreaseButton.classList.toggle("quantity-btn-disabled",!t.canIncrease)),this.quantitySpan&&(this.quantitySpan.textContent=t.currentQuantity.toString(),this.quantitySpan.setAttribute("aria-label","Current quantity: "+t.currentQuantity))}async handleQuantityChange(t){const n=this.calculateQuantityLimits();t>0&&!n.canIncrease||await this.commands.cart.updateItemQuantity(this.params.itemId,t)}createQuantityContainer(){const t=this.calculateQuantityLimits(),n=this.getItemStore();if(!n)return document.createElement("div");const i=document.createElement("div");return i.className="item-quantity "+this.config.layout.quantityCounterStyle,this.qtyDecreaseButton=document.createElement("button"),this.qtyDecreaseButton.type="button",this.qtyDecreaseButton.className="quantity-btn-decrease",this.qtyDecreaseButton.textContent="−",this.qtyDecreaseButton.setAttribute("aria-label","Decrease quantity"),this.qtyDecreaseButton.addEventListener("click",async t=>{t.preventDefault(),t.stopPropagation(),await this.handleQuantityChange(-1)}),this.quantitySpan=document.createElement("span"),this.quantitySpan.className="quantity-value",this.qtyIncreaseButton=document.createElement("button"),this.qtyIncreaseButton.type="button",this.qtyIncreaseButton.className="quantity-btn-increase",this.qtyIncreaseButton.textContent="+",this.qtyIncreaseButton.setAttribute("aria-label","Increase quantity"),this.qtyIncreaseButton.addEventListener("click",async t=>{t.preventDefault(),t.stopPropagation(),await this.handleQuantityChange(1)}),this.updateButtonStates(t),i.appendChild(this.qtyDecreaseButton),i.appendChild(this.quantitySpan),i.appendChild(this.qtyIncreaseButton),i}createPriceContainer(){const t=this.getItemStore();if(!t)return document.createElement("div");const n=document.createElement("div");n.className="item-price-container";const i=document.createElement("span");if(i.className="item-price",i.textContent=formatCentToDollarText(t.price),n.appendChild(i),t.quantity>1){const i=document.createElement("span");i.className="item-price-per-unit",i.textContent="("+formatCentToDollarText(t.unitPrice)+" ea)",n.appendChild(i)}return n}template(){const t=[];if(this.config.layout.showQuantityCounter){const n=this.createQuantityContainer();t.push(n)}const n=this.createPriceContainer();return t.push(n),t}}class CartPromoCodeComponent extends BaseComponent{get hostClasses(){return["promo-container-wrapper"]}constructor(){super({watchOnlyStorePaths:["cart.promoCode"]}),this.isApplying=![],this.promoInput=null,this.applyButton=null,this.promoCodePill=null}onStoreWatch(t){const n=t.find(t=>"cart.promoCode"===t.path);if(n){const{value:t,oldValue:i}=n,o=Boolean(null==i?void 0:i.code),r=Boolean(null==t?void 0:t.code);if(!o&&r)return this.container.innerHTML="",this.createAppliedContainer(t),void 0;if(o&&!r)return this.container.innerHTML="",this.createInputContainer(),void 0;if(r&&this.promoCodePill&&t.discountAmount!==(null==i?void 0:i.discountAmount))return this.promoCodePill.textContent=t.code+" (- "+formatCentToDollarText(t.discountAmount)+")",void 0}}createAppliedContainer(t){const n=document.createElement("div");n.classList.add("promo-applied-container"),this.promoCodePill=document.createElement("div"),this.promoCodePill.classList.add("promo-code-pill"),this.promoCodePill.textContent=(null==t?void 0:t.code)+" (- "+formatCentToDollarText((null==t?void 0:t.discountAmount)||0)+")";const i=document.createElement("button");i.type="button",i.classList.add("promo-remove-btn"),i.textContent="Remove",i.setAttribute("role","button"),i.setAttribute("aria-label","Remove promo code "+(null==t?void 0:t.code)),i.setAttribute("tabindex","0"),i.addEventListener("click",async()=>{await this.commands.cart.removePromoCode()}),i.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||this.commands.cart.removePromoCode()}),n.appendChild(this.promoCodePill),n.appendChild(i),this.container.appendChild(n),this.promoInput=null,this.applyButton=null}createInputContainer(){const t=document.createElement("div");t.classList.add("promo-code-container");const n=document.createElement("div");n.classList.add("promo-container"),n.appendChild(this.createPromoInput()),n.appendChild(this.createApplyButton()),t.appendChild(n),this.container.appendChild(t),this.promoCodePill=null}updateApplyButtonState(){if(!this.applyButton||!this.promoInput)return;const t=this.promoInput.getValue().replace(/[^a-zA-Z0-9]/g,"").trim(),n=t.length>=3&&t.length<=255,i=this.getStoreValue("cart.loading"),o=this.getStoreValue("cart.promoCode"),r=this.getStoreValue("cart.events")||[],s=hasCartAnyPromoCodeEvents(r);this.applyButton.disabled=!n||i||Boolean(null==o?void 0:o.discountAmount)||this.isApplying||s}createPromoInput(){const t=this.getConfigs("global");return this.promoInput=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:"promoCode",placeholder:"Enter promo code",autocomplete:![],className:"promo-input "+t.layout.inputFieldStyle,validation:{min:3,max:255},onChange:t=>{const n=t.toUpperCase(),i=this.promoInput;i.setValue(n),this.updateApplyButtonState()}}),this.promoInput}createApplyButton(){this.applyButton=document.createElement("button"),this.applyButton.type="button",this.applyButton.classList.add("apply-button"),this.applyButton.disabled=!![],this.applyButton.textContent="Apply",this.applyButton.setAttribute("tabindex","0"),this.applyButton.setAttribute("role","button"),this.applyButton.setAttribute("aria-label","Apply promo code");const T=async()=>{const t=this.promoInput.getValue().trim().toUpperCase();if(t)try{this.isApplying=!![],this.applyButton.disabled=!![],this.applyButton.setAttribute("aria-label","Applying promo code"),await this.commands.cart.applyPromoCode(t),this.applyButton.setAttribute("aria-label","Apply promo code")}catch(n){this.logger.error("Cart promo code application failed",{promoCode:t,error:n instanceof Error?n.message:String(n)})}};return this.applyButton.addEventListener("click",T),this.applyButton.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),T())}),this.applyButton}template(){const t=this.getStoreValue("cart.promoCode");if(this.promoInput=null,this.applyButton=null,this.promoCodePill=null,null==t?void 0:t.code){const n=document.createElement("div");n.classList.add("promo-applied-container"),this.promoCodePill=document.createElement("div"),this.promoCodePill.classList.add("promo-code-pill"),this.promoCodePill.textContent=t.code+" (- "+formatCentToDollarText(t.discountAmount)+")";const i=document.createElement("button");return i.type="button",i.classList.add("promo-remove-btn"),i.textContent="Remove",i.setAttribute("role","button"),i.setAttribute("aria-label","Remove promo code "+t.code),i.setAttribute("tabindex","0"),i.addEventListener("click",async()=>{await this.commands.cart.removePromoCode()}),i.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||this.commands.cart.removePromoCode()}),n.appendChild(this.promoCodePill),n.appendChild(i),n}const n=document.createElement("div");n.classList.add("promo-code-container");const i=document.createElement("div");return i.classList.add("promo-container"),i.appendChild(this.createPromoInput()),i.appendChild(this.createApplyButton()),n.appendChild(i),n}disconnected(){this.promoInput=null,this.applyButton=null,this.promoCodePill=null}}class CartRetailerComponent extends BaseComponent{constructor(){super({watchStorePaths:["cart.retailers.{retailerId}"],autoDestroy:!![],autoDestroyPath:"cart.retailers.{retailerId}"})}getRetailerId(){return this.params.retailerId}createFulfillmentElement(t){return ComponentFactoryService.createElement({type:o.CART_FULFILLMENT,fulfillmentId:t})}getFulfillmentElementById(t){return this.container.querySelector('[data-fulfillment-id="'+t+'"]')}getFulfillmentContainer(){return this.container.querySelector("#retailer-fulfillment-container")}getFulfillmentInsertionPoint(){const t=this.getFulfillmentContainer();if(t)return{parent:t.parentElement,nextSibling:t.nextElementSibling};const n=this.container.querySelectorAll("[data-fulfillment-id]");if(n.length>0){const t=n[n.length-1];return{parent:t.parentElement,nextSibling:t.nextElementSibling}}return null}addFulfillmentElement(t){const n=this.getFulfillmentInsertionPoint();if(n){const i=this.createFulfillmentElement(t);i.setAttribute("data-fulfillment-id",t);const o=this.getFulfillmentContainer();o&&o.remove(),n.nextSibling?n.parent.insertBefore(i,n.nextSibling):n.parent.appendChild(i)}}removeFulfillmentElement(t){const n=this.getFulfillmentElementById(t);if(n){const t=n.parentElement,i=n.nextElementSibling;n.remove();const o=this.container.querySelectorAll("[data-fulfillment-id]");if(0===o.length){const n=document.createElement("div");n.id="retailer-fulfillment-container",i?t.insertBefore(n,i):t.appendChild(n)}}}handleFulfillmentsUpdate(t,n){const i=new Set(t||[]),o=new Set(n||[]);for(const r of i)o.has(r)||this.removeFulfillmentElement(r);for(const r of o)i.has(r)||this.addFulfillmentElement(r)}setupFulfillmentElements(){const t=this.getRetailerId(),n=this.getStoreValue("cart.retailers."+t+".fulfillments")||[],i=this.container.querySelectorAll("[data-fulfillment-id]");for(const r of i)r.remove();let o=this.getFulfillmentContainer();if(!o){const t=this.container.querySelector(".retailer-body-container"),n=this.container.querySelector("#retailer-subtotal-container");o=document.createElement("div"),o.id="retailer-fulfillment-container",t&&n&&t.insertBefore(o,n)}for(const r of n)this.addFulfillmentElement(r)}setupSubtotalElement(){const t=this.getRetailerId(),n=this.container.querySelector("#retailer-subtotal-container");if(n){const i=ComponentFactoryService.createElement({type:o.CART_RETAILER_SUBTOTAL,retailerId:t});n.replaceWith(i)}}onStoreChanged(t){const n=this.getRetailerId(),i="cart.retailers."+n,o=t.find(t=>t.path===i);if(o){const t=o.oldValue,n=o.value,i=(null==t?void 0:t.fulfillments)||[],r=(null==n?void 0:n.fulfillments)||[];JSON.stringify(i)!==JSON.stringify(r)&&this.handleFulfillmentsUpdate(i,r)}return![]}afterRender(){this.setupFulfillmentElements(),this.setupSubtotalElement(),this.setupSectionToggle()}setupSectionToggle(){const t=this.container.querySelector(".section-toggle"),n=this.container.querySelector(".retailer-section"),i=this.container.querySelector(".section-header-label");if(t&&n&&i){const B=()=>{const n=t.checked;i.setAttribute("aria-label",n?"Expand retailer section":"Collapse retailer section"),i.setAttribute("aria-expanded",n?"false":"true")};t.addEventListener("change",()=>{t.checked?n.classList.add("collapsed"):n.classList.remove("collapsed"),B()}),i.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),t.click())}),t.checked?n.classList.add("collapsed"):n.classList.remove("collapsed"),B()}}template(){const t=this.getRetailerId(),n=this.getStoreValue("cart.retailers."+t),i=document.createElement("section");i.className="retailer-section";const o=document.createElement("div");o.className="cart-retailer-header";const r=document.createElement("div");r.className="retailer-info";const s=document.createElement("h2");s.className="section-title",s.textContent=n.name,r.appendChild(s);const a=document.createElement("input");a.type="checkbox",a.id=n.id,a.className="section-toggle",r.appendChild(a);const l=document.createElement("label");l.htmlFor=n.id,l.className="section-header-label",l.setAttribute("role","button"),l.setAttribute("tabindex","0"),l.setAttribute("aria-label","Collapse retailer section"),l.setAttribute("aria-expanded","true");const c=document.createElement("span");c.className="chevron",c.innerHTML=ChevronDownIcon({width:20,height:20,className:"chevron-down-icon"}),l.appendChild(c),r.appendChild(l),o.appendChild(r),i.appendChild(o);const d=document.createElement("div");d.className="retailer-body-container";const u=document.createElement("div");u.id="retailer-fulfillment-container",d.appendChild(u);const h=document.createElement("div");return h.id="retailer-subtotal-container",d.appendChild(h),i.appendChild(d),i}}class CartRetailerSubtotalComponent extends BaseComponent{get hostClasses(){return["retailer-subtotal-container"]}constructor(){super({watchStorePaths:["cart.retailers.{retailerId}"],autoDestroy:!![],autoDestroyPath:"cart.retailers.{retailerId}"})}getRetailerItemCount(t,n){const i=Object.values(t||{}).filter(t=>t.retailerId===n);let o=0;for(const r of i)o+=r.quantity;return o}template(){const t=this.params.retailerId,n=this.getStoreValue("cart.retailers."+t+".subtotal")||0,i=this.getStoreValue("cart.retailers."+t+".engravingFee")||0,o=this.getStoreValue("cart.items"),r=this.getRetailerItemCount(o,t),s=1===r?"item":"items",a=document.createElement("h3");a.className="retailer-subtotal-header",a.textContent="Subtotal ("+r+" "+s+"):";const l=document.createElement("span");return l.className="retailer-subtotal-amount",l.textContent=formatCentToDollarText(n+i),[a,l]}}class CheckoutComponent extends BaseComponent{constructor(){super({watchStorePaths:["checkout.rerender","checkout.presale"]})}template(){var t,n,i;const r=this.store.get("checkout.presale"),s=this.getConfigs("global"),a=this.clientConfig.get("promoTicker"),l=null!==(n=null===(t=null==s?void 0:s.experienceFeatures)||void 0===t?void 0:t.promoTicker)&&void 0!==n?n:[],c=null!=a?a:l,d=this.store.get("address"),u=hasActiveItems(c,null===(i=null==d?void 0:d.address)||void 0===i?void 0:i.state),h=this.params.isIndependentComponent&&!this.clientConfig.isBuilder(),p=document.createElement("div");p.classList.add("checkout-container"),h&&p.classList.add("no-header"),this.params.isIndependentComponent&&p.classList.add("independent");const m=ComponentFactoryService.createElement({type:o.CHECKOUT_INFORMATION});p.appendChild(m);const f=ComponentFactoryService.createElement({type:o.CHECKOUT_ORDER_SUMMARY});if(p.appendChild(f),!r&&(!c.length||!u)&&h)return[p];const b=document.createElement("div");if(b.classList.add("checkout-header-wrapper"),!h){const t=ComponentFactoryService.createElement({type:o.CHECKOUT_HEADER});b.appendChild(t)}if(c.length&&u&&!r){const t=ComponentFactoryService.createElement({context:"checkout",type:o.PROMO_CODE_TICKER,tickers:c});b.appendChild(t)}if(r){const t=ComponentFactoryService.createElement({type:o.CHECKOUT_PRESALE_COUNTDOWN});b.appendChild(t)}return[b,p]}}class CheckoutAmountsComponent extends BaseComponent{get hostClasses(){return["checkout-amounts-container"]}constructor(){super({watchStorePaths:["checkout.amounts"]})}template(){var t,n,i;const o=this.getStoreValue("checkout"),r=Boolean(o.promoCode),s=Boolean(null===(t=o.giftCards)||void 0===t?void 0:t.length),a=this.getConfigs("global"),l=Object.keys(o.onDemandFulfillmentTipInfo||{}).length>0,c=Object.values(o.items||{}),d=[],u=document.createElement("div");u.classList.add("checkout-amount-line");const h=document.createElement("span");h.textContent="Subtotal ("+c.length+" item"+(c.length>1?"s":"")+")",u.appendChild(h);const p=document.createElement("span");p.textContent=formatCentToDollarText(o.amounts.subtotal),u.appendChild(p),d.push(u);const m=document.createElement("div");m.classList.add("checkout-amount-line");const f=document.createElement("span");f.textContent="Shipping",m.appendChild(f);const b=document.createElement("span");b.textContent=formatCentToDollarText(o.amounts.shipping),m.appendChild(b),d.push(m);const w=document.createElement("div");w.classList.add("checkout-amount-line");const C=document.createElement("span");C.textContent="Delivery",w.appendChild(C);const k=document.createElement("span");if(k.textContent=formatCentToDollarText(o.amounts.delivery),w.appendChild(k),d.push(w),(null===(n=null==o?void 0:o.amounts)||void 0===n?void 0:n.engraving)>0){const t=document.createElement("div");t.classList.add("checkout-amount-line");const n=document.createElement("span");n.textContent="Engraving",t.appendChild(n);const i=document.createElement("span");i.textContent=formatCentToDollarText(o.amounts.engraving),t.appendChild(i),d.push(t)}const S=document.createElement("div");S.classList.add("checkout-amount-line");const E=document.createElement("span");E.textContent="Taxes & Fees",S.appendChild(E);const _=document.createElement("span");if(_.textContent=formatCentToDollarText(o.amounts.tax+o.amounts.service+o.amounts.platform),S.appendChild(_),d.push(S),r){const t=document.createElement("div");t.classList.add("checkout-amount-line");const n=document.createElement("span");n.textContent="Promo Code ("+(null===(i=o.promoCode)||void 0===i?void 0:i.code.toUpperCase())+")",t.appendChild(n);const r=document.createElement("span");r.textContent="-"+formatCentToDollarText(o.amounts.discounts),t.appendChild(r),d.push(t)}if(s){const t=document.createElement("div");t.classList.add("checkout-amount-line");const n=document.createElement("span");n.textContent="Gift Cards Applied",t.appendChild(n);const i=document.createElement("span");i.textContent="-"+formatCentToDollarText(o.amounts.giftCards),t.appendChild(i),d.push(t)}if(l){const t=document.createElement("div");t.classList.add("checkout-amount-line");const n=document.createElement("span");n.textContent="Tips",t.appendChild(n);const i=document.createElement("span");i.textContent=formatCentToDollarText(o.amounts.tip),t.appendChild(i),d.push(t)}const D=document.createElement("div");D.classList.add("checkout-separator"),d.push(D);const P=document.createElement("div");P.classList.add("checkout-amount-total");const F=document.createElement("span");F.textContent="Total",P.appendChild(F);const A=document.createElement("span");if(A.textContent=formatCentToDollarText(o.amounts.total),P.appendChild(A),d.push(P),o.presale){const t=document.createElement("div");t.classList.add("checkout-amount-due");const n=document.createElement("span");n.textContent="Amount due today",t.appendChild(n);const i=document.createElement("span");i.textContent=formatCentToDollarText(0),t.appendChild(i),d.push(t);const o=document.createElement("div");o.classList.add("checkout-presale-locked-message");const r=htmlStringToElement(InfoIcon({color:a.theme.defaultTextColor}));o.appendChild(r);const s=document.createElement("p");s.textContent="Pre-ordered items will be charged when shipped.",o.appendChild(s),d.push(o)}return d}}const gt="lce-checkout-stripe-slot",vt={firstName:"firstName",lastName:"lastName",email:"email",phone:"phone",birthDate:"birthDate",addressTwo:"addressTwo",company:"company"},yt={firstName:"firstName",lastName:"lastName",email:"email",phone:"phone",addressTwo:"addressTwo",message:"message"},bt={firstName:"firstName",lastName:"lastName",email:"email",phone:"phone",company:"company",addressOne:"addressOne",addressTwo:"addressTwo",city:"city",state:"state",zipCode:"zipCode"};class CheckoutBillingComponent extends BaseComponent{get hostClasses(){return["checkout-billing-form"]}constructor(){super({watchStorePaths:["checkout.paymentForm.billingSameAsShipping"]}),this.billingData={firstName:{isValid:![],value:""},lastName:{isValid:![],value:""},email:{isValid:![],value:""},phone:{isValid:![],value:""},company:{isValid:!![],value:""},addressOne:{isValid:![],value:""},addressTwo:{isValid:!![],value:""},city:{isValid:![],value:""},state:{isValid:![],value:""},zipCode:{isValid:![],value:""}}}billingSameAsShippingToggle(){const t=this.getStoreValue("checkout.paymentForm.billingSameAsShipping"),n=document.createElement("div");n.classList.add("checkout-billing-same-as-shipping-toggle-container");const i=document.createElement("div");i.classList.add("checkout-checkbox-container");const o=document.createElement("span");o.id="billingSameAsShipping",o.classList.add("checkout-checkbox-visual"),o.setAttribute("role","checkbox"),o.setAttribute("tabindex","0"),o.setAttribute("aria-label","Billing same as shipping checkbox"),o.setAttribute("aria-checked",t?"true":"false"),t&&o.classList.add("checked"),o.innerHTML=CheckboxIcon({width:16,height:16}),n.addEventListener("click",async()=>{await this.commands.checkout.toggleBillingSameAsShipping()}),n.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await this.commands.checkout.toggleBillingSameAsShipping())});const r=document.createElement("label");return r.textContent="Billing address same as shipping address",r.setAttribute("for","billingSameAsShipping"),r.classList.add("billing-checkbox-label"),i.appendChild(o),i.appendChild(r),n.appendChild(i),n}updateSaveButtonState(){const t=!Object.values(this.billingData).every(t=>t.isValid),n={firstName:this.billingData.firstName.value,lastName:this.billingData.lastName.value,email:this.billingData.email.value,phone:this.billingData.phone.value,company:this.billingData.company.value,addressOne:this.billingData.addressOne.value,addressTwo:this.billingData.addressTwo.value,city:this.billingData.city.value,state:this.billingData.state.value,zipCode:this.billingData.zipCode.value};this.params.isFormValid(!t,n)}template(){const t=this.getStoreValue("checkout.paymentForm"),n=[],r=this.billingSameAsShippingToggle();if(n.push(r),t.billingSameAsShipping)return n;t.data&&(t.data.firstName&&(this.billingData.firstName={isValid:!![],value:t.data.firstName}),t.data.lastName&&(this.billingData.lastName={isValid:!![],value:t.data.lastName}),t.data.email&&(this.billingData.email={isValid:!![],value:t.data.email}),t.data.phone&&(this.billingData.phone={isValid:!![],value:t.data.phone}),t.data.company&&(this.billingData.company={isValid:!![],value:t.data.company}),t.data.addressOne&&(this.billingData.addressOne={isValid:!![],value:t.data.addressOne}),t.data.addressTwo&&(this.billingData.addressTwo={isValid:!![],value:t.data.addressTwo}),t.data.city&&(this.billingData.city={isValid:!![],value:t.data.city}),t.data.state&&(this.billingData.state={isValid:!![],value:t.data.state}),t.data.zipCode&&(this.billingData.zipCode={isValid:!![],value:t.data.zipCode})),this.updateSaveButtonState();const s=document.createElement("div");s.classList.add("section-title-container");const a=document.createElement("h3");a.textContent="Your billing info",a.classList.add("section-title"),s.appendChild(a);const l=document.createElement("p");l.textContent="Provide the info relevant to your payment method",l.classList.add("section-subtitle"),s.appendChild(l),n.push(s);const c=document.createElement("div");c.classList.add("section-form-container");const d=document.createElement("div");d.classList.add("checkout-two-col-container");const u=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:bt.firstName,label:"First Name",autocomplete:!![],validation:{required:!![]},onChange:async t=>{this.billingData.firstName.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.firstName})},onValidation:t=>{this.billingData.firstName.isValid=t,this.updateSaveButtonState()}});u.setAttribute("aria-label","First name input"),d.appendChild(u);const h=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:bt.lastName,label:"Last Name",autocomplete:!![],validation:{required:!![]},onChange:async t=>{this.billingData.lastName.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.lastName})},onValidation:t=>{this.billingData.lastName.isValid=t,this.updateSaveButtonState()}});h.setAttribute("aria-label","Last name input"),d.appendChild(h),c.appendChild(d);const p=ComponentFactoryService.createElement({type:o.INPUT,inputType:"email",name:bt.email,label:"Email",autocomplete:!![],validation:{required:!![]},onChange:async t=>{this.billingData.email.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.email})},onValidation:t=>{this.billingData.email.isValid=t,this.updateSaveButtonState()}});p.setAttribute("aria-label","Email input"),c.appendChild(p);const m=document.createElement("div");m.classList.add("checkout-two-col-container");const f=ComponentFactoryService.createElement({type:o.INPUT,inputType:"tel",name:bt.phone,label:"Phone",autocomplete:!![],validation:{required:!![]},onChange:async t=>{this.billingData.phone.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.phone})},onValidation:t=>{this.billingData.phone.isValid=t,this.updateSaveButtonState()}});f.setAttribute("aria-label","Phone input"),m.appendChild(f);const b=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:bt.company,label:"Company (optional)",autocomplete:!![],onChange:async t=>{this.billingData.company.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.company})},onValidation:t=>{this.billingData.company.isValid=t,this.updateSaveButtonState()}});b.setAttribute("aria-label","Company input"),m.appendChild(b),c.appendChild(m);const w=document.createElement("div");w.classList.add("checkout-two-col-container");const C=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:bt.addressOne,label:"Street Address",autocomplete:!![],validation:{required:!![]},onChange:async t=>{this.billingData.addressOne.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.addressOne})},onValidation:t=>{this.billingData.addressOne.isValid=t,this.updateSaveButtonState()}});C.setAttribute("aria-label","Street address input"),w.appendChild(C);const k=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:bt.addressTwo,label:"Apt, suite, etc. (optional)",onChange:async t=>{this.billingData.addressTwo.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.addressTwo})},onValidation:t=>{this.billingData.addressTwo.isValid=t,this.updateSaveButtonState()}});k.setAttribute("aria-label","Apt, suite, etc. (optional) input"),w.appendChild(k),c.appendChild(w);const S=document.createElement("div");S.classList.add("checkout-three-col-container");const E=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:bt.city,label:"City",autocomplete:!![],validation:{required:!![]},onChange:async t=>{this.billingData.city.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.city})},onValidation:t=>{this.billingData.city.isValid=t,this.updateSaveButtonState()}});E.setAttribute("aria-label","City input"),S.appendChild(E);const _=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:bt.state,label:"State",autocomplete:!![],placeholder:"NY",validation:{required:!![],customValidator:t=>t&&2===t.length&&/^[A-Z]{2}$/.test(t)?null:"State must be 2 uppercase characters"},onChange:async t=>{this.billingData.state.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.state})},onValidation:t=>{this.billingData.state.isValid=t,this.updateSaveButtonState()}});_.setAttribute("aria-label","State input"),S.appendChild(_);const D=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:bt.zipCode,label:"Zip Code",autocomplete:!![],validation:{required:!![]},onChange:async t=>{this.billingData.zipCode.value=t,this.pubSub.publishForm(i.BILLING,{fieldName:bt.zipCode})},onValidation:t=>{this.billingData.zipCode.isValid=t,this.updateSaveButtonState()}});return D.setAttribute("aria-label","Zip Code input"),S.appendChild(D),c.appendChild(S),n.push(c),n}}class CheckoutBuyer extends BaseComponent{get hostClasses(){return["checkout-buyer-information"]}constructor(){super({watchStorePaths:["checkout.customerForm.data"],watchOnlyStorePaths:["checkout.customerForm.isSaving"]}),this.customerData={firstName:{isValid:![],value:""},lastName:{isValid:![],value:""},email:{isValid:![],value:""},phone:{isValid:![],value:""},addressTwo:{isValid:![],value:""},company:{isValid:![],value:""},birthDate:{isValid:![],value:""}},this.saveButtonText="Save Buyer Information"}onStoreWatch(t){const n=t.find(t=>"checkout.customerForm.isSaving"===t.path);n&&(n.value?(this.saveButton.textContent="Saving...",this.saveButton.disabled=!![]):(this.saveButton.textContent=this.saveButtonText,this.updateSaveButtonState()))}updateSaveButtonState(){this.saveButton.disabled=!(this.customerData.firstName.isValid&&this.customerData.lastName.isValid&&this.customerData.email.isValid&&this.customerData.phone.isValid&&this.customerData.birthDate.isValid)}template(){const t=this.store.get("checkout.customerForm.data");t.firstName&&(this.customerData.firstName={isValid:!![],value:t.firstName}),t.lastName&&(this.customerData.lastName={isValid:!![],value:t.lastName}),t.email&&(this.customerData.email={isValid:!![],value:t.email}),t.phone&&(this.customerData.phone={isValid:!![],value:t.phone}),t.company&&(this.customerData.company={isValid:!![],value:t.company}),t.birthDate&&(this.customerData.birthDate={isValid:!![],value:t.birthDate});const n=[],r=document.createElement("div");r.classList.add("section-title-container");const s=document.createElement("h3");s.textContent="Buyer Information",s.classList.add("section-title"),r.appendChild(s);const a=document.createElement("p");a.textContent="Buyer information is used to process your order and for delivery purposes.",a.classList.add("section-subtitle"),r.appendChild(a),n.push(r);const l=document.createElement("div");l.classList.add("section-form-container");const c=document.createElement("div");c.classList.add("checkout-two-col-container");const d=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:vt.firstName,label:"First Name",autocomplete:!![],validation:{required:!![]},value:t.firstName,onChange:async t=>{this.customerData.firstName.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.firstName})},onValidation:t=>{this.customerData.firstName.isValid=t,this.updateSaveButtonState()}});c.appendChild(d);const u=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:vt.lastName,label:"Last Name",autocomplete:!![],validation:{required:!![]},value:t.lastName,onChange:async t=>{this.customerData.lastName.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.lastName})},onValidation:t=>{this.customerData.lastName.isValid=t,this.updateSaveButtonState()}});c.appendChild(u),l.appendChild(c);const h=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:vt.company,label:"Company (optional)",autocomplete:!![],value:t.company,onChange:async t=>{this.customerData.company.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.company})},onValidation:t=>{this.customerData.company.isValid=t,this.updateSaveButtonState()}});l.appendChild(h);const p=ComponentFactoryService.createElement({type:o.INPUT,inputType:"email",name:vt.email,label:"Email",autocomplete:!![],validation:{required:!![]},value:t.email,onChange:async t=>{this.customerData.email.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.email})},onValidation:t=>{this.customerData.email.isValid=t,this.updateSaveButtonState()}});l.appendChild(p);const m=ComponentFactoryService.createElement({type:o.INPUT,inputType:"tel",name:vt.phone,label:"Phone",autocomplete:!![],validation:{required:!![]},value:t.phone,onChange:async t=>{this.customerData.phone.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.phone})},onValidation:t=>{this.customerData.phone.isValid=t,this.updateSaveButtonState()}});l.appendChild(m);const f=ComponentFactoryService.createElement({type:o.BIRTHDATE_INPUT,inputType:"date",name:vt.birthDate,label:"Birthdate",validation:{required:!![],minAge:21,minYear:1930},value:t.birthDate,onChange:async t=>{this.customerData.birthDate.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.birthDate})},onValidation:t=>{this.customerData.birthDate.isValid=t,this.updateSaveButtonState()}});return l.appendChild(f),n.push(l),this.saveButton=document.createElement("button"),this.saveButton.type="button",this.saveButton.classList.add("save-form-info-button"),this.saveButton.textContent=this.saveButtonText,this.saveButton.addEventListener("click",async()=>{await this.commands.checkout.saveCustomerForm({customerData:{firstName:this.customerData.firstName.value,lastName:this.customerData.lastName.value,email:this.customerData.email.value,phone:this.customerData.phone.value,company:this.customerData.company.value,birthDate:this.customerData.birthDate.value},shippingAddressTwo:this.customerData.addressTwo.value,deliveryInstructions:""})}),n.push(this.saveButton),this.updateSaveButtonState(),n}}class CheckoutBuyerSummaryComponent extends BaseComponent{get hostClasses(){return["checkout-summary-form-container"]}constructor(){super({watchStorePaths:["checkout.customerForm"]})}template(){const t=[],n=this.getStoreValue("checkout.customerForm.data"),i=document.createElement("div");i.classList.add("checkout-summary-form-header");const o=document.createElement("h2");o.textContent="Buyer: "+n.firstName+" "+n.lastName,i.appendChild(o);const r=document.createElement("span");if(r.textContent="Edit",r.setAttribute("aria-label","Edit Buyer Information"),r.setAttribute("role","button"),r.setAttribute("tabindex","0"),r.addEventListener("click",async()=>{await this.commands.checkout.editCustomerForm()}),r.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await this.commands.checkout.editCustomerForm())}),i.appendChild(r),t.push(i),n.company){const i=document.createElement("p");i.classList.add("checkout-summary-form-line"),i.textContent=n.company,t.push(i)}const s=document.createElement("p");s.classList.add("checkout-summary-form-line"),s.textContent=n.email,t.push(s);const a=document.createElement("p");a.classList.add("checkout-summary-form-line"),a.textContent=n.phone,t.push(a);const l=document.createElement("p");return l.classList.add("checkout-summary-form-line"),l.textContent=formatISODateToMMDDYYYY(n.birthDate),t.push(l),t}}const xt=["span","p","a","b","i","div","strong","em","u","br","h1","h2","h3","h4","h5","h6","ul","ol","li","blockquote","code","pre","img"],wt={a:["href","title","target","rel"],img:["src","alt","width","height","title"],blockquote:["cite"],div:["class"],span:["class"],p:["class"],strong:["class"],em:["class"],code:["class"],pre:["class"],h1:["class"],h2:["class"],h3:["class"],h4:["class"],h5:["class"],h6:["class"],ul:["class"],ol:["class"],li:["class"]};function sanitizeAttributeValue(t,n){return"href"===t?/^(https?:\/\/[^\s<>"']+|mailto:[^\s<>"']+|tel:[^\s<>"']+|\/[^\s<>"']*|#[^\s<>"']*)$/i.test(n)?n:null:"src"===t?/^https?:\/\/[^\s<>"']+$/i.test(n)?n:null:"class"===t?n.replace(/[^a-zA-Z0-9\s\-_]/g,"").trim():n.replace(/[<>"']/g,"").trim()}function cleanNode(t){if(t.nodeType===Node.TEXT_NODE){const n=t.textContent||"",i=n.replace(/<[^>]*>/g,"");if(i.trim()){const t=document.createTextNode(i);return t}return null}if(t.nodeType===Node.ELEMENT_NODE){const n=t,i=n.tagName.toLowerCase();if(xt.includes(i)){const t=document.createElement(i),o=wt[i]||[];for(const i of Array.from(n.attributes)){const n=i.name.toLowerCase();if(o.includes(n)){const o=sanitizeAttributeValue(n,i.value);null!==o&&t.setAttribute(n,o)}}"a"===i&&(t.setAttribute("target","_blank"),t.setAttribute("rel","noopener noreferrer"));for(const i of Array.from(n.childNodes)){const n=cleanNode(i);n&&t.appendChild(n)}return t}const o=document.createDocumentFragment();for(const t of Array.from(n.childNodes)){const n=cleanNode(t);n&&o.appendChild(n)}return o.childNodes.length>0?o:null}return null}function sanitizeHTML(t){if(!t||"string"!=typeof t)return"";try{const n=new DOMParser,i=n.parseFromString(t,"text/html"),o=i.querySelector("parsererror");if(o)return console.warn("HTML parsing error detected"),"";const r=document.createDocumentFragment();for(const t of Array.from(i.body.childNodes)){const n=cleanNode(t);n&&r.appendChild(n)}const s=document.createElement("div");return s.appendChild(r),s.innerHTML}catch(n){return console.error("HTML sanitization error:",n),""}}class CheckoutCompletedComponent extends BaseComponent{get hostClasses(){return["checkout-completed-container"]}template(){var t,n,i,r,s,a;const l=[],c=this.getConfigs("configurations"),d=this.getConfigs("global"),u=this.getConfigs("checkout"),h=this.config.layout.exitUrl||window.location.host,p=this.config.layout.thankYouButtonText||"Continue Shopping";if(null===(n=null===(t=this.config.layout)||void 0===t?void 0:t.checkoutCompleted)||void 0===n?void 0:n.customLogo){const t=document.createElement("div");t.classList.add("checkout-completed-header-container");const n=document.createElement("img");n.src=null===(r=null===(i=this.config.layout)||void 0===i?void 0:i.checkoutCompleted)||void 0===r?void 0:r.customLogo,n.alt=c.partnerName+" Logo",t.appendChild(n),l.push(t)}const m=document.createElement("div");m.classList.add("checkout-completed-section-container");const f=document.createElement("div");f.classList.add("checkout-completed-title-container");const b=document.createElement("div");b.classList.add("checkout-completed-title-section");const w=document.createElement("h3");w.innerHTML=(null===(a=null===(s=this.config.layout)||void 0===s?void 0:s.checkoutCompleted)||void 0===a?void 0:a.customText)||"Thank You for Your Order!",b.appendChild(w);const C=document.createElement("p");C.textContent="Your payment has been successfully processed.",b.appendChild(C),f.appendChild(b),m.appendChild(f);const k=document.createElement("div");k.classList.add("checkout-completed-sub-section");const S=document.createElement("div");S.classList.add("checkout-completed-line");const E=document.createElement("h3");E.textContent="Order Number",S.appendChild(E);const _=document.createElement("span");_.textContent=this.params.orderNumber,S.appendChild(_),k.appendChild(S);const D=document.createElement("div");D.classList.add("checkout-completed-line");const P=document.createElement("h3");P.textContent="Order Amount",D.appendChild(P);const F=document.createElement("span");F.textContent=""+formatCentToDollarText(this.params.orderTotal),D.appendChild(F),k.appendChild(D);const A=document.createElement("div");A.classList.add("checkout-completed-line");const O=document.createElement("h3");O.textContent="Payment Method",A.appendChild(O);const N=document.createElement("span");N.textContent="** "+this.params.cardLast4,A.appendChild(N),k.appendChild(A),m.appendChild(k);const R=document.createElement("div");R.classList.add("checkout-completed-sub-section");const M=document.createElement("p");M.innerHTML=this.params.giftRecipientEmail?"Order updates and your gift message will be sent to <strong>"+this.params.giftRecipientEmail+"</strong>.<br><br>A confirmation email and receipt has been sent to <strong>"+this.params.customerEmail+"</strong>.":"A confirmation email and receipt has been sent to <strong>"+this.params.customerEmail+"</strong>.",R.appendChild(M),m.appendChild(R),l.push(m);const q=document.createElement("div");q.classList.add("checkout-completed-section-container");const j=document.createElement("button");j.type="button";const U=document.createElement("span");U.textContent=p,j.setAttribute("tabindex","0"),j.setAttribute("role","button"),j.setAttribute("aria-label",p),j.appendChild(U);const V=htmlStringToElement(ArrowRightIcon({width:16,height:16,color:d.theme.selectedTextColor}));j.appendChild(V),j.addEventListener("click",()=>{window.location.href=h}),j.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),window.location.href=h)}),q.appendChild(j),l.push(q);const K=document.createElement("div");K.classList.add("checkout-completed-section-container");const Y=document.createElement("div");Y.classList.add("checkout-completed-help-section"),K.appendChild(Y);const W=document.createElement("p");W.textContent="Questions about your order? Contact us at ";const Q=document.createElement("a");Q.href="mailto:"+c.supportEmail,Q.textContent=c.supportEmail,W.appendChild(Q),Y.appendChild(W);const Z=document.createElement("p"),X=(new Date).toLocaleDateString("en-US",{month:"2-digit",day:"2-digit",year:"numeric"});if(Z.textContent="Order placed on "+X,Y.appendChild(Z),l.push(K),u.layout.legalMessage.show){const t=document.createElement("div");t.classList.add("checkout-separator");const n=document.createElement("div");n.classList.add("checkout-legal-message"),n.innerHTML=sanitizeHTML(u.layout.legalMessage.text);const i=document.createElement("div");i.classList.add("checkout-separator"),l.push(t),l.push(n),l.push(i)}if(d.layout.showPoweredBy){const t=ComponentFactoryService.createElement({type:o.POWERED_BY,context:"general"});l.push(t)}return l}}class CheckoutDeliverToComponent extends BaseComponent{get hostClasses(){return["checkout-delivery-information"]}constructor(){super({watchStorePaths:["checkout.isGift"],watchOnlyStorePaths:["checkout.customerForm.isSaving","checkout.giftRecipientForm.isSaving"]}),this.customerData={firstName:{isValid:![],value:""},lastName:{isValid:![],value:""},email:{isValid:![],value:""},phone:{isValid:![],value:""},company:{isValid:!![],value:""},birthDate:{isValid:![],value:""},addressTwo:{isValid:!![],value:""},deliveryInstructions:{isValid:!![],value:""}},this.giftData={firstName:{isValid:![],value:""},lastName:{isValid:![],value:""},email:{isValid:![],value:""},phone:{isValid:![],value:""},message:{isValid:![],value:""},addressTwo:{isValid:!![],value:""},deliveryInstructions:{isValid:!![],value:""}},this.saveButtonText="Save Delivery Information"}onStoreWatch(t){const n=t.find(t=>"checkout.customerForm.isSaving"===t.path),i=t.find(t=>"checkout.giftRecipientForm.isSaving"===t.path);(null==n?void 0:n.value)||(null==i?void 0:i.value)?(this.saveButton.textContent="Saving...",this.saveButton.disabled=!![]):(this.saveButton.textContent=this.saveButtonText,this.updateSaveButtonState())}updateSaveButtonState(){const t=this.getStoreValue("checkout.isGift")||![];let n;n=t?!(this.giftData.firstName.isValid&&this.giftData.lastName.isValid&&this.giftData.email.isValid&&this.giftData.phone.isValid&&this.giftData.message.isValid&&this.giftData.addressTwo.isValid):!(this.customerData.firstName.isValid&&this.customerData.lastName.isValid&&this.customerData.email.isValid&&this.customerData.phone.isValid&&this.customerData.birthDate.isValid),this.saveButton.disabled=n}template(){const t=this.getConfigs("global"),n=this.getStoreValue("checkout.isGift"),r=this.store.get("checkout.giftRecipientForm.data"),s=this.store.get("checkout.customerForm.data"),a=this.store.get("address.formattedAddress"),l=n?r:s,c=this.store.get("checkout.shippingAddressTwo"),d=this.store.get("checkout.deliveryInstructions");s.firstName&&(this.customerData.firstName={isValid:!![],value:s.firstName}),s.lastName&&(this.customerData.lastName={isValid:!![],value:s.lastName}),s.email&&(this.customerData.email={isValid:!![],value:s.email}),s.phone&&(this.customerData.phone={isValid:!![],value:s.phone}),s.company&&(this.customerData.company={isValid:!![],value:s.company}),s.birthDate&&(this.customerData.birthDate={isValid:!![],value:s.birthDate}),r.firstName&&(this.giftData.firstName={isValid:!![],value:r.firstName}),r.lastName&&(this.giftData.lastName={isValid:!![],value:r.lastName}),r.email&&(this.giftData.email={isValid:!![],value:r.email}),r.phone&&(this.giftData.phone={isValid:!![],value:r.phone}),r.message&&(this.giftData.message={isValid:!![],value:r.message}),c&&(this.customerData.addressTwo={isValid:!![],value:c},this.giftData.addressTwo={isValid:!![],value:c}),d&&(this.customerData.deliveryInstructions={isValid:!![],value:d},this.giftData.deliveryInstructions={isValid:!![],value:d});const u=Object.keys(this.store.get("checkout.onDemandFulfillmentTipInfo")||{}).length>0,h=[],p=document.createElement("div");p.classList.add("delivery-header-container");const m=document.createElement("div");m.classList.add("delivery-header-content");const f=document.createElement("div");f.classList.add("delivery-title-container");const b=document.createElement("h3");b.textContent="Deliver to",b.classList.add("delivery-title");const w=document.createElement("p");w.textContent="Package recipient must be 21+",w.classList.add("delivery-subtitle"),f.appendChild(b),f.appendChild(w),p.appendChild(f),h.push(p);const C=document.createElement("div");C.classList.add("section-form-container");const k=document.createElement("div");k.classList.add("checkout-two-col-container");const S=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:n?yt.firstName:vt.firstName,label:"First Name",autocomplete:!![],validation:{required:!![]},value:l.firstName,onChange:t=>{n?(this.giftData.firstName.value=t,this.pubSub.publishForm(i.GIFT,{fieldName:yt.firstName})):(this.customerData.firstName.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.firstName}))},onValidation:t=>{n?this.giftData.firstName.isValid=t:this.customerData.firstName.isValid=t,this.updateSaveButtonState()}});S.setAttribute("aria-label","First Name Input"),k.appendChild(S);const E=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:n?yt.lastName:vt.lastName,label:"Last Name",autocomplete:!![],validation:{required:!![]},value:l.lastName,onChange:t=>{n?(this.giftData.lastName.value=t,this.pubSub.publishForm(i.GIFT,{fieldName:yt.lastName})):(this.customerData.lastName.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.lastName}))},onValidation:t=>{n?this.giftData.lastName.isValid=t:this.customerData.lastName.isValid=t,this.updateSaveButtonState()}});if(E.setAttribute("aria-label","Last Name Input"),k.appendChild(E),C.appendChild(k),!n){const t=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:vt.company,label:"Company (optional)",autocomplete:!![],value:l.company,onChange:async t=>{this.customerData.company.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.company})},onValidation:t=>{this.customerData.company.isValid=t,this.updateSaveButtonState()}});t.setAttribute("aria-label","Company Input"),C.appendChild(t)}const _=ComponentFactoryService.createElement({type:o.INPUT,inputType:"email",name:n?yt.email:vt.email,label:"Email",autocomplete:!![],validation:{required:!![]},value:l.email,onChange:t=>{n?(this.giftData.email.value=t,this.pubSub.publishForm(i.GIFT,{fieldName:yt.email})):(this.customerData.email.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.email}))},onValidation:t=>{n?this.giftData.email.isValid=t:this.customerData.email.isValid=t,this.updateSaveButtonState()}});_.setAttribute("aria-label","Email Input"),C.appendChild(_);const D=ComponentFactoryService.createElement({type:o.INPUT,inputType:"tel",name:n?yt.phone:vt.phone,label:"Phone",autocomplete:!![],validation:{required:!![]},value:l.phone,onChange:t=>{n?(this.giftData.phone.value=t,this.pubSub.publishForm(i.GIFT,{fieldName:yt.phone})):(this.customerData.phone.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.phone}))},onValidation:t=>{n?this.giftData.phone.isValid=t:this.customerData.phone.isValid=t,this.updateSaveButtonState()}});if(D.setAttribute("aria-label","Phone Input"),C.appendChild(D),!n){const t=ComponentFactoryService.createElement({type:o.BIRTHDATE_INPUT,inputType:"date",name:vt.birthDate,label:"Birthdate",validation:{required:!![],minAge:21,minYear:1930},value:l.birthDate,onChange:async t=>{this.customerData.birthDate.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.birthDate})},onValidation:t=>{this.customerData.birthDate.isValid=t,this.updateSaveButtonState()}});t.setAttribute("aria-label","Birthdate Input"),C.appendChild(t)}const P=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:"address_one",label:"Delivery address",value:a,disabled:!![],className:"disabled-input"});P.setAttribute("aria-label","Delivery Address Input"),C.appendChild(P);const F=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:n?yt.addressTwo:vt.addressTwo,label:"Apt, suite, etc. (optional)",value:c,onChange:t=>{n?(this.giftData.addressTwo.value=t,this.pubSub.publishForm(i.GIFT,{fieldName:yt.addressTwo})):(this.customerData.addressTwo.value=t,this.pubSub.publishForm(i.CUSTOMER,{fieldName:vt.addressTwo}))},onValidation:t=>{n?this.giftData.addressTwo.isValid=t:this.customerData.addressTwo.isValid=t,this.updateSaveButtonState()}});if(F.setAttribute("aria-label","Address Line 2 Input"),C.appendChild(F),n){const n=document.createElement("div");n.classList.add("custom-input","textarea",t.layout.inputFieldStyle);const o=document.createElement("label");o.textContent="Gift Message*",o.setAttribute("for",yt.message);const s=document.createElement("textarea");s.name=yt.message,s.id=yt.message,s.rows=4,s.value=r.message||"",s.setAttribute("aria-label","Gift Message Textarea"),s.addEventListener("input",async t=>{const n=t.target.value;this.giftData.message.value=n,this.giftData.message.isValid=n.length>0,this.pubSub.publishForm(i.GIFT,{fieldName:yt.message}),this.updateSaveButtonState()});const a=document.createElement("p");a.textContent="Your gift message will be emailed to the recipient along with delivery details.",a.classList.add("textarea-message-disclaimer"),n.appendChild(o),n.appendChild(s),n.appendChild(a),C.appendChild(n)}if(u){const i=document.createElement("div");i.classList.add("custom-input","textarea",t.layout.inputFieldStyle);const o=document.createElement("label");o.textContent="Delivery Instructions",o.setAttribute("for","delivery_instructions");const r=document.createElement("textarea");r.id="delivery_instructions",r.name="delivery_instructions",r.rows=4,r.setAttribute("aria-label","Delivery Instructions Textarea"),r.value=d,r.addEventListener("input",async t=>{const i=t.target.value;n?(this.giftData.deliveryInstructions.value=i,this.giftData.deliveryInstructions.isValid=i.length>0):(this.customerData.deliveryInstructions.value=i,this.customerData.deliveryInstructions.isValid=i.length>0)});const s=document.createElement("p");s.textContent="Include gate codes, apartment numbers, or preferred drop-off locations for your driver.",s.classList.add("textarea-message-disclaimer"),i.appendChild(o),i.appendChild(r),i.appendChild(s),C.appendChild(i)}h.push(C),this.saveButton=document.createElement("button"),this.saveButton.type="button",this.saveButton.classList.add("save-form-info-button"),this.saveButton.textContent=this.saveButtonText,this.saveButton.setAttribute("aria-label","Save Delivery Information"),this.saveButton.setAttribute("role","button"),this.saveButton.setAttribute("tabindex","0");const H=async()=>{n?await this.commands.checkout.saveGiftRecipientForm({firstName:this.giftData.firstName.value,lastName:this.giftData.lastName.value,email:this.giftData.email.value,phone:this.giftData.phone.value,message:this.giftData.message.value,shippingAddressTwo:this.giftData.addressTwo.value,deliveryInstructions:this.giftData.deliveryInstructions.value}):await this.commands.checkout.saveCustomerForm({customerData:{firstName:this.customerData.firstName.value,lastName:this.customerData.lastName.value,email:this.customerData.email.value,phone:this.customerData.phone.value,company:this.customerData.company.value,birthDate:this.customerData.birthDate.value},shippingAddressTwo:this.customerData.addressTwo.value,deliveryInstructions:this.customerData.deliveryInstructions.value})};return this.saveButton.addEventListener("click",H),this.saveButton.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await H())}),h.push(this.saveButton),this.updateSaveButtonState(),h}}class CheckoutDeliverToSummaryComponent extends BaseComponent{get hostClasses(){return["checkout-summary-form-container"]}constructor(){super({watchStorePaths:["checkout.isGift","checkout.customerForm","checkout.giftRecipientForm","checkout.deliveryInstructions"]})}template(){const t=[],n=this.getStoreValue("checkout.isGift"),i=this.getStoreValue("checkout.customerForm.data"),o=this.getStoreValue("checkout.giftRecipientForm.data"),r=this.getStoreValue("address"),s=this.getStoreValue("checkout.deliveryInstructions"),a=this.getStoreValue("checkout.shippingAddressTwo"),l=document.createElement("div");l.classList.add("checkout-summary-form-header");const c=document.createElement("h2");c.textContent=n?"Delivering to "+o.firstName+" "+o.lastName:"Delivering to "+i.firstName+" "+i.lastName,l.appendChild(c);const d=document.createElement("span");d.textContent="Edit",d.setAttribute("aria-label","Edit Delivery Information"),d.setAttribute("role","button"),d.setAttribute("tabindex","0");const g=async()=>{n?await this.commands.checkout.editGiftRecipientForm():await this.commands.checkout.editCustomerForm()};if(d.addEventListener("click",g),d.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await g())}),l.appendChild(d),t.push(l),!n&&i.company){const n=document.createElement("p");n.classList.add("checkout-summary-form-line"),n.textContent=i.company,t.push(n)}const u=document.createElement("p");u.classList.add("checkout-summary-form-line"),u.textContent=r.address.one+(a?", "+a:"")+", "+r.address.city+", "+r.address.state+", "+r.address.zip,t.push(u);const h=document.createElement("p");h.classList.add("checkout-summary-form-line"),h.textContent=n?o.email:i.email,t.push(h);const p=document.createElement("p");if(p.classList.add("checkout-summary-form-line"),p.textContent=n?o.phone:i.phone,t.push(p),!n&&i.birthDate){const n=document.createElement("p");n.classList.add("checkout-summary-form-line"),n.textContent=formatISODateToMMDDYYYY(i.birthDate),t.push(n)}if(n){const n=document.createElement("div");n.classList.add("checkout-summary-form-line-container");const i=document.createElement("span");i.classList.add("checkout-summary-form-line-container-label"),i.textContent="Gift Message:",n.appendChild(i);const r=document.createElement("span");r.classList.add("checkout-summary-form-line"),r.textContent=o.message||"No message provided.",n.appendChild(r),t.push(n)}if(s){const n=document.createElement("div");n.classList.add("checkout-summary-form-line-container");const i=document.createElement("span");i.classList.add("checkout-summary-form-line-container-label"),i.textContent="Delivery Instructions:",n.appendChild(i);const o=document.createElement("span");o.classList.add("checkout-summary-form-line"),o.textContent=s||"No instructions provided.",n.appendChild(o),t.push(n)}return t}}class CheckoutGiftCardsComponent extends BaseComponent{get hostClasses(){return["input-gift-card-container"]}constructor(){super({watchOnlyStorePaths:["checkout.giftCards","checkout.giftCardError","checkout.loading"]}),this.isApplying=![],this.giftCardInput=null,this.applyButton=null}onStoreWatch(t){var n;const i=t.find(t=>"checkout.giftCards"===t.path),o=t.find(t=>"checkout.loading"===t.path);i&&i.value.length>((null===(n=i.oldValue)||void 0===n?void 0:n.length)||0)&&this.giftCardInput&&this.giftCardInput.setValue(""),o&&this.updateApplyButtonState()}updateApplyButtonState(){if(!this.applyButton||!this.giftCardInput)return;const t=this.giftCardInput.getValue().trim(),n=t.length>=3&&t.length<=255,i=this.getStoreValue("checkout.loading"),o=this.getStoreValue("checkout.giftCardError");this.applyButton.disabled=!n||i||Boolean(o)||this.isApplying}createGiftCardInput(){return this.giftCardInput=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:"giftCards",placeholder:"Enter gift card code",autocomplete:![],validation:{min:3,max:255},onChange:t=>{const n=t.toUpperCase(),i=this.giftCardInput;i.setValue(n),this.updateApplyButtonState()}}),this.giftCardInput}createApplyButton(){this.applyButton=document.createElement("button"),this.applyButton.type="button",this.applyButton.classList.add("apply-button"),this.applyButton.disabled=!![],this.applyButton.textContent="Apply",this.applyButton.setAttribute("tabindex","0"),this.applyButton.setAttribute("role","button"),this.applyButton.setAttribute("aria-label","Apply gift card");const T=async()=>{const t=this.giftCardInput.getValue().trim().toUpperCase();if(t)try{this.isApplying=!![],this.updateApplyButtonState(),await this.commands.checkout.applyGiftCard(t)}catch(n){this.logger.error("Checkout gift card application failed",{giftCardCode:t,error:n instanceof Error?n.message:String(n)})}finally{this.isApplying=![],this.updateApplyButtonState()}};return this.applyButton.addEventListener("click",T),this.applyButton.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),T())}),this.applyButton}template(){this.giftCardInput=null,this.applyButton=null;const t=[];return t.push(this.createGiftCardInput()),t.push(this.createApplyButton()),t}disconnected(){this.giftCardInput=null,this.applyButton=null}}class CheckoutHeaderComponent extends BaseComponent{get hostClasses(){return["checkout-header-container"]}template(){const t=this.store.get("checkout.presale"),n=this.getConfigs("checkout");let i=null;if(!t){i=document.createElement("button"),i.classList.add("checkout-header-button"),i.setAttribute("aria-label","Back to Cart"),i.addEventListener("click",()=>{if(this.clientConfig.isBuilder())return this.logger.info("Back To Cart Button Is Disabled In Builder Mode"),void 0;this.commands.ui.openDrawer(o.CART)});const t=document.createElement("span");t.innerHTML=ChevronLeftIcon({}),i.appendChild(t)}const r=document.createElement("h1");r.textContent=(null==n?void 0:n.layout.drawerHeaderText)||"Checkout",r.classList.add("checkout-header-title"),r.setAttribute("aria-label","Checkout Page");const s=document.createElement("button");return s.innerHTML=CloseIcon({width:16,height:16}),s.classList.add("checkout-header-button-close"),s.setAttribute("aria-label","Close Checkout"),s.addEventListener("click",()=>{this.commands.ui.closeDrawer()}),i?[i,r,s]:[r,s]}}class CheckoutInformationComponent extends BaseComponent{get hostClasses(){return["checkout-information-section"]}constructor(){super({watchOnlyStorePaths:["checkout.isGift","checkout.customerForm.isEditing","checkout.giftRecipientForm.isEditing","checkout.paymentForm.isEditing"]})}onStoreWatch(){const t=this.getStoreValue("checkout.isGift"),n=this.getStoreValue("checkout.customerForm.isEditing"),i=this.getStoreValue("checkout.giftRecipientForm.isEditing"),o=this.getStoreValue("checkout.paymentForm.isEditing");t?(this.buyerForm.style.display=n?"block":"none",this.buyerSummary.style.display=n?"none":"block",this.deliveryToForm.style.display=i?"block":"none",this.deliverToSummary.style.display=i?"none":"block"):(this.deliveryToForm.style.display=n?"block":"none",this.deliverToSummary.style.display=n?"none":"block",this.buyerForm.style.display="none",this.buyerSummary.style.display="none"),this.paymentForm.style.display=o?"block":"none",this.paymentSummary.style.display=o?"none":"block"}template(){const t=[],n=this.getStoreValue("checkout.isGift"),i=this.getStoreValue("checkout.customerForm"),r=this.getStoreValue("checkout.giftRecipientForm"),s=this.getStoreValue("checkout.paymentForm"),a=ComponentFactoryService.createElement({type:o.CHECKOUT_SEND_AS_GIFT});return t.push(a),this.deliveryToForm=ComponentFactoryService.createElement({type:o.CHECKOUT_DELIVER_TO}),this.deliveryToForm.style.display=n?r.isEditing?"block":"none":i.isEditing?"block":"none",t.push(this.deliveryToForm),this.deliverToSummary=ComponentFactoryService.createElement({type:o.CHECKOUT_DELIVER_TO_SUMMARY}),this.deliverToSummary.style.display=n?r.isEditing?"none":"block":i.isEditing?"none":"block",t.push(this.deliverToSummary),this.buyerForm=ComponentFactoryService.createElement({type:o.CHECKOUT_BUYER}),this.buyerForm.style.display=n&&i.isEditing?"block":"none",t.push(this.buyerForm),this.buyerSummary=ComponentFactoryService.createElement({type:o.CHECKOUT_BUYER_SUMMARY}),this.buyerSummary.style.display=n&&!i.isEditing?"block":"none",t.push(this.buyerSummary),this.paymentForm=ComponentFactoryService.createElement({type:o.CHECKOUT_PAYMENT}),this.paymentForm.style.display=s.isEditing?"block":"none",t.push(this.paymentForm),this.paymentSummary=ComponentFactoryService.createElement({type:o.CHECKOUT_PAYMENT_SUMMARY}),this.paymentSummary.style.display=s.isEditing?"none":"block",t.push(this.paymentSummary),t}}class CheckoutItemComponent extends BaseComponent{get hostClasses(){return["checkout-item-card"]}constructor(){super({autoDestroy:!![],autoDestroyPath:"checkout.items.{itemId}",watchStorePaths:["checkout.items.{itemId}","checkout.items"]}),this.trashButton=null}onStoreChanged(t){var n,i,o,r;const s=t.find(t=>"checkout.items"===t.path);s&&(this.updateTrashButtonState(),this.setupMinimumPurchaseAlert(),this.checkAndUpdateLoadingState());const a=t.find(t=>t.path==="checkout.items."+this.params.itemId);if(a){const t=a.oldValue,s=a.value;if(s.updating)return![];const l=(null==t?void 0:t.quantity)!==(null==s?void 0:s.quantity),c=(null===(i=null===(n=null==t?void 0:t.attributes)||void 0===n?void 0:n.engraving)||void 0===i?void 0:i.lines)||[],d=(null===(r=null===(o=null==s?void 0:s.attributes)||void 0===o?void 0:o.engraving)||void 0===r?void 0:r.lines)||[],u=JSON.stringify(c)!==JSON.stringify(d);(l||u)&&this.updateEngravingElement(s)}return![]}updateEngravingElement(t){var n,i;const r=this.getConfigs("global"),s=this.container.querySelector(".engraving-view-container");if(s&&s.remove(),(null===(i=null===(n=null==t?void 0:t.attributes)||void 0===n?void 0:n.engraving)||void 0===i?void 0:i.hasEngraving)===!![]&&r.layout.enablePersonalization){const n=ComponentFactoryService.createElement({type:o.ENGRAVING_VIEW,identifier:t.cartItemId,context:"checkout"}),i=this.container.querySelector(".checkout-item-card-footer");i&&i.before(n)}}setupMinimumPurchaseAlert(){const t=this.getStoreValue("checkout.items."+this.params.itemId);if(!t)return;const n=t.fulfillmentId;if(!n)return;if(!this.container)return;const i=this.container.querySelector(".checkout-item-card-header");if(i){const r=this.getStoreValue("cart.fulfillments."+n),s=this.container.querySelector('[data-component-type="checkout-retailer-alert"]');if(s&&s.remove(),r&&shouldShowMinimumPurchaseAlert(r,t.pack)){const n=getMinimumPurchaseMessage(r,t.pack),s=ComponentFactoryService.createElement({type:o.PURCHASE_MIN_ALERT,message:n.message,messageType:n.type,currentTotal:r.subtotal,config:{showIcon:!![],alertType:"minimal"}});s.setAttribute("data-component-type","checkout-retailer-alert"),i.before(s)}}}updateTrashButtonState(){if(!this.trashButton)return;const t=this.getStoreValue("checkout"),n=Object.keys(t.items).length,i=1===n;this.trashButton.disabled=i,i?this.trashButton.classList.add("action-disabled"):this.trashButton.classList.remove("action-disabled")}createLoadingOverlay(){const t=document.createElement("div");t.className="cart-loading-backdrop",t.setAttribute("data-loading-id","item-loading-overlay");const n=document.createElement("div");n.className="cart-loading-spinner-container";const i=document.createElement("div");return i.className="cart-loading-spinner",i.innerHTML='\n <svg class="cart-spinner" width="32" height="32" viewBox="0 0 50 50">\n <circle\n class="cart-spinner-path"\n cx="25"\n cy="25"\n r="20"\n fill="none"\n stroke-width="3"\n stroke-linecap="round"\n stroke-dasharray="31.416"\n stroke-dashoffset="31.416"\n />\n </svg>\n ',n.appendChild(i),t.appendChild(n),t}hasLoadingOverlay(){return!!this.container.querySelector('[data-loading-id="item-loading-overlay"]')}showLoadingOverlay(){if(this.hasLoadingOverlay())return;const t=this.createLoadingOverlay();this.container.appendChild(t),this.container instanceof HTMLElement&&(this.container.style.position="relative")}hideLoadingOverlay(){const t=this.container.querySelector('[data-loading-id="item-loading-overlay"]');t&&(t.remove(),this.container instanceof HTMLElement&&(this.container.style.position=""))}isItemUpdating(){const t=this.getStoreValue("checkout.items."+this.params.itemId);return t?t.updating===!![]:![]}checkAndUpdateLoadingState(){const t=this.isItemUpdating(),n=this.hasLoadingOverlay();t&&!n?this.showLoadingOverlay():!t&&n&&this.hideLoadingOverlay()}afterRender(){this.updateTrashButtonState(),this.checkAndUpdateLoadingState()}template(){var t,n,i;const r=this.getConfigs("global"),s=this.getStoreValue("checkout.items."+this.params.itemId),a=null===(t=null==s?void 0:s.attributes)||void 0===t?void 0:t.presale,l=(null==a?void 0:a.isActive)&&(null==a?void 0:a.estimatedShipBy)?"Ships by "+formatISODateToMMDDYYYY(a.estimatedShipBy):"";if(!s)return[];const c=document.createElement("div");c.classList.add("checkout-item-card-header");const d=document.createElement("div");d.classList.add("checkout-item-image");const u=document.createElement("img");u.src=s.mainImage,u.alt=s.name,u.loading="lazy",d.appendChild(u),c.appendChild(d);const h=document.createElement("div");h.classList.add("checkout-item-details-container");const p=document.createElement("h4");p.classList.add("checkout-item-title"),p.textContent=s.name,h.appendChild(p);const m=document.createElement("div");m.classList.add("checkout-item-subtitle");const f=document.createElement("span");f.textContent=a.isActive?""+l:((null==s?void 0:s.expectationDetail)||"")+",",m.appendChild(f);const b=document.createElement("span");b.textContent="From "+((null==s?void 0:s.retailerName)||""),m.appendChild(b),h.appendChild(m),c.appendChild(h),this.trashButton=document.createElement("button"),this.trashButton.type="button",this.trashButton.innerHTML=TrashIcon({}),this.trashButton.addEventListener("click",async t=>{var n;if(t.preventDefault(),t.stopPropagation(),!(null===(n=this.trashButton)||void 0===n?void 0:n.disabled))try{await this.commands.checkout.removeItem(s.cartItemId)}catch(i){this.logger.error("Checkout item removal failed",i)}}),c.appendChild(this.trashButton);const w=ComponentFactoryService.createElement({type:o.CHECKOUT_ITEM_QUANTITY,itemId:s.cartItemId}),C=[];if(C.push(c),r.layout.enablePersonalization&&(null===(i=null===(n=null==s?void 0:s.attributes)||void 0===n?void 0:n.engraving)||void 0===i?void 0:i.hasEngraving)===!![]){const t=ComponentFactoryService.createElement({type:o.ENGRAVING_VIEW,identifier:s.cartItemId,context:"checkout"});C.push(t)}return C.push(w),C}disconnected(){this.hideLoadingOverlay()}}class CheckoutItemQuantityComponent extends BaseComponent{get hostClasses(){return["checkout-item-card-footer"]}constructor(){super({watchStorePaths:["checkout.items.{itemId}"],watchOnlyStorePaths:["checkout.items"],autoDestroy:!![],autoDestroyPath:"checkout.items.{itemId}"})}onStoreWatch(t){const n=t.find(t=>"checkout.items"===t.path);if(n){const t=this.calculateQuantityLimits();this.updateButtonStates(t)}}getAvailableQuantity(){var t,n,i;const o=this.getStoreValue("checkout.items."+this.params.itemId);if(!o)return 0;const r=this.getStoreValue("products");if(!r)return 0;const s=o.partNumber,a=o.fulfillmentId,l=null===(i=null===(n=null===(t=Object.values(r).find(t=>t.sizes[o.liquidId]))||void 0===t?void 0:t.sizes)||void 0===n?void 0:n[o.liquidId])||void 0===i?void 0:i.attributes.maxQuantityPerOrder;if(!l)return 0;const c=this.getStoreValue("checkout.items")||{},d=Object.values(c).filter(t=>t.partNumber===s&&t.fulfillmentId===a),u=d.reduce((t,n)=>t+n.quantity,0);return l-u}calculateQuantityLimits(){var t;const n=this.getStoreValue("checkout.items."+this.params.itemId);if(!n)return{currentQuantity:0,availableQuantity:0,isTheOnlyItem:![],canIncrease:![],canDecrease:![]};const i=this.getStoreValue("checkout"),o=1===(null===(t=Object.values(i.items))||void 0===t?void 0:t.length),r=n.quantity,s=this.getAvailableQuantity(),a=s>0,l=!(o&&1===r);return{currentQuantity:r,availableQuantity:s,isTheOnlyItem:o,canIncrease:a,canDecrease:l}}updateButtonStates(t){this.decreaseButton&&(this.decreaseButton.disabled=!t.canDecrease,this.decreaseButton.classList.toggle("disabled",!t.canDecrease)),this.increaseButton&&(this.increaseButton.disabled=!t.canIncrease,this.increaseButton.classList.toggle("disabled",!t.canIncrease),t.canIncrease?this.increaseButton.setAttribute("aria-label","Increase quantity"):this.increaseButton.setAttribute("aria-label","Cannot increase quantity above maximum")),this.quantitySpan&&(this.quantitySpan.textContent=t.currentQuantity.toString(),this.quantitySpan.setAttribute("aria-label","Current quantity: "+t.currentQuantity))}async handleQuantityChange(t){const n=this.calculateQuantityLimits(),i=this.params.itemId;if((!(t<0)||n.canDecrease)&&(!(t>0)||n.canIncrease)){if(!i)return this.logger.error("Checkout item quantity change failed: Item ID not found in component params",{componentParams:this.params,delta:t}),void 0;try{await this.commands.checkout.updateCheckoutItemQuantity(i,t)}catch(o){this.logger.error("Checkout item quantity change operation failed",o)}}}template(){const t=this.getStoreValue("checkout.items."+this.params.itemId);if(!t)return this.logger.warn("Checkout item not found during template render",{itemId:this.params.itemId}),[];const n=this.calculateQuantityLimits(),i=document.createElement("div");i.classList.add("checkout-item-quantity-container"),this.decreaseButton=document.createElement("button"),this.decreaseButton.type="button",this.decreaseButton.classList.add("quantity-decrease"),this.decreaseButton.textContent="-",this.decreaseButton.setAttribute("aria-label","Decrease quantity"),this.decreaseButton.addEventListener("click",async t=>{t.preventDefault(),t.stopPropagation(),await this.handleQuantityChange(-1)}),i.appendChild(this.decreaseButton),this.quantitySpan=document.createElement("span"),this.quantitySpan.classList.add("product-count"),i.appendChild(this.quantitySpan),this.increaseButton=document.createElement("button"),this.increaseButton.type="button",this.increaseButton.classList.add("quantity-increase"),this.increaseButton.textContent="+",this.increaseButton.addEventListener("click",async t=>{t.preventDefault(),t.stopPropagation(),await this.handleQuantityChange(1)}),i.appendChild(this.increaseButton),this.updateButtonStates(n);const o=document.createElement("span");if(o.classList.add("checkout-item-price-text"),o.textContent=formatCentToDollarText(t.price),t.quantity>1){const n=document.createElement("span");n.classList.add("checkout-item-price-each-text"),n.textContent=" ("+formatCentToDollarText(t.unitPrice)+" ea)",o.appendChild(n)}return[i,o]}}class CheckoutItemsComponent extends BaseComponent{get hostClasses(){return["checkout-items-container"]}constructor(){super({watchStorePaths:["checkout.items"]})}createItemElement(t){return ComponentFactoryService.createElement({type:o.CHECKOUT_ITEM,itemId:t})}getItemsListContainer(){return this.container.querySelector(".checkout-items-list")}getTogglerLabel(){return this.container.querySelector(".checkout-items-toggler-label")}getCurrentItemsMap(){const t=this.getStoreValue("checkout.items")||{},n=new Map;for(const i of Object.values(t))i&&i.cartItemId&&n.set(i.cartItemId,i);return n}syncItemsWithStore(){const t=this.getItemsListContainer();if(!t)return;const n=this.getCurrentItemsMap(),i=t.querySelectorAll("[data-item-id]"),o=new Set;for(const r of i){const t=r.getAttribute("data-item-id");t&&o.add(t)}for(const r of i){const t=r.getAttribute("data-item-id");t&&!n.has(t)&&r.remove()}for(const[r]of n)if(!o.has(r)){const n=this.createItemElement(r);n.setAttribute("data-item-id",r),t.appendChild(n)}this.updateItemCount()}updateItemCount(){const t=this.getTogglerLabel();if(!t)return;const n=this.getCurrentItemsMap(),i=n.size;t.textContent=i+" item"+(1!==i?"s":"")}onStoreChanged(t){let n;for(let i=0;i<t.length;i++){const o=t[i];if("checkout"===o.path||"checkout.items"===o.path||"checkout.items."===o.path.substring(0,15)){n=o;break}}return n?(this.syncItemsWithStore(),![]):![]}handleToggle(){const t=this.container.querySelector(".checkout-items-toggler-button"),n=this.container.querySelector(".checkout-items-list");if(t&&n){const i=n.classList.contains("show");n.classList.toggle("show"),t.classList.toggle("expanded"),i?(t.setAttribute("aria-expanded","false"),t.setAttribute("aria-label","Expand checkout items")):(t.setAttribute("aria-expanded","true"),t.setAttribute("aria-label","Collapse checkout items"))}}setupToggler(){const t=this.container.querySelector(".checkout-items-toggler"),n=this.container.querySelector(".checkout-items-toggler-button"),i=this.container.querySelector(".checkout-items-list");if(t&&n&&i){const o=i.classList.contains("show");n.setAttribute("tabindex","0"),n.setAttribute("aria-expanded",o?"true":"false"),n.setAttribute("aria-label",o?"Collapse checkout items":"Expand checkout items"),t.addEventListener("click",()=>this.handleToggle()),t.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),this.handleToggle())})}}afterRender(){this.setupToggler(),this.syncItemsWithStore()}template(){const t=this.getStoreValue("checkout.items"),n=Object.values(t||{}),i=document.createElement("div");i.classList.add("checkout-items-toggler");const o=document.createElement("span");o.classList.add("checkout-items-toggler-label"),o.textContent=n.length+" item"+(1!==n.length?"s":""),i.appendChild(o);const r=document.createElement("button");r.type="button",r.classList.add("checkout-items-toggler-button"),r.innerHTML=ChevronDownIcon({width:20,height:20,className:"chevron-icon"}),i.appendChild(r);const s=document.createElement("div");s.classList.add("checkout-items-list","show");for(const a of n){const t=this.createItemElement(a.cartItemId);t.setAttribute("data-item-id",a.cartItemId),s.appendChild(t)}return[i,s]}}class CheckoutOrderSummaryComponent extends BaseComponent{get hostClasses(){return["checkout-summary-section"]}constructor(){super({watchOnlyStorePaths:["checkout.amounts"]})}onStoreWatch(t){const n=t.find(t=>"checkout.amounts"===t.path);if(n){const t=this.getStoreValue("checkout"),n=Object.values(t.items||{}).length;this.updateZeroAmountElement(0===t.amounts.total&&n>0)}}updateZeroAmountElement(t){const n=this.container.querySelector(".checkout-zero-amount-container");if(t&&!n){const t=document.createElement("div");t.classList.add("checkout-zero-amount-container"),t.textContent="Credit card required to complete order (even when fully covered by gift card)";const n=this.container.querySelector("checkout-amounts-lc, .checkout-amounts-container");n&&n.after(t)}else!t&&n&&n.remove()}afterRender(){const t=this.getStoreValue("checkout.amounts");t&&this.updateZeroAmountElement(0===t.total)}handleEmailToggle(t){this.commands.checkout.toggleMarketingPreferences("canEmail"),t.classList.toggle("checked");const n=t.classList.contains("checked");t.setAttribute("aria-checked",n?"true":"false")}handleSmsToggle(t){this.commands.checkout.toggleMarketingPreferences("canSms"),t.classList.toggle("checked");const n=t.classList.contains("checked");t.setAttribute("aria-checked",n?"true":"false")}marketingOptInsContainer(){const t=this.config.layout.emailOptIn,n=this.config.layout.smsOptIn;if(!t.show&&!n.show)return null;const i=document.createElement("div");if(i.classList.add("checkout-marketing-opt-ins-container"),t.show){const n=document.createElement("div");let o;n.classList.add("checkout-checkbox-container"),o=this.clientConfig.isBuilder()?t.checked:this.store.get("checkout.marketingPreferences.canEmail");const r=document.createElement("span");r.id="emailOptIn",r.classList.add("checkout-checkbox-visual"),o&&r.classList.add("checked"),r.innerHTML=CheckboxIcon({width:16,height:16}),r.setAttribute("role","checkbox"),r.setAttribute("tabindex","0"),r.setAttribute("aria-label","Email opt-in checkbox"),r.setAttribute("aria-checked",o?"true":"false"),r.addEventListener("click",()=>this.handleEmailToggle(r)),r.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),this.handleEmailToggle(r))});const s=document.createElement("label");s.setAttribute("for","emailOptIn"),s.classList.add("checkbox-label"),s.innerHTML=sanitizeHTML(t.text),s.addEventListener("click",t=>{const n=t.target,i="A"===n.tagName||n.closest("a");i||(this.commands.checkout.toggleMarketingPreferences("canEmail"),r.classList.toggle("checked"))}),n.appendChild(r),n.appendChild(s),i.appendChild(n)}if(n.show){const t=document.createElement("div");let o;t.classList.add("checkout-checkbox-container"),o=this.clientConfig.isBuilder()?n.checked:this.store.get("checkout.marketingPreferences.canSms");const r=document.createElement("span");r.classList.add("checkout-checkbox-visual"),r.id="smsOptIn",o&&r.classList.add("checked"),r.innerHTML=CheckboxIcon({width:16,height:16}),r.setAttribute("role","checkbox"),r.setAttribute("tabindex","0"),r.setAttribute("aria-label","SMS opt-in checkbox"),r.setAttribute("aria-checked",o?"true":"false"),r.addEventListener("click",()=>this.handleSmsToggle(r)),r.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),this.handleSmsToggle(r))});const s=document.createElement("label");s.setAttribute("for","smsOptIn"),s.classList.add("checkbox-label"),s.innerHTML=sanitizeHTML(n.text),s.addEventListener("click",t=>{const n=t.target,i="A"===n.tagName||n.closest("a");i||(this.commands.checkout.toggleMarketingPreferences("canSms"),r.classList.toggle("checked"))}),t.appendChild(r),t.appendChild(s),i.appendChild(t)}return i}hasOnDemandOrder(){const t=this.getStoreValue("checkout.onDemandFulfillmentTipInfo")||{};return Object.keys(t).length>0}template(){var t;const n=[],i=this.getConfigs("global"),r=this.getConfigs("checkout"),s=this.getConfigs("global"),a=r.layout.allowGiftCards,l=null===(t=null==s?void 0:s.layout)||void 0===t?void 0:t.allowPromoCodes,c=document.createElement("div");c.classList.add("section-title-container");const d=document.createElement("h3");d.textContent="Order Summary",d.classList.add("section-title"),c.appendChild(d),n.push(c);const u=ComponentFactoryService.createElement({type:o.CHECKOUT_ITEMS});n.push(u);const h=document.createElement("div");h.classList.add("checkout-separator");const p=document.createElement("div");if(p.classList.add("checkout-separator"),n.push(h),a||l){const t=ComponentFactoryService.createElement({type:o.CHECKOUT_PC_GC});n.push(t)}if(this.hasOnDemandOrder()){const t=ComponentFactoryService.createElement({type:o.CHECKOUT_TIPS});n.push(t),n.push(p)}const m=document.createElement("div");m.classList.add("section-title-container");const f=document.createElement("h3");f.textContent="100% Secure Payments",f.classList.add("disclaimer-header"),m.appendChild(f);const b=document.createElement("p");b.textContent="If a person over 21 is not available to receive this order, it will be returned for a $20 restocking fee. Valid Government ID required.",b.classList.add("disclaimer-description"),m.appendChild(b),n.push(m);const w=ComponentFactoryService.createElement({type:o.CHECKOUT_AMOUNTS});n.push(w);const C=ComponentFactoryService.createElement({type:o.CHECKOUT_PLACE_ORDER_BUTTON});n.push(C);const k=this.marketingOptInsContainer();if(k&&n.push(k),r.layout.legalMessage.show){const t=document.createElement("div");t.classList.add("checkout-separator");const i=document.createElement("div");i.classList.add("checkout-legal-message"),i.innerHTML=sanitizeHTML(r.layout.legalMessage.text),n.push(t),n.push(i)}const S=document.createElement("div");if(S.classList.add("checkout-separator"),n.push(S),i.layout.showPoweredBy){const t=ComponentFactoryService.createElement({type:o.POWERED_BY,context:"checkout"});n.push(t)}return n}}class CheckoutPaymentComponent extends BaseComponent{get hostClasses(){return["checkout-payment-form"]}constructor(){super({watchOnlyStorePaths:["checkout.paymentForm.isSaving","checkout.paymentForm.billingSameAsShipping"]}),this.stripeHandlerElement=null,this.hardcodedPaymentElement=null,this.billingFormData=null,this.isValidBillingForm=![],this.isBillingSameAsShipping=!![],this.stripeFormStatus={isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null},this.savedCardInfo=null,this.showingStripeSummary=![],this.isSavingPayment=![]}onStoreWatch(t){for(const n of t)switch(n.path){case"checkout.paymentForm.isSaving":this.isSavingPayment=n.value,this.updateSaveButtonState();break;case"checkout.paymentForm.billingSameAsShipping":this.handleBillingSameAsShippingChange(n.value)}}handleBillingSameAsShippingChange(t){this.isBillingSameAsShipping=t,t&&(this.billingFormData=null,this.isValidBillingForm=![]),this.updateSaveButtonState(),this.updateErrorMessage()}async afterRender(){var t;this.isBillingSameAsShipping=null!==(t=this.getStoreValue("checkout.paymentForm.billingSameAsShipping"))&&void 0!==t?t:!![],this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId")&&(this.stripeFormStatus={isFormComplete:!![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null}),this.updateSaveButtonState()}updateSaveButtonState(){if(!this.saveButton)return;let t=!![],n="Save Payment Information";if(this.isSavingPayment||this.stripeFormStatus.isProcessing)n="Saving...",t=!![];else if(this.stripeFormStatus.hasError)n="Fix Errors and Retry",t=![];else if(this.showingStripeSummary&&this.savedCardInfo){const n=this.isBillingSameAsShipping||this.isValidBillingForm;t=!n}else{const n=this.stripeFormStatus.isFormComplete,i=this.isBillingSameAsShipping||this.isValidBillingForm;t=!(n&&i)}this.saveButton.disabled=t,this.saveButton.textContent=n,this.saveButton.classList.toggle("processing",this.isSavingPayment||this.stripeFormStatus.isProcessing),this.saveButton.classList.toggle("error",this.stripeFormStatus.hasError)}updateErrorMessage(){if(!this.errorMessageElement)return;let t="";this.stripeFormStatus.hasError&&this.stripeFormStatus.errorMessage?t=this.stripeFormStatus.errorMessage:this.isBillingSameAsShipping||this.isValidBillingForm||!this.stripeFormStatus.isFormComplete||(t="Please complete the billing address form"),t?(this.errorMessageElement.textContent=t,this.errorMessageElement.style.display="block"):(this.errorMessageElement.textContent="",this.errorMessageElement.style.display="none")}showError(t){this.errorMessageElement&&(this.errorMessageElement.textContent=t,this.errorMessageElement.style.display="block",setTimeout(()=>{this.errorMessageElement&&this.errorMessageElement.textContent===t&&(this.errorMessageElement.style.display="none")},5e3))}template(){const t=[],n=document.createElement("div");n.classList.add("section-title-container");const i=document.createElement("h3");i.textContent="Payment",i.classList.add("section-title"),n.appendChild(i);const r=document.createElement("p");if(r.textContent="All transactions are secure and encrypted.",r.classList.add("section-subtitle"),n.appendChild(r),t.push(n),this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId")){this.hardcodedPaymentElement=document.createElement("div"),this.hardcodedPaymentElement.classList.add("hardcoded-payment-notice");const n=document.createElement("p");n.innerHTML="⚠️ Development Mode<br/>Payment Method: "+this.clientConfig.get("paymentMethodId"),this.hardcodedPaymentElement.appendChild(n),t.push(this.hardcodedPaymentElement)}else this.stripeHandlerElement=ComponentFactoryService.createElement({type:o.CHECKOUT_STRIPE_HANDLER,callbacks:{onStripeFormStatusChanged:t=>{this.stripeFormStatus=t,this.updateSaveButtonState(),this.updateErrorMessage()},onSavedCardInfoChanged:t=>{this.savedCardInfo=t},onEditModeVisibilityChanged:t=>{this.showingStripeSummary=t,this.updateSaveButtonState()},onPaymentSessionConfirmed:async(t,n)=>{const i={paymentSession:{confirmationTokenId:t,setupIntentId:n}};!this.isBillingSameAsShipping&&this.billingFormData&&(i.billingFormData=this.billingFormData),await this.commands.checkout.savePaymentForm(i)}}}),t.push(this.stripeHandlerElement);this.errorMessageElement=document.createElement("div"),this.errorMessageElement.classList.add("payment-error-message"),this.errorMessageElement.style.display="none",this.errorMessageElement.setAttribute("role","alert"),t.push(this.errorMessageElement);const s=ComponentFactoryService.createElement({type:o.CHECKOUT_BILLING,isFormValid:(t,n)=>{this.billingFormData=n,this.isValidBillingForm=t,this.updateSaveButtonState(),this.updateErrorMessage()}});return t.push(s),this.saveButton=document.createElement("button"),this.saveButton.type="button",this.saveButton.classList.add("save-form-info-button"),this.saveButton.textContent="Save Payment Information",this.saveButton.setAttribute("aria-label","Save payment information"),this.saveButton.setAttribute("role","button"),this.saveButton.setAttribute("tabindex","0"),this.saveButton.addEventListener("click",async()=>{await this.handleSaveButtonClick()}),this.saveButton.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await this.handleSaveButtonClick())}),t.push(this.saveButton),t}async handleSaveButtonClick(){var t;if(!this.isSavingPayment&&!this.stripeFormStatus.isProcessing)if(this.showingStripeSummary&&this.savedCardInfo)try{const t={};!this.isBillingSameAsShipping&&this.isValidBillingForm&&this.billingFormData&&(t.billingFormData=this.billingFormData),await this.commands.checkout.savePaymentForm(t)}catch(n){this.logger.error("Failed to save payment form in edit mode",n),this.showError("Failed to save payment information.")}else if(this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId"))try{const t={};!this.isBillingSameAsShipping&&this.isValidBillingForm&&this.billingFormData&&(t.billingFormData=this.billingFormData),await this.commands.checkout.savePaymentForm(t)}catch(i){this.logger.error("Failed to save payment form in beta mode",i),this.showError("Failed to save payment information.")}else this.updateErrorMessage(),this.validatePrerequisites()&&(null===(t=this.stripeHandlerElement)||void 0===t||t.submitStripeForm())}validatePrerequisites(){return this.isBillingSameAsShipping||this.isValidBillingForm?this.stripeFormStatus.isFormComplete?!![]:(this.showError("Please complete all required payment fields."),![]):(this.showError("Please complete the billing address form before saving."),![])}disconnected(){var t;this.isSavingPayment=![],null===(t=super.disconnected)||void 0===t||t.call(this)}}class CheckoutPaymentSummaryComponent extends BaseComponent{get hostClasses(){return["checkout-summary-form-container"]}constructor(){super({watchStorePaths:["checkout.paymentForm"]})}template(){var t,n,i,o,r,s,a,l,c,d;const u=[],h=this.getStoreValue("checkout.paymentForm"),p=document.createElement("div");p.classList.add("checkout-summary-form-header");const m=document.createElement("h2");m.textContent="Paying with "+capitalizeFirstLetter(null!==(i=null===(n=null===(t=h.paymentMethod)||void 0===t?void 0:t.card)||void 0===n?void 0:n.brand)&&void 0!==i?i:"")+" "+(null===(r=null===(o=h.paymentMethod)||void 0===o?void 0:o.card)||void 0===r?void 0:r.last4),p.appendChild(m);const f=document.createElement("span");f.textContent="Edit",f.setAttribute("aria-label","Edit Payment Information"),f.setAttribute("role","button"),f.setAttribute("tabindex","0"),f.addEventListener("click",async()=>{await this.commands.checkout.editPaymentForm()}),f.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await this.commands.checkout.editPaymentForm())}),p.appendChild(f),u.push(p);const b=document.createElement("p");return b.classList.add("checkout-summary-form-line"),b.textContent="Exp. "+(null===(a=null===(s=h.paymentMethod)||void 0===s?void 0:s.card)||void 0===a?void 0:a.expMonth)+"/"+(null===(d=null===(c=null===(l=h.paymentMethod)||void 0===l?void 0:l.card)||void 0===c?void 0:c.expYear)||void 0===d?void 0:d.slice(-2)),u.push(b),u}}class CheckoutPlaceOrderButtonComponent extends BaseComponent{get hostClasses(){return["checkout-place-order-button-container"]}constructor(){super({watchOnlyStorePaths:["checkout.loading","checkout.error","checkout.customerForm.isValid","checkout.giftRecipientForm.isValid","checkout.paymentForm.isValid"]}),this.errorTimeoutId=null}afterRender(){this.placeOrderButton=this.container.querySelector(".checkout-place-order-button"),this.errorContainer=this.container.querySelector(".checkout-error-wrapper"),this.updateButtonState()}disconnected(){this.clearErrorTimeout()}onStoreWatch(t){const n=t.some(t=>"checkout.loading"===t.path||"checkout.error"===t.path||"checkout.customerForm.isValid"===t.path||"checkout.giftRecipientForm.isValid"===t.path||"checkout.paymentForm.isValid"===t.path);n&&this.updateButtonState()}updateButtonState(){if(!this.placeOrderButton)return;const t=this.store.get("checkout.loading")||![],n=this.store.get("checkout.error")||null;this.updateErrorDisplay(n);const i=this.determineButtonState({isCheckoutLoading:t,hasCheckoutError:!!n});this.placeOrderButton.classList.remove("processing","ready","disabled"),this.placeOrderButton.classList.add(i.state),this.placeOrderButton.disabled=i.disabled,this.placeOrderButton.textContent=i.text}clearErrorTimeout(){null!==this.errorTimeoutId&&(clearTimeout(this.errorTimeoutId),this.errorTimeoutId=null)}updateErrorDisplay(t){if(!this.errorContainer)return;const n=this.errorContainer.querySelector(".error-text");n&&(this.clearErrorTimeout(),t?(n.textContent=t,this.errorContainer.style.display="block",this.errorTimeoutId=setTimeout(async()=>{this.errorTimeoutId=null,await this.commands.checkout.clearCheckoutError()},3e3)):(n.textContent="",this.errorContainer.style.display="none"))}determineButtonState({isCheckoutLoading:t,hasCheckoutError:n}){const i=this.config.layout.placeOrderButtonText,o=this.store.get("checkout.presale");let r=![];if(!o){const t=this.getStoreValue("cart.fulfillments")||{};r=Object.values(t).some(t=>hasUnmetMinimum(t))}const s=this.store.get("checkout.isGift"),a=this.store.get("checkout.customerForm.isValid"),l=this.store.get("checkout.giftRecipientForm.isValid"),c=this.store.get("checkout.paymentForm.isValid");return r||s&&!l||!a||!c?{state:"disabled",text:i,disabled:!![]}:t?{state:"processing",text:"Placing Order...",disabled:!![]}:n?{state:"disabled",text:i,disabled:!![]}:{state:"ready",text:i,disabled:![]}}async handlePlaceOrderClick(){try{if(this.clientConfig.isBuilder())return this.logger.info("Checkout Place Order Button Is Disabled In Builder Mode"),void 0;const t=this.store.get("checkout.loading");if(t)return;await this.commands.checkout.checkoutComplete()}catch(t){this.logger.error("Error handling place order click",t)}}template(){const t=document.createElement("button");t.type="button",t.textContent=this.config.layout.placeOrderButtonText,t.classList.add("checkout-place-order-button"),t.disabled=!![],t.setAttribute("tabindex","0"),t.setAttribute("role","button"),t.setAttribute("aria-label","Place Order"),t.addEventListener("click",this.handlePlaceOrderClick.bind(this)),t.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await this.handlePlaceOrderClick())});const n=document.createElement("div");n.classList.add("checkout-error-wrapper"),n.setAttribute("role","alert"),n.style.display="none";const i=document.createElement("div");i.classList.add("checkout-error");const r=document.createElement("span");r.classList.add("icon-error"),r.innerHTML=ErrorInfoIcon({});const s=document.createElement("span");s.classList.add("error-text"),i.appendChild(r),i.appendChild(s),n.appendChild(i);const a=ComponentFactoryService.createElement({type:o.ALERT,errorStorePath:"checkout.events",fromEvents:!![],showFirstEvent:![]});return[n,a,t]}}class CheckoutPresaleCountdownComponent extends BaseComponent{get hostClasses(){return["checkout-presale-countdown-container"]}constructor(){super({watchStorePaths:["checkout.presale","ui.drawer"]}),this.countdownInterval=null,this.expiresAt=null,this.totalDuration=300,this.rootElement=null,this.scrollHandler=null,this.scrollContainer=null,this.isCurrentlyScrolled=![],this.isUnderOneMinute=![]}onStoreChanged(t){var n;const i=t.find(t=>"checkout.presale"===t.path);if(null==i?void 0:i.value)return this.updateExpiresAt(i.value.expiresAt),!![];const o=t.find(t=>"ui.drawer"===t.path);return(null===(n=null==o?void 0:o.value)||void 0===n?void 0:n.isOpen)===![]&&(this.stopCountdown(),this.cleanupScrollListener(),this.isCurrentlyScrolled=![],this.isUnderOneMinute=![]),![]}afterRender(){const t=this.store.get("checkout.presale");(null==t?void 0:t.expiresAt)&&this.updateExpiresAt(t.expiresAt),this.setupDrawerScrollDetection()}disconnected(){this.stopCountdown(),this.cleanupScrollListener()}setupDrawerScrollDetection(){const findScrollContainer=()=>{var t,n;const i=[".drawer-content"];for(const r of i){const n=null===(t=this.rootElement)||void 0===t?void 0:t.closest(r);if(n&&this.isScrollable(n))return n}let o=null===(n=this.rootElement)||void 0===n?void 0:n.parentElement;for(;o&&o!==document.body;){if(this.isScrollable(o))return o;o=o.parentElement}return null};if(this.scrollContainer=findScrollContainer(),!this.scrollContainer)return this.logger.warn("Could not find scrollable drawer container"),void 0;this.scrollHandler=()=>{var t,n;if(!this.scrollContainer)return;const i=this.scrollContainer.scrollTop,o=70,r=10;!this.isCurrentlyScrolled&&i>o?(this.isCurrentlyScrolled=!![],null===(t=this.rootElement)||void 0===t||t.classList.add("is-scrolled"),this.addHostClasses("is-scrolled")):this.isCurrentlyScrolled&&i<r&&(this.isCurrentlyScrolled=![],null===(n=this.rootElement)||void 0===n||n.classList.remove("is-scrolled"),this.removeHostClasses("is-scrolled"))},this.scrollContainer.addEventListener("scroll",this.scrollHandler,{passive:!![]}),this.scrollHandler()}isScrollable(t){const n=window.getComputedStyle(t),i=n.overflowY;return t.scrollHeight>=t.clientHeight&&("auto"===i||"scroll"===i||"overlay"===i)}cleanupScrollListener(){this.scrollHandler&&this.scrollContainer&&(this.scrollContainer.removeEventListener("scroll",this.scrollHandler),this.scrollHandler=null,this.scrollContainer=null)}updateExpiresAt(t){this.stopCountdown();try{if(this.expiresAt=new Date(t),Number.isNaN(this.expiresAt.getTime()))return this.logger.error("Invalid presale expiration date",{expiresAtString:t}),this.handleExpire(),void 0;if(this.expiresAt<=new Date)return this.handleExpire(),void 0;const n=new Date,i=Math.floor((this.expiresAt.getTime()-n.getTime())/1e3);i<this.totalDuration&&(this.totalDuration=Math.max(i,240)),this.startCountdown()}catch(n){this.logger.error("Failed to parse presale expiration date",n),this.handleExpire()}}startCountdown(){this.updateCountdown(),this.countdownInterval=window.setInterval(()=>{this.updateCountdown()},10)}stopCountdown(){this.countdownInterval&&(clearInterval(this.countdownInterval),this.countdownInterval=null)}updateCountdown(){if(!this.expiresAt||!this.rootElement)return;const t=new Date,n=Math.max(0,this.expiresAt.getTime()-t.getTime()),i=n/1e3,o=this.totalDuration-i,r=Math.max(0,Math.min(100,o/this.totalDuration*100)),s=i<60;if(s!==this.isUnderOneMinute){this.isUnderOneMinute=s;const t=this.rootElement.querySelector(".checkout-presale-timer");this.isUnderOneMinute?(this.rootElement.classList.add("time-warning"),null==t||t.classList.add("time-warning"),this.addHostClasses("time-warning")):(this.rootElement.classList.remove("time-warning"),null==t||t.classList.remove("time-warning"),this.removeHostClasses("time-warning"))}const a=this.rootElement.querySelector("[data-timer]");a&&(a.textContent=this.formatTime(n));const l=this.rootElement.querySelector("[data-progress-fill]");l&&(l.style.width=r+"%"),0===n&&this.handleExpire()}formatTime(t){const n=Math.floor(t/1e3),i=Math.floor(n/60),o=n%60,r=Math.floor(t%1e3/10);return i.toString().padStart(2,"0")+":"+o.toString().padStart(2,"0")+":"+r.toString().padStart(2,"0")}handleExpire(){this.clientConfig.isBuilder()||(this.stopCountdown(),this.commands.checkout.openPresaleExpiredDrawer())}template(){const t=document.createElement("div");t.classList.add("checkout-presale-countdown"),this.rootElement=t;const n=document.createElement("div");n.classList.add("checkout-presale-text-container");const i=document.createElement("div");i.classList.add("checkout-presale-heading");const o=document.createElement("h2");o.textContent="LIMITED PRE-ORDER:";const r=document.createElement("div");r.classList.add("checkout-presale-timer"),r.setAttribute("data-timer",""),r.textContent="00:00:00",i.appendChild(o),i.appendChild(r);const s=document.createElement("p");s.textContent="Please complete your transaction within the time limit. Time expiration or page refresh will release the product to other customers.",s.classList.add("checkout-presale-subtitle"),n.appendChild(i),n.appendChild(s);const a=document.createElement("div");a.className="checkout-presale-progress-bar",a.setAttribute("data-progress","");const l=document.createElement("div");return l.className="checkout-presale-progress-fill",l.setAttribute("data-progress-fill",""),l.style.width="0%",a.appendChild(l),t.appendChild(n),t.appendChild(a),t}}class CheckoutPresaleExpiredComponent extends BaseComponent{constructor(){super(...arguments),this.autoCloseInterval=null,this.autoCloseSeconds=10,this.autoCloseElement=null}get hostClasses(){return["checkout-completed-container"]}get hostAttributes(){return{role:"alert","aria-live":"assertive"}}afterRender(){this.startAutoCloseCountdown()}disconnected(){this.stopAutoCloseCountdown()}handleExit(){this.stopAutoCloseCountdown(),this.commands.ui.closeDrawer()}startAutoCloseCountdown(){this.updateAutoCloseDisplay(),this.autoCloseInterval=window.setInterval(()=>{this.autoCloseSeconds--,this.updateAutoCloseDisplay(),this.autoCloseSeconds<=0&&this.handleExit()},1e3)}stopAutoCloseCountdown(){null!==this.autoCloseInterval&&(clearInterval(this.autoCloseInterval),this.autoCloseInterval=null)}updateAutoCloseDisplay(){this.autoCloseElement&&(this.autoCloseElement.textContent=""+this.autoCloseSeconds)}template(){const t=[],n=this.getConfigs("global"),i=document.createElement("div");i.classList.add("checkout-completed-section-container");const r=document.createElement("div");r.classList.add("checkout-completed-title-section");const s=document.createElement("div");s.classList.add("checkout-completed-title-section");const a=document.createElement("p");a.classList.add("presale-expired-title"),a.textContent="Session Expired",s.appendChild(a);const l=document.createElement("p");l.textContent="Your reservation time has ended. The item has been released for other customers.",s.appendChild(l),r.appendChild(s),i.appendChild(r);const c=document.createElement("div");c.classList.add("checkout-completed-help-section"),c.textContent="To ensure fair access for all customers, we can only hold items for a limited time. You can try to reserve the item again if it's still available.",i.appendChild(c),t.push(i);const d=document.createElement("div");d.classList.add("checkout-completed-section-container");const u=document.createElement("button");u.setAttribute("aria-label","Continue shopping"),u.type="button";const h=document.createElement("span");h.textContent="Continue Shopping",u.setAttribute("tabindex","0"),u.setAttribute("role","button"),u.setAttribute("aria-label","Continue Shopping"),u.appendChild(h);const p=htmlStringToElement(ArrowRightIcon({width:16,height:16}));u.appendChild(p),u.addEventListener("click",()=>this.handleExit()),u.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),this.handleExit())}),d.appendChild(u),t.push(d);const m=document.createElement("div");m.classList.add("checkout-completed-section-container");const f=document.createElement("p");f.classList.add("checkout-completed-auto-close-text"),f.textContent="This view will close automatically in:",this.autoCloseElement=document.createElement("div"),this.autoCloseElement.classList.add("checkout-completed-auto-close-seconds"),this.autoCloseElement.setAttribute("aria-live","polite"),this.autoCloseElement.setAttribute("aria-atomic","true"),this.autoCloseElement.textContent=""+this.autoCloseSeconds;const b=document.createElement("span");if(b.classList.add("checkout-completed-auto-close-text"),b.textContent="seconds",m.appendChild(f),m.appendChild(this.autoCloseElement),m.appendChild(b),t.push(m),n.layout.showPoweredBy){const n=document.createElement("div");n.classList.add("checkout-completed-powered-by-container");const i=ComponentFactoryService.createElement({type:o.POWERED_BY,context:"checkout"});n.appendChild(i),t.push(n)}return t}}class CheckoutPromoCodeComponent extends BaseComponent{get hostClasses(){return["input-promo-code-container"]}constructor(){super({watchOnlyStorePaths:["checkout.promoCode","checkout.loading"]}),this.isApplying=![],this.promoInput=null,this.applyButton=null,this.promoCodeText=null}onStoreWatch(t){const n=t.find(t=>"checkout.promoCode"===t.path),i=t.find(t=>"checkout.loading"===t.path);if(n){const{value:t,oldValue:i}=n,o=Boolean(i),r=Boolean(t);if(!o&&r)return this.container.innerHTML="",this.createAppliedContainer(t),void 0;if(o&&!r)return this.container.innerHTML="",this.createInputContainer(),void 0;r&&this.promoCodeText&&t.discountAmount!==(null==i?void 0:i.discountAmount)&&(this.promoCodeText.textContent=t.code+" (- "+formatCentToDollarText(t.discountAmount)+")")}i&&this.updateApplyButtonState()}updateApplyButtonState(){if(!this.applyButton||!this.promoInput)return;const t=this.promoInput.getValue().trim(),n=t.length>=3&&t.length<=255,i=this.getStoreValue("checkout.loading"),o=this.getStoreValue("checkout.promoCode"),r=this.getStoreValue("checkout.promoCodeError");this.applyButton.disabled=!n||i||Boolean(o)||Boolean(r)||this.isApplying}createPromoInput(){return this.promoInput=ComponentFactoryService.createElement({type:o.INPUT,inputType:"text",name:"promoCode",placeholder:"Enter promo code",autocomplete:![],validation:{min:3,max:255},onChange:t=>{const n=t.toUpperCase(),i=this.promoInput;i.setValue(n),this.updateApplyButtonState()}}),this.promoInput}createApplyButton(){this.applyButton=document.createElement("button"),this.applyButton.type="button",this.applyButton.classList.add("apply-button"),this.applyButton.disabled=!![],this.applyButton.textContent="Apply",this.applyButton.setAttribute("tabindex","0"),this.applyButton.setAttribute("role","button"),this.applyButton.setAttribute("aria-label","Apply promo code");const T=async()=>{const t=this.promoInput.getValue().trim().toUpperCase();if(t)try{this.isApplying=!![],this.updateApplyButtonState(),await this.commands.checkout.applyPromoCode(t)}catch(n){this.logger.error("Checkout promo code application failed",{promoCode:t,error:n instanceof Error?n.message:String(n)})}finally{this.isApplying=![],this.updateApplyButtonState()}};return this.applyButton.addEventListener("click",T),this.applyButton.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),T())}),this.applyButton}createAppliedContainer(t){const n=document.createElement("div");n.classList.add("checkout-pc-gc-applied"),this.promoCodeText=document.createElement("span"),this.promoCodeText.textContent=(null==t?void 0:t.code)+" (- "+formatCentToDollarText((null==t?void 0:t.discountAmount)||0)+")";const i=document.createElement("button");i.type="button",i.classList.add("remove-button"),i.textContent="Remove",i.addEventListener("click",async()=>{await this.commands.checkout.removePromoCode()}),n.appendChild(this.promoCodeText),n.appendChild(i),this.container.appendChild(n),this.promoInput=null,this.applyButton=null}createInputContainer(){this.container.appendChild(this.createPromoInput()),this.container.appendChild(this.createApplyButton()),this.promoCodeText=null}template(){const t=this.getStoreValue("checkout.promoCode");if(this.promoInput=null,this.applyButton=null,this.promoCodeText=null,t){const n=document.createElement("div");n.classList.add("checkout-pc-gc-applied"),this.promoCodeText=document.createElement("span"),this.promoCodeText.textContent=t.code+" (- "+formatCentToDollarText(t.discountAmount)+")";const i=document.createElement("button");return i.type="button",i.classList.add("remove-button"),i.textContent="Remove",i.addEventListener("click",async()=>{await this.commands.checkout.removePromoCode()}),n.appendChild(this.promoCodeText),n.appendChild(i),n}const n=[];return n.push(this.createPromoInput()),n.push(this.createApplyButton()),n}disconnected(){this.promoInput=null,this.applyButton=null,this.promoCodeText=null}}class CheckoutSendAsGiftComponent extends BaseComponent{get hostClasses(){return["gift-toggle-container"]}constructor(){super({watchStorePaths:["checkout.isGift"]})}template(){const t=this.getStoreValue("checkout.isGift"),n=document.createElement("div");n.classList.add("gift-label-wrapper");const i=document.createElement("span");i.textContent="Send as Gift? (Free)",i.classList.add("gift-toggle-label"),n.appendChild(i);const o=document.createElement("span");o.textContent="With personalized note & gift receipt.",o.classList.add("gift-toggle-description"),n.appendChild(o);const r=document.createElement("div");r.classList.add("toggle-switch"),r.classList.toggle("active",t);const s=document.createElement("div");return s.classList.add("toggle-slider"),r.setAttribute("tabindex","0"),r.setAttribute("aria-label","Toggle Gift Option"),r.setAttribute("role","switch"),r.setAttribute("aria-checked",t?"true":"false"),r.appendChild(s),r.addEventListener("click",async()=>{await this.commands.checkout.toggleIsGift()}),r.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await this.commands.checkout.toggleIsGift())}),[n,r]}}class CheckoutStripeFormComponent extends HTMLElement{constructor(){super(...arguments),this.A=![],this.O=null,this.N=null,this.R=null,this.M=![],this.L=![],this.B=![],this.q=null}async initialize({data:t}){if(this.A)return console.warn("Stripe form already initialized, ignoring subsequent calls"),void 0;this.j=t.stripeConfig,await this.initializeStripe(),this.setupEventListeners(),this.A=!![],await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}async initializeStripe(){try{window.Stripe||await this.loadStripeJS();const t=this.j;this.O=window.Stripe(t.publishableKey),this.N=this.O.elements({clientSecret:t.clientSecret,appearance:t.appearance}),this.R=this.N.create("payment",t.elementOptions),this.R.mount(this),this.R.on("change",async t=>{const n=!!t.error,i=t.complete,o=n?t.error.message:null;this.L=i,this.M||await this.updateStripeFormStatus({isFormComplete:i,isProcessing:![],hasCompletedPayment:![],errorMessage:o,hasError:n})}),this.R.on("focus",async()=>{this.M||await this.updateStripeFormStatus({isFormComplete:this.L,isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}),this.B=![]}catch(t){throw await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:"Failed to initialize payment form"}),t}}setupEventListeners(){this.addEventListener("lce:s:submit",async()=>{await this.handleSubmit()}),this.addEventListener("lce:s:refreshSession",this.handleRefreshSession.bind(this)),this.addEventListener("lce:s:reset",async()=>{await this.resetForm()})}async handleRefreshSession(t){const{stripeConfig:n}=t.detail;n&&(this.j=n,await this.refreshPaymentSession())}async handleSubmit(){var t,n;if(this.M)return console.warn("Payment already processing, ignoring duplicate submission"),void 0;if(!this.L)return await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:"Please complete all required payment fields"}),void 0;this.M=!![],await this.updateStripeFormStatus({isFormComplete:this.L,isProcessing:!![],hasCompletedPayment:![],hasError:![],errorMessage:"Processing payment..."});try{this.B&&(console.log("Session already used, requesting refresh..."),await this.requestSessionRefresh());const t=await this.createConfirmationTokenId(),n=this.j.clientSecret,i=n.split("_secret_")[0];this.B=!![],this.dispatchEvent(new CustomEvent("lce:s:ps-confirmed",{detail:{confirmationTokenId:t,setupIntentId:i},bubbles:!![],composed:!![]})),await this.updateStripeFormStatus({isFormComplete:!![],isProcessing:![],hasCompletedPayment:!![],hasError:![],errorMessage:null})}catch(i){console.error("Payment submission error:",i),this.B=!![],await this.updateStripeFormStatus({isFormComplete:this.L,isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:(null==i?void 0:i.message)||"Payment processing failed. Please try again."}),((null===(t=null==i?void 0:i.message)||void 0===t?void 0:t.includes("expired"))||(null===(n=null==i?void 0:i.message)||void 0===n?void 0:n.includes("invalid")))&&setTimeout(()=>this.requestSessionRefresh(),1e3)}finally{this.M=![]}}async requestSessionRefresh(){return this.q||(this.q=new Promise((t,n)=>{const i=setTimeout(()=>{this.removeEventListener("lce:s:refreshSession",e),this.q=null,n(new Error("Session refresh timeout"))},1e4),e=()=>{clearTimeout(i),this.removeEventListener("lce:s:refreshSession",e),this.q=null,t()};this.addEventListener("lce:s:refreshSession",e,{once:!![]}),this.dispatchEvent(new CustomEvent("lce:s:requestSessionRefresh",{bubbles:!![],composed:!![]}))})),this.q}async refreshPaymentSession(){try{this.N&&this.N.update({clientSecret:this.j.clientSecret}),this.B=![],await this.updateStripeFormStatus({isFormComplete:this.L,isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}catch(X){console.error("Failed to refresh payment session:",X),await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:"Failed to refresh payment session"})}}async resetForm(){try{this.R&&this.R.clear(),this.L=![],this.B=![],await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}catch(X){console.error("Failed to reset form:",X)}}async updateStripeFormStatus(t){this.dispatchEvent(new CustomEvent("lce:s:updateStripeFormStatus",{detail:{status:t},bubbles:!![],composed:!![]}))}async createConfirmationTokenId(){if(!this.N)throw new SDKError("Payment elements not initialized");try{const{error:t}=await this.N.submit();if(t)throw new SDKError(t.message||"Failed to submit payment information");const n={elements:this.N,params:{payment_method_data:{allow_redisplay:"always",billing_details:{name:"Guest",address:{country:"US"}}},shipping:{name:"Guest",address:{country:"US",city:null,line1:null,line2:null,postal_code:null,state:null}}}},{error:i,confirmationToken:o}=await this.O.createConfirmationToken(n);if(i)throw new SDKError(i.message||"Failed to create confirmation token");if(!o||!o.id)throw new SDKError("Invalid confirmation token received");return o.id}catch(t){if(t instanceof SDKError)throw t;throw new SDKError("Payment processing error: "+(t.message||"Unknown error"))}}async disconnected(){await this.cleanupForm()}disconnectedCallback(){this.cleanupForm().catch(t=>{console.error("Error during Stripe form disconnection cleanup:",t)})}async cleanupForm(){var t,n;try{this.q=null,this.R&&(this.R.unmount(),this.R=null),this.N&&(null===(n=(t=this.N).destroy)||void 0===n?void 0:n.call(t),this.N=null),this.O=null,this.M=![],this.L=![],this.B=![],this.A=![],this.isConnected&&await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}catch(i){console.warn("Error during Stripe form cleanup:",i)}}loadStripeJS(){return new Promise((t,n)=>{const i=document.querySelector('script[src*="stripe.com"]');if(i)return i.addEventListener("load",()=>t()),i.addEventListener("error",()=>n(new Error("Failed to load Stripe.js"))),void 0;const o=document.createElement("script");o.src="https://js.stripe.com/basil/stripe.js",o.async=!![],o.onload=()=>t(),o.onerror=()=>n(new Error("Failed to load Stripe.js")),document.head.appendChild(o)})}}class CheckoutStripeHandlerComponent extends BaseComponent{get hostClasses(){return["checkout-stripe-handler"]}constructor(){super({watchOnlyStorePaths:["checkout.paymentForm.paymentMethod","checkout.paymentForm.isEditing"]}),this.stripeFormElement=null,this.rootComponent=null,this.isCreatingStripeForm=![],this.stripeFormStatus={isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null},this.isInEditMode=![],this.savedCardInfo=null,this.isChangingPayment=![],this.callbacks={}}beforeConnected(){this.callbacks=this.params.callbacks||{}}onStoreWatch(t){for(const n of t)switch(n.path){case"checkout.paymentForm.paymentMethod":this.handleSavedCardChange(n.value);break;case"checkout.paymentForm.isEditing":this.handleEditModeChange(n.value)}}handleSavedCardChange(t){var n,i,o,r;(null===(n=null==t?void 0:t.card)||void 0===n?void 0:n.brand)&&(null===(i=null==t?void 0:t.card)||void 0===i?void 0:i.last4)?this.savedCardInfo={brand:t.card.brand,last4:t.card.last4}:this.savedCardInfo=null,null===(r=(o=this.callbacks).onSavedCardInfoChanged)||void 0===r||r.call(o,this.savedCardInfo),this.updateDisplayState()}handleEditModeChange(t){this.isInEditMode=t,this.updateDisplayState()}updateDisplayState(){var t,n,i,o,r,s;this.isInEditMode&&this.savedCardInfo&&!this.isChangingPayment?(this.showStripeSummary(),this.hideStripeForm(),null===(n=(t=this.callbacks).onEditModeVisibilityChanged)||void 0===n||n.call(t,!![])):this.isInEditMode||this.isChangingPayment?(this.hideStripeSummary(),this.showStripeForm(),null===(o=(i=this.callbacks).onEditModeVisibilityChanged)||void 0===o||o.call(i,![]),this.stripeFormElement||this.isCreatingStripeForm||this.createAndMountStripeForm().catch(t=>{this.logger.error("Failed to create stripe form in updateDisplayState",t)})):(this.hideStripeSummary(),this.hideStripeForm(),null===(s=(r=this.callbacks).onEditModeVisibilityChanged)||void 0===s||s.call(r,![]))}async afterRender(){var t,n,i,o;this.isInEditMode=null!==(t=this.getStoreValue("checkout.paymentForm.isEditing"))&&void 0!==t?t:![];const r=this.getStoreValue("checkout.paymentForm.paymentMethod");(null===(n=null==r?void 0:r.card)||void 0===n?void 0:n.brand)&&r.card.last4&&(this.savedCardInfo={brand:r.card.brand,last4:r.card.last4}),null===(o=(i=this.callbacks).onSavedCardInfoChanged)||void 0===o||o.call(i,this.savedCardInfo),this.updateDisplayState(),(this.isInEditMode&&!this.savedCardInfo||this.isChangingPayment)&&await this.createAndMountStripeForm()}setupStripeFormEventListeners(){if(!this.stripeFormElement)return this.logger.warn("Cannot set up event listeners: Stripe form element is null"),void 0;this.stripeFormElement.addEventListener("lce:s:updateStripeFormStatus",t=>{var n,i;this.stripeFormStatus=t.detail.status,null===(i=(n=this.callbacks).onStripeFormStatusChanged)||void 0===i||i.call(n,this.stripeFormStatus)}),this.stripeFormElement.addEventListener("lce:s:ps-confirmed",async t=>{var n,i,o,r,s;try{const{confirmationTokenId:o,setupIntentId:r}=t.detail;await(null===(i=(n=this.callbacks).onPaymentSessionConfirmed)||void 0===i?void 0:i.call(n,o,r)),this.isChangingPayment=![]}catch(a){this.logger.error("Failed to save payment form",a),this.stripeFormStatus={isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:(null==a?void 0:a.message)||"Failed to save payment information. Please try again."},null===(r=(o=this.callbacks).onStripeFormStatusChanged)||void 0===r||r.call(o,this.stripeFormStatus),null===(s=this.stripeFormElement)||void 0===s||s.dispatchEvent(new CustomEvent("lce:s:reset",{bubbles:!![],composed:!![]}))}}),this.stripeFormElement.addEventListener("lce:s:requestSessionRefresh",async()=>{var t;try{const n=await this.doStripeConfig();null===(t=this.stripeFormElement)||void 0===t?void 0:t.dispatchEvent(new CustomEvent("lce:s:refreshSession",{detail:{stripeConfig:n}}))}catch(n){this.logger.error("Failed to refresh payment session",n)}})}showStripeSummary(){if(!this.stripeSummaryContainer||!this.savedCardInfo)return;this.stripeSummaryContainer.innerHTML="";const t=document.createElement("span");t.classList.add("stripe-summary-text"),t.textContent=capitalizeFirstLetter(this.savedCardInfo.brand||"")+" ending in "+this.savedCardInfo.last4;const n=document.createElement("button");n.type="button",n.classList.add("change-payment-link"),n.textContent="Change",n.setAttribute("aria-label","Change Payment Method"),n.setAttribute("role","button"),n.setAttribute("tabindex","0"),n.addEventListener("click",()=>this.handleChangePayment()),n.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),this.handleChangePayment())}),this.stripeSummaryContainer.append(t,n),this.stripeSummaryContainer.style.display="flex"}hideStripeSummary(){this.stripeSummaryContainer&&(this.stripeSummaryContainer.style.display="none",this.stripeSummaryContainer.innerHTML="")}showStripeForm(){this.stripeFormContainer&&(this.stripeFormContainer.style.display="block")}hideStripeForm(){this.stripeFormContainer&&(this.stripeFormContainer.style.display="none"),this.removeExistingStripeForm()}async handleChangePayment(){var t,n;this.isChangingPayment=!![],this.stripeFormStatus={isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null},null===(n=(t=this.callbacks).onStripeFormStatusChanged)||void 0===n||n.call(t,this.stripeFormStatus),this.updateDisplayState()}template(){const t=[];this.stripeSummaryContainer=document.createElement("div"),this.stripeSummaryContainer.classList.add("stripe-summary-container"),this.stripeSummaryContainer.style.display="none",t.push(this.stripeSummaryContainer),this.stripeFormContainer=document.createElement("div"),this.stripeFormContainer.classList.add("stripe-form-container");const n=document.createElement("slot");return n.setAttribute("name",gt),this.stripeFormContainer.appendChild(n),t.push(this.stripeFormContainer),t}submitStripeForm(){this.stripeFormElement&&this.stripeFormStatus.isFormComplete&&!this.stripeFormStatus.hasCompletedPayment&&this.stripeFormElement.dispatchEvent(new CustomEvent("lce:s:submit"))}getStripeFormStatus(){return{...this.stripeFormStatus}}findRootComponent(){if(this.rootComponent)return this.rootComponent;let t=this,n=null;for(;t&&t!==document.body;){const i=t.hasAttribute("checkout"),r=t.tagName.toLowerCase()===ComponentFactoryService.getComponentTagName(o.LCE_ELEMENT),s=t.hasAttribute("drawer"),a=(null==n?void 0:n.tagName.toLowerCase())===ComponentFactoryService.getComponentTagName(o.DRAWER),l="checkout"===(null==n?void 0:n.getAttribute("data-target"));if(i||r&&s&&a&&l)return this.rootComponent=t,t;n=t,t=t.parentElement||t.getRootNode().host}return null}removeExistingStripeForm(){this.stripeFormElement&&(this.stripeFormElement.remove(),this.stripeFormElement=null)}async doStripeConfig(){const t=this.store.get("checkout.paymentForm.paymentSession");!this.isChangingPayment&&(null==t?void 0:t.key)&&(null==t?void 0:t.secret)||await this.commands.checkout.getPaymentSession();const n=this.store.get("checkout.paymentForm.paymentSession"),i=this.getConfigs("global");return{publishableKey:n.key,clientSecret:n.secret,appearance:{theme:"stripe",variables:{fontFamily:i.theme.paragraphFont.name+", system-ui, sans-serif",borderRadius:i.theme.buttonCornerRadius},rules:{".Input":{border:"filled"===i.layout.inputFieldStyle?"none":"1px solid "+i.theme.accentColor,backgroundColor:"filled"===i.layout.inputFieldStyle?i.theme.accentColor:"transparent"}}},elementOptions:{layout:"tabs",defaultValues:{billingDetails:{name:"Guest",address:{country:"US"}}},fields:{billingDetails:{address:{postalCode:"auto",country:"never"}}},terms:{applePay:"never",auBecsDebit:"never",bancontact:"never",card:"never",cashapp:"never",googlePay:"never",ideal:"never",paypal:"never",sepaDebit:"never",sofort:"never",usBankAccount:"never"}}}}async createAndMountStripeForm(){var t,n,i;if(this.isCreatingStripeForm)return this.logger.info("Stripe form creation already in progress, skipping"),void 0;if(this.isInEditMode&&this.savedCardInfo&&!this.isChangingPayment)return this.logger.info("In edit mode with saved card, skipping stripe form creation"),void 0;const r=this.findRootComponent();if(!r)return this.logger.error("Could not find root component for Stripe form"),void 0;if(null===(t=this.stripeFormElement)||void 0===t?void 0:t.isConnected)return this.logger.info("Stripe form already exists and is connected, skipping creation"),void 0;const s=r.querySelectorAll('[slot="'+gt+'"]');if(s.length>0)for(const o of s)o.remove();this.isCreatingStripeForm=!![];try{const t=await this.doStripeConfig();this.stripeFormElement=ComponentFactoryService.createElement({type:o.CHECKOUT_STRIPE_FORM,stripeConfig:t}),this.setupStripeFormEventListeners(),this.stripeFormElement.setAttribute("slot",gt),r.appendChild(this.stripeFormElement)}catch(a){this.logger.error("Stripe form element creation failed",a),this.stripeFormStatus={...this.stripeFormStatus,hasError:!![],errorMessage:"Failed to initialize payment form. Please reload the page."},null===(i=(n=this.callbacks).onStripeFormStatusChanged)||void 0===i||i.call(n,this.stripeFormStatus),this.stripeFormElement=null}finally{this.isCreatingStripeForm=![]}}disconnected(){var t;this.removeExistingStripeForm(),this.rootComponent=null,this.isCreatingStripeForm=![],this.isChangingPayment=![],null===(t=super.disconnected)||void 0===t||t.call(this)}}class CheckoutTipsComponent extends BaseComponent{get hostClasses(){return["checkout-tips-container"]}constructor(){super({watchStorePaths:["checkout.onDemandFulfillmentTipInfo","checkout.tipSelection","checkout.updating","checkout.amounts"]}),this.isInitialized=![]}afterRender(){this.setupToggler()}getTipSelection(){const t=this.getStoreValue("checkout.tipSelection");return null!=t?t:10}getOnDemandFulfillmentTipInfo(){return this.getStoreValue("checkout.onDemandFulfillmentTipInfo")||{}}getFulfillmentTipInfoArray(){return Object.values(this.getOnDemandFulfillmentTipInfo())}async handlePercentageSelect(t){const n=this.getStoreValue("checkout.updating")||![];if(!n)try{await this.commands.checkout.updateTips(t)}catch(i){this.logger.error("Checkout tips update failed",i)}}async handleFulfillmentTipInput(t,n){const i=this.getStoreValue("checkout.updating")||![];if(i)return;const o=this.getOnDemandFulfillmentTipInfo();if(!o[t])return;const r=Math.round(100*n);try{await this.commands.checkout.updateFulfillmentTip(t,r)}catch(s){this.logger.error("Checkout fulfillment tip update failed",s)}}async removeTipFromFulfillment(t){const n=this.getStoreValue("checkout.updating")||![];if(n)return;const i=this.getOnDemandFulfillmentTipInfo();if(i[t])try{await this.commands.checkout.removeFulfillmentTip(t)}catch(o){this.logger.error("Checkout fulfillment tip removal failed",o)}}createTipSelectionButtons(){const t=document.createElement("div");t.classList.add("checkout-tip-selection-container");const n=[10,18,20],i=this.getStoreValue("checkout.updating")||![],o=this.getTipSelection();for(const r of n){const n=document.createElement("button");n.type="button",n.textContent=r+"%",n.classList.add("checkout-tip-button"),n.disabled=i,o===r&&n.classList.add("selected"),n.addEventListener("click",()=>this.handlePercentageSelect(r)),t.appendChild(n)}return t}setupToggler(){const t=this.container.querySelector(".checkout-tip-distribution-header"),n=this.container.querySelector(".checkout-items-toggler-button"),i=this.container.querySelector(".retailers-tips-list");t&&n&&i&&t.addEventListener("click",()=>{const t=i.classList.contains("show");i.classList.toggle("show"),t?(n.setAttribute("aria-expanded","false"),n.setAttribute("aria-label","Expand tips section")):(n.setAttribute("aria-expanded","true"),n.setAttribute("aria-label","Collapse tips section")),n.classList.toggle("expanded")})}createTipDistribution(){const t=document.createElement("section");t.classList.add("checkout-tip-distribution-container");const n=this.getFulfillmentTipInfoArray();if(0===n.length)return t;const i=document.createElement("div");i.classList.add("checkout-tip-distribution-header");const o=document.createElement("h3");o.textContent="View Tip Distribution",o.classList.add("checkout-sub-header"),i.appendChild(o);const r=document.createElement("button");r.type="button",r.classList.add("checkout-items-toggler-button"),r.innerHTML=ChevronDownIcon({width:20,height:20,className:"chevron-icon"}),i.appendChild(r),t.appendChild(i);const s=document.createElement("div");s.classList.add("retailers-tips-list","show");for(const a of n){const t=document.createElement("div");t.classList.add("checkout-tip-distribution-item");const n=document.createElement("h4");n.textContent=a.retailerName,n.classList.add("checkout-sub-header"),t.appendChild(n);const i=document.createElement("div");i.classList.add("checkout-tip-fulfillment-input-wrapper");const o=document.createElement("div");o.classList.add("dollar-input-container");const r=document.createElement("span");r.classList.add("dollar-sign"),r.textContent="$";const l=document.createElement("input");let c;l.type="number",l.id="tip-input-"+a.fulfillmentId,l.name="tip-"+a.fulfillmentId,l.min="0",l.step="0.01",l.placeholder="0.00",l.classList.add("dollar-input"),l.value=a.tip>0?(a.tip/100).toFixed(2):"",l.disabled=this.getStoreValue("checkout.updating")||![],l.addEventListener("wheel",t=>{t.preventDefault()}),l.addEventListener("keydown",t=>{"-"!==t.key&&"+"!==t.key||t.preventDefault()}),l.addEventListener("keydown",t=>{"ArrowUp"!==t.key&&"ArrowDown"!==t.key||t.preventDefault()}),l.addEventListener("paste",t=>{t.preventDefault()}),l.addEventListener("contextmenu",t=>{t.preventDefault()}),l.addEventListener("input",t=>{const n=t.target;let i=n.value;if(Number.parseFloat(i)<0&&(n.value=Math.abs(Number.parseFloat(i)).toString(),i=n.value),i.includes(".")){const t=i.split(".");t.length>1&&t[1].length>2&&(n.value=t[0]+"."+t[1].substring(0,2))}}),l.addEventListener("input",t=>{const n=t.target,i=Number.parseFloat(n.value)||0;c&&clearTimeout(c),c=setTimeout(()=>{this.handleFulfillmentTipInput(a.fulfillmentId,i)},500)}),o.appendChild(r),o.appendChild(l),i.appendChild(o);const d=document.createElement("button");d.type="button",d.textContent="Remove",d.classList.add("checkout-tip-remove-button"),d.disabled=this.getStoreValue("checkout.updating")||![],d.addEventListener("click",()=>this.removeTipFromFulfillment(a.fulfillmentId)),i.appendChild(d),t.appendChild(i),s.appendChild(t)}return t.appendChild(s),t}async initializeDefaultTip(){if(this.isInitialized)return;const t=this.getStoreValue("checkout.tipSelection"),n=this.getFulfillmentTipInfoArray();if(t&&n.length>0){const t=n.some(t=>t.tip>0);if(t)this.isInitialized=!![];else try{this.isInitialized=!![],await this.commands.checkout.updateTips(10)}catch(i){this.logger.error("Default tip initialization failed",i),this.isInitialized=![]}}if(null==t)try{this.isInitialized=!![],await this.commands.checkout.updateTips(10)}catch(o){this.logger.error("Default tip initialization failed during fallback",o),this.isInitialized=![]}}template(){const t=[],n=this.getFulfillmentTipInfoArray();if(0===n.length)return t;n.length>0&&this.initializeDefaultTip();const i=document.createElement("section");i.classList.add("checkout-tip-container");const o=document.createElement("h3");o.classList.add("checkout-sub-header"),o.textContent="Add a tip",i.appendChild(o);const r=document.createElement("div");r.classList.add("checkout-tip-config-container");const s=this.createTipSelectionButtons();r.appendChild(s),i.appendChild(r);const a=document.createElement("p");a.classList.add("checkout-tip-disclaimer"),a.textContent="Tips will be split proportionally between retailers.",i.appendChild(a);const l=this.createTipDistribution();return t.push(i,l),t}}class CheckoutPcGcComponent extends BaseComponent{get hostClasses(){return["checkout-sections-container"]}constructor(){super({watchOnlyStorePaths:["checkout.loading","checkout.giftCardError","checkout.promoCodeError","checkout.giftCards"]}),this.appliedGiftCardsContainer=null}onStoreWatch(t){var n,i;const o=t.find(t=>"checkout.giftCardError"===t.path),r=t.find(t=>"checkout.promoCodeError"===t.path),s=t.find(t=>"checkout.giftCards"===t.path);if(s&&this.updateAppliedGiftCards(s.value),o){const t=this.container.querySelector(".input-gift-card-container");if(t){const i=t.nextElementSibling;if((null===(n=null==i?void 0:i.classList)||void 0===n?void 0:n.contains("error-banner-checkout"))&&(null==i?void 0:i.remove()),o.value){const n=this.createErrorElement(o.value);t.after(n)}const r=t.querySelector(".apply-button");r&&(r.disabled=Boolean(o.value))}}if(r){const t=this.container.querySelector(".input-promo-code-container");if(t){const n=t.nextElementSibling;if((null===(i=null==n?void 0:n.classList)||void 0===i?void 0:i.contains("error-banner-checkout"))&&(null==n?void 0:n.remove()),r.value){const n=this.createErrorElement(r.value);t.after(n)}const o=t.querySelector(".apply-button");o&&(o.disabled=Boolean(r.value))}}}updateAppliedGiftCards(t){const n=t&&t.length>0;if(!n)return this.appliedGiftCardsContainer&&(this.appliedGiftCardsContainer.remove(),this.appliedGiftCardsContainer=null),void 0;this.appliedGiftCardsContainer||(this.appliedGiftCardsContainer=document.createElement("div"),this.appliedGiftCardsContainer.classList.add("checkout-pc-gc-sub-container"),this.container.appendChild(this.appliedGiftCardsContainer)),this.appliedGiftCardsContainer.innerHTML="",t.forEach(t=>{const n=this.createAppliedGiftCardElement(t);this.appliedGiftCardsContainer.appendChild(n)})}createAppliedGiftCardElement(t){const n=document.createElement("div");n.classList.add("checkout-pc-gc-applied"),n.setAttribute("data-gift-card-code",t.code);const i=document.createElement("span");i.textContent=t.code+" (- "+formatCentToDollarText(t.discountAmount)+")",n.appendChild(i);const o=document.createElement("button");return o.type="button",o.textContent="Remove",o.addEventListener("click",async()=>{await this.commands.checkout.removeGiftCard(t.code)}),n.appendChild(o),n}pcInputContainer(){const t=ComponentFactoryService.createElement({type:o.CHECKOUT_PROMO_CODE,classList:["input-promo-code-container"]});return t}gcInputContainer(){const t=ComponentFactoryService.createElement({type:o.CHECKOUT_GIFT_CARDS});return t}inputContainer(){var t;const n=this.getConfigs("checkout"),i=this.getConfigs("global"),o=n.layout.allowGiftCards,r=null===(t=null==i?void 0:i.layout)||void 0===t?void 0:t.allowPromoCodes,s=document.createElement("div");s.classList.add("checkout-pc-gc-sub-container");const a=this.pcInputContainer(),l=this.gcInputContainer();r&&s.appendChild(a);const c=this.getStoreValue("checkout.promoCodeError");if(c){const t=this.createErrorElement(c);t.classList.add("promo-code-error-wrapper"),s.appendChild(t)}o&&s.appendChild(l);const d=this.getStoreValue("checkout.giftCardError");if(d){const t=this.createErrorElement(d);s.appendChild(t)}return s}createErrorElement(t){const n=document.createElement("div");n.classList.add("error-banner-checkout");const i=document.createElement("div");i.innerHTML=ErrorInfoIcon({});const o=document.createElement("p");return o.textContent=t.toString(),n.appendChild(i),n.appendChild(o),setTimeout(async()=>{await this.commands.checkout.clearPromoCodeError(),await this.commands.checkout.clearGiftCardError(),n.remove()},3e3),n}template(){const t=this.getStoreValue("checkout.giftCards");this.appliedGiftCardsContainer=null;const n=[];return n.push(this.inputContainer()),t&&t.length>0&&(this.appliedGiftCardsContainer=document.createElement("div"),this.appliedGiftCardsContainer.classList.add("checkout-pc-gc-sub-container"),t.forEach(t=>{const n=this.createAppliedGiftCardElement(t);this.appliedGiftCardsContainer.appendChild(n)}),n.push(this.appliedGiftCardsContainer)),n}disconnected(){this.appliedGiftCardsContainer=null}}function fulfillmentAddress(t,n){if(!t)return"";if(n===r.SHIPPING){const n=[t.city,t.state].filter(Boolean);return n.join(", ")}const i=[t.one,t.two,t.city,t.state].filter(Boolean);return i.join(", ")}function renderPopupRetailerCard({fulfillment:t,selectedFulfillmentType:n,isSelected:i,fulfillmentStatus:o,selectedSizeAttributes:s}){var a,l,c,d,u;let h=0;const p=null==s?void 0:s.presale,m=(null==p?void 0:p.isActive)&&(null==p?void 0:p.estimatedShipBy)?"Ships by "+formatISODateToMMDDYYYY(p.estimatedShipBy):"",f=n===r.SHIPPING,b=n===r.ON_DEMAND;f&&(h=(null===(l=null===(a=null==t?void 0:t.fees)||void 0===a?void 0:a.individual)||void 0===l?void 0:l.fee)||0),b&&(h=(null===(c=null==t?void 0:t.fees)||void 0===c?void 0:c.fee)||0);const w=fulfillmentAddress(t.retailerAddress,n);let C=null;n===r.ON_DEMAND&&o.openTime&&(null==o?void 0:o.closeTime)&&(C=o.isOpen?"Closes at "+format24TimeTo12$1(null==o?void 0:o.closeTime):"Opens at "+format24TimeTo12$1(null==o?void 0:o.openTime));const k=n===r.ON_DEMAND&&o&&o.isClosed?"closed":"",S=document.createElement("div");S.className="popup-retailer-card "+(i?"selected":"")+" "+k,S.setAttribute("data-fulfillment-id",t.fulfillmentId),S.setAttribute("role","button"),S.setAttribute("tabindex","0"),S.setAttribute("aria-pressed",i?"true":"false");const E=n===r.SHIPPING?"Shipping":"Same-day delivery";S.setAttribute("aria-label",E+" from "+t.retailerName+", "+formatCentToDollarText(null!==(d=t.price)&&void 0!==d?d:0));const _=document.createElement("div");_.className="row";const D=document.createElement("span");D.className="name",D.textContent=t.retailerName,_.appendChild(D);const P=document.createElement("span");P.className="price",P.textContent=formatCentToDollarText(null!==(u=t.price)&&void 0!==u?u:0),_.appendChild(P),S.appendChild(_);const F=document.createElement("div");F.className="row";const A=document.createElement("span");A.className="expectation",A.textContent=o.isClosed?C:(null==p?void 0:p.isActive)?m:(null==t?void 0:t.expectation.detail)||"No expectation available",F.appendChild(A);const O=document.createElement("span");if(O.className="fee",O.textContent=h>0?formatCentToDollarText(h):"Free Delivery",F.appendChild(O),S.appendChild(F),b){const t=document.createElement("div");t.className="row";const n=document.createElement("span");n.className="address",n.textContent=w,t.appendChild(n),S.appendChild(t)}return S}function renderFulfillmentTabsContainer({shippingFulfillments:t,onDemandFulfillments:n,shippingSelected:i,onDemandSelected:o,onTabClick:s,enableShippingFulfillment:a,enableOnDemandFulfillment:l}){const c=n.length>0,d=document.createElement("div");if(d.className="fulfillment-tabs-container",d.setAttribute("role","tablist"),d.setAttribute("aria-label","Delivery method options"),a){const n=document.createElement("div");n.className="fulfillment-tab "+(i?"selected":""),n.setAttribute("data-fulfillment-type",r.SHIPPING),n.setAttribute("role","tab"),n.setAttribute("tabindex","0"),n.setAttribute("aria-selected",i?"true":"false"),n.setAttribute("aria-label","Shipping, "+t.length+" options"),n.addEventListener("click",s),n.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),n.click())});const o=document.createElement("span");o.className="fulfillment-tab-label "+(i?"selected":""),o.textContent="Shipping ("+t.length+")",n.appendChild(o),d.appendChild(n)}if(l){const t=document.createElement("div");t.className="fulfillment-tab "+(o?"selected":"")+" "+(c?"":"disabled"),t.setAttribute("data-fulfillment-type",r.ON_DEMAND),t.setAttribute("role","tab"),t.setAttribute("tabindex","0"),t.setAttribute("aria-selected",o?"true":"false"),t.setAttribute("aria-label","Same-day delivery, "+n.length+" options"),c||t.setAttribute("aria-disabled","true"),t.addEventListener("click",s),t.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),t.click())});const i=document.createElement("span");i.className="fulfillment-tab-label "+(o?"selected":""),i.textContent="Same-Day Delivery ("+n.length+")",t.appendChild(i),d.appendChild(t)}return d}class ProductAddToCartSectionComponent extends BaseComponent{get hostClasses(){return["add-to-cart-container"]}get hostAttributes(){return{role:"region","aria-live":"polite","aria-atomic":"false","aria-label":"Add to cart section"}}constructor(){super({watchStorePaths:["products.{productId}.quantity","products.{productId}.selectedFulfillment","products.{productId}.fulfillmentHasAvailability","cart.items","products.{productId}.updating"]})}getProductId(){return this.params.productId}getAvailableQuantity(){var t;const n=this.getProductId(),i=this.getStoreValue("products."+n);if(!i.selectedFulfillment||!i.selectedSizeId)return 0;const o=i.selectedFulfillment.partNumber,r=i.selectedFulfillment.fulfillmentId,s=null===(t=i.sizes[i.selectedSizeId].attributes)||void 0===t?void 0:t.maxQuantityPerOrder;if(!s)return 0;const a=this.getStoreValue("cart.items")||{},l=Object.values(a).filter(t=>t.partNumber===o&&t.fulfillmentId===r),c=l.reduce((t,n)=>t+n.quantity,0);return s-c}isFulfillmentClosed(){const t=this.getProductId(),n=this.getStoreValue("products."+t);if(!n.selectedFulfillment)return![];const i=getRetailerOffHours(n.selectedFulfillment);return n.selectedFulfillmentType===r.ON_DEMAND&&i&&i.isClosed}isButtonLoading(){const t=this.getProductId();return this.getStoreValue("products."+t+".updating")}calculateQuantityLimits(){const{quantity:t}=this.calculateTotalPrice(),n=this.getAvailableQuantity(),i=t<n;return{currentQuantity:t,availableQuantity:n,canIncrease:i,canDecrease:t>1}}async handleAddToCart(){var t,n,i;const o=this.getProductId(),r=this.getStoreValue("products."+o);if(!r.selectedFulfillment)return this.logger.error("Product add to cart failed: No fulfillment option selected",{productId:o,selectedSizeId:r.selectedSizeId}),void 0;const s=this.getSizeAttributes(),a=(null===(t=null==s?void 0:s.presale)||void 0===t?void 0:t.isActive)===!![],l=this.isPresaleActive(s);a&&l?await this.commands.product.addPresaleToCart(o,{upc:r.sizes[r.selectedSizeId].upc,fulfillmentId:r.selectedFulfillment.fulfillmentId,partNumber:null===(n=r.selectedFulfillment)||void 0===n?void 0:n.partNumber,quantity:r.quantity,identifier:o}):await this.commands.product.addToCart(o,{upc:r.sizes[r.selectedSizeId].upc,fulfillmentId:r.selectedFulfillment.fulfillmentId,partNumber:null===(i=r.selectedFulfillment)||void 0===i?void 0:i.partNumber,quantity:r.quantity,identifier:o})}async handleQuantityChange(t){const n=this.getProductId();await this.commands.product.updateQuantity(n,t)}calculateTotalPrice(){const t=this.getProductId(),n=this.getStoreValue("products."+t),i=n.selectedFulfillment,o=i.price*n.quantity;return{quantity:n.quantity,totalPrice:o}}createQuantityContainer(t){const n=this.calculateQuantityLimits(),i=document.createElement("div");return i.className="quantity-container "+t,this.qtyDecreaseButton=document.createElement("button"),this.qtyDecreaseButton.type="button",this.qtyDecreaseButton.className="quantity-decrease",this.qtyDecreaseButton.textContent="−",this.qtyDecreaseButton.disabled=!n.canDecrease,this.qtyDecreaseButton.setAttribute("aria-label","Decrease quantity"),this.qtyDecreaseButton.setAttribute("aria-disabled",(!n.canDecrease).toString()),n.canDecrease||(this.qtyDecreaseButton.disabled=!![],this.qtyDecreaseButton.classList.add("disabled")),this.qtyDecreaseButton.addEventListener("click",async t=>{t.preventDefault(),await this.handleQuantityChange(-1)}),this.quantityText=document.createElement("span"),this.quantityText.className="product-count",this.quantityText.textContent=n.currentQuantity.toString(),this.quantityText.setAttribute("role","status"),this.quantityText.setAttribute("aria-label","Current quantity: "+n.currentQuantity),this.qtyIncreaseButton=document.createElement("button"),this.qtyIncreaseButton.type="button",this.qtyIncreaseButton.className="quantity-increase",this.qtyIncreaseButton.textContent="+",this.qtyIncreaseButton.disabled=!n.canIncrease,this.qtyIncreaseButton.setAttribute("aria-label","Increase quantity"),this.qtyIncreaseButton.setAttribute("aria-disabled",(!n.canIncrease).toString()),n.canIncrease||(this.qtyIncreaseButton.disabled=!![],this.qtyIncreaseButton.classList.add("disabled")),this.qtyIncreaseButton.addEventListener("click",async t=>{t.preventDefault(),await this.handleQuantityChange(1)}),i.appendChild(this.qtyDecreaseButton),i.appendChild(this.quantityText),i.appendChild(this.qtyIncreaseButton),i}getSizeAttributes(){const t=this.getProductId(),n=this.getStoreValue("products."+t+".selectedSizeId"),i=this.getStoreValue("products."+t+".sizes."+n);return(null==i?void 0:i.attributes)||{}}isPresaleActive(t){const n=null==t?void 0:t.presale;if(!n)return![];if(!n.isActive)return![];if(n.canPurchaseOn){const t=new Date(n.canPurchaseOn),i=new Date;if(i.getTime()<t.getTime())return![]}return!![]}createAddToCartButton(){var t;const{totalPrice:n}=this.calculateTotalPrice(),i=this.getSizeAttributes(),o=this.calculateQuantityLimits(),r=(null===(t=null==i?void 0:i.presale)||void 0===t?void 0:t.isActive)===!![],s=this.isPresaleActive(i),a=r?this.config.layout.preSaleButtonText:this.config.layout.addToCartButtonText;this.addToCartButton=document.createElement("button"),this.addToCartButton.type="button",this.addToCartButton.className="add-to-cart-button",this.addToCartButton.textContent=this.config.layout.addToCartButtonShowTotalPrice?a+" - "+formatCentToDollarText(n):a;const l=r&&!s||0===o.availableQuantity||this.isFulfillmentClosed(),c=this.isButtonLoading(),d=this.config.layout.addToCartButtonShowTotalPrice?a+" for "+formatCentToDollarText(n):a;return this.addToCartButton.setAttribute("aria-label",d),this.addToCartButton.setAttribute("aria-busy",c.toString()),this.addToCartButton.setAttribute("aria-disabled",l.toString()),l&&(this.addToCartButton.disabled=!![],this.addToCartButton.classList.add("disabled")),c&&(this.addToCartButton.disabled=!![],this.addToCartButton.classList.add("loading")),this.addToCartButton.addEventListener("click",async t=>{if(t.preventDefault(),this.clientConfig.isBuilder())return this.logger.info("Product Add To Cart Button Is Disabled In Builder Mode"),void 0;await this.handleAddToCart()}),this.addToCartButton}template(){const t=this.getProductId(),n=this.getStoreValue("products."+t+".fulfillmentHasAvailability"),i=this.getConfigs("configurations");if(!n||!i.isElementsEnabled)return[];const o=[];if(this.config.layout.showQuantityCounter){const t=this.createQuantityContainer(this.config.layout.quantityCounterStyle);o.push(t)}const r=this.createAddToCartButton();return o.push(r),o}}class ProductDescriptionComponent extends BaseComponent{constructor(){super(...arguments),this.isCollapsed=!![]}get hostClasses(){return["product-description"]}template(){const t=this.params.productId,n=this.getStoreValue("products."+t+".description"),i=this.getStoreValue("products."+t+".htmlDescription"),o="About this product:",r="See More",s="See Less",a=document.createElement("h3");a.className="title",a.textContent=o;const l=document.createElement("div");l.className="content collapsed",l.innerHTML=""===(null==i?void 0:i.trim())?n:sanitizeHTML(i);const c=document.createElement("span");c.className="collapse-button",c.textContent=r,c.setAttribute("role","button"),c.setAttribute("tabindex","0"),c.setAttribute("aria-label","Show more product information"),c.setAttribute("aria-expanded","false");const toggleContent=()=>{this.isCollapsed=!this.isCollapsed,l.classList.toggle("collapsed"),c.textContent=this.isCollapsed?r:s,c.setAttribute("aria-label",this.isCollapsed?"Show more product information":"Show less product information"),c.setAttribute("aria-expanded",this.isCollapsed?"false":"true")};return c.addEventListener("click",toggleContent),c.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),toggleContent())}),[a,l,c]}}class ProductDrawerComponent extends BaseComponent{get hostClasses(){return["product-drawer-container"]}constructor(){super({watchStorePaths:["products.{productId}.drawer"]}),this.isOpen=![],this.contentContainer=null,this.currentContentType=null}getProductId(){return this.params.productId}onStoreChanged(t){var n;const i=t.find(t=>t.path==="products."+this.getProductId()+".drawer");if(!i)return![];const o=i.value,r=o.isOpen,s=null===(n=o.contentConfig)||void 0===n?void 0:n.type,a=s!==this.currentContentType;return r&&!this.isOpen?(this.currentContentType=s,this.openWithContent(o),![]):r&&this.isOpen&&!a?![]:r&&this.isOpen&&a?(this.currentContentType=s,this.openWithContent(o),![]):!r&&this.isOpen?(this.close(),this.currentContentType=null,![]):![]}openWithContent({contentConfig:t}){const n=this.getProductId();try{if(this.contentContainer&&(this.contentContainer.innerHTML=""),!t)return this.logger.warn("Product drawer opening attempted without content configuration",{productId:n}),void 0;const{type:i,data:o}=t||{},r=ComponentFactoryService.createElement({type:i,...o});this.contentContainer&&this.contentContainer.appendChild(r),this.open()}catch(i){this.logger.error("Failed to open product drawer",i),this.commands.product.closeProductDrawer(n)}}open(){this.isOpen=!![],this.updateDrawerState()}close(){this.isOpen=![],this.updateDrawerState()}updateDrawerState(){this.isOpen&&this.container.classList.add("open"),this.isOpen||this.container.classList.remove("open")}template(){const t=document.createElement("div");return t.classList.add("product-drawer-content"),this.contentContainer=t,t}}class ProductImageCarouselComponent extends BaseComponent{get hostClasses(){const t=this.config.layout.fulfillmentDisplay;return["product-image-carousel",t]}constructor(){super({watchOnlyStorePaths:["products.{productId}.mainImage"]}),this.mainImageElement=null,this.galleryViewport=null,this.galleryContainer=null,this.thumbnails=[],this.currentImageIndex=0,this.isDragging=![],this.hasMoved=![],this.startX=0,this.currentTranslateX=0,this.translateX=0}afterRender(){this.cacheElements(),this.setupEventListeners(),this.scrollToIndex(0)}onStoreWatch(t){const n=this.params.productId,i=t.find(t=>t.path==="products."+n+".mainImage");if(null==i?void 0:i.value){const t=this.params.images.indexOf(null==i?void 0:i.value);-1!==t?this.selectImage(t):this.mainImageElement&&(this.mainImageElement.style="--bg-image: url('"+i.value+"')")}}cacheElements(){this.galleryViewport=this.container.querySelector(".gallery-viewport"),this.galleryContainer=this.container.querySelector(".gallery-container"),this.thumbnails=Array.from(this.container.querySelectorAll(".gallery-image-wrapper"))}setupEventListeners(){for(let n=0;n<this.thumbnails.length;n++){const t=this.thumbnails[n];t.addEventListener("click",()=>{this.hasMoved||this.selectImage(n)})}const t=this.container.querySelectorAll(".carousel-dot");for(let n=0;n<t.length;n++){const i=t[n];i.addEventListener("click",()=>this.selectImage(n))}this.setupMainImageSwipe(),this.galleryContainer&&this.setupGalleryDrag()}selectImage(t){var n,i;if(t<0||t>=this.params.images.length)return;this.mainImageElement&&(this.mainImageElement.style="--bg-image: url('"+this.params.images[t]+"')",this.mainImageElement.title="Product image "+(t+1)),null===(n=this.thumbnails[this.currentImageIndex])||void 0===n||n.classList.remove("selected"),null===(i=this.thumbnails[t])||void 0===i||i.classList.add("selected");const o=this.container.querySelectorAll(".carousel-dot");for(let r=0;r<o.length;r++){const n=o[r];n.classList.toggle("active",r===t)}this.currentImageIndex=t,this.galleryViewport&&this.scrollToIndex(t)}scrollToIndex(t){if(!this.galleryViewport||!this.thumbnails[t])return;const n=this.thumbnails[t],i=this.galleryViewport.offsetWidth,o=n.offsetLeft+n.offsetWidth/2,r=i/2,s=r-o,a=0,l=-(this.galleryContainer.scrollWidth-i);this.translateX=Math.max(l,Math.min(a,s)),this.updateTransform(!![])}setupMainImageSwipe(){var t,n;let i=0,o=0;null===(t=this.mainImageElement)||void 0===t?void 0:t.addEventListener("touchstart",t=>{i=t.touches[0].clientX,o=t.touches[0].clientY},{passive:!![]}),null===(n=this.mainImageElement)||void 0===n||n.addEventListener("touchend",t=>{const n=t.changedTouches[0].clientX-i,r=t.changedTouches[0].clientY-o;Math.abs(n)>Math.abs(r)&&Math.abs(n)>50&&(n>0?this.previousImage():this.nextImage())},{passive:!![]})}setupGalleryDrag(){if(this.galleryContainer){this.galleryContainer.addEventListener("mousedown",this.handleDragStart.bind(this)),window.addEventListener("mousemove",this.handleDragMove.bind(this)),window.addEventListener("mouseup",this.handleDragEnd.bind(this)),this.galleryContainer.addEventListener("touchstart",this.handleDragStart.bind(this),{passive:!![]}),window.addEventListener("touchmove",this.handleDragMove.bind(this),{passive:![]}),window.addEventListener("touchend",this.handleDragEnd.bind(this));for(const t of this.galleryContainer.querySelectorAll("img"))t.addEventListener("dragstart",t=>t.preventDefault())}}handleDragStart(t){this.isDragging=!![],this.hasMoved=![],this.startX="touches"in t?t.touches[0].clientX:t.clientX,this.currentTranslateX=this.translateX,this.galleryContainer&&(this.galleryContainer.style.cursor="grabbing")}handleDragMove(t){if(!this.isDragging||!this.galleryViewport)return;"touchmove"===t.type&&t.preventDefault();const n="touches"in t?t.touches[0].clientX:t.clientX,i=n-this.startX;Math.abs(i)>5&&(this.hasMoved=!![]);const o=this.currentTranslateX+i,r=0,s=-(this.galleryContainer.scrollWidth-this.galleryViewport.offsetWidth);this.translateX=Math.max(s,Math.min(r,o)),this.updateTransform(![])}handleDragEnd(){this.isDragging=![],this.galleryContainer&&(this.galleryContainer.style.cursor=""),setTimeout(()=>{this.hasMoved=![]},10)}updateTransform(t){this.galleryContainer&&(this.galleryContainer.style.transition=t?"transform 0.3s ease":"none",this.galleryContainer.style.transform="translate3d("+this.translateX+"px, 0, 0)")}nextImage(){this.selectImage((this.currentImageIndex+1)%this.params.images.length)}previousImage(){this.selectImage(0===this.currentImageIndex?this.params.images.length-1:this.currentImageIndex-1)}template(){const t=[],n=this.params.images.length>1,i=document.createElement("div");if(i.className="main-image",i.title="Product main image",i.style="--bg-image: url('"+(this.params.mainImage||this.params.images[0])+"')",n){const t=document.createElement("div");t.className="carousel-dots";for(let n=0;n<this.params.images.length;n++){const i=document.createElement("button");i.type="button",i.className="carousel-dot "+(0===n?"active":""),i.setAttribute("data-index",n.toString()),t.appendChild(i)}i.appendChild(t)}this.mainImageElement=i,t.push(i);const o=document.createElement("div");o.className="gallery-viewport";const r=document.createElement("div");r.className="gallery-container";for(let s=0;s<this.params.images.length;s++){const t=this.params.images[s],n=document.createElement("div");n.className="gallery-image-wrapper "+(0===s?"selected":"");const i=document.createElement("img");i.src=t,i.className="gallery-image",i.alt="Product thumbnail "+(s+1),i.loading="lazy",n.appendChild(i),r.appendChild(n)}return o.appendChild(r),t.push(o),t}}class ProductInteractionsComponent extends BaseComponent{get hostClasses(){return["product-interactions"]}constructor(){super({watchOnlyStorePaths:["products.{productId}.selectedFulfillmentType"]}),this.addPersonalizationSpan=null}onStoreWatch(t){var n,i,o,s;const a=this.getProductId();if(!t.some(t=>t.path==="products."+a+".selectedFulfillmentType"))return;const l=this.getStoreValue("products."+a),c=l.sizes[l.selectedSizeId],d=this.getConfigs("global");this.addPersonalizationSpan&&(l.selectedFulfillmentType===r.SHIPPING&&d.layout.enablePersonalization&&l.productHasAvailability&&(null===(i=null===(n=null==c?void 0:c.attributes)||void 0===n?void 0:n.engraving)||void 0===i?void 0:i.status)===!![]&&(null===(o=null==l?void 0:l.selectedFulfillment)||void 0===o?void 0:o.isVariantEngravable)===!![]&&(null===(s=null==l?void 0:l.selectedFulfillment)||void 0===s?void 0:s.canEngrave)===!![]?this.addPersonalizationSpan.style.display="inline":this.addPersonalizationSpan.style.display="none")}getProductId(){return this.params.productId}afterRender(){this.setupSizeButtonsEventListener()}setupSizeButtonsEventListener(){const t=this.getProductId(),n=this.container.querySelectorAll("[select-size]");for(const i of n){const o=i.textContent||"",r=i.classList.contains("selected");i.setAttribute("role","button"),i.setAttribute("tabindex","0"),i.setAttribute("aria-label","Select "+o),i.setAttribute("aria-pressed",r?"true":"false"),i.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),i.click())}),i.addEventListener("click",async()=>{var o,r,s,a;const l=i.dataset.sizeId;if(!l)return this.logger.warn("Product size selection failed: Size ID not found in button element",{productId:t,buttonElement:i.outerHTML.substring(0,100)}),void 0;await this.commands.product.selectSize(t,l);for(const t of n)t.classList.remove("selected"),t.setAttribute("aria-pressed","false");i.classList.add("selected"),i.setAttribute("aria-pressed","true");const c=this.getStoreValue("products."+t),d=c.sizes[l],u=this.getConfigs("global");this.addPersonalizationSpan&&(u.layout.enablePersonalization&&(null===(r=null===(o=null==d?void 0:d.attributes)||void 0===o?void 0:o.engraving)||void 0===r?void 0:r.status)===!![]&&c.productHasAvailability&&(null===(s=c.selectedFulfillment)||void 0===s?void 0:s.isVariantEngravable)===!![]&&(null===(a=c.selectedFulfillment)||void 0===a?void 0:a.canEngrave)===!![]?this.addPersonalizationSpan.style.display="inline":this.addPersonalizationSpan.style.display="none")})}}renderProductSizes(t,n){const i=document.createElement("div");i.className="size-container";const o=document.createElement("h3");o.className="size-label",o.textContent="Size",o.id="size-label",i.appendChild(o);const r=document.createElement("div");r.className="size-buttons-container",r.setAttribute("role","group"),r.setAttribute("aria-labelledby","size-label");for(const s of Object.values(n)){const n=document.createElement("span");n.setAttribute("data-size-id",s.id),n.setAttribute("select-size",""),n.className="size-button "+(s.id===t?"selected":"");const i=s.packDesc?" ("+s.packDesc+")":"";n.textContent=""+s.size+i,r.appendChild(n)}return i.appendChild(r),i}hasIndependentAddressComponent(){var t;return(null===(t=null===document||void 0===document?void 0:document.querySelectorAll("lce-element[address]"))||void 0===t?void 0:t.length)>0}template(){var t,n,i,r,s;const a=this.getProductId(),l=this.getStoreValue("products."+a),c=l.sizes[l.selectedSizeId],d=this.getConfigs("global"),u=[],h=document.createElement("div");h.className="price-personalization-container";const p=ComponentFactoryService.createElement({type:o.PRODUCT_PRICE,productId:a});if(h.appendChild(p),d.layout.enablePersonalization&&l.productHasAvailability&&(null===(n=null===(t=null==c?void 0:c.attributes)||void 0===t?void 0:t.engraving)||void 0===n?void 0:n.status)===!![]&&(null===(i=null==l?void 0:l.selectedFulfillment)||void 0===i?void 0:i.canEngrave)===!![]&&(null===(r=null==l?void 0:l.selectedFulfillment)||void 0===r?void 0:r.isVariantEngravable)===!![]){this.addPersonalizationSpan=document.createElement("span"),this.addPersonalizationSpan.className="add-personalization-span",this.addPersonalizationSpan.textContent="Personalize Your Bottle",this.addPersonalizationSpan.setAttribute("role","button"),this.addPersonalizationSpan.setAttribute("tabindex","0"),this.addPersonalizationSpan.setAttribute("aria-label","Personalize Your Bottle");const addPersonalization=async()=>{var t,n,i,r,s,c,d,u;const h=l.sizes[l.selectedSizeId];await this.commands.product.openProductDrawer(a,o.ENGRAVING_FORM,{identifier:a,context:"product",lines:[],maxLines:(null===(n=null===(t=h.attributes)||void 0===t?void 0:t.engraving)||void 0===n?void 0:n.maxLines)||1,maxCharsPerLine:(null===(r=null===(i=h.attributes)||void 0===i?void 0:i.engraving)||void 0===r?void 0:r.maxCharsPerLine)||16,fee:(null===(c=null===(s=h.attributes)||void 0===s?void 0:s.engraving)||void 0===c?void 0:c.fee)||0,location:null===(u=null===(d=h.attributes)||void 0===d?void 0:d.engraving)||void 0===u?void 0:u.location})};this.addPersonalizationSpan.addEventListener("click",async()=>{await addPersonalization()}),this.addPersonalizationSpan.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await addPersonalization())}),h.appendChild(this.addPersonalizationSpan)}u.push(h);const m=this.renderProductSizes(l.selectedSizeId,l.sizes);if(u.push(m),!this.hasIndependentAddressComponent()){const t=ComponentFactoryService.createElement({type:o.ADDRESS_DISPLAY,productId:a});u.push(t)}const f=ComponentFactoryService.createElement({type:o.PRODUCT_RETAILERS,productId:a});u.push(f);const b=ComponentFactoryService.createElement({type:o.PRODUCT_ADD_TO_CART_SECTION,productId:a});u.push(b);const w=null===(s=null==c?void 0:c.attributes)||void 0===s?void 0:s.presale;if((null==w?void 0:w.isActive)===!![]&&(null==w?void 0:w.language)){const t=document.createElement("div");t.className="product-presale-notice",t.innerHTML=sanitizeHTML((null==w?void 0:w.language)||""),u.push(t)}if(this.config.layout.showDescription&&(l.description.trim().length>0||l.htmlDescription.trim().length>0)){const t=ComponentFactoryService.createElement({type:o.PRODUCT_DESCRIPTION,productId:a});u.push(t)}return u}}class ProductLoadingComponent extends BaseComponent{template(){const t=Boolean(this.getStoreValue("address")),{showTitle:n,showDescription:i,showQuantityCounter:o,fulfillmentDisplay:r,showImages:s}=this.config.layout,a=document.createElement("div");a.classList.add("product-content-wrapper");const l=document.createElement("div");if(l.classList.add("skeleton-container"),n){const t=document.createElement("div");t.classList.add("wave","sc-title"),l.appendChild(t)}if(!t){const t=document.createElement("div");return t.classList.add("wave","sc-add-to-cart"),l.appendChild(t),l}const c=document.createElement("div");c.classList.add("wave","sc-price"),l.appendChild(c);const d=document.createElement("div");d.classList.add("sc-sizes");const u=document.createElement("div");u.classList.add("wave","sc-size-button"),d.appendChild(u);const h=document.createElement("div");h.classList.add("wave","sc-size-button"),d.appendChild(h);const p=document.createElement("div");p.classList.add("wave","sc-size-button"),d.appendChild(p);const m=document.createElement("div");m.classList.add("wave","sc-size-button"),d.appendChild(m);const f=document.createElement("div");f.classList.add("wave","sc-size-button"),d.appendChild(f),l.appendChild(d);const b=document.createElement("div");b.classList.add("sc-row");const w=document.createElement("div");w.classList.add("wave","sc-price"),b.appendChild(w);const C=document.createElement("div");C.classList.add("wave","sc-personalization"),b.appendChild(C),l.appendChild(b);const k=document.createElement("div");k.classList.add("wave","sc-deliver-to"),l.appendChild(k);const S=document.createElement("div");S.classList.add("wave","sc-address"),l.appendChild(S);const E=document.createElement("div");E.classList.add("wave","sc-retailers",r),l.appendChild(E);const _=document.createElement("div");if(_.classList.add("sc-row"),o){const t=document.createElement("div");t.classList.add("wave","sc-quantity"),_.appendChild(t)}const D=document.createElement("div");if(D.classList.add("wave","sc-add-to-cart"),_.appendChild(D),l.appendChild(_),i){const t=document.createElement("div");t.classList.add("wave","sc-description-title"),l.appendChild(t);const n=document.createElement("div");n.classList.add("wave","sc-description-line"),l.appendChild(n);const i=document.createElement("div");i.classList.add("wave","sc-description-line"),l.appendChild(i);const o=document.createElement("div");o.classList.add("wave","sc-description-line"),l.appendChild(o);const r=document.createElement("div");r.classList.add("wave","sc-description-more"),l.appendChild(r)}const P=document.createElement("div");if(P.classList.add("product-content"),P.appendChild(l),a.appendChild(P),s){a.classList.add("has-images");const t=this.createImageSkeletons();a.prepend(t)}return a}createImageSkeletons(){const t=document.createElement("div");t.classList.add("product-image-carousel","skeleton");const n=document.createElement("div");n.classList.add("wave","sc-main-image"),n.title="Product main image loading";const i=document.createElement("div");i.classList.add("carousel-dots");for(let s=0;s<3;s++){const t=document.createElement("div");t.classList.add("wave","sc-carousel-dot"),i.appendChild(t)}n.appendChild(i),t.appendChild(n);const o=document.createElement("div");o.classList.add("gallery-viewport");const r=document.createElement("div");r.classList.add("gallery-container");for(let s=0;s<4;s++){const t=document.createElement("div");t.classList.add("gallery-image-wrapper");const n=document.createElement("div");n.classList.add("wave","sc-gallery-thumbnail"),t.appendChild(n),r.appendChild(t)}return o.appendChild(r),t.appendChild(o),t}}class ProductOptionsComponent extends BaseComponent{get hostClasses(){return["product-options"]}constructor(){super({watchStorePaths:["address"],watchOnlyStorePaths:["products.{productId}.drawer.isOpen"]})}getProductId(){return this.params.productId}onStoreWatch(t){const n=this.getProductId(),i=t.find(t=>t.path==="products."+n+".drawer.isOpen");if(i){const t=i.value===!![];t&&this.addHostClasses("hide-content"),t||this.removeHostClasses("hide-content")}}template(){const t=this.getProductId(),n=this.getStoreValue("address.formattedAddress");if(n)return ComponentFactoryService.createElement({type:o.PRODUCT_INTERACTIONS,productId:this.getProductId()});const i=document.createElement("button");return i.type="button",i.className="product-options-open-address-button",i.textContent=this.config.layout.buyNowButtonText,i.addEventListener("click",async()=>{this.clientConfig.isMobile()&&this.commands.ui.openDrawer(o.ADDRESS_INPUT,{productId:t}),this.clientConfig.isMobile()||await this.commands.product.openProductDrawer(t,o.ADDRESS_INPUT,{productId:t})}),i}}class ProductPriceComponent extends BaseComponent{get hostClasses(){return["main-product-price"]}get hostAttributes(){return{role:"status","aria-live":"polite","aria-atomic":"true","aria-label":"Product price"}}constructor(){super({watchStorePaths:["products.{productId}.selectedSizeId","products.{productId}.selectedFulfillmentType","products.{productId}.selectedFulfillment","products.{productId}.selectedFulfillmentId","products.{productId}.fulfillmentHasAvailability"]})}getProductId(){return this.params.productId}template(){var t;const n=this.getProductId(),i=this.getStoreValue("products."+n);let o=(null===(t=i.priceInfo)||void 0===t?void 0:t.avg)||0;return i.selectedFulfillment&&(o=i.selectedFulfillment.price),formatCentToDollarText(o)}}class ProductRetailersComponent extends BaseComponent{get hostClasses(){return["product-retailers"]}constructor(){super({watchStorePaths:["products.{productId}.productHasAvailability"]})}get hostAttributes(){return{role:"status","aria-live":"polite","aria-atomic":"true","aria-label":"Retailer information"}}getProductId(){return this.params.productId}template(){const t=this.getProductId(),n=this.getStoreValue("products."+t),i=this.getConfigs("product"),r=[],s=this.getConfigs("configurations");if(!n.productHasAvailability||!s.isElementsEnabled){const t=document.createElement("p");return t.className="product-no-availability-message",t.innerHTML=sanitizeHTML(this.config.layout.noAvailabilityText),r.push(t),r}const a="carousel"===i.layout.fulfillmentDisplay?o.PRODUCT_RETAILERS_CAROUSEL:o.PRODUCT_RETAILERS_POPUP,l=ComponentFactoryService.createElement({type:a,productId:t});return r.push(l),r}}class ProductRetailersCarouselComponent extends BaseComponent{get hostClasses(){return["retailers-container","carousel"]}constructor(){super({watchStorePaths:["products.{productId}.selectedSizeId","products.{productId}.selectedFulfillmentType","products.{productId}.fulfillmentHasAvailability"],watchOnlyStorePaths:["products.{productId}.selectedFulfillmentId"]}),this.listViewport=null,this.listContainer=null,this.retailerCards=[],this.isDragging=![],this.hasMoved=![],this.startX=0,this.currentTranslateX=0,this.translateX=0}afterRender(){this.cacheElements(),this.setupDrag();const t=this.retailerCards.findIndex(t=>t.classList.contains("selected"));-1!==t&&this.scrollToIndex(t)}cacheElements(){this.retailerCards=Array.from(this.container.querySelectorAll(".carousel-retailer-card"))}getProductId(){return this.params.productId}onStoreWatch(t){const n=this.getProductId(),i=t.find(t=>t.path==="products."+n+".selectedFulfillmentId");(null==i?void 0:i.value)&&this.updateSelectedCard(i.value)}updateSelectedCard(t){for(const i of this.retailerCards)i.classList.remove("selected"),i.setAttribute("aria-pressed","false");const n=this.retailerCards.findIndex(n=>n.dataset.fulfillmentId===t);-1!==n&&(this.retailerCards[n].classList.add("selected"),this.retailerCards[n].setAttribute("aria-pressed","true"),this.scrollToIndex(n))}scrollToIndex(t){if(!this.listViewport||!this.retailerCards[t])return;const n=this.retailerCards[t],i=this.listViewport.offsetWidth,o=n.offsetLeft+n.offsetWidth/2,r=i/2,s=r-o,a=0,l=-(this.listContainer.scrollWidth-i);this.translateX=Math.max(l,Math.min(a,s)),this.updateTransform(!![])}setupDrag(){this.listContainer&&(this.listContainer.addEventListener("mousedown",this.handleDragStart.bind(this)),window.addEventListener("mousemove",this.handleDragMove.bind(this)),window.addEventListener("mouseup",this.handleDragEnd.bind(this)),this.listContainer.addEventListener("touchstart",this.handleDragStart.bind(this),{passive:!![]}),window.addEventListener("touchmove",this.handleDragMove.bind(this),{passive:![]}),window.addEventListener("touchend",this.handleDragEnd.bind(this)))}handleDragStart(t){this.isDragging=!![],this.hasMoved=![],this.startX="touches"in t?t.touches[0].clientX:t.clientX,this.currentTranslateX=this.translateX,this.listContainer&&(this.listContainer.style.cursor="grabbing")}handleDragMove(t){if(!this.isDragging||!this.listViewport)return;"touchmove"===t.type&&t.preventDefault();const n="touches"in t?t.touches[0].clientX:t.clientX,i=n-this.startX;Math.abs(i)>5&&(this.hasMoved=!![]);const o=this.currentTranslateX+i,r=0,s=-(this.listContainer.scrollWidth-this.listViewport.offsetWidth);this.translateX=Math.max(s,Math.min(r,o)),this.updateTransform(![])}handleDragEnd(){this.isDragging=![],this.listContainer&&(this.listContainer.style.cursor=""),setTimeout(()=>{this.hasMoved=![]},10)}updateTransform(t){this.listContainer&&(this.listContainer.style.transition=t?"transform 0.3s ease":"none",this.listContainer.style.transform="translate3d("+this.translateX+"px, 0, 0)")}async onFulfillmentTabClick(t){const n=this.getProductId(),i=t.currentTarget.dataset.fulfillmentType;if(!i)return this.logger.warn("Product fulfillment type selection failed: Type not found in target element",{productId:n,targetElement:t.currentTarget.outerHTML.substring(0,100)}),void 0;await this.commands.product.changeFulfillmentType(n,i)}async onRetailerCardClick(t){if(this.hasMoved)return;const n=this.getProductId(),i=t.currentTarget.dataset.fulfillmentId;if(!i)return this.logger.warn("Product retailer selection failed: Fulfillment ID not found in target element",{productId:n,targetElement:t.currentTarget.outerHTML.substring(0,100)}),void 0;const o=this.getStoreValue("products."+n+".selectedFulfillment");if(o&&o.fulfillmentId===i)return this.logger.info("Product retailer selection skipped: Same fulfillment already selected",{productId:n,fulfillmentId:i}),void 0;await this.commands.product.selectFulfillment(n,i)}generateRetailerCard({fulfillment:t,selectedFulfillmentType:n,isSelected:i,fulfillmentStatus:o,selectedSizeAttributes:s}){var a,l,c,d,u;let h=0;const p=null==s?void 0:s.presale,m=(null==p?void 0:p.isActive)&&(null==p?void 0:p.estimatedShipBy)?"Ships by "+formatISODateToMMDDYYYY(p.estimatedShipBy):"",f=n===r.SHIPPING,b=n===r.ON_DEMAND;f&&(h=(null===(l=null===(a=null==t?void 0:t.fees)||void 0===a?void 0:a.individual)||void 0===l?void 0:l.fee)||0),b&&(h=(null===(c=null==t?void 0:t.fees)||void 0===c?void 0:c.fee)||0);const w=fulfillmentAddress(t.retailerAddress,n);let C=null;n===r.ON_DEMAND&&o.openTime&&(null==o?void 0:o.closeTime)&&(C=o.isOpen?"Closes at "+format24TimeTo12$1(null==o?void 0:o.closeTime):"Opens at "+format24TimeTo12$1(null==o?void 0:o.openTime));const k=n===r.ON_DEMAND&&o&&o.isClosed?"closed":"",S=document.createElement("div");S.className="carousel-retailer-card "+(i?"selected":"")+" "+k,S.setAttribute("data-fulfillment-id",t.fulfillmentId),S.setAttribute("role","button"),S.setAttribute("tabindex","0"),S.setAttribute("aria-pressed",i?"true":"false");const E=n===r.SHIPPING?"Shipping":"Same-day delivery";S.setAttribute("aria-label",E+" from "+t.retailerName+", "+formatCentToDollarText(null!==(d=t.price)&&void 0!==d?d:0));const _=document.createElement("div");_.className="retailer-header";const D=document.createElement("h3");if(D.className="name",D.textContent=t.retailerName,_.appendChild(D),b){const t=document.createElement("h3");t.className="address",t.textContent=w,_.appendChild(t)}const P=document.createElement("div");P.className="retailer-body";const F=document.createElement("span");F.className="product-price",F.textContent=formatCentToDollarText(null!==(u=t.price)&&void 0!==u?u:0);const A=document.createElement("span");A.className="shipping-price",A.textContent=h>0?"+ "+formatCentToDollarText(h):"FREE Delivery";const O=document.createElement("span");return O.className="expectation",O.textContent=o.isClosed?C:(null==p?void 0:p.isActive)?m:(null==t?void 0:t.expectation.detail)||"No expectation available",P.append(F,A,O),S.append(_,P),S}template(){const t=this.getProductId(),n=this.getStoreValue("products."+t),i=this.getStoreValue("products."+t+".sizes."+n.selectedSizeId),o=(null==i?void 0:i.attributes)||null,s=[];for(const r in i.shippingFulfillments)Object.prototype.hasOwnProperty.call(i.shippingFulfillments,r)&&s.push(i.shippingFulfillments[r]);const a=[];for(const r in i.onDemandFulfillments)Object.prototype.hasOwnProperty.call(i.onDemandFulfillments,r)&&a.push(i.onDemandFulfillments[r]);const l=n.selectedFulfillmentType===r.SHIPPING,c=n.selectedFulfillmentType===r.ON_DEMAND,d=l?s:a,u=renderFulfillmentTabsContainer({shippingFulfillments:s,onDemandFulfillments:a,shippingSelected:l,onDemandSelected:c,onTabClick:this.onFulfillmentTabClick.bind(this),enableShippingFulfillment:this.config.layout.enableShippingFulfillment,enableOnDemandFulfillment:this.config.layout.enableOnDemandFulfillment});if(!n.fulfillmentHasAvailability||0===d.length){const t=document.createElement("p");return t.className="product-no-availability-message",t.innerHTML=sanitizeHTML(this.config.layout.noAvailabilityText),[u,t]}this.listViewport=document.createElement("div"),this.listViewport.className="carousel-fulfillment-list-viewport",this.listContainer=document.createElement("div"),this.listContainer.className="carousel-fulfillment-list-container";for(const h of d){const t=getRetailerOffHours(h),i=this.generateRetailerCard({fulfillment:h,selectedFulfillmentType:n.selectedFulfillmentType,isSelected:h.fulfillmentId===n.selectedFulfillmentId,fulfillmentStatus:t,selectedSizeAttributes:o}),s=n.selectedFulfillmentType===r.ON_DEMAND&&t&&t.isClosed;s?i.setAttribute("aria-disabled","true"):(i.addEventListener("click",this.onRetailerCardClick.bind(this)),i.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),i.click())})),this.listContainer.appendChild(i)}return this.listViewport.appendChild(this.listContainer),[u,this.listViewport]}}class ProductRetailersPopupComponent extends BaseComponent{get hostClasses(){return["retailers-container","popup"]}constructor(){super({watchStorePaths:["products.{productId}.selectedSizeId","products.{productId}.selectedFulfillmentType","products.{productId}.selectedFulfillment","products.{productId}.fulfillmentHasAvailability"]})}getProductId(){return this.params.productId}template(){const t=this.getProductId(),n=this.getStoreValue("products."+t),i=this.getStoreValue("products."+t+".sizes."+n.selectedSizeId),s=(null==i?void 0:i.attributes)||null,a=this.config.layout.enableShippingFulfillment,l=this.config.layout.enableOnDemandFulfillment,c=Object.values(i.shippingFulfillments),d=Object.values(i.onDemandFulfillments),u=(a?c.length:0)+(l?d.length:0),h=document.createElement("div");h.className="header";const p=document.createElement("span");p.className="header-label",p.textContent=n.selectedFulfillmentType===r.SHIPPING?"Shipping From:":"Delivering From:";const m=document.createElement("button");if(m.className="delivery-options",m.type="button",m.textContent="See Delivery Options ("+u+")",m.setAttribute("aria-label","View all "+u+" delivery options"),m.addEventListener("click",async()=>{0!==u&&(this.clientConfig.isMobile()&&this.commands.ui.openDrawer(o.PRODUCT_RETAILERS_POPUP_LIST,{productId:t}),this.clientConfig.isMobile()||await this.commands.product.openProductDrawer(t,o.PRODUCT_RETAILERS_POPUP_LIST,{productId:t}))}),h.appendChild(p),h.appendChild(m),!n.fulfillmentHasAvailability){const t=document.createElement("p");return t.className="fulfillments-no-availability-message",t.innerHTML=sanitizeHTML(this.config.layout.noAvailabilityText),[h,t]}const f=document.createElement("div");f.className="popup-fulfillment-list-container";const b=getRetailerOffHours(n.selectedFulfillment),w=renderPopupRetailerCard({fulfillment:n.selectedFulfillment,selectedFulfillmentType:n.selectedFulfillmentType,isSelected:![],fulfillmentStatus:b,selectedSizeAttributes:s});return f.appendChild(w),[h,f]}}class ProductRetailersPopupListComponent extends BaseComponent{get hostClasses(){return["retailers-popup-list-container"]}constructor(){super({watchStorePaths:["products.{productId}.selectedSizeId","products.{productId}.selectedFulfillmentType","products.{productId}.selectedFulfillment","products.{productId}.fulfillmentHasAvailability"]})}getProductId(){return this.params.productId}async onFulfillmentTabClick(t){const n=this.getProductId(),i=t.currentTarget.dataset.fulfillmentType;if(!i)return this.logger.warn("Product fulfillment type selection failed: Type not found in target element",{productId:n,targetElement:t.currentTarget.outerHTML.substring(0,100)}),void 0;await this.commands.product.changeFulfillmentType(n,i)}async onRetailerCardClick(t){const n=this.getProductId(),i=t.currentTarget.dataset.fulfillmentId;if(!i)return this.logger.warn("Product retailer selection failed: Fulfillment ID not found in target element",{productId:n,targetElement:t.currentTarget.outerHTML.substring(0,100)}),void 0;const B=async()=>{this.clientConfig.isMobile()||await this.commands.product.closeProductDrawer(n),this.clientConfig.isMobile()&&this.commands.ui.closeDrawer()},o=this.getStoreValue("products."+n+".selectedFulfillment");if(o&&o.fulfillmentId===i)return await B(),void 0;await this.commands.product.selectFulfillment(n,i),await B()}template(){const t=this.getProductId(),n=this.getStoreValue("products."+t),i=this.getStoreValue("products."+t+".sizes."+n.selectedSizeId),o=(null==i?void 0:i.attributes)||null,s=[];for(const r in i.shippingFulfillments)Object.prototype.hasOwnProperty.call(i.shippingFulfillments,r)&&s.push(i.shippingFulfillments[r]);const a=[];for(const r in i.onDemandFulfillments)Object.prototype.hasOwnProperty.call(i.onDemandFulfillments,r)&&a.push(i.onDemandFulfillments[r]);const l=n.selectedFulfillmentType===r.SHIPPING,c=n.selectedFulfillmentType===r.ON_DEMAND,d=l?s:a,u=document.createElement("h5");u.className="popup-retailers-section-title",u.textContent="Delivery Options";const h=renderFulfillmentTabsContainer({shippingFulfillments:s,onDemandFulfillments:a,shippingSelected:l,onDemandSelected:c,onTabClick:this.onFulfillmentTabClick.bind(this),enableShippingFulfillment:this.config.layout.enableShippingFulfillment,enableOnDemandFulfillment:this.config.layout.enableOnDemandFulfillment});if(!n.fulfillmentHasAvailability||0===d.length){const t=document.createElement("p");return t.className="fulfillments-no-availability-message",t.innerHTML=sanitizeHTML(this.config.layout.noAvailabilityText),[u,h,t]}const p=document.createElement("div");p.className="popup-fulfillment-list-container";for(const r of d){const t=getRetailerOffHours(r),i=renderPopupRetailerCard({fulfillment:r,selectedFulfillmentType:n.selectedFulfillmentType,isSelected:r.fulfillmentId===n.selectedFulfillmentId,fulfillmentStatus:t,selectedSizeAttributes:o});i.addEventListener("click",this.onRetailerCardClick.bind(this)),i.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),i.click())}),p.appendChild(i)}return[u,h,p]}}class ProductComponent extends BaseComponent{constructor(){super({watchStorePaths:["products.{productId}.loading","products.{productId}.error"],watchOnlyStorePaths:["products.{productId}.drawer.isOpen","products.{productId}.rerender"]}),this.titleElement=null}getProductId(){return this.params.productId}onStoreWatch(t){const n=this.getProductId(),i=t.find(t=>t.path==="products."+n+".drawer.isOpen"),o=t.find(t=>t.path==="products."+n+".rerender");i&&this.titleElement&&this.titleElement.classList.toggle("hide",i.value),(null==o?void 0:o.value)===!![]&&this.rerender("ProductComponentRerender")}template(){var t;const n=this.getProductId(),i=this.getStoreValue("products."+n);if(!i)return ComponentFactoryService.createElement({type:o.PRODUCT_LOADING});if(i.error)return productionComponentError({title:"Product Unavailable",message:"We're sorry, this product is currently unavailable.",componentType:o.PRODUCT});if(i.loading)return ComponentFactoryService.createElement({type:o.PRODUCT_LOADING});const r=i.sizes[i.selectedSizeId],s=document.createElement("div");s.classList.add("product-content-wrapper"),s.setAttribute("role","region"),s.setAttribute("aria-label",""+i.name);const a=document.createElement("div");if(a.classList.add("product-content"),a.setAttribute("role","region"),a.setAttribute("aria-label",""+i.name),this.config.layout.showTitle){const t=document.createElement("h1");t.classList.add("product-title"),t.textContent=i.name,this.titleElement=t,a.appendChild(t)}const l=ComponentFactoryService.createElement({type:o.PRODUCT_OPTIONS,productId:n});a.appendChild(l);const c=ComponentFactoryService.createElement({type:o.PRODUCT_DRAWER,productId:n});if(a.appendChild(c),s.appendChild(a),!this.config.layout.showImages||!(null===(t=i.images)||void 0===t?void 0:t.length))return s;s.classList.add("has-images");const d=ComponentFactoryService.createElement({type:o.PRODUCT_IMAGE_CAROUSEL,images:i.images,mainImage:r.image,productId:n});return s.prepend(d),d.setAttribute("aria-label","Product images"),s}async disconnected(){const t=this.getProductId();t&&await this.commands.product.removeProduct(t)}}class ProductListCardComponent extends BaseComponent{get hostClasses(){return["product-list-card",this.params.variant,this.params.fillCard?"fill":""]}getAvailabilityData(){var t,n,i;const o=this.params.product,r=this.getStoreValue("address.address"),s={hasAvailability:![],upc:"",fulfillmentId:"",partNumber:"",quantity:1,state:(null==r?void 0:r.state)||"",isPresale:![],isPresaleActive:![]},a=o.sizes[0];if(!a)return s;const l=a.variants[0];if(!l)return s;s.upc=a.upc;const c=a.attributes||{};s.isPresale=(null===(t=c.presale)||void 0===t?void 0:t.isActive)===!![],s.isPresaleActive=this.isPresaleActive(c);for(const d of this.params.fulfillments){const t=l.fulfillments.some(t=>t===d.id);if(t){const t="shipping"===d.type&&(null===(n=l.fulfillmentTypes)||void 0===n?void 0:n.shipping)||"onDemand"===d.type&&(null===(i=l.fulfillmentTypes)||void 0===i?void 0:i.onDemand);if(t&&l.stock>0){s.hasAvailability=!![],s.fulfillmentId=d.id,s.partNumber=l.partNumber;break}}}return s}isPresaleActive(t){const n=null==t?void 0:t.presale;if(!n)return![];if(!n.isActive)return![];if(n.canPurchaseOn){const t=new Date(n.canPurchaseOn),i=new Date;if(i.getTime()<t.getTime())return![]}return!![]}async handleAddToCart(t){if(!t.hasAvailability)return;const n=this.params.product.salsifyGrouping||this.params.product.id||"";t.isPresale&&t.isPresaleActive?await this.commands.productList.addPresaleToCart({upc:t.upc,fulfillmentId:t.fulfillmentId,partNumber:t.partNumber,quantity:t.quantity,identifier:n}):await this.commands.productList.addToCart({upc:t.upc,fulfillmentId:t.fulfillmentId,partNumber:t.partNumber,quantity:t.quantity,identifier:n})}template(){var t,n,i,o;const r=this.params.product,s=r.sizes[0],a=s?s.image:r.images[0],l=r.name,c=s?s.size:null,d=null!==(i=null===(n=null===(t=null==s?void 0:s.variants)||void 0===t?void 0:t[0])||void 0===n?void 0:n.price)&&void 0!==i?i:(null===(o=r.priceInfo)||void 0===o?void 0:o.average)||0,u=this.getAvailabilityData();return this.createVariantStandard({image:a,name:l,size:c,price:d,availability:u})}generateProductUrl(){var t;if(!this.params.productUrl)return null;const n=this.params.product,i=null===(t=n.sizes)||void 0===t?void 0:t[0],o=this.params.productUrl;if(o.includes("{upc}")){const t=(null==i?void 0:i.upc)||"";return t?o.replace("{upc}",t):(this.logger.warn("Product URL template requires {upc} but product has no UPC"),null)}if(o.includes("{grouping}")){const t=n.salsifyGrouping||"";return t?o.replace("{grouping}",t):(this.logger.warn("Product URL template requires {grouping} but product has no salsifyGrouping"),null)}return null}createVariantStandard(t){const{image:n,name:i,size:o,price:r,availability:s}=t,a=[],l=this.generateProductUrl(),c=document.createElement("div");c.className="plc__image-content";const d=document.createElement("div");d.className="plc__image-wrapper";const u=document.createElement("img");if(u.className="plc__image",u.src=n,u.alt=i,u.loading="lazy",d.appendChild(u),c.appendChild(d),l){const t=document.createElement("a");t.href=l,t.className="plc__image-link",t.target="_blank",t.rel="noopener noreferrer",t.addEventListener("click",()=>{this.commands.productList.trackSelectItem(this.params.product)}),t.appendChild(c),a.push(t)}else a.push(c);const h=document.createElement("div");h.className="plc__content";const p=document.createElement("h3");if(p.className="plc__title",p.textContent=i,l){const t=document.createElement("a");t.href=l,t.className="plc__title-link",t.target="_blank",t.rel="noopener noreferrer",t.addEventListener("click",()=>{this.commands.productList.trackSelectItem(this.params.product)}),t.appendChild(p),h.appendChild(t)}else h.appendChild(p);const m=document.createElement("div");m.className="plc__size-price-wrapper";const f=document.createElement("div");f.className="plc__price",f.textContent=formatCentToDollarText(r),m.appendChild(f);const b=document.createElement("div");b.className="plc__size",b.textContent=o||"",m.appendChild(b),h.appendChild(m),a.push(h);const w=document.createElement("button");return w.type="button",w.className="plc__button",w.disabled=!s.hasAvailability,s.hasAvailability?w.textContent="Add to Cart":(w.textContent="Not Available In "+s.state.toUpperCase(),this.addHostClasses("not-available")),w.addEventListener("click",async t=>{t.preventDefault(),t.stopPropagation(),await this.handleAddToCart(s)}),a.push(w),a}}class ProductListCardLoadingComponent extends BaseComponent{get hostClasses(){return["product-list-card-loading__container"]}createSkeletonCard(t){const n=document.createElement("div");n.classList.add("slc__card");const i=document.createElement("div");i.className="slc__image-content";const o=document.createElement("div");o.className="slc__image-wrapper";const r=document.createElement("div");r.classList.add("wave","slc__image"),o.appendChild(r),i.appendChild(o);const s=document.createElement("div");s.className="slc__content";const a=document.createElement("div");a.className="slc__title-container";const l=document.createElement("div");l.classList.add("wave","slc__title","slc__title-line-1"),a.appendChild(l);const c=document.createElement("div");c.classList.add("wave","slc__title","slc__title-line-2"),a.appendChild(c),s.appendChild(a);const d=document.createElement("div");d.className="slc__size-price-wrapper";const u=document.createElement("div");u.classList.add("wave","slc__price"),d.appendChild(u);const h=document.createElement("div");h.classList.add("wave","slc__size"),d.appendChild(h),s.appendChild(d);const p=document.createElement("div");return p.classList.add("wave","slc__button"),n.appendChild(i),n.appendChild(s),n.appendChild(p),n}template(){const t=[],n=100/this.params.columns;this.container.style.setProperty("--card-width",n+"%"),this.container.style.setProperty("--columns",""+this.params.columns);const i=this.params.rows*this.params.columns;for(let o=0;o<i;o++){const n=this.createSkeletonCard(o);t.push(n)}return t}}class ProductListFiltersComponent extends BaseComponent{get hostClasses(){return["product-list-filters-container"]}isSameDayDeliveryDisabled(){var t,n;return!(!(null===(t=this.params.currentFilters)||void 0===t?void 0:t.personalized)&&!(null===(n=this.params.currentFilters)||void 0===n?void 0:n.preOrder))}isPersonalizationDisabled(){var t;return"onDemand"===(null===(t=this.params.currentFilters)||void 0===t?void 0:t.deliveryOptions)}isPreOrderDisabled(){var t;return"onDemand"===(null===(t=this.params.currentFilters)||void 0===t?void 0:t.deliveryOptions)}template(){var t,n,i;const o=[],r=document.createElement("div");r.className="product-list-filters-header";const s=document.createElement("h3");if(s.className="product-list-filters-title",s.textContent="Filters",r.appendChild(s),o.push(r),this.params.enablePersonalized){const n=document.createElement("div");n.className="product-list-filters-personalized";const i=document.createElement("label");i.className="product-list-filters-personalized-label",i.setAttribute("for","personalized-switch"),i.textContent="Personalized Bottles",n.appendChild(i);const r=document.createElement("input");if(r.type="checkbox",r.id="personalized-switch",r.className="product-list-filters-personalized-switch",r.disabled=this.isPersonalizationDisabled(),r.checked=(null===(t=this.params.currentFilters)||void 0===t?void 0:t.personalized)||![],r.addEventListener("change",t=>{var n,i;const o=t.target;null===(i=(n=this.params).onPersonalizedChange)||void 0===i?void 0:i.call(n,o.checked)}),n.appendChild(r),this.isPersonalizationDisabled()){const t=document.createElement("div");t.className="product-list-filters-warning",t.textContent="(Not Available With Same-Day Delivery)",n.appendChild(t)}o.push(n)}if(this.params.enablePreOrder){const t=document.createElement("div");t.className="product-list-filters-pre-order";const i=document.createElement("label");i.className="product-list-filters-pre-order-label",i.setAttribute("for","pre-order-switch"),i.textContent="Pre-Order",t.appendChild(i);const r=document.createElement("input");if(r.type="checkbox",r.id="pre-order-switch",r.className="product-list-filters-pre-order-switch",r.disabled=this.isPreOrderDisabled(),r.checked=(null===(n=this.params.currentFilters)||void 0===n?void 0:n.preOrder)||![],r.addEventListener("change",t=>{var n,i;const o=t.target;null===(i=(n=this.params).onPreOrderChange)||void 0===i?void 0:i.call(n,o.checked)}),t.appendChild(r),this.isPreOrderDisabled()){const n=document.createElement("div");n.className="product-list-filters-warning",n.textContent="(Not Available With Same-Day Delivery)",t.appendChild(n)}o.push(t)}if(this.params.enableDeliveryOptions){const t=[{value:"all",label:"All"},{value:"shipping",label:"Shipping"},{value:"onDemand",label:"Same-Day Delivery"}],n=document.createElement("div");n.className="product-list-filters-delivery-options";const r=document.createElement("div");r.className="product-list-filters-delivery-options-header";const s=document.createElement("h3");s.className="product-list-filters-delivery-options-label",s.textContent="Delivery Options",r.appendChild(s),n.appendChild(r);const a=document.createElement("div");a.className="product-list-filters-delivery-options-list";for(const o of t){const t=document.createElement("div");t.className="product-list-filters-delivery-option";const n=document.createElement("input");n.type="radio",n.id="delivery-"+o.value,n.name="delivery-options",n.value=o.value,n.className="product-list-filters-delivery-radio";const r="onDemand"===o.value&&this.isSameDayDeliveryDisabled();n.disabled=r,n.checked=o.value===((null===(i=this.params.currentFilters)||void 0===i?void 0:i.deliveryOptions)||"all"),n.addEventListener("change",t=>{var n,i;const o=t.target;null===(i=(n=this.params).onDeliveryOptionsChange)||void 0===i?void 0:i.call(n,o.value)});const s=document.createElement("label");s.htmlFor="delivery-"+o.value,s.className="product-list-filters-delivery-radio-label "+(r?"disabled":""),s.textContent=o.label,t.appendChild(n),t.appendChild(s),a.appendChild(t)}n.appendChild(a),o.push(n)}return o}}var Ct;(function(t){t.IDLE="idle",t.LOADING_INITIAL="loading_initial",t.LOADING_MORE="loading_more",t.ERROR="error"})(Ct||(Ct={}));class ProductListComponent extends BaseComponent{get hostClasses(){const t=["product-list"];return this.params.filters.length>0&&t.push("has-filters"),t}constructor(){super({watchOnlyStorePaths:["address"]}),this.products=[],this.retailers=[],this.pagination={currentPage:0,totalPages:0,hasMorePages:!![]},this.currentFilters={personalized:![],preOrder:![],deliveryOptions:"all"},this.cardsContainer=null,this.filtersContainer=null,this.sentinelElement=null,this.personalizedSwitch=null,this.preOrderSwitch=null,this.deliveryRadios=[],this.deliveryRadioLabels=new Map,this.loadingState=Ct.IDLE,this.scrollObserver=null,this.initializationPromise=null}async connected(){if(this.initializationPromise)return this.initializationPromise;this.initializationPromise=this.initializeComponent(),await this.initializationPromise}disconnectedCallback(){super.disconnectedCallback(),this.doCleanup()}async initializeComponent(){try{this.setLoadingState(Ct.LOADING_INITIAL),await this.loadInitialProducts(),this.cardsContainer&&(this.renderProducts(),this.setupInfiniteScroll()),this.setLoadingState(Ct.IDLE)}catch(X){this.logger.error("Error initializing product list:",X),this.setLoadingState(Ct.ERROR),this.showErrorState("Failed to load products")}}template(){const t=[];return this.params.filters.length>0&&t.push(this.createFiltersContainer()),this.cardsContainer=this.createCardsContainer(),t.push(this.cardsContainer),this.renderCurrentState(),t}setLoadingState(t){this.loadingState=t,this.cardsContainer&&this.renderCurrentState()}renderCurrentState(){if(this.cardsContainer)switch(this.loadingState){case Ct.LOADING_INITIAL:this.renderLoadingState();break;case Ct.ERROR:break;case Ct.IDLE:case Ct.LOADING_MORE:this.updateSentinel()}}async loadInitialProducts(){var t;try{const n=this.buildApiParams(0),i=await this.commands.productList.getProductList(n);this.products=i.products||[],this.retailers=i.retailers||[],this.updatePagination(i.navigation),this.syncFiltersFromResponse((null===(t=i.navigation)||void 0===t?void 0:t.filters)||[])}catch(n){throw this.logger.error("Error loading initial products:",n),this.products=[],this.retailers=[],this.pagination.hasMorePages=![],n}}async loadMoreProducts(){if(this.loadingState!==Ct.LOADING_MORE&&this.pagination.hasMorePages)try{this.setLoadingState(Ct.LOADING_MORE);const t=this.pagination.currentPage+1,n=this.buildApiParams(t),i=await this.commands.productList.getProductList(n);i.products&&i.products.length>0?(this.products.push(...i.products),this.mergeRetailers(i.retailers||[]),this.updatePagination(i.navigation),this.appendNewProducts(i.products)):(this.pagination.hasMorePages=![],this.updatePagination(i.navigation)),this.setLoadingState(Ct.IDLE)}catch(t){this.logger.error("Error loading more products:",t),this.setLoadingState(Ct.ERROR),this.showSentinelError("Error loading products")}}mergeRetailers(t){const n=new Map(this.retailers.map(t=>[t.id,t]));for(const i of t)n.has(i.id)||(this.retailers.push(i),n.set(i.id,i))}updatePagination(t){var n,i,o,r;t&&(this.pagination={currentPage:null!==(n=t.currentPage)&&void 0!==n?n:0,totalPages:null!==(i=t.totalPages)&&void 0!==i?i:0,hasMorePages:(null!==(o=t.currentPage)&&void 0!==o?o:0)<(null!==(r=t.totalPages)&&void 0!==r?r:1)-1})}buildApiParams(t){return{page:t,perPage:this.params.rows*this.params.columns,filters:this.buildFiltersFromState()}}buildFiltersFromState(){const t=[{key:"availability",values:"IN_STOCK"}];return this.currentFilters.personalized&&t.push({key:"engraving",values:"YES"}),this.currentFilters.preOrder&&t.push({key:"presale",values:"YES"}),"all"!==this.currentFilters.deliveryOptions&&t.push({key:"fulfillment",values:[this.currentFilters.deliveryOptions]}),t}syncFiltersFromResponse(t){if(t)for(const n of t)switch(n.key){case"engraving":this.currentFilters.personalized="YES"===n.values;break;case"presale":this.currentFilters.preOrder="YES"===n.values;break;case"fulfillment":Array.isArray(n.values)&&(n.values.includes("onDemand")?this.currentFilters.deliveryOptions="onDemand":n.values.includes("shipping")?this.currentFilters.deliveryOptions="shipping":this.currentFilters.deliveryOptions="all")}}async onFilterChange(){try{this.updateFiltersUI(),this.resetPagination(),this.products=[],this.retailers=[],this.cleanupScrollObserver(),this.clearCardsContainer(),this.setLoadingState(Ct.LOADING_INITIAL),await this.loadInitialProducts(),this.renderProducts(),this.setupInfiniteScroll(),this.setLoadingState(Ct.IDLE)}catch(X){this.logger.error("Error handling filter change:",X),this.setLoadingState(Ct.ERROR),this.showErrorState("Error updating filters")}}resetPagination(){this.pagination={currentPage:0,totalPages:0,hasMorePages:!![]}}updateFiltersUI(){this.filtersContainer&&(this.updatePersonalizedSwitch(),this.updatePreOrderSwitch(),this.updateDeliveryOptions())}updatePersonalizedSwitch(){this.personalizedSwitch&&(this.personalizedSwitch.checked=this.currentFilters.personalized,this.personalizedSwitch.disabled=this.isPersonalizationDisabled())}updatePreOrderSwitch(){this.preOrderSwitch&&(this.preOrderSwitch.checked=this.currentFilters.preOrder,this.preOrderSwitch.disabled=this.isPreOrderDisabled())}updateDeliveryOptions(){0!==this.deliveryRadios.length&&this.deliveryRadios.forEach(t=>{const n="onDemand"===t.value&&this.isSameDayDeliveryDisabled();t.disabled=n,n&&"onDemand"===t.value||(t.checked=t.value===this.currentFilters.deliveryOptions),this.updateRadioLabel(t,n)})}updateRadioLabel(t,n){const i=this.deliveryRadioLabels.get(t.id);i&&(i.className="product-list-filters-delivery-radio-label "+(n?"disabled":""))}isPersonalizationDisabled(){return"onDemand"===this.currentFilters.deliveryOptions}isPreOrderDisabled(){return"onDemand"===this.currentFilters.deliveryOptions}isSameDayDeliveryDisabled(){return this.currentFilters.personalized||this.currentFilters.preOrder}createCardsContainer(){const t=document.createElement("div");t.className="product-list-cards__container";const n=100/this.params.columns;return t.style.setProperty("--card-width",n+"%"),t.style.setProperty("--columns",""+this.params.columns),t}renderLoadingState(){if(!this.cardsContainer)return;this.clearCardsContainer();const t=ComponentFactoryService.createElement({type:o.PRODUCT_LIST_CARD_LOADING,cardVariant:this.params.cardVariant,rows:this.params.rows,columns:this.params.columns,fillCard:this.params.fillCard,filters:this.params.filters,productUrl:this.params.productUrl});this.cardsContainer.appendChild(t)}renderProducts(){if(this.cardsContainer){if(this.clearCardsContainer(),0===this.products.length){const t=this.createInfoElement("No products found");return this.cardsContainer.appendChild(t),void 0}for(const t of this.products){const n=this.createProductCard(t);n&&this.cardsContainer.appendChild(n)}}}appendNewProducts(t){if(this.cardsContainer&&0!==t.length){this.sentinelElement&&this.sentinelElement.parentNode===this.cardsContainer&&this.sentinelElement.remove();for(const n of t){const t=this.createProductCard(n);t&&this.cardsContainer.appendChild(t)}this.sentinelElement?(this.cardsContainer.appendChild(this.sentinelElement),this.updateSentinel(),this.scrollObserver&&this.pagination.hasMorePages&&this.scrollObserver.observe(this.sentinelElement)):this.pagination.hasMorePages&&this.setupInfiniteScroll()}}createProductCard(t){var n;try{const i=null===(n=t.sizes)||void 0===n?void 0:n[0];if(!i)return this.logger.warn("Product "+t.id+" has no sizes"),null;const r=new Map(this.retailers.flatMap(t=>t.fulfillments.map(t=>[t.id,t]))),s=new Set(i.variants.flatMap(t=>t.fulfillments)),a=Array.from(s).map(t=>r.get(t)).filter(t=>Boolean(t));return ComponentFactoryService.createElement({type:o.PRODUCT_LIST_CARD,variant:this.params.cardVariant,fillCard:this.params.fillCard,product:t,fulfillments:a,productUrl:this.params.productUrl})}catch(i){return this.logger.error("Error creating product card for product "+t.id+":",i),null}}createFiltersContainer(){return this.filtersContainer=ComponentFactoryService.createElement({type:o.PRODUCT_LIST_FILTERS,enablePersonalized:this.params.filters.includes(c.PERSONALIZATION),enablePreOrder:this.params.filters.includes(c.PRE_ORDER),enableDeliveryOptions:this.params.filters.includes(c.DELIVERY_OPTIONS),currentFilters:this.currentFilters,onPersonalizedChange:async t=>{this.currentFilters.personalized=t,await this.onFilterChange()},onPreOrderChange:async t=>{this.currentFilters.preOrder=t,await this.onFilterChange()},onDeliveryOptionsChange:async t=>{this.currentFilters.deliveryOptions=t,"onDemand"===t&&(this.currentFilters.personalized=![],this.currentFilters.preOrder=![]),await this.onFilterChange()}}),this.storeFilterElementReferences(),this.filtersContainer}storeFilterElementReferences(){if(!this.filtersContainer)return;this.personalizedSwitch=this.filtersContainer.querySelector("#personalized-switch"),this.preOrderSwitch=this.filtersContainer.querySelector("#pre-order-switch");const t=this.filtersContainer.querySelectorAll('input[name="delivery-options"]');this.deliveryRadios=Array.from(t),this.deliveryRadioLabels.clear(),this.deliveryRadios.forEach(t=>{var n;const i=null===(n=this.filtersContainer)||void 0===n?void 0:n.querySelector('label[for="'+t.id+'"]');i&&this.deliveryRadioLabels.set(t.id,i)})}setupInfiniteScroll(){this.cardsContainer&&this.pagination.hasMorePages&&(this.cleanupScrollObserver(),this.sentinelElement=this.createScrollSentinel(),this.cardsContainer.appendChild(this.sentinelElement),this.scrollObserver=new IntersectionObserver(t=>{const n=t[0];n.isIntersecting&&this.loadingState===Ct.IDLE&&this.pagination.hasMorePages&&void this.loadMoreProducts()},{root:null,rootMargin:"100px",threshold:.1}),this.scrollObserver.observe(this.sentinelElement))}createScrollSentinel(){const t=document.createElement("div");return t.className="product-list-scroll-sentinel",this.updateSentinelContent(t),t}updateSentinel(){this.sentinelElement&&this.updateSentinelContent(this.sentinelElement)}updateSentinelContent(t){let n;t.innerHTML="",n=this.loadingState===Ct.LOADING_MORE?this.createLoadingElement("Loading more products..."):this.pagination.hasMorePages?this.createInfoElement("Scroll for more products"):this.createInfoElement("No more products",!![]),t.appendChild(n)}showSentinelError(t){if(!this.sentinelElement)return;this.sentinelElement.innerHTML="";const n=this.createErrorElement(t);this.sentinelElement.appendChild(n)}createLoadingElement(t){const n=document.createElement("div");n.className="product-list-sentinel-container";const i=document.createElement("div");i.className="product-list-sentinel-spinner";const o=document.createElement("div");return o.className="product-list-sentinel-text",o.textContent=t,n.appendChild(i),n.appendChild(o),n}createErrorElement(t){const n=document.createElement("div");n.className="product-list-sentinel-error-container";const i=document.createElement("div");i.className="product-list-sentinel-error-icon",i.innerHTML="⚠";const o=document.createElement("div");return o.className="product-list-sentinel-error-text",o.textContent=t,n.appendChild(i),n.appendChild(o),n}createInfoElement(t,n=![]){const i=document.createElement("div");if(i.className="product-list-sentinel-info-container",!n&&t.includes("Scroll")){const t=document.createElement("div");t.className="product-list-sentinel-icon",t.innerHTML="↓",i.appendChild(t)}else if(n){const t=document.createElement("div");t.className="product-list-sentinel-divider",i.appendChild(t)}const o=document.createElement("div");return o.className=n?"product-list-sentinel-info-text no-more":"product-list-sentinel-info-text",o.textContent=t,i.appendChild(o),i}showErrorState(t){if(!this.cardsContainer)return;this.clearCardsContainer();const n=this.createErrorElement(t);this.cardsContainer.appendChild(n)}clearCardsContainer(){if(this.cardsContainer)for(this.sentinelElement&&this.sentinelElement.parentNode===this.cardsContainer&&(this.sentinelElement.remove(),this.sentinelElement=null);this.cardsContainer.firstChild;)this.cardsContainer.removeChild(this.cardsContainer.firstChild)}cleanupScrollObserver(){this.scrollObserver&&(this.scrollObserver.disconnect(),this.scrollObserver=null),this.sentinelElement&&(this.sentinelElement=null)}async onStoreWatch(t){const n=t.find(t=>"address"===t.path);if(n&&void 0!==n.value&&this.cardsContainer)try{this.resetPagination(),this.products=[],this.retailers=[],this.cleanupScrollObserver(),this.clearCardsContainer(),this.renderLoadingState(),await this.loadInitialProducts(),this.cardsContainer&&(this.renderProducts(),this.setupInfiniteScroll())}catch(i){this.logger.error("Error reloading products after address change:",i),this.setLoadingState(Ct.ERROR),this.cardsContainer&&this.showErrorState("Failed to reload products")}}doCleanup(){this.cleanupScrollObserver(),this.products=[],this.retailers=[],this.cardsContainer=null,this.filtersContainer=null,this.personalizedSwitch=null,this.preOrderSwitch=null,this.deliveryRadios=[],this.deliveryRadioLabels.clear(),this.initializationPromise=null}}class AlertComponent extends BaseComponent{constructor(){super(...arguments),this.hideTimeout=null,this.elements=[]}get hostClasses(){return["alert-wrapper","hidden"]}get hostAttributes(){return{role:"alert","aria-live":"polite"}}beforeSetupStoreWatchers(){this.reactiveOptions.watchStorePaths=[this.params.errorStorePath]}afterRender(){this.updateAlert()}onStoreWatch(t){t.length>0&&this.updateAlert()}getErrorMessages(){var t,n;const i=null!==(t=this.params.fromEvents)&&void 0!==t?t:![],o=null!==(n=this.params.showFirstEvent)&&void 0!==n?n:!![];if(i){const t=this.store.get(this.params.errorStorePath)||[],n=t.filter(t=>null==t?void 0:t.message).map(t=>({message:t.message,level:t.level||"error",type:t.type}));return o?n.slice(0,1):n}const r=this.store.get(this.params.errorStorePath);return r?[{message:r,level:"error"}]:[]}createErrorElement(t){const n=document.createElement("div");n.classList.add("alert-container","alert-"+t.level);const i=document.createElement("span");i.classList.add("alert-icon"),i.innerHTML=ErrorInfoIcon({className:t.level+"-icon"});const o=document.createElement("span");return o.classList.add("alert-text"),o.textContent=t.message,n.appendChild(i),n.appendChild(o),n}scheduleHide(){var t;this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=null);const n=null!==(t=this.params.autoHideDelay)&&void 0!==t?t:3e3;this.hideTimeout=setTimeout(()=>{this.hideAllErrors(),this.hideTimeout=null},n)}hideAllErrors(){var t;this.addHostClasses("hidden"),this.removeHostClasses("alert-success","alert-info","alert-warning","alert-error"),this.elements.forEach(t=>{t.parentNode&&t.parentNode.removeChild(t)}),this.elements=[];const n=null!==(t=this.params.fromEvents)&&void 0!==t?t:![];n?this.store.set(this.params.errorStorePath,[]):this.store.set(this.params.errorStorePath,null)}updateAlert(){const t=this.getErrorMessages();if(this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=null),this.elements.forEach(t=>{t.parentNode&&t.parentNode.removeChild(t)}),this.elements=[],0===t.length)return this.addHostClasses("hidden"),this.removeHostClasses("alert-success","alert-info","alert-warning","alert-error"),void 0;this.removeHostClasses("hidden"),this.elements=t.map(t=>this.createErrorElement(t)),this.elements.forEach(t=>{this.container.appendChild(t)}),this.scheduleHide()}template(){return[]}disconnectedCallback(){this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=null),super.disconnectedCallback()}}class ButtonsOpenCartComponent extends BaseComponent{get hostClasses(){return["lce-ui-button",...this.params.classes||[]]}template(){const t=this.getConfigs("global");this.addEventListener("click",()=>{this.commands.ui.openDrawer(o.CART)});const n=document.createElement("span");if(n.className="lce-cart-button-icon",n.innerHTML=BagIcon({color:t.theme.primaryColor}),this.params.showItemsCount){const t=document.createElement("span");return t.className="lce-cart-button-badge",t.style.visibility="hidden",[n,t]}return[n]}afterRender(){this.params.showItemsCount&&this.setupCartBadge()}setupCartBadge(){const t=this.container.querySelector(".lce-cart-button-badge");if(!t)return;const n=this.getStoreValue("cart.totals.quantity")||0;t.textContent=n.toString(),t.style.visibility=n>0?"visible":"hidden",this.store.watch("cart.totals",()=>{const n=this.getStoreValue("cart.totals.quantity")||0;t.textContent=n.toString(),t.style.visibility=n>0?"visible":"hidden"})}}class DrawerComponent extends BaseComponent{constructor(){super({watchStorePaths:["ui.drawer"]}),this.isOpen=![],this.wrapperElement=null,this.drawerElement=null,this.backdropElement=null,this.contentContainer=null,this.currentContentType=null,this.isTransitioning=![],this.boundHandleKeydown=this.handleKeydown.bind(this)}disconnected(){this.backdropElement&&this.backdropElement.removeEventListener("click",this.handleBackdropClick.bind(this)),document.removeEventListener("keydown",this.boundHandleKeydown)}onStoreChanged(t){var n;const i=t.find(t=>"ui.drawer"===t.path);if(!i)return![];const o=i.value,r=o.isOpen,s=null===(n=o.contentConfig)||void 0===n?void 0:n.type,a=s!==this.currentContentType;return r&&!this.isOpen?(this.currentContentType=s,this.openWithContent(o),![]):r&&this.isOpen&&!a?![]:r&&this.isOpen&&a?(this.currentContentType=s,this.openWithContent(o),![]):!r&&this.isOpen?(this.close(),this.currentContentType=null,![]):![]}openWithContent({contentConfig:t}){try{if(!t)return this.logger.warn("Drawer opening attempted without content configuration"),void 0;const{type:n,data:i}=t||{};let o;o=this.isElementsEnabled()?ComponentFactoryService.createElement({type:n,...i}):this.clientConfig.isProduction()?productionComponentError({title:"Element Unavailable",message:"We're sorry, this element is currently unavailable.",componentType:n}):componentError({message:"Elements is not enabled.",componentType:n}),this.isOpen&&this.contentContainer&&this.contentContainer.firstElementChild?this.animateContentSwap(o,n):(this.cleanupCurrentContent(),this.contentContainer&&this.contentContainer.appendChild(o),this.updateDrawerContentTypeClass(n),this.open()),this.addHostAttribute("data-target",n.toString().toLowerCase())}catch(n){this.logger.error("Drawer content loading failed",n),this.commands.ui.closeDrawer()}}animateContentSwap(t,n){if(!this.contentContainer||this.isTransitioning)return;this.isTransitioning=!![];const i=this.contentContainer.firstElementChild;i.classList.add("drawer-content-fade-out"),requestAnimationFrame(()=>{i.classList.add("fading")}),setTimeout(()=>{i.remove(),t.classList.add("drawer-content-fade-in"),this.contentContainer.appendChild(t),this.updateDrawerContentTypeClass(n),requestAnimationFrame(()=>{t.classList.add("visible"),setTimeout(()=>{t.classList.remove("drawer-content-fade-in","visible"),this.isTransitioning=![]},150)})},150)}open(){this.isOpen=!![],this.updateDrawerState()}close(){this.isOpen=![],this.updateDrawerState()}cleanupCurrentContent(){this.contentContainer&&(this.contentContainer.innerHTML="")}handleBackdropClick(){this.commands.ui.closeDrawer()}handleKeydown(t){this.isOpen&&"Escape"===t.key&&this.commands.ui.closeDrawer()}updateDrawerContentTypeClass(t){if(!this.drawerElement)return;const n=["drawer"];this.isOpen&&n.push("open"),n.push(t.toString().toLowerCase()),this.drawerElement.className=n.join(" ")}updateDrawerState(){this.wrapperElement&&this.drawerElement&&this.backdropElement&&(this.isOpen&&(this.wrapperElement.classList.add("open"),this.backdropElement.classList.add("visible"),document.body.style.overflow="hidden",this.currentContentType&&this.updateDrawerContentTypeClass(this.currentContentType)),this.isOpen||(this.wrapperElement.classList.remove("open"),this.backdropElement.classList.remove("visible"),document.body.style.overflow="",this.drawerElement.className="drawer"))}isElementsEnabled(){var t;try{const n=this.themeProvider.getConfigs("configurations");return null!==(t=null==n?void 0:n.isElementsEnabled)&&void 0!==t?t:![]}catch(n){return this.logger.error("Could not check elements enabled status, defaulting to not enabled",n),!![]}}template(){return this.wrapperElement=document.createElement("div"),this.wrapperElement.classList.add("drawer-wrapper"),this.backdropElement=document.createElement("div"),this.backdropElement.classList.add("drawer-backdrop"),this.backdropElement.addEventListener("click",this.handleBackdropClick.bind(this)),this.drawerElement=document.createElement("div"),this.drawerElement.classList.add("drawer"),this.contentContainer=document.createElement("div"),this.contentContainer.classList.add("drawer-content"),this.drawerElement.append(this.contentContainer),this.wrapperElement.append(this.backdropElement),this.wrapperElement.append(this.drawerElement),document.addEventListener("keydown",this.boundHandleKeydown),this.wrapperElement}}class EngravingFormComponent extends BaseComponent{constructor(){super(...arguments),this.engravingLines=[],this.fulfillmentId=null,this.partNumber=null}get hostClasses(){return["engraving-form"]}beforeConnected(){var t;if(this.engravingLines=this.params.lines,"product"===this.params.context){const n=this.store.get("products."+this.params.identifier);this.fulfillmentId=n.selectedFulfillmentId,this.partNumber=(null===(t=n.selectedFulfillment)||void 0===t?void 0:t.partNumber)||null}if("cart"===this.params.context){const t=this.store.get("cart.items."+this.params.identifier);this.fulfillmentId=t.fulfillmentId,this.partNumber=t.partNumber}}calculateTotalPrice(){var t,n;if("product"===this.params.context){const i=this.store.get("products."+this.params.identifier),o=i.sizes[i.selectedSizeId],r=o.shippingFulfillments[this.fulfillmentId],s=r.price,a=(null===(n=null===(t=null==o?void 0:o.attributes)||void 0===t?void 0:t.engraving)||void 0===n?void 0:n.fee)||0;return s+a}if("cart"===this.params.context){const t=this.store.get("cart.items."+this.params.identifier),n=t.unitPrice,i=t.attributes.engraving.fee||0;return n+i}return 0}productInformationSection(){const t=[];let n="",i="";if("product"===this.params.context){const o=this.store.get("products."+this.params.identifier);o.mainImage?t.push(o.mainImage):t.push(...o.images||[]),n=o.name,i=o.sizes[o.selectedSizeId].size}if("cart"===this.params.context){const o=this.store.get("cart.items."+this.params.identifier);o.mainImage&&t.push(o.mainImage),n=o.name,i=o.size}const o=document.createElement("div");if(o.className="product-info-section",t.length>0){const i=document.createElement("div");i.className="product-image-container";const r=document.createElement("img");r.src=t[0],r.alt=n,r.loading="lazy",r.className="product-image",i.appendChild(r),o.appendChild(i)}const r=document.createElement("div");r.className="product-details-container";const s=document.createElement("div");s.className="product-header";const a=document.createElement("h4");a.className="product-title",a.textContent=n,this.productPriceSpan=document.createElement("span"),this.productPriceSpan.className="product-price",this.productPriceSpan.textContent=formatCentToDollarText(this.calculateTotalPrice()),s.appendChild(a),s.appendChild(this.productPriceSpan),r.appendChild(s);const l=document.createElement("p");l.className="product-size-text",l.textContent=i,r.appendChild(l);const c=document.createElement("p");return c.className="engraving-fees-disclaimer",c.textContent="Personalization fees included in total, varies by retailer.",r.appendChild(c),o.appendChild(r),o}addToCartButtonText(t){if("product"!==this.params.context)return"Save";const n=this.getConfigs("product"),i=n.layout.addToCartButtonText;return n.layout.addToCartButtonShowTotalPrice?i+" - "+formatCentToDollarText(t):i}retailersSection(){var t,n,i,o,r,s,a;const l=this.store.get("products."+this.params.identifier),c=l.sizes[l.selectedSizeId],d=Object.values(c.shippingFulfillments).filter(t=>t.isVariantEngravable&&t.canEngrave),u=document.createElement("div");u.className="fulfillment-section";const h=document.createElement("p");if(h.className="shipping-from-text",h.innerHTML="Shipping from: <b>"+(null===(t=l.selectedFulfillment)||void 0===t?void 0:t.retailerName)+"</b>",u.appendChild(h),1===d.length)return u;const p=document.createElement("div");p.className="fulfillment-options-container",u.appendChild(p);const m=document.createElement("span");m.className="see-more-fulfillments",m.textContent="See More Delivery Options ("+d.length+")",m.setAttribute("role","button"),m.setAttribute("tabindex","0"),m.setAttribute("aria-label","See More Delivery Options ("+d.length+")"),m.setAttribute("aria-expanded","false");const I=()=>{const t=p.classList.contains("expanded");p.classList.toggle("expanded"),t?(m.textContent="See More Delivery Options ("+d.length+")",m.setAttribute("aria-label","See More Delivery Options ("+d.length+")"),m.setAttribute("aria-expanded","false")):(m.textContent="See Less Delivery Options",m.setAttribute("aria-label","See Less Delivery Options"),m.setAttribute("aria-expanded","true"))};m.addEventListener("click",I),m.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),I())}),u.appendChild(m);for(const f of d){const t=document.createElement("div");t.className="fulfillment-option",t.setAttribute("data-fulfillment-id",f.fulfillmentId),f.fulfillmentId===(null===(n=l.selectedFulfillment)||void 0===n?void 0:n.fulfillmentId)&&t.classList.add("selected"),t.setAttribute("role","button"),t.setAttribute("tabindex","0"),t.setAttribute("aria-label","Select delivery from "+f.retailerName+", "+formatCentToDollarText(f.price+((null===(o=null===(i=l.sizes[l.selectedSizeId].attributes)||void 0===i?void 0:i.engraving)||void 0===o?void 0:o.fee)||0))+", "+f.expectation.engraving),t.setAttribute("aria-pressed",f.fulfillmentId===(null===(r=l.selectedFulfillment)||void 0===r?void 0:r.fulfillmentId)?"true":"false");const x=()=>{this.fulfillmentId=f.fulfillmentId,this.partNumber=f.partNumber;const n=this.calculateTotalPrice();this.addToCartButton.textContent=this.addToCartButtonText(n),this.productPriceSpan.textContent=formatCentToDollarText(n);const i=p.querySelector(".fulfillment-option.selected");i&&(i.classList.remove("selected"),i.setAttribute("aria-pressed","false")),t.classList.add("selected"),t.setAttribute("aria-pressed","true"),h.innerHTML="Shipping from: <b>"+f.retailerName+"</b>"};t.addEventListener("click",x),t.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),x())});const c=f.price+((null===(a=null===(s=l.sizes[l.selectedSizeId].attributes)||void 0===s?void 0:s.engraving)||void 0===a?void 0:a.fee)||0),d=document.createElement("div");d.className="option-row row-1",t.appendChild(d);const u=document.createElement("span");u.className="retailer-name",u.textContent=f.retailerName,d.appendChild(u);const m=document.createElement("span");m.className="fulfillment-price",m.textContent=formatCentToDollarText(c),d.appendChild(m),t.appendChild(d);const b=document.createElement("div");b.className="option-row row-2",t.appendChild(b);const w=document.createElement("span");w.className="estimated-time",w.textContent=""+f.expectation.engraving,b.appendChild(w),t.appendChild(b),p.appendChild(t)}return u}engravingLinesSection(){var t;const{lines:n,maxLines:i,location:o,maxCharsPerLine:r}=this.params,s=document.createElement("div");s.className="engraving-section";const a=document.createElement("p");if(a.className="engraving-title",a.textContent="Personalize Your Bottle",s.appendChild(a),o&&(null===(t=null==o?void 0:o.trim())||void 0===t?void 0:t.length)>0){const t=document.createElement("p");t.className="engraving-location-text",t.textContent="Your message will appear "+o.toLowerCase()+".",s.appendChild(t)}const l=Array.from({length:i},(t,i)=>{const o=i+1,s=document.createElement("div");s.className="engraving-input-wrapper",s.setAttribute("data-line-number",o.toString());const a=document.createElement("input");a.type="text",a.id="engraving-line-"+o,a.dataset.lineNumber=o.toString(),a.maxLength=r,a.value=n[i]||"",a.placeholder=o>1?"Line "+o+" (optional)":"Line "+o,a.className="engraving-input",a.autocomplete="off",a.setAttribute("aria-label",o>1?"Engraving line "+o+", optional, maximum "+r+" characters":"Engraving line "+o+", maximum "+r+" characters");const l=document.createElement("span");return l.className="engraving-char-count",l.textContent=a.value.length+"/"+r,l.setAttribute("aria-live","polite"),l.setAttribute("aria-atomic","true"),a.addEventListener("input",()=>{l.textContent=a.value.length+"/"+r,this.engravingLines[i]=a.value.trim().toUpperCase(),this.addToCartButton.disabled=this.engravingLines.length<=0}),s.appendChild(a),s.appendChild(l),s}),c=document.createElement("div");return c.className="engraving-inputs-container",c.append(...l),s.appendChild(c),s}actionButtonsSection(){const{identifier:t,context:n}=this.params,i=document.createElement("div");i.className="action-buttons-container";const r=document.createElement("button");r.type="button",r.className="cancel-action-button",r.textContent="Cancel",r.setAttribute("aria-label","Cancel personalization and close");const z=async()=>{"product"===n&&await this.commands.product.closeProductDrawer(t),"cart"===n&&this.commands.ui.openDrawer(o.CART)};r.addEventListener("click",z),r.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),z())}),i.appendChild(r),this.addToCartButton=document.createElement("button"),this.addToCartButton.type="button",this.addToCartButton.className="add-to-cart-button",this.addToCartButton.disabled=this.engravingLines.length<=0,this.addToCartButton.textContent=this.addToCartButtonText(this.calculateTotalPrice()),this.addToCartButton.setAttribute("aria-label","product"===n?"Add personalized item to cart":"Update personalization and return to cart");const g=async()=>{const i=this.engravingLines.map(t=>t.trim().toUpperCase()).filter(t=>t&&t.length>0);if("product"===n&&this.fulfillmentId&&this.partNumber){const n=this.store.get("products."+t);await this.commands.product.addToCart(t,{upc:n.sizes[n.selectedSizeId].upc,fulfillmentId:this.fulfillmentId,partNumber:this.partNumber,quantity:1,engravingLines:i,identifier:t}),await this.commands.product.closeProductDrawer(t)}"cart"===n&&(await this.commands.cart.updateItemEngraving(t,i),this.commands.ui.openDrawer(o.CART))};return this.addToCartButton.addEventListener("click",g),this.addToCartButton.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),g())}),i.appendChild(this.addToCartButton),i}template(){const t=[],n=this.productInformationSection();if(t.push(n),"product"===this.params.context){const n=this.retailersSection();t.push(n)}const i=this.engravingLinesSection();t.push(i);const o=this.actionButtonsSection();t.push(o);const r=document.createElement("p");return r.className="engraving-disclaimer",r.innerHTML="Personalized orders require up to 10 business days to be processed and then shipped. Tracking information will be provided once processed. <b>Personalized bottle orders cannot be cancelled.</b>",t.push(r),t}}class EngravingViewComponent extends BaseComponent{get hostClasses(){const t=this.getConfigs("global");return["engraving-view-container",t.layout.personalizationCardStyle,this.params.context]}engravingQuantityFee(){const t=this.params.identifier;if("cart"===this.params.context){const n=this.getStoreValue("cart.items."+t),i=(null==n?void 0:n.attributes.engraving.fee)||0,o=(null==n?void 0:n.quantity)||1;return{quantity:o,fee:i,total:i*o}}if("checkout"===this.params.context){const n=this.getStoreValue("checkout.items."+t),i=(null==n?void 0:n.attributes.engraving.fee)||0,o=(null==n?void 0:n.quantity)||1;return{quantity:o,fee:i,total:i*o}}return{quantity:0,fee:0,total:0}}engravingLines(){const t=this.params.identifier;if("cart"===this.params.context){const n=this.getStoreValue("cart.items."+t);return(null==n?void 0:n.attributes.engraving.lines)||[]}if("checkout"===this.params.context){const n=this.getStoreValue("checkout.items."+t);return(null==n?void 0:n.attributes.engraving.lines)||[]}return[]}handleEdit(){var t,n,i,r,s,a,l,c,d,u,h,p,m,f,b,w,C,k,S,E;const _=this.params.identifier,D={identifier:_,context:this.params.context,lines:[],maxLines:1,maxCharsPerLine:16,fee:0,location:""};if("cart"===this.params.context){const o=this.getStoreValue("cart.items."+_);D.lines=(null===(n=null===(t=null==o?void 0:o.attributes)||void 0===t?void 0:t.engraving)||void 0===n?void 0:n.lines)||[],D.maxLines=(null===(r=null===(i=null==o?void 0:o.attributes)||void 0===i?void 0:i.engraving)||void 0===r?void 0:r.maxLines)||1,D.maxCharsPerLine=(null===(a=null===(s=null==o?void 0:o.attributes)||void 0===s?void 0:s.engraving)||void 0===a?void 0:a.maxCharsPerLine)||16,D.fee=(null===(c=null===(l=null==o?void 0:o.attributes)||void 0===l?void 0:l.engraving)||void 0===c?void 0:c.fee)||0,D.location=(null===(u=null===(d=null==o?void 0:o.attributes)||void 0===d?void 0:d.engraving)||void 0===u?void 0:u.location)||""}if("checkout"===this.params.context){const t=this.getStoreValue("checkout.items."+_);D.lines=(null===(p=null===(h=null==t?void 0:t.attributes)||void 0===h?void 0:h.engraving)||void 0===p?void 0:p.lines)||[],D.maxLines=(null===(f=null===(m=null==t?void 0:t.attributes)||void 0===m?void 0:m.engraving)||void 0===f?void 0:f.maxLines)||1,D.maxCharsPerLine=(null===(w=null===(b=null==t?void 0:t.attributes)||void 0===b?void 0:b.engraving)||void 0===w?void 0:w.maxCharsPerLine)||16,D.fee=(null===(k=null===(C=null==t?void 0:t.attributes)||void 0===C?void 0:C.engraving)||void 0===k?void 0:k.fee)||0,D.location=(null===(E=null===(S=null==t?void 0:t.attributes)||void 0===S?void 0:S.engraving)||void 0===E?void 0:E.location)||""}this.commands.ui.openDrawer(o.ENGRAVING_FORM,D)}async handleRemove(){const t=this.params.identifier;"cart"===this.params.context&&await this.commands.cart.updateItemEngraving(t,[]),"checkout"===this.params.context&&await this.commands.checkout.removeItemEngraving(t)}template(){const t=this.engravingQuantityFee(),n=this.engravingLines();if(0===n.length)return"";const i=document.createElement("div");i.className="engraving-header";const o=document.createElement("h3");o.textContent="Personalization";const r=document.createElement("span");if(r.className="engraving-fee",1===t.quantity&&(r.textContent=formatCentToDollarText(t.total,![])),t.quantity>1){r.textContent=formatCentToDollarText(t.total,![]);const n=document.createElement("span");n.className="engraving-fee-each",n.textContent=" ("+formatCentToDollarText(t.fee,![])+" ea)",r.appendChild(n)}i.appendChild(o),i.appendChild(r);const s=document.createElement("div");s.className="engraving-body";const a=document.createElement("div");a.className="engraving-lines";for(const d of n){const t=document.createElement("span");t.className="engraving-line",t.textContent=d,a.appendChild(t)}const l=document.createElement("div");l.className="engraving-actions";const c=document.createElement("button");c.type="button",c.classList.add("remove-button"),c.textContent="Remove",c.setAttribute("aria-label","Remove engraving");const G=async()=>{await this.handleRemove()};if(c.addEventListener("click",G),c.addEventListener("keydown",async t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),await G())}),l.appendChild(c),"checkout"!==this.params.context){const t=document.createElement("button");t.type="button",t.classList.add("edit-button"),t.textContent="Edit",t.setAttribute("aria-label","Edit engraving"),t.addEventListener("click",this.handleEdit.bind(this)),t.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),this.handleEdit())}),l.appendChild(t)}return s.appendChild(a),s.appendChild(l),[i,s]}}class BirthdateInputComponent extends BaseComponent{constructor(){super(...arguments),this.validationTimeout=null}get hostClasses(){const t=this.getConfigs("global");return["custom-input","birthdate",t.layout.inputFieldStyle]}afterRender(){this.monthInput=this.container.querySelector('input[data-field="month"]'),this.dayInput=this.container.querySelector('input[data-field="day"]'),this.yearInput=this.container.querySelector('input[data-field="year"]'),this.errorContainer=this.container.querySelector("div.error-container"),this.setupEventListeners(),this.populateInitialValue()}populateInitialValue(){if(this.params.value){const t=this.params.value.split("-");3===t.length&&(this.yearInput.value=t[0],this.monthInput.value=t[1],this.dayInput.value=t[2])}}setupEventListeners(){this.monthInput.addEventListener("input",t=>{this.formatMonth(t),this.handleNavigation(t,this.dayInput),this.handleChange()}),this.dayInput.addEventListener("input",t=>{this.formatDay(t),this.handleNavigation(t,this.yearInput),this.handleChange()}),this.yearInput.addEventListener("input",t=>{this.formatYear(t),this.handleChange()}),this.monthInput.addEventListener("blur",()=>{this.padMonthOnBlur(),this.validateInput()}),this.dayInput.addEventListener("blur",()=>{this.padDayOnBlur(),this.validateInput()}),this.yearInput.addEventListener("blur",()=>{this.validateInput()});const t=[this.monthInput,this.dayInput,this.yearInput];for(const n of t)n.addEventListener("focus",()=>this.clearErrors());this.dayInput.addEventListener("keydown",t=>{"Backspace"===t.key&&""===this.dayInput.value&&0===this.dayInput.selectionStart&&(this.monthInput.focus(),this.monthInput.setSelectionRange(this.monthInput.value.length,this.monthInput.value.length))}),this.yearInput.addEventListener("keydown",t=>{"Backspace"===t.key&&""===this.yearInput.value&&0===this.yearInput.selectionStart&&(this.dayInput.focus(),this.dayInput.setSelectionRange(this.dayInput.value.length,this.dayInput.value.length))})}formatMonth(t){const n=t.target;let i=n.value.replace(/\D/g,"");if(i.length>2&&(i=i.substring(0,2)),1===i.length){const t=Number.parseInt(i,10);t>=2&&t<=9&&(i="0"+i)}else if(2===i.length){const t=Number.parseInt(i,10);t>12?i="12":t<1&&"00"!==i&&(i="01")}n.value=i}formatDay(t){const n=t.target;let i=n.value.replace(/\D/g,"");if(i.length>2&&(i=i.substring(0,2)),1===i.length){const t=Number.parseInt(i,10);t>=4&&t<=9&&(i="0"+i)}else if(2===i.length){const t=Number.parseInt(i,10);t>31?i="31":t<1&&"00"!==i&&(i="01")}n.value=i}formatYear(t){const n=t.target;let i=n.value.replace(/\D/g,"");i.length>4&&(i=i.substring(0,4)),n.value=i}padMonthOnBlur(){const t=this.monthInput.value;if(1===t.length){const n=Number.parseInt(t,10);if(n>=0&&n<=9&&(this.monthInput.value="0"+t,this.params.onChange)){const t=this.getFormattedValue();this.params.onChange(t)}}}padDayOnBlur(){const t=this.dayInput.value;if(1===t.length){const n=Number.parseInt(t,10);if(n>=0&&n<=9&&(this.dayInput.value="0"+t,this.params.onChange)){const t=this.getFormattedValue();this.params.onChange(t)}}}handleNavigation(t,n){const i=t.target,o=i===this.yearInput?4:2;i.value.length===o&&n&&n.focus()}handleChange(){if(this.clearErrors(),this.scheduleValidation(),this.params.onChange){const t=this.getFormattedValue();this.params.onChange(t)}}isFieldsComplete(){const t=this.monthInput.value,n=this.dayInput.value,i=this.yearInput.value;return 2===t.length&&2===n.length&&4===i.length}scheduleValidation(){if(null!==this.validationTimeout&&clearTimeout(this.validationTimeout),this.isFieldsComplete())return this.validateInput(),void 0;this.validationTimeout=setTimeout(()=>{this.validateInput(),this.validationTimeout=null},500)}getFormattedValue(){const t=this.monthInput.value.padStart(2,"0"),n=this.dayInput.value.padStart(2,"0"),i=this.yearInput.value;return t&&n&&i&&4===i.length?i+"-"+t+"-"+n:""}validateDate(t,n,i){if(!t||!n||!i||4!==i.length)return![];const o=Number.parseInt(t,10),r=Number.parseInt(n,10),s=Number.parseInt(i,10);if(o<1||o>12||r<1||r>31||s<1e3)return![];const a=new Date(s,o-1,r);return a.getFullYear()===s&&a.getMonth()===o-1&&a.getDate()===r}calculateAge(t){const n=new Date;let i=n.getFullYear()-t.getFullYear();const o=n.getMonth()-t.getMonth();return(o<0||0===o&&n.getDate()<t.getDate())&&i--,i}validateInput(){const t=this.monthInput.value,n=this.dayInput.value,i=this.yearInput.value,o=[],r=this.params.validation;if(!r)return this.showErrors([]),!![];const s=2===t.length&&2===n.length&&4===i.length,a=t||n||i;if(r.required&&!a)o.push("Please enter a complete date (MM/DD/YYYY)");else if(a&&!s)o.push("Please enter a complete date (MM/DD/YYYY)");else if(s)if(this.validateDate(t,n,i)){const s=Number.parseInt(t,10),a=Number.parseInt(n,10),l=Number.parseInt(i,10),c=new Date(l,s-1,a);if(void 0!==r.minYear&&l<r.minYear&&o.push("Year must be "+r.minYear+" or later"),void 0!==r.maxYear&&l>r.maxYear&&o.push("Year must be "+r.maxYear+" or earlier"),void 0!==r.minAge||void 0!==r.maxAge){const t=this.calculateAge(c);void 0!==r.minAge&&t<r.minAge&&o.push("Must be at least "+r.minAge+" years old"),void 0!==r.maxAge&&t>r.maxAge&&o.push("Must be no more than "+r.maxAge+" years old")}if(r.customValidator){const t=r.customValidator(this.getFormattedValue());t&&o.push(t)}}else o.push("Please enter a valid date");this.showErrors(o);const l=0===o.length;return this.params.onValidation&&this.params.onValidation(l,o),l}showErrors(t){this.errorContainer.innerHTML="";const n=[this.monthInput,this.dayInput,this.yearInput];if(t.length>0){this.errorContainer.classList.add("show");for(const t of n)t.classList.add("input-error");for(const n of t){const t=document.createElement("div");t.className="error-message",t.textContent=n,this.errorContainer.appendChild(t)}}else for(const i of n)i.classList.remove("input-error")}clearErrors(){const t=[this.monthInput,this.dayInput,this.yearInput],n=t.some(t=>t.classList.contains("input-error"));if(n){for(const n of t)n.classList.remove("input-error");this.errorContainer.innerHTML="",this.errorContainer.classList.remove("show")}}getValue(){return this.getFormattedValue()}setValue(t){if(t){const n=t.split("/");3===n.length&&(this.monthInput.value=n[0],this.dayInput.value=n[1],this.yearInput.value=n[2])}else this.monthInput.value="",this.dayInput.value="",this.yearInput.value=""}validate(){return this.validateInput()}focus(){this.monthInput.focus()}disable(){this.monthInput.disabled=!![],this.dayInput.disabled=!![],this.yearInput.disabled=!![]}enable(){this.monthInput.disabled=![],this.dayInput.disabled=![],this.yearInput.disabled=![]}clear(){this.setValue(""),this.clearErrors()}template(){var t;const n=[];if(this.params.label){const i=document.createElement("label");i.textContent=this.params.label,(null===(t=this.params.validation)||void 0===t?void 0:t.required)&&(i.textContent+="*"),i.setAttribute("for",this.params.name+"-month"),n.push(i)}const i=document.createElement("div");i.className="date-input-container";const o=document.createElement("input");o.type="text",o.placeholder="MM",o.name=this.params.name+"-month",o.id=this.params.name+"-month",o.maxLength=2,o.className="date-field month-field",o.setAttribute("data-field","month"),o.inputMode="numeric";const r=document.createElement("span");r.className="date-separator",r.textContent="/";const s=document.createElement("input");s.type="text",s.placeholder="DD",s.name=this.params.name+"-day",s.id=this.params.name+"-day",s.maxLength=2,s.className="date-field day-field",s.setAttribute("data-field","day"),s.inputMode="numeric";const a=document.createElement("span");a.className="date-separator",a.textContent="/";const l=document.createElement("input");l.type="text",l.placeholder="YYYY",l.name=this.params.name+"-year",l.id=this.params.name+"-year",l.maxLength=4,l.className="date-field year-field",l.setAttribute("data-field","year"),l.inputMode="numeric",this.params.disabled&&(o.disabled=!![],s.disabled=!![],l.disabled=!![]),this.params.className&&(i.className+=" "+this.params.className),i.appendChild(o),i.appendChild(r),i.appendChild(s),i.appendChild(a),i.appendChild(l);const c=document.createElement("div");return c.className="error-container",n.push(i),n.push(c),n}}class InputComponent extends BaseComponent{constructor(){super(...arguments),this.validationTimeout=null}get hostClasses(){const t=this.getConfigs("global");return["custom-input",t.layout.inputFieldStyle]}handlePhoneKeydown(t){if("Backspace"===t.key){const n=t.target,i=n.selectionStart||0,o=n.value;i>0&&/\D/.test(o[i-1])&&setTimeout(()=>{const t=Math.max(0,i-2);n.setSelectionRange(t,t)},0)}}formatPhoneNumber(t){const n=t.target;let i=n.value.replace(/\D/g,"");i.length>10&&(i=i.substring(0,10)),i.length>=6?i="("+i.substring(0,3)+") "+i.substring(3,6)+"-"+i.substring(6):i.length>=3&&(i="("+i.substring(0,3)+") "+i.substring(3)),n.value=i}formatDate(t){const n=t.target;let i=n.value.replace(/\D/g,"");i.length>8&&(i=i.substring(0,8)),i.length>=5?i=i.substring(0,2)+"/"+i.substring(2,4)+"/"+i.substring(4):i.length>=3&&(i=i.substring(0,2)+"/"+i.substring(2)),n.value=i}validateEmail(t){const n=/^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;return n.test(t)}validateTel(t){const n=/^\(\d{3}\) \d{3}-\d{4}$/;return n.test(t)}validateDate(t){const n=/^(0[1-9]|1[0-2])\/(0[1-9]|[12]\d|3[01])\/\d{4}$/;if(!n.test(t))return![];const[i,o,r]=t.split("/").map(Number),s=new Date(r,i-1,o);return s.getFullYear()===r&&s.getMonth()===i-1&&s.getDate()===o}isFieldComplete(){var t,n,i;const o=this.inputElement.value.trim();if(!o)return![];switch(this.params.inputType){case"tel":return this.validateTel(o);case"date":return this.validateDate(o);case"email":return o.includes("@")&&(null===(t=o.split("@")[1])||void 0===t?void 0:t.includes("."));case"number":return!Number.isNaN(Number.parseFloat(o));default:return(null===(n=this.params.validation)||void 0===n?void 0:n.max)&&o.length>=this.params.validation.max||(null===(i=this.params.validation)||void 0===i?void 0:i.min)&&o.length>=this.params.validation.min?!![]:o.length>=3}}validateInput(){const t=this.inputElement.value,n=[],i=this.params.validation;if(!i)return this.showErrors([]),!![];if(i.required&&!t.trim()&&n.push("This field is required"),!i.required&&!t.trim())return this.showErrors([]),!![];if(t.trim()){if("email"!==this.params.inputType||this.validateEmail(t)||n.push("Please enter a valid email address"),"tel"!==this.params.inputType||this.validateTel(t)||n.push("Please enter a valid phone number ((XXX) XXX-XXXX)"),"date"!==this.params.inputType||this.validateDate(t)||n.push("Please enter a valid date (MM/DD/YYYY)"),"number"===this.params.inputType){const o=Number.parseFloat(t);Number.isNaN(o)?t.trim()&&n.push("Please enter a valid number"):(void 0!==i.min&&o<i.min&&n.push("Value must be at least "+i.min),void 0!==i.max&&o>i.max&&n.push("Value must be no more than "+i.max))}if("text"!==this.params.inputType&&"email"!==this.params.inputType||(void 0!==i.min&&t.length<i.min&&n.push("Must be at least "+i.min+" characters"),void 0!==i.max&&t.length>i.max&&n.push("Must be no more than "+i.max+" characters")),i.pattern){const o=new RegExp(i.pattern);o.test(t)||n.push("Invalid format")}if(i.customValidator){const o=i.customValidator(t);o&&n.push(o)}}this.showErrors(n);const o=0===n.length;return this.params.onValidation&&this.params.onValidation(o,n),o}scheduleValidation(){if(null!==this.validationTimeout&&clearTimeout(this.validationTimeout),this.isFieldComplete())return this.validateInput(),void 0;this.validationTimeout=setTimeout(()=>{this.validateInput(),this.validationTimeout=null},500)}showErrors(t){if(this.errorContainer.innerHTML="",t.length>0){this.errorContainer.classList.add("show"),this.inputElement.classList.add("input-error");for(const n of t){const t=document.createElement("div");t.className="error-message",t.textContent=n,this.errorContainer.appendChild(t)}}else this.inputElement.classList.remove("input-error")}clearErrors(){this.inputElement.classList.contains("input-error")&&(this.inputElement.classList.remove("input-error"),this.errorContainer.innerHTML="",this.errorContainer.classList.remove("show"))}getValue(){return this.inputElement.value}setValue(t){this.inputElement.value=t,"tel"===this.params.inputType&&this.formatPhoneNumber({target:this.inputElement}),"date"===this.params.inputType&&this.formatDate({target:this.inputElement})}validate(){return this.validateInput()}focus(){this.inputElement.focus()}disable(){this.inputElement.disabled=!![]}enable(){this.inputElement.disabled=![]}template(){var t;const n=[];if(this.params.label){const i=document.createElement("label");i.textContent=this.params.label,(null===(t=this.params.validation)||void 0===t?void 0:t.required)&&(i.textContent+="*"),i.setAttribute("for",this.params.name),n.push(i)}return this.inputElement=document.createElement("input"),this.inputElement.type=this.params.inputType,this.inputElement.placeholder=this.params.placeholder||"",this.inputElement.name=this.params.name,this.inputElement.id=this.params.name,this.params.autocomplete&&(this.inputElement.autocomplete=this.params.autocomplete?"on":"off"),this.params.className&&(this.inputElement.className=this.params.className),this.params.hostClassName&&this.addHostClasses(this.params.hostClassName),this.params.disabled&&(this.inputElement.disabled=!![]),this.params.value&&(this.inputElement.value=this.params.value),this.params.validation&&(this.params.validation.required&&(this.inputElement.required=!![]),void 0!==this.params.validation.min&&(this.inputElement.min=this.params.validation.min.toString()),void 0!==this.params.validation.max&&(this.inputElement.max=this.params.validation.max.toString()),this.params.validation.pattern&&(this.inputElement.pattern=this.params.validation.pattern)),"tel"===this.params.inputType&&(this.inputElement.addEventListener("keydown",this.handlePhoneKeydown.bind(this)),this.inputElement.addEventListener("input",this.formatPhoneNumber.bind(this))),"date"===this.params.inputType&&this.inputElement.addEventListener("input",this.formatDate.bind(this)),this.inputElement.addEventListener("focusout",this.validateInput.bind(this)),this.inputElement.addEventListener("input",t=>{this.clearErrors(),this.scheduleValidation(),this.params.onChange&&this.params.onChange(t.target.value)}),this.errorContainer=document.createElement("div"),this.errorContainer.className="error-container",n.push(this.inputElement),n.push(this.errorContainer),n}}class LceElementComponent extends HTMLElement{constructor(){super(),this.A=![],this.U=null;const t=ClientConfigService.getInstance();this.V=this.attachShadow({mode:t.get("openShadowDom")?"open":"closed"})}initialize(t,n){if(this.A)return;if(!t||"string"!=typeof t)throw new SDKError("LceElementComponent: contentType must be a non-empty string");if(!(n&&n instanceof HTMLElement))throw new SDKError("LceElementComponent: contentElement must be a valid HTMLElement");if(this.setAttribute(t.toLowerCase(),""),!this.V)throw new SDKError("LceElementComponent: Shadow DOM container is not available");n&&"function"==typeof n.rerender&&(this.U=t=>{n.rerender(t||"LceElementRerender")}),this.V.appendChild(n),this.applyBasicStyles();const i=ThemeProviderService.getInstance(),o=i.getStylesheet(t);this.applyThemeStyles(o),this.A=!![],this.V=null}rerender(t){this.U&&this.U(t)}applyBasicStyles(){const t="\n :host {\n display: block;\n contain: layout style paint;\n isolation: isolate;\n width: 100%;\n height: auto;\n }\n\n :host([drawer]),\n :host([address]),\n :host([buttons-cart-open]) {\n contain: none;\n isolation: auto;\n }\n ";try{if(this.isCSSStyleSheetSupported()){const n=new CSSStyleSheet;n.replaceSync(t),this.V.adoptedStyleSheets=[n,...this.V.adoptedStyleSheets]}else this.createFallbackStylesheet(t)}catch(X){this.createFallbackStylesheet(t)}}isCSSStyleSheetSupported(){try{if("undefined"==typeof CSSStyleSheet)return![];if("function"!=typeof CSSStyleSheet.prototype.replaceSync)return![];const t=new CSSStyleSheet;return t.replaceSync("/* test */"),!![]}catch(t){return![]}}applyThemeStyles(t){t.forEach(t=>{"string"==typeof t?this.createFallbackStylesheet(t):this.V.adoptedStyleSheets=[...this.V.adoptedStyleSheets,t]})}createFallbackStylesheet(t){const n=document.createElement("style");n.textContent=t,this.V&&this.V.appendChild(n)}}class PoweredByComponent extends BaseComponent{get hostClasses(){return["powered-by-container",this.params.context,this.getConfigs("global").layout.poweredByMode]}createPoweredBySection(){const t=document.createElement("div");t.className="pb-title-container";const n=document.createElement("span");n.className="pb-text",n.textContent="Powered by",t.appendChild(n);const i=document.createElement("span");i.className="pb-lc",i.textContent="LiquidCommerce",t.appendChild(i);const o=document.createElement("span");return o.className="pb-dot",o.textContent=".",t.appendChild(o),t}createDisclaimerSection(){const t=document.createElement("div");t.className="pb-disclaimer-container";const n=this.getDisclaimerConfig();return n.parts.forEach(n=>{"text"===n.type?t.appendChild(document.createTextNode(n.content)):"link"===n.type&&t.appendChild(this.createLink(n.href,n.text))}),t}getDisclaimerConfig(){return"checkout"===this.params.context?{parts:[{type:"text",content:"All orders are fulfilled by LiquidCommerce, which is owned and operated by ReserveBar Holdings Corp., an independent third party that facilitates transactions between customers and licensed retailers. By placing an order, you agree to "},{type:"link",href:"https://www.reservebar.com/privacy-policy.html",text:"LiquidCommerce's Privacy Policy"},{type:"text",content:" and "},{type:"link",href:"https://www.reservebar.com/terms-conditions",text:"Terms and Conditions of Sale"},{type:"text",content:"."}]}:{parts:[{type:"text",content:"LiquidCommerce is owned & operated by ReserveBar. See our "},{type:"link",href:"https://www.reservebar.com/privacy-policy.html",text:"Privacy Policy"},{type:"text",content:" and "},{type:"link",href:"https://www.reservebar.com/terms-conditions",text:"Terms & Conditions"},{type:"text",content:"."}]}}createLink(t,n){const i=document.createElement("a");return i.href=t,i.target="_blank",i.rel="noopener noreferrer",i.className="pb-link",i.textContent=n,i.setAttribute("role","link"),i.setAttribute("aria-label","Read "+n),i}template(){const t=this.createPoweredBySection(),n=this.createDisclaimerSection();return[t,n]}}class PromoCodeTickerComponent extends BaseComponent{constructor(){super(...arguments),this.applyButton=null,this.promoCodeApplied=![],this.currentActiveTicker=null}get hostClasses(){return["promo-ticker",this.params.context]}beforeSetupStoreWatchers(){this.reactiveOptions.watchOnlyStorePaths=["cart.promoCode","checkout.promoCode"]}onStoreWatch(t){const n=t.find(t=>"cart.promoCode"===t.path||"checkout.promoCode"===t.path);if(!n||!this.applyButton||!this.currentActiveTicker)return;const i=this.isPromoCodeApplied(this.currentActiveTicker.promoCode);i&&!this.promoCodeApplied?(this.applyButton.disabled=!![],this.applyButton.textContent="APPLIED",this.promoCodeApplied=!![]):!i&&this.promoCodeApplied&&(this.applyButton.disabled=![],this.applyButton.textContent="APPLY",this.promoCodeApplied=![])}isPromoCodeApplied(t){const n=this.store.get("cart.promoCode"),i=this.store.get("checkout.promoCode");return(null==n?void 0:n.code)===t||(null==i?void 0:i.code)===t}getActiveTickers(){var t;const n=this.store.get("address");return null===(t=this.params.tickers)||void 0===t?void 0:t.filter(t=>{var i;return isDateTimeInRange({startDate:t.activeFrom,endDate:t.activeUntil,addressState:null===(i=null==n?void 0:n.address)||void 0===i?void 0:i.state})})}selectCurrentTicker(t){return 0===t.length?null:t[0]}generateTextContent(t){const n=document.createElement("div");n.classList.add("promo-ticker__text-group");const i=t.text.map(t=>t.trim()).map(t=>t.substring(0,50)).filter(t=>""!==t.trim()).slice(0,5);for(const o of i){const i=o.trim();if(!i)continue;const r=document.createElement("span");r.classList.add("promo-ticker__text-item"),r.textContent=i,n.appendChild(r);const s=document.createElement("span");s.classList.add("promo-ticker__separator"),s.textContent=t.separator,n.appendChild(s)}return n}async handlePromoClick(){var t;(null===(t=this.currentActiveTicker)||void 0===t?void 0:t.promoCode)&&("cart"===this.params.context&&await this.commands.cart.applyPromoCode(this.currentActiveTicker.promoCode),"checkout"===this.params.context&&await this.commands.checkout.applyPromoCode(this.currentActiveTicker.promoCode))}template(){const t=this.getActiveTickers();if(this.currentActiveTicker=this.selectCurrentTicker(t),!this.currentActiveTicker)return[];this.promoCodeApplied=this.isPromoCodeApplied(this.currentActiveTicker.promoCode);const n=document.createElement("div");n.classList.add("promo-ticker__content");const i=document.createElement("div");i.classList.add("promo-ticker__track");for(let r=0;r<5;r++)i.appendChild(this.generateTextContent(this.currentActiveTicker));n.appendChild(i);const o=document.createElement("button");return o.type="button",o.classList.add("promo-ticker__cta"),o.textContent="APPLY",o.setAttribute("aria-label","Apply promo code"),this.promoCodeApplied&&(o.disabled=!![],o.textContent="APPLIED"),o.addEventListener("click",()=>this.handlePromoClick()),o.addEventListener("keydown",t=>{"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),this.handlePromoClick())}),this.applyButton=o,[n,o]}}const kt=LoggerFactory.get("ElementsClientHelper"),isObject=t=>null!==t&&"object"==typeof t&&!Array.isArray(t),getType=t=>null===t?"null":Array.isArray(t)?"array":typeof t;function deepMergeConfigs(t,n){if(!t||!n)return t;const i={...t},o=[];for(const r in n){const s=n[r],a=i[r];if(!(r in t)){o.push('Property "'+r+'" does not exist in target schema, skipping merge.');continue}const l=getType(s),c=getType(a);l===c?isObject(s)&&isObject(a)?i[r]=deepMergeConfigs(a,s):i[r]=s:o.push('Type mismatch for key "'+r+'": source is '+l+", target is "+c+". Skipping merge.")}return o.length>0&&kt.warn("Merging configurations with warnings:",o),i}const St=new Map([["global.layout.enablePersonalization",[o.PRODUCT,o.CART,o.CHECKOUT,o.ENGRAVING_FORM,o.ENGRAVING_VIEW,o.PRODUCT_INTERACTIONS,o.CART_ITEM,o.CHECKOUT_ITEM]],["global.layout.personalizationText",[o.PRODUCT,o.CART,o.CHECKOUT,o.ENGRAVING_FORM,o.ENGRAVING_VIEW,o.CART_ITEM]],["global.layout.personalizationCardStyle",[o.PRODUCT,o.CART,o.CHECKOUT,o.ENGRAVING_FORM,o.ENGRAVING_VIEW]],["global.layout.allowPromoCodes",[o.CART,o.CART_PROMO_CODE,o.CART_FOOTER,o.CHECKOUT_ORDER_SUMMARY,o.CHECKOUT_PC_GC]],["global.layout.inputFieldStyle",[o.CART,o.CHECKOUT,o.ADDRESS,o.INPUT,o.BIRTHDATE_INPUT,o.ADDRESS_INPUT,o.CHECKOUT_DELIVER_TO,o.CHECKOUT_BUYER,o.CHECKOUT_BILLING,o.CHECKOUT_PAYMENT,o.CART_PROMO_CODE]],["global.layout.showPoweredBy",[o.CART,o.CHECKOUT,o.CHECKOUT_COMPLETED,o.POWERED_BY,o.CART_FOOTER,o.CHECKOUT_ORDER_SUMMARY,o.CHECKOUT_PRESALE_EXPIRED]],["global.layout.poweredByMode",[o.POWERED_BY]],["product.layout.showImages",[o.PRODUCT,o.PRODUCT_IMAGE_CAROUSEL]],["product.layout.showTitle",[o.PRODUCT]],["product.layout.showDescription",[o.PRODUCT,o.PRODUCT_DESCRIPTION,o.PRODUCT_INTERACTIONS]],["product.layout.showQuantityCounter",[o.PRODUCT,o.PRODUCT_ADD_TO_CART_SECTION]],["product.layout.showOffHours",[o.PRODUCT,o.PRODUCT_RETAILERS,o.PRODUCT_RETAILERS_CAROUSEL,o.PRODUCT_RETAILERS_POPUP,o.PRODUCT_RETAILERS_POPUP_LIST]],["product.layout.quantityCounterStyle",[o.PRODUCT,o.PRODUCT_ADD_TO_CART_SECTION]],["product.layout.fulfillmentDisplay",[o.PRODUCT,o.PRODUCT_IMAGE_CAROUSEL,o.PRODUCT_RETAILERS]],["product.layout.enableShippingFulfillment",[o.PRODUCT,o.PRODUCT_RETAILERS,o.PRODUCT_RETAILERS_CAROUSEL,o.PRODUCT_RETAILERS_POPUP,o.PRODUCT_RETAILERS_POPUP_LIST]],["product.layout.enableOnDemandFulfillment",[o.PRODUCT,o.PRODUCT_RETAILERS,o.PRODUCT_RETAILERS_CAROUSEL,o.PRODUCT_RETAILERS_POPUP,o.PRODUCT_RETAILERS_POPUP_LIST]],["product.layout.addToCartButtonText",[o.PRODUCT,o.PRODUCT_ADD_TO_CART_SECTION,o.ENGRAVING_FORM]],["product.layout.addToCartButtonShowTotalPrice",[o.PRODUCT,o.PRODUCT_ADD_TO_CART_SECTION,o.ENGRAVING_FORM]],["product.layout.buyNowButtonText",[o.PRODUCT,o.PRODUCT_OPTIONS]],["product.layout.preSaleButtonText",[o.PRODUCT,o.PRODUCT_ADD_TO_CART_SECTION]],["cart.layout.showQuantityCounter",[o.CART,o.CART_ITEM_QUANTITY_PRICE]],["cart.layout.quantityCounterStyle",[o.CART,o.CART_ITEM_QUANTITY_PRICE]],["cart.layout.drawerHeaderText",[o.CART,o.CART_HEADER]],["cart.layout.goToCheckoutButtonText",[o.CART,o.CART_FOOTER]],["checkout.layout.emailOptIn",[o.CHECKOUT,o.CHECKOUT_ORDER_SUMMARY]],["checkout.layout.smsOptIn",[o.CHECKOUT,o.CHECKOUT_ORDER_SUMMARY]],["checkout.layout.allowGiftCards",[o.CHECKOUT,o.CHECKOUT_GIFT_CARDS,o.CHECKOUT_ORDER_SUMMARY,o.CHECKOUT_PC_GC]],["checkout.layout.legalMessage",[o.CHECKOUT,o.CHECKOUT_ORDER_SUMMARY,o.CHECKOUT_COMPLETED]],["checkout.layout.exitUrl",[o.CHECKOUT,o.CHECKOUT_COMPLETED]],["checkout.layout.thankYouButtonText",[o.CHECKOUT,o.CHECKOUT_COMPLETED]],["checkout.layout.drawerHeaderText",[o.CHECKOUT,o.CHECKOUT_HEADER]],["checkout.layout.placeOrderButtonText",[o.CHECKOUT,o.CHECKOUT_PLACE_ORDER_BUTTON]],["checkout.layout.checkoutCompleted",[o.CHECKOUT_COMPLETED]]]);function getComponentTypesForLayoutFields(t,n){const i=new Set;for(const o of Object.keys(n)){const n=St.get(t+"."+o);if(n)for(const t of n)i.add(t)}return Array.from(i)}class ElementsBaseClient{constructor(t){this.clientPrepared=![],this.componentFactoryInitialized=![],this.cartDrawerCreated=![],this.injectedComponents=new Map,this.clientConfig=ClientConfigService.getInstance(),this.store=StoreService.getInstance(),this.commands=CommandService.getInstance(),this.apiClient=ApiClientService.getInstance(),this.themeProvider=ThemeProviderService.getInstance(),this.fingerPrintService=FingerPrintService.getInstance(),this.googleTagManager=GoogleTagManagerService.getInstance(),this.clientAction=ClientActionService.getInstance(),this.telemetry=TelemetryService.getInstance(),this.debugPanel=DebugPanelService.getInstance(),this.logger=LoggerFactory.get("Client"),this.authClient=AuthClientService.getInstance({apiKey:t.apiKey,env:t.env,baseUrl:t.baseUrl})}async prepare(){try{if(this.clientPrepared)return;await this.prepareEssentialServices(),this.deferHeavyInitialization(),this.clientPrepared=!![],this.clientConfig.set("clientPrepared",!![])}catch(t){throw this.logger.error("Failed to prepare client",t),this.clientPrepared=![],this.clientConfig.set("clientPrepared",![]),t}}async prepareEssentialServices(){this.clientConfig.set("version",X.version),this.clientConfig.isProduction()?LoggerFactory.setEnableLogging(![]):this.clientConfig.isDebuggingEnabled()&&(LoggerFactory.setEnableLogging(!![]),this.logger.info("🐞 Debugging mode is enabled"),this.clientConfig.isDebugPanelEnabled()&&(this.debugPanel.initialize(),this.logger.info("🔧 Debug panel initialized"))),this.telemetry.isEnabled()&&(LoggerFactory.setTelemetryService(this.telemetry),this.logger.info("📊 Telemetry initialized")),this.logger.info("🔐 Starting authentication...");const t=await this.authClient.authenticate();if(!t)throw this.clientPrepared=![],new SDKError("Authentication failed. Please try again.",!![]);this.logger.info("✅ Authentication completed"),this.logger.info("🌐 Setting up API client..."),await this.apiClient.setClient(this.authClient),this.logger.info("✅ API client setup completed"),this.logger.info("⚙️ Loading configurations...");let n=await this.apiClient.getAllConfigs();this.logger.info("✅ Configurations loaded"),this.clientConfig.set("partnerCode",n.configurations.partnerCode),this.clientConfig.set("partnerName",n.configurations.partnerName),this.logger.info("🔍 Setting up fingerprinting and store...");const i=await this.fingerPrintService.getId(n.configurations.partnerCode),o=this.fingerPrintService.isLocalStorageWebApiAvailable();this.clientConfig.set("userDeviceId",i),this.clientConfig.set("isLocalStorageAvailable",o);const r=o?null:await this.apiClient.getPersistedStore(i);if(await this.store.initialize({userDeviceId:i,isLocalStorageAvailable:o,persistedStore:r}),this.logger.info("✅ Store setup completed"),this.logger.info("🎨 Initializing theme provider..."),this.clientConfig.hasCustomTheme()){const t=this.clientConfig.get("customTheme"),i=n.global.layout.showPoweredBy;n=deepMergeConfigs(n,t),n.global.layout.showPoweredBy=i}await this.themeProvider.initialize(n),this.logger.info("✅ Theme provider initialized"),this.logger.info("📦 Registering essential components..."),this.registerEssentialComponents(),this.logger.info("✅ Essential components registered"),this.logger.info("🎯 Essential services preparation completed")}deferHeavyInitialization(){setTimeout(async()=>{try{await this.initializeHeavyServices()}catch(t){this.logger.error("Heavy initialization failed",t)}},0)}async initializeHeavyServices(){const t=this.themeProvider.getConfigs("configurations");await this.googleTagManager.initialize({partnerName:t.partnerName,partnerGtmId:t.googleTagManagerId,partnerEnableGaTracking:t.enablePartnerGaTracking,liquidCommerceEnableGaTracking:t.enableLiquidCommerceGaTracking,liquidCommerceGtmId:t.liquidCommerceGoogleTagManagerId}),this.isElementsEnabled()&&await this.commands.common.loadCart(),this.ensureCartDrawerExists(),this.ensureAllComponentsRegistered()}get actions(){return this.clientAction.actions}async processInjectElement(t){if(this.ensureAllComponentsRegistered(),!t||"object"!=typeof t)throw new SDKError("Invalid parameters provided. Expected an object, received: "+typeof t,!![]);const{type:n,containerId:i,...r}=t;if(!i||"string"!=typeof i)throw new SDKError("Container ID is required and must be a string. Received: "+("string"==typeof i?'"'+i+'"':i),!![]);if(!n)throw new SDKError("Component type is required (e.g., product, cart, checkout).",!![]);const s=i.replace("#",""),a=document.getElementById(s);if(!a)return console.warn("Container with ID '"+s+"' not found"),null;a.innerHTML="";const l={type:t.type,useShadowDom:!![],isIndependentComponent:!![],wrapInLceElement:!![],...r},c=ComponentFactoryService.createElement(l);return safeReplaceChildren(a,c),t.type===o.CHECKOUT&&await this.commands.checkout.loadCheckout(),this.createInjectedComponentWrapper(s,t.type,c)}async processInjectProduct(t){if(this.ensureAllComponentsRegistered(),0===t.length)throw new SDKError("At least one product is required. Received empty array.",!![]);t.length>20&&this.logger.warn("You can only inject up to 20 products at a time, limiting to 20 products");const n=t.slice(0,20),i=[],r=[];for(const o of n){if(!o||"object"!=typeof o){this.logger.warn("Invalid product parameter: must be an object");continue}if(!o.containerId||"string"!=typeof o.containerId){this.logger.warn("Container ID is required and must be a string for product with ID '"+o.identifier+"'");continue}const t=o.containerId.replace("#","").trim();if(!t){this.logger.warn("Container ID is required for product with ID '"+o.identifier+"'");continue}const n=document.getElementById(t);if(!n){this.logger.warn("Container with ID '"+t+"' not found for product '"+o.identifier+"'");continue}const r=i.every(n=>n.containerId!==t);if(!r){this.logger.warn("Duplicate container ID '"+t+"' found, skipping");continue}if(!o.identifier||"string"!=typeof o.identifier){this.logger.warn("Product identifier is required and must be a string for container ID '"+t+"'");continue}const s=i.every(t=>t.identifier!==o.identifier);s?i.push({containerId:t,identifier:o.identifier}):this.logger.warn("Duplicate product identifier '"+o.identifier+"' found, skipping")}for(const s of i){const t=ComponentFactoryService.createElement({type:o.PRODUCT,useShadowDom:!![],productId:s.identifier,isIndependentComponent:!![],wrapInLceElement:!![]}),n=document.getElementById(s.containerId);n?(n.innerHTML="",n.appendChild(t),r.push(this.createInjectedComponentWrapper(s.containerId,o.PRODUCT,t)),await this.commands.product.createProductInstance(s.identifier,!![])):this.logger.warn("Product ("+s.identifier+") container with ID '"+s.containerId+"' not found")}return await this.commands.product.loadMultipleProducts(i.map(t=>t.identifier)),r}async injectProductList(t){if(!this.isElementsEnabled())return this.injectDisabledElementsError(t.containerId,o.CHECKOUT),void 0;if(!t)throw new SDKError("Product list requires a container ID parameter.",!![]);if(!t.containerId||"string"!=typeof t.containerId)throw new SDKError("Product list container ID is required and must be a string. Received: "+("string"==typeof t.containerId?'"'+t.containerId+'"':t.containerId),!![]);if(t.rows&&("number"!=typeof t.rows||t.rows<1||t.rows>10))throw new SDKError("Rows must be a number between 1 and 10. Received: "+t.rows,!![]);if(t.columns&&("number"!=typeof t.columns||t.columns<1||t.columns>4))throw new SDKError("Columns must be a number between 1 and 4. Received: "+t.columns,!![]);if(t.cardVariant&&!Object.values(l).includes(t.cardVariant))throw new SDKError('Invalid card variant "'+t.cardVariant+'". Valid options: '+Object.values(l).join(", "),!![]);if(t.filters&&!Array.isArray(t.filters))throw new SDKError("Filters must be an array. Received: "+typeof t.filters,!![]);if(t.filters&&t.filters.length>0){const n=Object.values(c);for(const i of t.filters)if(!n.includes(i))throw new SDKError('Invalid filter "'+i+'". Valid options: '+n.join(", "),!![])}if(t.productUrl&&"string"==typeof t.productUrl&&!t.productUrl.includes("{upc}")&&!t.productUrl.includes("{grouping}"))throw new SDKError('Product URL must include either {upc} or {grouping} placeholder. Received: "'+t.productUrl+'"',!![]);const n=document.getElementById(t.containerId.replace("#",""));if(!n)throw new SDKError('Cannot find element with ID "'+t.containerId+'". Make sure the element exists before adding the product list.',!![]);const i=ComponentFactoryService.createElement({type:o.PRODUCT_LIST,wrapInLceElement:!![],cardVariant:t.cardVariant||l.STANDARD,fillCard:t.fillCard||![],rows:t.rows||4,columns:t.columns||4,filters:t.filters||[],productUrl:t.productUrl});safeReplaceChildren(n,i)}ensureCartDrawerExists(){if(!this.cartDrawerCreated)try{const t=ComponentFactoryService.createElement({type:o.DRAWER,useShadowDom:!![],isIndependentComponent:!![],wrapInLceElement:!![]});document.body.appendChild(t),this.cartDrawerCreated=!![]}catch(t){this.logger.warn("Failed to create cart drawer:",t)}}ensureAllComponentsRegistered(){this.componentFactoryInitialized||(this.registerComponents(),this.componentFactoryInitialized=!![])}createInjectedComponentWrapper(t,n,i){const o={getType:()=>n,getElement:()=>document.getElementById(t),rerender:()=>{try{i&&"function"==typeof i.rerender?i.rerender("InjectedComponentRerender"):this.logger.warn("Component in container '"+t+"' does not support rerender")}catch(n){this.logger.warn("Failed to rerender component in container '"+t+"'")}}};return this.injectedComponents.set(t,o),o}rerenderInjectedComponentsByType(t){for(const[n,i]of this.injectedComponents)i.getType()===t&&i.rerender()}isElementsEnabled(){var t;try{const n=this.themeProvider.getConfigs("configurations");return null!==(t=null==n?void 0:n.isElementsEnabled)&&void 0!==t?t:![]}catch(n){return this.logger.warn("Could not check elements enabled status, defaulting to not enabled",n),!![]}}injectDisabledElementsError(t,n){const i=document.getElementById(t.replace("#",""));if(!i)return this.logger.warn("Container with ID '"+t+"' not found for disabled elements error"),void 0;let o;o=this.clientConfig.isProduction()?productionComponentError({title:"Element Unavailable",message:"We're sorry, this element is currently unavailable.",componentType:n}):componentError({message:"Elements is not enabled.",componentType:n}),i.innerHTML="",safeReplaceChildren(i,o)}registerEssentialComponents(){ComponentFactoryService.registerComponent(o.LCE_ELEMENT,LceElementComponent),ComponentFactoryService.registerComponent(o.DRAWER,DrawerComponent),ComponentFactoryService.registerComponent(o.BUTTONS_CART_OPEN,ButtonsOpenCartComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LOADING,ProductLoadingComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LIST_CARD_LOADING,ProductListCardLoadingComponent),ComponentFactoryService.registerComponent(o.CART,AddressInputComponent),ComponentFactoryService.registerComponent(o.ADDRESS_INPUT,AddressInputComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LIST,ProductListComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LIST_CARD,ProductListCardComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LIST_FILTERS,ProductListFiltersComponent)}registerComponents(){this.componentFactoryInitialized||this.registerAllComponents()}registerAllComponents(){ComponentFactoryService.registerComponent(o.DRAWER,DrawerComponent),ComponentFactoryService.registerComponent(o.INPUT,InputComponent),ComponentFactoryService.registerComponent(o.BIRTHDATE_INPUT,BirthdateInputComponent),ComponentFactoryService.registerComponent(o.ENGRAVING_FORM,EngravingFormComponent),ComponentFactoryService.registerComponent(o.ENGRAVING_VIEW,EngravingViewComponent),ComponentFactoryService.registerComponent(o.BUTTONS_CART_OPEN,ButtonsOpenCartComponent),ComponentFactoryService.registerComponent(o.POWERED_BY,PoweredByComponent),ComponentFactoryService.registerComponent(o.LCE_ELEMENT,LceElementComponent),ComponentFactoryService.registerComponent(o.PURCHASE_MIN_ALERT,PurchaseMinAlertComponent),ComponentFactoryService.registerComponent(o.ALERT,AlertComponent),ComponentFactoryService.registerComponent(o.PROMO_CODE_TICKER,PromoCodeTickerComponent),ComponentFactoryService.registerComponent(o.ADDRESS,AddressComponent),ComponentFactoryService.registerComponent(o.ADDRESS_INPUT,AddressInputComponent),ComponentFactoryService.registerComponent(o.ADDRESS_DISPLAY,AddressDisplayComponent),ComponentFactoryService.registerComponent(o.PRODUCT,ProductComponent),ComponentFactoryService.registerComponent(o.PRODUCT_IMAGE_CAROUSEL,ProductImageCarouselComponent),ComponentFactoryService.registerComponent(o.PRODUCT_OPTIONS,ProductOptionsComponent),ComponentFactoryService.registerComponent(o.PRODUCT_DESCRIPTION,ProductDescriptionComponent),ComponentFactoryService.registerComponent(o.PRODUCT_INTERACTIONS,ProductInteractionsComponent),ComponentFactoryService.registerComponent(o.PRODUCT_ADD_TO_CART_SECTION,ProductAddToCartSectionComponent),ComponentFactoryService.registerComponent(o.PRODUCT_RETAILERS,ProductRetailersComponent),ComponentFactoryService.registerComponent(o.PRODUCT_RETAILERS_CAROUSEL,ProductRetailersCarouselComponent),ComponentFactoryService.registerComponent(o.PRODUCT_RETAILERS_POPUP,ProductRetailersPopupComponent),ComponentFactoryService.registerComponent(o.PRODUCT_RETAILERS_POPUP_LIST,ProductRetailersPopupListComponent),ComponentFactoryService.registerComponent(o.PRODUCT_PRICE,ProductPriceComponent),ComponentFactoryService.registerComponent(o.PRODUCT_DRAWER,ProductDrawerComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LOADING,ProductLoadingComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LIST,ProductListComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LIST_CARD,ProductListCardComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LIST_FILTERS,ProductListFiltersComponent),ComponentFactoryService.registerComponent(o.PRODUCT_LIST_CARD_LOADING,ProductListCardLoadingComponent),ComponentFactoryService.registerComponent(o.CART,CartComponent),ComponentFactoryService.registerComponent(o.CART_RETAILER,CartRetailerComponent),ComponentFactoryService.registerComponent(o.CART_ITEM,CartItemComponent),ComponentFactoryService.registerComponent(o.CART_FOOTER,CartFooterComponent),ComponentFactoryService.registerComponent(o.CART_ITEM_QUANTITY_PRICE,CartItemQuantityPriceComponent),ComponentFactoryService.registerComponent(o.CART_RETAILER_SUBTOTAL,CartRetailerSubtotalComponent),ComponentFactoryService.registerComponent(o.CART_PROMO_CODE,CartPromoCodeComponent),ComponentFactoryService.registerComponent(o.CART_HEADER,CartHeaderComponent),ComponentFactoryService.registerComponent(o.CART_BODY,CartBodyComponent),ComponentFactoryService.registerComponent(o.CART_FULFILLMENT,CartFulfillmentComponent),ComponentFactoryService.registerComponent(o.CHECKOUT,CheckoutComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_INFORMATION,CheckoutInformationComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_PAYMENT,CheckoutPaymentComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_PAYMENT_SUMMARY,CheckoutPaymentSummaryComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_STRIPE_HANDLER,CheckoutStripeHandlerComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_STRIPE_FORM,CheckoutStripeFormComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_BILLING,CheckoutBillingComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_ORDER_SUMMARY,CheckoutOrderSummaryComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_PROMO_CODE,CheckoutPromoCodeComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_GIFT_CARDS,CheckoutGiftCardsComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_AMOUNTS,CheckoutAmountsComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_ITEMS,CheckoutItemsComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_COMPLETED,CheckoutCompletedComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_DELIVER_TO,CheckoutDeliverToComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_DELIVER_TO_SUMMARY,CheckoutDeliverToSummaryComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_BUYER,CheckoutBuyer),ComponentFactoryService.registerComponent(o.CHECKOUT_BUYER_SUMMARY,CheckoutBuyerSummaryComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_TIPS,CheckoutTipsComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_PC_GC,CheckoutPcGcComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_ITEM,CheckoutItemComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_ITEM_QUANTITY,CheckoutItemQuantityComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_PLACE_ORDER_BUTTON,CheckoutPlaceOrderButtonComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_HEADER,CheckoutHeaderComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_PRESALE_COUNTDOWN,CheckoutPresaleCountdownComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_PRESALE_EXPIRED,CheckoutPresaleExpiredComponent),ComponentFactoryService.registerComponent(o.CHECKOUT_SEND_AS_GIFT,CheckoutSendAsGiftComponent)}}class ElementsClient extends ElementsBaseClient{constructor(){super(...arguments),this.ui={cartButton:(t,n)=>{if(!t||"string"!=typeof t)throw new SDKError("Cart button requires a valid container ID. Received: "+("string"==typeof t?'"'+t+'"':t),!![]);this.ensureCartDrawerExists();const i=document.getElementById(t.replace("#",""));if(!i)throw new SDKError('Cannot find element with ID "'+t+'". Make sure the element exists before adding the cart button.',!![]);const r=ComponentFactoryService.createElement({type:o.BUTTONS_CART_OPEN,useShadowDom:!![],isIndependentComponent:!![],wrapInLceElement:!![],showItemsCount:n});i.innerHTML="",safeReplaceChildren(i,r)},floatingCartButton:t=>{this.ensureCartDrawerExists();const n=ComponentFactoryService.createElement({type:o.BUTTONS_CART_OPEN,useShadowDom:!![],isIndependentComponent:!![],wrapInLceElement:!![],classes:["independent"],showItemsCount:t});document.body.appendChild(n)},cartSubtotal:t=>{if(!t||"string"!=typeof t)throw new SDKError("Cart subtotal display requires a valid element ID. Received: "+("string"==typeof t?'"'+t+'"':t),!![]);const n=document.getElementById(t.replace("#",""));if(!n)throw new SDKError('Cannot find element with ID "'+t+'". Make sure the element exists before displaying cart subtotal.',!![]);n.innerHTML="",n.classList.add("lce-cart-subtotal");const v=t=>{n.textContent=formatCentToDollarText(t)},i=this.store.get("cart.totals.subtotal")||0;v(i),this.store.watch("cart.totals",()=>{const t=this.store.get("cart.totals.subtotal")||0;v(t)})},cartItemsCount:(t,n)=>{if(!t||"string"!=typeof t)throw new SDKError("Cart items count display requires a valid element ID. Received: "+("string"==typeof t?'"'+t+'"':t),!![]);let i=!![];n&&"boolean"==typeof n.hideZero&&(i=n.hideZero);const o=document.getElementById(t.replace("#",""));if(!o)throw new SDKError('Cannot find element with ID "'+t+'". Make sure the element exists before displaying cart items count.',!![]);o.innerHTML="",o.classList.add("lce-cart-items-count");const z=t=>{o.textContent=t.toString(),0===t?(i&&(o.style.visibility="hidden"),o.classList.add("no-items")):(i&&(o.style.visibility="visible"),o.classList.remove("no-items"))},r=this.store.get("cart.totals.quantity")||0;z(r),this.store.watch("cart.totals",()=>{const t=this.store.get("cart.totals.quantity")||0;z(t)})}}}async injectProductElement(t){if(!Array.isArray(t))throw new SDKError("Product injection requires an array of product parameters. Received: "+typeof t,!![]);if(!this.isElementsEnabled()){for(const n of t)this.injectDisabledElementsError(n.containerId,o.PRODUCT);return[]}return await this.processInjectProduct(t)}async injectAddressElement(t,n){if(!t||"string"!=typeof t)throw new SDKError("Address element requires a valid container ID. Received: "+("string"==typeof t?'"'+t+'"':t),!![]);return this.isElementsEnabled()?await this.processInjectElement({type:o.ADDRESS,containerId:t,options:n}):(this.injectDisabledElementsError(t,o.ADDRESS),null)}async injectCartElement(t){if(!t||"string"!=typeof t)throw new SDKError("Cart element requires a valid container ID. Received: "+("string"==typeof t?'"'+t+'"':t),!![]);return this.isElementsEnabled()?await this.processInjectElement({type:o.CART,containerId:t}):(this.injectDisabledElementsError(t,o.CART),null)}async injectCheckoutElement(t){if(!t||"string"!=typeof t)throw new SDKError("Checkout element requires a valid container ID. Received: "+("string"==typeof t?'"'+t+'"':t),!![]);return this.isElementsEnabled()?await this.processInjectElement({type:o.CHECKOUT,containerId:t}):(this.injectDisabledElementsError(t,o.CHECKOUT),null)}getInjectedComponents(){return this.injectedComponents}}async function Elements(t,i){try{SingletonManager.setContext({isBuilder:![]});const o=ClientConfigService.getInstance();o.initialize(t,{env:i.env,isBuilder:![],debugMode:i.debugMode,customTheme:i.customTheme,promoTicker:i.promoTicker,proxy:i.proxy,development:i.development});const r=o.getConfigs();SingletonManager.setClientConstructor(ElementsClient);const s=await SingletonManager.getClient(r);if(!s.clientPrepared)throw new SDKError("Failed to initialize. Check console for authentication or configuration errors.",!![]);const a={injectProductElement:s.injectProductElement.bind(s),injectAddressElement:s.injectAddressElement.bind(s),injectCartElement:s.injectCartElement.bind(s),injectCheckoutElement:s.injectCheckoutElement.bind(s),injectProductList:s.injectProductList.bind(s),ui:s.ui,actions:s.actions,getInjectedComponents:s.getInjectedComponents.bind(s)};window.elements=a;const l=PubSubService.getInstance();return l.publishAction(n.CLIENT_READY,{isReady:!![],message:"Elements Client Is Ready",timestamp:Date.now(),version:o.get("version")}),a}catch(o){try{const t=LoggerFactory.get("ElementsClientInit");t.error("Elements Client Initialization failed",o)}catch(r){console.error("[LiquidCommerce Elements] Client initialization failed:",null==o?void 0:o.message)}try{const t=ClientConfigService.getInstance(),i=PubSubService.getInstance();i.publishAction(n.CLIENT_READY,{isReady:![],message:"Initialization failed: "+(null==o?void 0:o.message),timestamp:Date.now(),version:t.get("version")||"unknown"})}catch(s){console.warn("[LiquidCommerce Elements] Could not fire error event - services unavailable")}return null}}const Et={CORE:{MAIN_SCRIPT:"data-liquid-commerce-elements",TOKEN:"data-token",ENV:"data-env",DEBUG_MODE:"data-debug-mode"},PROMO_TICKER:{CODE:"data-promo-code",TEXT:"data-promo-text",SEPARATOR:"data-promo-separator",ACTIVE_FROM:"data-promo-active-from",ACTIVE_UNTIL:"data-promo-active-until",CODE_PARAM:"data-promo-code-param"},PRODUCT:{PRODUCT:"data-product",CONTAINER:"data-container",PARAM:"data-product-param",FULFILLMENT_TYPE_PARAM:"data-product-fulfillment-type-param",LCE_PRODUCT:"data-lce-product"},PRODUCT_LIST:{LIST:"data-liquid-commerce-elements-products-list",SCRIPT:"data-liquid-commerce-elements-products",CARD:"data-card",CARD_FILL:"data-card-fill",ROWS:"data-rows",COLUMNS:"data-columns",FILTERS:"data-filters",PRODUCT_URL:"data-product-url"},CART:{BUTTON:"data-cart-button",BADGE_BUTTON:"data-cart-badge-button",MOBILE_BUTTON:"data-cart-mobile-button",MOBILE_BADGE_BUTTON:"data-cart-mobile-badge-button",BUTTON_HIDDEN:"data-cart-button-hidden",TOGGLE_BUTTON:"data-lce-cart-toggle-button",ITEMS_COUNT:"data-lce-cart-items-count"},DEVELOPMENT:"data-liquid-commerce-elements-development"};function startsWithLcePrefix(t){return null!==t&&"lce_"===t.substring(0,4)}function generateElementId({prefix:t,index:n}){const i=Math.random().toString(36).substring(2,7),o=void 0!==t?t:"",r=void 0!==n?n:"",s=o&&r?"-":"";return""+o+s+r+i}function pairsFromMainScript(t){const n=[];try{const o=t.getAttributeNames().filter(t=>t.substring(0,12)===Et.PRODUCT.PRODUCT);for(const r of o)try{const i=r.match(/^data-product(-(.+))?$/),o=(null==i?void 0:i[2])?"-"+i[2]:"",s=""+Et.PRODUCT.CONTAINER+o;if(t.hasAttribute(s)){const i=t.getAttribute(s),o=t.getAttribute(r);i&&o&&n.push({containerId:i,identifier:o})}}catch(i){console.error("[LiquidCommerce Elements Auto Initialization] Error processing product attribute:",i)}}catch(o){console.error("[LiquidCommerce Elements Auto Initialization] Error extracting products from main script:",o)}return n}function pairsFromProductsScript(){const t=[];try{const i=document.querySelectorAll("script["+Et.PRODUCT_LIST.SCRIPT+"]");for(const o of i)try{const n=JSON.parse(o.textContent||"[]");if(!Array.isArray(n))continue;for(const i of n)i.containerId&&i.identifier&&t.push({containerId:i.containerId,identifier:i.identifier})}catch(n){console.error("[LiquidCommerce Elements Auto Initialization] Invalid JSON in data-liquid-commerce-elements-products script",n)}}catch(i){console.error("[LiquidCommerce Elements Auto Initialization] Error extracting products from products script:",i)}return t}function pairsFromAttributedElements(){const t=[];try{const i=document.querySelectorAll("div["+Et.PRODUCT.LCE_PRODUCT+"]");let o=0;for(const r of i)try{const n=generateElementId({prefix:"lce-p",index:o});r.setAttribute("id",n);const i=r.getAttribute(Et.PRODUCT.LCE_PRODUCT);n&&i&&t.push({containerId:n,identifier:i}),o+=1}catch(n){console.error("[LiquidCommerce Elements Auto Initialization] Error processing attributed element:",n)}}catch(i){console.error("[LiquidCommerce Elements Auto Initialization] Error extracting products from attributed elements:",i)}return t}async function addProductToCartViaQueryParam(t,n){try{const o=n.getAttribute(Et.PRODUCT.PARAM),s=n.getAttribute(Et.PRODUCT.FULFILLMENT_TYPE_PARAM);if(!o)return;if(!startsWithLcePrefix(o))return console.warn('[LiquidCommerce Elements Auto Initialization] Ignoring product query parameter "'+o+'" because it does not start with "lce_" prefix.'),void 0;const a=new URLSearchParams(window.location.search),l=a.get(o);if(!l)return;let c=r.SHIPPING;if(s)if(startsWithLcePrefix(s)){const t=a.get(s);t!==r.ON_DEMAND&&t!==r.SHIPPING||(c=t)}else console.warn('[LiquidCommerce Elements Auto Initialization] Ignoring product fulfillment type query parameter "'+s+'" because it does not start with "lce_" prefix.');try{await t.actions.cart.addProduct([{identifier:l,fulfillmentType:c,quantity:1}],!![])}catch(i){console.error("[LiquidCommerce Elements Auto Initialization] Failed to add product from query parameter to cart:",i)}}catch(o){console.error("[LiquidCommerce Elements Auto Initialization] Failed to process product query parameter:",o)}}async function addPromoCodeToCartViaQueryParam(t,n){try{const o=n.getAttribute(Et.PROMO_TICKER.CODE_PARAM);if(!o)return;if(!startsWithLcePrefix(o))return console.warn('[LiquidCommerce Elements Auto Initialization] Ignoring promo code query parameter "'+o+'" because it does not start with "lce_" prefix.'),void 0;const r=new URLSearchParams(window.location.search),s=r.get(o);if(!s)return;try{await t.actions.cart.applyPromoCode(s)}catch(i){console.error("[LiquidCommerce Elements Auto Initialization] Failed to apply promo code from query parameter to cart:",i)}}catch(o){console.error("[LiquidCommerce Elements Auto Initialization] Failed to process promo code query parameter:",o)}}async function setupCartButtonWithPosition(t,n,i,o){var r,s,a;try{const l=i.includes("mobile"),c=l?"mobile":"desktop",d=!l,u=n.getAttribute(i),h=n.getAttribute(o);if(!n.hasAttribute(i)&&!n.hasAttribute(o))return;if(d){if(n.hasAttribute(i)&&!u)return t.ui.floatingCartButton(![]),void 0;if(n.hasAttribute(o)&&!h)return t.ui.floatingCartButton(!![]),void 0}const p=u||h,m=!!h;if(!p)return d&&(console.warn("[LiquidCommerce Elements Auto Initialization] No cart button position specified. Using floating button."),t.ui.floatingCartButton(m)),void 0;const f=["above","below","replace","inside"],b=p.match(/^(\w+):(.+)$/),w=b&&f.includes(b[1])?b[1]:"inside";let C=b?b[2]:p;/^[#.]/.test(C)||/\s/.test(C)||(C="#"+C);const k=document.querySelector(C);if(!k)return d&&(console.warn('[LiquidCommerce Elements Auto Initialization] Cart target "'+C+'" not found. Using floating button.'),t.ui.floatingCartButton(m)),void 0;const S=document.createElement("div");switch(S.classList.add("lce-cart-"+c+"-button-container"),S.id=generateElementId({prefix:"lce-cart-"+c+"-btn"}),w){case"above":null===(r=k.parentNode)||void 0===r?void 0:r.insertBefore(S,k);break;case"below":null===(s=k.parentNode)||void 0===s?void 0:s.insertBefore(S,k.nextSibling);break;case"replace":null===(a=k.parentNode)||void 0===a?void 0:a.replaceChild(S,k);break;default:k.appendChild(S)}t.ui.cartButton(S.id,m)}catch(l){console.error("[LiquidCommerce Elements Auto Initialization] Failed to setup cart button:",l)}}async function setupCartButtons(t,n){n.hasAttribute(Et.CART.BUTTON_HIDDEN)||(await setupCartButtonWithPosition(t,n,Et.CART.BUTTON,Et.CART.BADGE_BUTTON),await setupCartButtonWithPosition(t,n,Et.CART.MOBILE_BUTTON,Et.CART.MOBILE_BADGE_BUTTON))}async function initializeProductsList(t){try{const n=document.querySelector("div["+Et.PRODUCT_LIST.LIST+"]");if(!n)return;const i="lce-products-list-container";n.className="lce-products-list-container",n.id=i;const o=n.getAttribute(Et.PRODUCT_LIST.CARD)||"standard",r=n.hasAttribute(Et.PRODUCT_LIST.CARD_FILL),s=Number.parseInt(n.getAttribute(Et.PRODUCT_LIST.ROWS)||"3",10)||3,a=Number.parseInt(n.getAttribute(Et.PRODUCT_LIST.COLUMNS)||"4",10)||4,l=n.getAttribute(Et.PRODUCT_LIST.FILTERS),c=n.getAttribute(Et.PRODUCT_LIST.PRODUCT_URL)||void 0;let d=[];l&&(d=l.split(",").map(t=>t.trim()).filter(t=>t.length>0)),await t.injectProductList({containerId:i,rows:s,columns:a,cardVariant:o,fillCard:r,filters:d,productUrl:c})}catch(n){console.error("[LiquidCommerce Elements Auto Initialization] Failed to initialize products list:",n)}}function setupEventListeners(){try{window.addEventListener("lce:actions.client_ready",async t=>{const n=t.detail;if(!n.data.isReady)return;const i=window.elements,o=document.querySelectorAll("["+Et.CART.TOGGLE_BUTTON+"]");if(o.length>0)for(const s of o)s.addEventListener("click",async t=>{t.stopPropagation(),t.preventDefault(),i.actions.cart.toggleCart()});const r=document.querySelectorAll("["+Et.CART.ITEMS_COUNT+"]");if(r.length>0){let t=0;for(const n of r){const o=n.getAttribute(Et.CART.ITEMS_COUNT),r=!(o&&"keep-zero"===o),s=Boolean(null==n?void 0:n.id);let a;s?a=n.id:(a=generateElementId({prefix:"lce-cart-items-count",index:t}),n.id=a),i.ui.cartItemsCount(a,{hideZero:r}),t+=1}}})}catch(X){console.error("[LiquidCommerce Elements Auto Initialization] Failed to setup event listeners:",X)}}function getDevelopmentConfigs(){const t=document.querySelector("script["+Et.DEVELOPMENT+"]");if(t)try{return JSON.parse(t.textContent||"{}")}catch(n){return console.error("[LiquidCommerce Elements Auto Initialization] Invalid JSON in development config script",n),void 0}}async function ElementsAutoInitialize(){var n,i,o,r,a,l;try{const l=document.querySelector("script["+Et.CORE.MAIN_SCRIPT+"]");if(!l)return;const c=l.getAttribute(Et.CORE.TOKEN),d=l.getAttribute(Et.CORE.ENV)||t.PRODUCTION,u=l.getAttribute(Et.CORE.DEBUG_MODE);if(!c)throw new SDKError('Missing required data-token attribute on the script tag. Add data-token="your-api-key" to the Elements script tag.',!![]);const h=l.getAttribute(Et.PROMO_TICKER.CODE),p=l.getAttribute(Et.PROMO_TICKER.TEXT),m=null!==(n=l.getAttribute(Et.PROMO_TICKER.SEPARATOR))&&void 0!==n?n:"•",f=null!==(i=l.getAttribute(Et.PROMO_TICKER.ACTIVE_FROM))&&void 0!==i?i:void 0,b=null!==(o=l.getAttribute(Et.PROMO_TICKER.ACTIVE_UNTIL))&&void 0!==o?o:void 0,w=pairsFromMainScript(l),C=pairsFromProductsScript(),k=pairsFromAttributedElements(),S=[...w,...C,...k],E=h&&p&&f&&b?{promoCode:h,text:p.split("|").map(t=>t.trim()).filter(t=>t.length>0),separator:m,activeFrom:null===(r=new Date(f))||void 0===r?void 0:r.toISOString(),activeUntil:null===(a=new Date(b))||void 0===a?void 0:a.toISOString()}:void 0;let _=s.NONE;u&&d!==t.PRODUCTION&&(_=u),setupEventListeners();const D=await Elements(c,{env:d,debugMode:_,promoTicker:E?[E]:void 0,development:getDevelopmentConfigs()});if(!D)throw new SDKError("Elements client returned null. Check console for authentication or API errors.",!![]);setupCartButtons(D,l),0!==S.length&&D.injectProductElement(S).catch(t=>{console.error("[LiquidCommerce Elements Auto Initialization] Failed to inject product elements:",t)}),initializeProductsList(D),addProductToCartViaQueryParam(D,l),addPromoCodeToCartViaQueryParam(D,l)}catch(c){console.error("[LiquidCommerce Elements Auto Initialization]",null!==(l=null==c?void 0:c.message)&&void 0!==l?l:String(c))}}function triggerElementsAutoInit(){try{"loading"===document.readyState?document.addEventListener("DOMContentLoaded",async()=>{setTimeout(async()=>{try{await ElementsAutoInitialize()}catch(X){console.error("[LiquidCommerce Elements Auto Initialization] Failed to initialize:",X)}},50)}):setTimeout(async()=>{try{await ElementsAutoInitialize()}catch(X){console.error("[LiquidCommerce Elements Auto Initialization] Failed to initialize:",X)}},50)}catch(X){console.error("[LiquidCommerce Elements Auto Initialization] Failed to setup initialization:",X)}}class ElementsBuilderClient extends ElementsBaseClient{async updateComponentGlobalConfigs(t){try{if(!t)throw new SDKError("Global configuration object is required.",!![]);if(this.themeProvider.updateComponentGlobalConfigs(t),t.layout&&Object.keys(t.layout).length>0){await this.commands.product.rerenderAllProducts(),this.commands.cart.rerenderCart(),this.commands.checkout.rerenderCheckout();for(const n of getComponentTypesForLayoutFields("global.layout",t.layout))this.rerenderInjectedComponentsByType(n)}this.logger.info("✅ Global theme configuration updated - changes applied to all components")}catch(n){throw this.logger.error("❌ Failed to update global theme configuration",n),new SDKError("Failed to update global configuration: "+n.message,!![])}}async updateProductComponent(t){try{if(!t)throw new SDKError("Product configuration object is required.",!![]);if(this.themeProvider.updateProductComponent(t),t.layout&&Object.keys(t.layout).length>0){await this.commands.product.rerenderAllProducts();for(const n of getComponentTypesForLayoutFields("product.layout",t.layout))this.rerenderInjectedComponentsByType(n)}this.logger.info("✅ Product component theme updated - changes applied to product elements")}catch(n){throw this.logger.error("❌ Failed to update product component theme",n),new SDKError("Failed to update product configuration: "+n.message,!![])}}updateCartComponent(t){try{if(!t)throw new SDKError("Cart configuration object is required.",!![]);if(this.themeProvider.updateCartComponent(t),t.layout&&Object.keys(t.layout).length>0){this.commands.cart.rerenderCart();for(const n of getComponentTypesForLayoutFields("cart.layout",t.layout))this.rerenderInjectedComponentsByType(n)}this.logger.info("✅ Cart component theme updated - changes applied to cart elements")}catch(n){throw this.logger.error("❌ Failed to update cart component theme",n),new SDKError("Failed to update cart configuration: "+n.message,!![])}}updateCheckoutComponent(t){try{if(!t)throw new SDKError("Checkout configuration object is required.",!![]);if(this.themeProvider.updateCheckoutComponent(t),t.layout&&Object.keys(t.layout).length>0){this.commands.checkout.rerenderCheckout();for(const n of getComponentTypesForLayoutFields("checkout.layout",t.layout))this.rerenderInjectedComponentsByType(n)}this.logger.info("✅ Checkout component theme updated - changes applied to checkout elements")}catch(n){throw this.logger.error("❌ Failed to update checkout component theme",n),new SDKError("Failed to update checkout configuration: "+n.message,!![])}}updateAddressComponent(t){try{if(!t)throw new SDKError("Address configuration object is required.",!![]);this.themeProvider.updateAddressComponent(t),this.logger.info("✅ Address component theme updated - changes applied to address elements")}catch(n){throw this.logger.error("❌ Failed to update address component theme",n),new SDKError("Failed to update address configuration: "+n.message,!![])}}async injectElement(t){if(!t)throw new SDKError("Element injection requires container ID and type parameters.",!![]);if(!t.containerId||"string"!=typeof t.containerId)throw new SDKError("Container ID is required and must be a string. Received: "+("string"==typeof t.containerId?'"'+t.containerId+'"':t.containerId),!![]);if(!t.type)throw new SDKError("Component type is required (e.g., product, cart, checkout).",!![]);return await this.processInjectElement(t)}async injectProductElement(t){if(!Array.isArray(t))throw new SDKError("Product injection requires an array of product parameters. Received: "+typeof t,!![]);return await this.processInjectProduct(t)}async injectAddressElement(t,n){if(!t||"string"!=typeof t)throw new SDKError("Address element requires a valid container ID. Received: "+("string"==typeof t?'"'+t+'"':t),!![]);return await this.processInjectElement({type:o.ADDRESS,containerId:t,options:n})}async injectCartElement(t){if(!t||"string"!=typeof t)throw new SDKError("Cart element requires a valid container ID. Received: "+("string"==typeof t?'"'+t+'"':t),!![]);return await this.processInjectElement({type:o.CART,containerId:t})}async injectCheckoutElement(t,n){if(!t||"string"!=typeof t)throw new SDKError("Checkout element requires a valid container ID. Received: "+("string"==typeof t?'"'+t+'"':t),!![]);const i=await this.processInjectElement({type:o.CHECKOUT,containerId:t});if(null==n?void 0:n.simulatePresale){const t=n.presaleExpiresInMinutes||15,i=new Date;i.setMinutes(i.getMinutes()+t),this.store.set("checkout.presale",{isLocked:!![],expiresAt:i.toISOString()}),this.logger.info("✅ Builder presale simulation activated - expires in "+t+" minutes")}return i}}async function ElementsBuilder(t,i){try{SingletonManager.setContext({isBuilder:!![]});const o=ClientConfigService.getInstance();o.initialize(t,{env:i.env,isBuilder:!![],debugMode:i.debugMode,customTheme:i.customTheme,promoTicker:i.promoTicker,proxy:void 0,development:void 0});const r=o.getConfigs();SingletonManager.setClientConstructor(ElementsBuilderClient);const s=await SingletonManager.getClient(r);if(!s.clientPrepared)throw new SDKError("Failed to initialize. Check console for authentication or configuration errors.",!![]);const a={updateComponentGlobalConfigs:s.updateComponentGlobalConfigs.bind(s),updateProductComponent:s.updateProductComponent.bind(s),updateAddressComponent:s.updateAddressComponent.bind(s),updateCartComponent:s.updateCartComponent.bind(s),updateCheckoutComponent:s.updateCheckoutComponent.bind(s),injectElement:s.injectElement.bind(s),injectProductElement:s.injectProductElement.bind(s),injectAddressElement:s.injectAddressElement.bind(s),injectCartElement:s.injectCartElement.bind(s),injectCheckoutElement:s.injectCheckoutElement.bind(s),injectProductList:s.injectProductList.bind(s),actions:s.actions};window.elementsBuilder=a;const l=PubSubService.getInstance();return l.publishAction(n.CLIENT_READY,{isReady:!![],message:"Elements Builder Client Is Ready",timestamp:Date.now(),version:o.get("version")}),a}catch(o){try{const t=LoggerFactory.get("ElementsBuilderClientInit");t.error("Elements Builder Client Initialization failed",o)}catch(r){console.error("[LiquidCommerce Elements] Builder Client initialization failed:",null==o?void 0:o.message)}try{const t=ClientConfigService.getInstance(),i=PubSubService.getInstance();i.publishAction(n.CLIENT_READY,{isReady:![],message:"Builder initialization failed: "+(null==o?void 0:o.message),timestamp:Date.now(),version:t.get("version")||"unknown"})}catch(s){console.warn("[LiquidCommerce Elements] Could not fire error event - services unavailable")}return null}}if(void 0===window.customElements)console.error("[LiquidCommerce Elements] SDK requires support for Web Components. Please include a Web Components polyfill for older browsers.");else if(void 0===HTMLElement.prototype.attachShadow)console.error("[LiquidCommerce Elements] SDK requires support for Shadow DOM. Please include a Shadow DOM polyfill for older browsers.");else try{const t=window.onerror;window.onerror=(n,i,o,r,s)=>isSDKError(s,i)?(console.error("[LiquidCommerce Elements] Unhandled SDK error:",{message:n,source:i,lineno:o,colno:r,error:s}),!![]):t?t(n,i,o,r,s):![];const n=window.onunhandledrejection;window.onunhandledrejection=t=>{if(t.reason&&isSDKError(t.reason))return console.error("[LiquidCommerce Elements] Unhandled SDK promise rejection:",t.reason),t.preventDefault(),void 0;n&&n.call(window,t)};try{initializeDOMPolyfills()}catch(_t){console.error("[LiquidCommerce Elements] DOM polyfills initialization failed:",_t)}try{triggerElementsAutoInit()}catch(Dt){console.error("[LiquidCommerce Elements] Auto-initialization failed:",Dt)}}catch(Tt){console.error("[LiquidCommerce Elements] SDK initialization failed:",Tt)}initializeDOMPolyfills(),window.Elements=Elements,window.ElementsBuilder=ElementsBuilder,exports.Elements=Elements,exports.ElementsBuilder=ElementsBuilder,Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"})});
|
|
1
|
+
(function(n,i){"object"==typeof exports&&"undefined"!=typeof module?i(exports):"function"==typeof define&&define.amd?define(["exports"],i):(n="undefined"!=typeof globalThis?globalThis:n||self,i(n.LiquidCommerceElements={}))})(this,function(exports){"use strict";function polyfillReplaceChildren(){"undefined"!=typeof Element&&"replaceChildren"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.replaceChildren=function(...n){for(;this.firstChild;)this.removeChild(this.firstChild);for(const i of n)"string"==typeof i?this.appendChild(document.createTextNode(i)):this.appendChild(i)})}function polyfillPrepend(){"undefined"!=typeof Element&&"prepend"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.prepend=function(...n){const i=document.createDocumentFragment();for(const r of n)"string"==typeof r?i.appendChild(document.createTextNode(r)):i.appendChild(r);this.insertBefore(i,this.firstChild)})}function polyfillRemove(){"undefined"!=typeof Element&&"remove"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.remove=function(){this.parentNode&&this.parentNode.removeChild(this)})}function polyfillReplaceWith(){"undefined"!=typeof Element&&"replaceWith"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.replaceWith=function(...n){const i=this.parentNode;if(!i)return;const r=document.createDocumentFragment();for(const s of n)"string"==typeof s?r.appendChild(document.createTextNode(s)):r.appendChild(s);i.replaceChild(r,this)})}function polyfillBefore(){"undefined"!=typeof Element&&"before"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.before=function(...n){const i=this.parentNode;if(!i)return;const r=document.createDocumentFragment();for(const s of n)"string"==typeof s?r.appendChild(document.createTextNode(s)):r.appendChild(s);i.insertBefore(r,this)})}function polyfillAfter(){"undefined"!=typeof Element&&"after"in Element.prototype||"undefined"!=typeof Element&&(Element.prototype.after=function(...n){const i=this.parentNode;if(!i)return;const r=document.createDocumentFragment();for(const s of n)"string"==typeof s?r.appendChild(document.createTextNode(s)):r.appendChild(s);i.insertBefore(r,this.nextSibling)})}function polyfillObjectFromEntries(){"undefined"!=typeof Object&&"fromEntries"in Object||"undefined"!=typeof Object&&(Object.fromEntries=n=>{const i={};for(const[r,s]of n)i[r]=s;return i})}function initializeDOMPolyfills(){try{polyfillReplaceChildren(),polyfillPrepend(),polyfillRemove(),polyfillReplaceWith(),polyfillBefore(),polyfillAfter(),polyfillObjectFromEntries()}catch(ut){console.warn("DOM polyfills initialization failed:",ut)}}function safeReplaceChildren(n,...i){try{if("replaceChildren"in n&&"function"==typeof n.replaceChildren)n.replaceChildren(...i);else{for(;n.firstChild;)n.removeChild(n.firstChild);for(const r of i)"string"==typeof r?n.appendChild(document.createTextNode(r)):n.appendChild(r)}}catch(r){console.error("replaceChildren operation failed:",r),1===i.length&&"string"==typeof i[0]&&(n.innerHTML=i[0])}}class SDKError extends Error{constructor(n,i=![]){super(n),this.name="SDKError",this.isSdk=!![],this.reThrow=i,Error.captureStackTrace&&Error.captureStackTrace(this,SDKError),Object.setPrototypeOf(this,SDKError.prototype)}}function isSDKError(n,i){if((null==n?void 0:n.isSdk)===!![])return n instanceof SDKError&&n.reThrow?![]:!![];if(!n||"object"!=typeof n)return i?isSDKSource(i):![];const r=String((null==n?void 0:n.message)||""),s=/liquidcommerce\s+elements/i.test(r),a=String((null==n?void 0:n.stack)||""),l=(null==n?void 0:n.source)||i||"",d=[/@[/\\](?:core|modules|constants|enums|interfaces|utils|static)[/\\]/,/[./]*[/\\](?:core|modules|constants|enums|interfaces|utils|static)[/\\]/,/node_modules[/\\]@liquidcommerce[/\\]elements-sdk[/\\]/i,/elements-sdk[/\\](?:src[/\\])?(?:core|modules)[/\\]/i,/chunk-[a-z0-9]+.*elements/i],u=[/\bElements\b(?!\w)/,/\bElementsBuilder\b/,/\bLiquidCommerceElements\b/,/BaseComponent/,/Elements(?:Base)?Client/,/(?:Auth|Store|Command|ApiClient|Telemetry|FingerPrint|GoogleTagManager|ClientConfig|ThemeProvider|ComponentFactory|PubSub|SingletonManager|DebugPanel)Service/,/(?:Cart|Product|Checkout|Address|ProductList|UI|Common)Commands/,/(?:Product|Cart|Checkout|Address|ProductList).*Component/],f=[/(?:service|commands|component)\.(?:ts|js)/,/auto-initialize\.(?:ts|js)/,/elements-(?:base-|builder-)?client\.(?:ts|js)/],g=[/elements-sdk[/\\]/i,/modules[/\\](?:cart|product|checkout|address|product-list|theme-provider|ui-components)[/\\]/,/core[/\\](?:auth|store|command|api-client|telemetry|fingerprint|google-tag-manager|client|component-factory|pubsub|singleton-manager|debug-panel)[/\\]/,/@liquidcommerce[/\\]elements-sdk/i],v=isSDKSource(l),b=d.some(n=>n.test(a)),x=u.some(n=>n.test(a)),w=f.some(n=>n.test(a)),C=g.some(n=>n.test(a));return s||v||b||x||w||C}function isSDKSource(n){if(!n||"string"!=typeof n)return![];const i=[/\/elements\.js$/i,/\/index\.esm\.js$/i,/@liquidcommerce\/elements-sdk/i,/node_modules[/\\]@liquidcommerce[/\\]elements-sdk/i,/@liquidcommerce[/\\]elements-sdk[/\\]/i,/\/elements-sdk[/\\]/i,/elements-sdk[/\\]src/i,/elements[-.]?[a-z0-9]*\.js$/i,/chunk.*elements/i,/elements.*chunk/i,/\?.*elements\.js/i,/#.*elements\.js/i];return i.some(i=>i.test(n))}var n,i,r,s,a,l,d,u,f,g,v;(function(n){n.ALE="BEER > ALE",n.LAGER="BEER > LAGER",n.BASE="BEER",n.NON_ALCOHOLIC="BEER > NON-ALCOHOLIC",n.OTHER_BEER="BEER > OTHER",n.OTHER_BEER_SOUR_BEER="BEER > SOUR BEER",n.OTHER_BEER_FLAVORED_BEER="BEER > FLAVORED BEER",n.OTHER_BEER_FRUIT_BEER="BEER > FRUIT BEER"})(n||(n={})),function(n){n.BASE="FOOD",n.PANTRY_OTHER="FOOD > PANTRY > OTHER",n.CANDY="FOOD > CANDY",n.CANDY_OTHER="FOOD > CANDY > OTHER",n.CBD="FOOD > CBD",n.CBD_OTHER="FOOD > CBD > OTHER",n.CHEESE="FOOD > CHEESE",n.CHEESE_OTHER="FOOD > CHEESE > OTHER",n.HOUSEHOLD="FOOD > HOUSEHOLD",n.HOUSEHOLD_SNACKS="FOOD > HOUSEHOLD > SNACKS",n.HOUSEHOLD_OTHER="FOOD > HOUSEHOLD > OTHER",n.PANTRY="FOOD > PANTRY",n.FRUIT="FOOD > FRUIT",n.OTHER="FOOD > OTHER",n.ICE="FOOD > ICE",n.ICE_CREAM="FOOD > ICE CREAM",n.PARTY_SUPPLIES="FOOD > PARTY SUPPLIES",n.PARTY_SUPPLIES_OTHER="FOOD > PARTY SUPPLIES > OTHER",n.SPIRITS_BASED="FOOD > SPIRITS BASED",n.GARNISHES="FOOD > GARNISHES"}(i||(i={})),function(n){n.BASE="MERCHANDISE",n.GLASSWARE="MERCHANDISE > GLASSWARE",n.GLASSWARE_OTHER="MERCHANDISE > GLASSWARE > OTHER",n.HUMIDOR="MERCHANDISE > HUMIDOR",n.ACCESSORY="MERCHANDISE > ACCESSORY",n.ACCESSORY_OTHER="MERCHANDISE > ACCESSORY > OTHER",n.GIFT_SET="MERCHANDISE > GIFT SET",n.GIFT_SET_GIFT_BAG="MERCHANDISE > GIFT SET > GIFT BAG",n.GIFT_SET_GIFT_CARD="MERCHANDISE > GIFT SET > GIFT CARD",n.BAR_TOOLS="MERCHANDISE > BAR TOOLS",n.BAR_TOOLS_ICE_BUCKET="MERCHANDISE > BAR TOOLS > ICE BUCKET",n.BAR_TOOLS_OTHER="MERCHANDISE > BAR TOOLS > OTHER"}(r||(r={})),function(n){n.BASE="MISCELLANEOUS",n.GIFT_CARD="MISCELLANEOUS > GIFT CARDS",n.PROMOTIONAL="MISCELLANEOUS > PROMOTIONAL",n.MEMBERSHIP="MISCELLANEOUS > MEMBERSHIP"}(s||(s={})),function(n){n.BASE="NON ALCOHOLIC",n.BITTERS="NON ALCOHOLIC > BITTERS",n.COCKTAIL_MIX="NON ALCOHOLIC > COCKTAIL MIX",n.COFFEE="NON ALCOHOLIC > COFFEE",n.ENERGY_DRINKS="NON ALCOHOLIC > ENERGY DRINKS",n.JUICE="NON ALCOHOLIC > JUICE",n.SODA="NON ALCOHOLIC > SODA",n.SPECIALTY_ITEM="NON ALCOHOLIC > SPECIALTY ITEM",n.SPECIALTY_ITEM_OTHER="NON ALCOHOLIC > SPECIALTY ITEM > OTHER",n.SPIRITS="NON ALCOHOLIC > SPIRITS",n.TEA="NON ALCOHOLIC > TEA",n.WATER="NON ALCOHOLIC > WATER",n.WINE="NON ALCOHOLIC > WINE",n.SPORTS_DRINKS="NON ALCOHOLIC > SPORTS DRINKS",n.SLURPEES="NON ALCOHOLIC > SLURPEES",n.GINGER_BEER="NON ALCOHOLIC > GINGER BEER",n.DAIRY="NON ALCOHOLIC > DAIRY",n.DAIRY_OTHER="NON ALCOHOLIC > DAIRY > OTHER",n.OTHER="NON ALCOHOLIC > OTHER"}(a||(a={})),function(n){n.BASE="READY TO DRINK",n.HARD_CIDER="READY TO DRINK > HARD CIDER",n.HARD_CIDER_PERRY_PEAR_CIDER="READY TO DRINK > HARD CIDER > PERRY (PEAR CIDER)",n.HARD_CIDER_APPLE_CIDER="READY TO DRINK > HARD CIDER > APPLE CIDER",n.HARD_CIDER_OTHER_FRUIT_CIDER="READY TO DRINK > HARD CIDER > FRUIT CIDER",n.HARD_TEA="READY TO DRINK > HARD TEA",n.HARD_SELTZER="READY TO DRINK > HARD SELTZER",n.MALT_BASED="READY TO DRINK > MALT BASED",n.SPIRITS_BASED_RTDS="READY TO DRINK > SPIRITS-BASED RTDS",n.SPIRITS_BASED_RTDS_AGAVE_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > AGAVE COCKTAILS",n.SPIRITS_BASED_RTDS_GIN_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > GIN COCKTAILS",n.SPIRITS_BASED_RTDS_RUM_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > RUM COCKTAILS",n.SPIRITS_BASED_RTDS_TEQUILA_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > TEQUILA COCKTAILS",n.SPIRITS_BASED_RTDS_VODKA_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > VODKA COCKTAILS",n.SPIRITS_BASED_RTDS_WHISKEY_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > WHISKEY COCKTAILS",n.SPIRITS_BASED_RTDS_OTHER="READY TO DRINK > SPIRITS-BASED RTDS > OTHER",n.SPIRITS_BASED_RTDS_FROZEN_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > FROZEN COCKTAILS",n.SPIRITS_BASED_RTDS_APERITIF_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > APERITIF COCKTAILS",n.SPIRITS_BASED_RTDS_DESSERT_COFFEE_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > DESSERT & COFFEE COCKTAILS",n.SPIRITS_BASED_RTDS_TEA_COCKTAILS="READY TO DRINK > SPIRITS-BASED RTDS > TEA COCKTAILS",n.WINE_COCKTAILS="READY TO DRINK > WINE COCKTAILS",n.OTHER="READY TO DRINK > OTHER"}(l||(l={})),function(n){n.BASE="SPIRITS",n.AMARO_APERITIF_VERMOUTH="SPIRITS > AMARO APERITIF & VERMOUTH",n.AMARO_APERITIF_VERMOUTH_OTHER="SPIRITS > AMARO APERITIF & VERMOUTH > OTHER",n.BAIJIU="SPIRITS > BAIJIU",n.BITTERS="SPIRITS > BITTERS",n.BRANDY="SPIRITS > BRANDY",n.BRANDY_COGNAC="SPIRITS > BRANDY > COGNAC",n.CACHACA="SPIRITS > CACHACA",n.GIN="SPIRITS > GIN",n.GIN_DRY_GIN="SPIRITS > GIN > DRY GIN",n.GIN_FLAVORED_GIN="SPIRITS > GIN > FLAVORED GIN",n.GIN_OLD_TOM_GIN="SPIRITS > GIN > OLD TOM GIN",n.GIN_OTHER="SPIRITS > GIN > OTHER",n.GRAIN_ALCOHOL="SPIRITS > GRAIN ALCOHOL",n.LIQUEUR="SPIRITS > LIQUEUR",n.MEZCAL="SPIRITS > MEZCAL",n.OTHER_SPIRITS="SPIRITS > OTHER SPIRITS",n.RUM="SPIRITS > RUM",n.RUM_AGED_RUM="SPIRITS > RUM > AGED RUM",n.RUM_DARK_RUM="SPIRITS > RUM > DARK RUM",n.RUM_FLAVORED_RUM="SPIRITS > RUM > FLAVORED RUM",n.RUM_GOLD_RUM="SPIRITS > RUM > GOLD RUM",n.RUM_OTHER="SPIRITS > RUM > OTHER",n.RUM_SPICED="SPIRITS > RUM > SPICED",n.RUM_WHITE_RUM="SPIRITS > RUM > WHITE RUM",n.SHOCHU="SPIRITS > SHOCHU",n.SOJU="SPIRITS > SOJU",n.SOTOL="SPIRITS > SOTOL",n.TEQUILA="SPIRITS > TEQUILA",n.TEQUILA_ANEJO="SPIRITS > TEQUILA > AÑEJO",n.TEQUILA_BLANCO="SPIRITS > TEQUILA > BLANCO",n.TEQUILA_CRISTALINO="SPIRITS > TEQUILA > CRISTALINO",n.TEQUILA_EXTRA_ANEJO="SPIRITS > TEQUILA > EXTRA AÑEJO",n.TEQUILA_OTHER="SPIRITS > TEQUILA > OTHER",n.TEQUILA_REPOSADO="SPIRITS > TEQUILA > REPOSADO",n.VODKA="SPIRITS > VODKA",n.VODKA_FLAVORED_VODKA="SPIRITS > VODKA > FLAVORED VODKA",n.VODKA_OTHER="SPIRITS > VODKA > OTHER",n.VODKA_REGULAR_VODKA="SPIRITS > VODKA > REGULAR VODKA",n.WHISKEY="SPIRITS > WHISKEY",n.WHISKEY_AMERICAN_WHISKEY="SPIRITS > WHISKEY > AMERICAN WHISKEY",n.WHISKEY_BOURBON="SPIRITS > WHISKEY > BOURBON",n.WHISKEY_CANADIAN_WHISKEY="SPIRITS > WHISKEY > CANADIAN WHISKEY",n.WHISKEY_IRISH_WHISKEY="SPIRITS > WHISKEY > IRISH WHISKEY",n.WHISKEY_MOONSHINE="SPIRITS > WHISKEY > MOONSHINE",n.WHISKEY_FLAVORED="SPIRITS > WHISKEY > FLAVORED WHISKEY",n.WHISKEY_OTHER="SPIRITS > WHISKEY > OTHER",n.WHISKEY_SCOTCH="SPIRITS > WHISKEY > SCOTCH"}(d||(d={})),function(n){n.BASE="WINE",n.CHAMPAGNE_SPARKLING="WINE > CHAMPAGNE & SPARKLING",n.CHAMPAGNE_SPARKLING_CAVA="WINE > CHAMPAGNE & SPARKLING > CAVA",n.CHAMPAGNE_SPARKLING_CHAMPAGNE="WINE > CHAMPAGNE & SPARKLING > CHAMPAGNE",n.CHAMPAGNE_SPARKLING_PROSECCO="WINE > CHAMPAGNE & SPARKLING > PROSECCO",n.CHAMPAGNE_SPARKLING_SPARKLING_WINE="WINE > CHAMPAGNE & SPARKLING > SPARKLING WINE",n.CHAMPAGNE_SPARKLING_OTHER="WINE > CHAMPAGNE & SPARKLING > OTHER",n.COOKING="WINE > COOKING",n.DESSERT_FORTIFIED_WINE="WINE > DESSERT & FORTIFIED WINE",n.DESSERT_FORTIFIED_WINE_MEAD="WINE > DESSERT & FORTIFIED WINE > MEAD",n.DESSERT_FORTIFIED_WINE_PORT="WINE > DESSERT & FORTIFIED WINE > PORT",n.DESSERT_FORTIFIED_WINE_SHERRY="WINE > DESSERT & FORTIFIED WINE > SHERRY",n.DESSERT_FORTIFIED_WINE_OTHER="WINE > DESSERT & FORTIFIED WINE > OTHER",n.RED_WINE="WINE > RED WINE",n.RED_WINE_AGIORGITIKO="WINE > RED WINE > AGIORGITIKO",n.RED_WINE_AGLIANICO="WINE > RED WINE > AGLIANICO",n.RED_WINE_ALICANTE_BOUSCHET="WINE > RED WINE > ALICANTE BOUSCHET",n.RED_WINE_BARBERA="WINE > RED WINE > BARBERA",n.RED_WINE_BARBARESCO="WINE > RED WINE > BARBARESCO",n.RED_WINE_BAROLO="WINE > RED WINE > BAROLO",n.RED_WINE_BEAUJOLAIS="WINE > RED WINE > BEAUJOLAIS",n.RED_WINE_BLAUER_ZWEIGELT="WINE > RED WINE > BLAUER ZWEIGELT",n.RED_WINE_BOBAL="WINE > RED WINE > BOBAL",n.RED_WINE_BONARDA="WINE > RED WINE > BONARDA",n.RED_WINE_BORDEAUX="WINE > RED WINE > BORDEAUX",n.RED_WINE_BORDEAUX_BLEND="WINE > RED WINE > BORDEAUX BLEND",n.RED_WINE_BURGUNDY="WINE > RED WINE > BURGUNDY",n.RED_WINE_CABERNET_FRANC="WINE > RED WINE > CABERNET FRANC",n.RED_WINE_CABERNET_SAUVIGNON="WINE > RED WINE > CABERNET SAUVIGNON",n.RED_WINE_CANNONAU="WINE > RED WINE > CANNONAU",n.RED_WINE_CARMENERE="WINE > RED WINE > CARMENERE",n.RED_WINE_CHAMBOURCIN="WINE > RED WINE > CHAMBOURCIN",n.RED_WINE_CHIANTI="WINE > RED WINE > CHIANTI",n.RED_WINE_CINSAULT="WINE > RED WINE > CINSAULT",n.RED_WINE_CORVINA="WINE > RED WINE > CORVINA",n.RED_WINE_DOLCETTO="WINE > RED WINE > DOLCETTO",n.RED_WINE_DORNFELDER="WINE > RED WINE > DORNFELDER",n.RED_WINE_FETEASCA_NEAGRA="WINE > RED WINE > FETEASCA NEAGRA",n.RED_WINE_GAMAY="WINE > RED WINE > GAMAY",n.RED_WINE_GRACIANO="WINE > RED WINE > GRACIANO",n.RED_WINE_GRENACHE="WINE > RED WINE > GRENACHE",n.RED_WINE_LIMNIO="WINE > RED WINE > LIMNIO",n.RED_WINE_MACABEO="WINE > RED WINE > MACABEO",n.RED_WINE_MALBEC="WINE > RED WINE > MALBEC",n.RED_WINE_MENCIA="WINE > RED WINE > MENCIA",n.RED_WINE_MERLOT="WINE > RED WINE > MERLOT",n.RED_WINE_MONICA="WINE > RED WINE > MONICA",n.RED_WINE_MONTEPULCIANO="WINE > RED WINE > MONTEPULCIANO",n.RED_WINE_MOURVEDRE_MONASTRELL="WINE > RED WINE > MOURVEDRE/MONASTRELL",n.RED_WINE_NEBBIOLO="WINE > RED WINE > NEBBIOLO",n.RED_WINE_NEGROAMARO="WINE > RED WINE > NEGROAMARO",n.RED_WINE_NERELLO_MASCALESE="WINE > RED WINE > NERELLO MASCALESE",n.RED_WINE_NERO_DAVOLA="WINE > RED WINE > NERO D'AVOLA",n.RED_WINE_PETIT_VERDOT="WINE > RED WINE > PETIT VERDOT",n.RED_WINE_PETITE_SIRAH="WINE > RED WINE > PETITE SIRAH",n.RED_WINE_PINOT_NOIR="WINE > RED WINE > PINOT NOIR",n.RED_WINE_PINOTAGE="WINE > RED WINE > PINOTAGE",n.RED_WINE_PRIMITIVO="WINE > RED WINE > PRIMITIVO",n.RED_WINE_RED_BLEND="WINE > RED WINE > RED BLEND",n.RED_WINE_RHONE_BLEND="WINE > RED WINE > RHONE BLEND",n.RED_WINE_RIOJA="WINE > RED WINE > RIOJA",n.RED_WINE_SAGRANTINO="WINE > RED WINE > SAGRANTINO",n.RED_WINE_SANGIOVESE="WINE > RED WINE > SANGIOVESE",n.RED_WINE_SAPERAVI="WINE > RED WINE > SAPERAVI",n.RED_WINE_SCHIAVA_TROLLINGER="WINE > RED WINE > SCHIAVA/TROLLINGER",n.RED_WINE_SYRAH_SHIRAZ="WINE > RED WINE > SYRAH/SHIRAZ",n.RED_WINE_TANNAT="WINE > RED WINE > TANNAT",n.RED_WINE_TEMPRANILLO="WINE > RED WINE > TEMPRANILLO",n.RED_WINE_TEROLDEGO="WINE > RED WINE > TEROLDEGO",n.RED_WINE_TINTA_DEL_TORO="WINE > RED WINE > TINTA DEL TORO",n.RED_WINE_TOURIGA_NACIONAL="WINE > RED WINE > TOURIGA NACIONAL",n.RED_WINE_VALPOLICELLA="WINE > RED WINE > VALPOLICELLA",n.RED_WINE_XINOMAVRO="WINE > RED WINE > XINOMAVRO",n.RED_WINE_ZINFANDEL="WINE > RED WINE > ZINFANDEL",n.RED_WINE_ZWEIGELT="WINE > RED WINE > ZWEIGELT",n.RED_WINE_OTHER="WINE > RED WINE > OTHER",n.ROSE_WINE="WINE > ROSE WINE",n.SAKE="WINE > SAKE",n.WHITE_WINE="WINE > WHITE WINE",n.WHITE_WINE_ALBARINO_ALVARINHO="WINE > WHITE WINE > ALBARINO/ALVARINHO",n.WHITE_WINE_ARNEIS="WINE > WHITE WINE > ARNEIS",n.WHITE_WINE_ASTI="WINE > WHITE WINE > ASTI",n.WHITE_WINE_ASSYRTIKO="WINE > WHITE WINE > ASSYRTIKO",n.WHITE_WINE_BURGUNDY="WINE > WHITE WINE > BURGUNDY",n.WHITE_WINE_CARRICANTE="WINE > WHITE WINE > CARRICANTE",n.WHITE_WINE_CATARRATTO="WINE > WHITE WINE > CATARRATTO",n.WHITE_WINE_CHABLIS="WINE > WHITE WINE > CHABLIS",n.WHITE_WINE_CHARDONNAY="WINE > WHITE WINE > CHARDONNAY",n.WHITE_WINE_CHENIN_BLANC="WINE > WHITE WINE > CHENIN BLANC",n.WHITE_WINE_CORTESE="WINE > WHITE WINE > CORTESE",n.WHITE_WINE_FALANGHINA="WINE > WHITE WINE > FALANGHINA",n.WHITE_WINE_FIANO="WINE > WHITE WINE > FIANO",n.WHITE_WINE_FRIULANO="WINE > WHITE WINE > FRIULANO",n.WHITE_WINE_FURMINT="WINE > WHITE WINE > FURMINT",n.WHITE_WINE_GARGANEGA="WINE > WHITE WINE > GARGANEGA",n.WHITE_WINE_GAVI="WINE > WHITE WINE > GAVI",n.WHITE_WINE_GEWURZTRAMINER="WINE > WHITE WINE > GEWURZTRAMINER",n.WHITE_WINE_GRECO_DI_TUFO="WINE > WHITE WINE > GRECO DI TUFO",n.WHITE_WINE_GRENACHE_BLANC="WINE > WHITE WINE > GRENACHE BLANC",n.WHITE_WINE_GRUNER_VELTLINER="WINE > WHITE WINE > GRUNER VELTLINER",n.WHITE_WINE_HUXELREBE="WINE > WHITE WINE > HUXELREBE",n.WHITE_WINE_INZOLIA="WINE > WHITE WINE > INZOLIA",n.WHITE_WINE_MALVASIA="WINE > WHITE WINE > MALVASIA",n.WHITE_WINE_MELON_DE_BOURGOGNE="WINE > WHITE WINE > MELON DE BOURGOGNE",n.WHITE_WINE_MOSCATO_BIANCO="WINE > WHITE WINE > MOSCATO BIANCO",n.WHITE_WINE_MOSCHOFILERO_FILERI="WINE > WHITE WINE > MOSCHOFILERO/FILERI",n.WHITE_WINE_MULLER_THURGAU_RIVANER="WINE > WHITE WINE > MULLER-THURGAU/RIVANER",n.WHITE_WINE_MUSCAT_MOSCATO="WINE > WHITE WINE > MUSCAT/MOSCATO",n.WHITE_WINE_PECORINO="WINE > WHITE WINE > PECORINO",n.WHITE_WINE_PICPOUL="WINE > WHITE WINE > PICPOUL",n.WHITE_WINE_PINOT_BLANC="WINE > WHITE WINE > PINOT BLANC",n.WHITE_WINE_PINOT_GRIGIO_PINOT_GRIS="WINE > WHITE WINE > PINOT GRIGIO/PINOT GRIS",n.WHITE_WINE_POUILLY_FUISSE="WINE > WHITE WINE > POUILLY-FUISSE",n.WHITE_WINE_POUILLY_FUME="WINE > WHITE WINE > POUILLY-FUME",n.WHITE_WINE_RIESLING="WINE > WHITE WINE > RIESLING",n.WHITE_WINE_RIOJA="WINE > WHITE WINE > RIOJA",n.WHITE_WINE_RODITIS="WINE > WHITE WINE > RODITIS",n.WHITE_WINE_SANCERRE="WINE > WHITE WINE > SANCERRE",n.WHITE_WINE_SAUVIGNON_BLANC="WINE > WHITE WINE > SAUVIGNON BLANC",n.WHITE_WINE_SEMILLON="WINE > WHITE WINE > SEMILLON",n.WHITE_WINE_SOAVE="WINE > WHITE WINE > SOAVE",n.WHITE_WINE_SYLVANER="WINE > WHITE WINE > SYLVANER",n.WHITE_WINE_TORRONTES="WINE > WHITE WINE > TORRONTES",n.WHITE_WINE_TREBBIANO_UGNI_BLANC="WINE > WHITE WINE > TREBBIANO/UGNI BLANC",n.WHITE_WINE_TURBIANA="WINE > WHITE WINE > TURBIANA",n.WHITE_WINE_TXAKOLINA="WINE > WHITE WINE > TXAKOLINA",n.WHITE_WINE_VERDEJO="WINE > WHITE WINE > VERDEJO",n.WHITE_WINE_VERDICCHIO="WINE > WHITE WINE > VERDICCHIO",n.WHITE_WINE_VERMENTINO="WINE > WHITE WINE > VERMENTINO",n.WHITE_WINE_VERNACCIA="WINE > WHITE WINE > VERNACCIA",n.WHITE_WINE_VIDIANO="WINE > WHITE WINE > VIDIANO",n.WHITE_WINE_VINHO_VERDE="WINE > WHITE WINE > VINHO VERDE",n.WHITE_WINE_VIOGNIER="WINE > WHITE WINE > VIOGNIER",n.WHITE_WINE_VIURA="WINE > WHITE WINE > VIURA",n.WHITE_WINE_OTHER="WINE > WHITE WINE > OTHER",n.WINE_OTHER="WINE > OTHER"}(u||(u={})),function(n){n.BRANDS="brands",n.FLAVOR="flavor",n.FULFILLMENT="fulfillment",n.TAGS="tags",n.REGION="region",n.VARIETY="variety",n.ENGRAVING="engraving",n.PRICE="price",n.PRESALE="presale",n.AVAILABILITY="availability",n.CATEGORIES="categories",n.SIZES="sizes",n.COLORS="colors",n.APPELLATION="appellation",n.COUNTRY="country",n.VINTAGE="vintage",n.MATERIALS="materials",n.COLLECTION_TAGS="collectionTags"}(f||(f={})),function(n){n.UNSPECIFIED="AVAILABILITY_UNSPECIFIED",n.IN_STOCK="IN_STOCK",n.OUT_OF_STOCK="OUT_OF_STOCK",n.PREORDER="PREORDER",n.BACKORDER="BACKORDER"}(g||(g={})),function(n){n.YES="YES",n.NO="NO"}(v||(v={}));const b={DEVELOPMENT:"development",STAGING:"staging",PRODUCTION:"production"},x={CLIENT_READY:"client_ready",ADDRESS_UPDATED:"address_updated",ADDRESS_CLEARED:"address_cleared",ADDRESS_FAILED:"address_failed",PRODUCT_LOADED:"product_loaded",PRODUCT_QUANTITY_INCREASE:"product_quantity_increase",PRODUCT_QUANTITY_DECREASE:"product_quantity_decrease",PRODUCT_ADD_TO_CART:"product_add_to_cart",PRODUCT_SIZE_CHANGED:"product_size_changed",PRODUCT_FULFILLMENT_TYPE_CHANGED:"product_fulfillment_type_changed",PRODUCT_FULFILLMENT_CHANGED:"product_fulfillment_changed",CART_LOADED:"cart_loaded",CART_CLOSED:"cart_closed",CART_OPENED:"cart_opened",CART_UPDATED:"cart_updated",CART_FAILED:"cart_failed",CART_RESET:"cart_reset",CART_ITEM_ADDED:"cart_item_added",CART_ITEM_REMOVED:"cart_item_removed",CART_ITEM_QUANTITY_INCREASE:"cart_item_quantity_increase",CART_ITEM_QUANTITY_DECREASE:"cart_item_quantity_decrease",CART_ITEM_ENGRAVING_UPDATED:"cart_item_engraving_updated",CART_PROMO_CODE_APPLIED:"cart_promo_code_applied",CART_PROMO_CODE_REMOVED:"cart_promo_code_removed",CART_PROMO_CODE_FAILED:"cart_promo_code_failed",CART_PRODUCT_ADD_SUCCESS:"cart_product_add_success",CART_PRODUCT_ADD_FAILED:"cart_product_add_failed",CHECKOUT_LOADED:"checkout_loaded",CHECKOUT_OPENED:"checkout_opened",CHECKOUT_CLOSED:"checkout_closed",CHECKOUT_FAILED:"checkout_failed",CHECKOUT_IS_GIFT_TOGGLED:"checkout_is_gift_toggled",CHECKOUT_BILLING_SAME_AS_SHIPPING_TOGGLED:"checkout_billing_same_as_shipping_toggled",CHECKOUT_MARKETING_PREFERENCES_TOGGLED:"checkout_marketing_preferences_toggled",CHECKOUT_CUSTOMER_INFORMATION_UPDATED:"checkout_customer_information_updated",CHECKOUT_GIFT_INFORMATION_UPDATED:"checkout_gift_information_updated",CHECKOUT_BILLING_INFORMATION_UPDATED:"checkout_billing_information_updated",CHECKOUT_ITEM_REMOVED:"checkout_item_removed",CHECKOUT_ITEM_QUANTITY_INCREASE:"checkout_item_quantity_increase",CHECKOUT_ITEM_QUANTITY_DECREASE:"checkout_item_quantity_decrease",CHECKOUT_ITEM_ENGRAVING_UPDATED:"checkout_item_engraving_updated",CHECKOUT_TIP_UPDATED:"checkout_tip_updated",CHECKOUT_SUBMIT_STARTED:"checkout_submit_started",CHECKOUT_SUBMIT_COMPLETED:"checkout_submit_completed",CHECKOUT_SUBMIT_FAILED:"checkout_submit_failed",CHECKOUT_PROMO_CODE_APPLIED:"checkout_promo_code_applied",CHECKOUT_PROMO_CODE_REMOVED:"checkout_promo_code_removed",CHECKOUT_PROMO_CODE_FAILED:"checkout_promo_code_failed",CHECKOUT_GIFT_CARD_APPLIED:"checkout_gift_card_applied",CHECKOUT_GIFT_CARD_REMOVED:"checkout_gift_card_removed",CHECKOUT_GIFT_CARD_FAILED:"checkout_gift_card_failed",CHECKOUT_PRODUCT_ADD_SUCCESS:"checkout_product_add_success",CHECKOUT_PRODUCT_ADD_FAILED:"checkout_product_add_failed"},w={CUSTOMER:"customer",GIFT:"gift",BILLING:"billing"},C={DRAWER:"drawer",INPUT:"input",BIRTHDATE_INPUT:"birthdate-input",ENGRAVING_FORM:"engraving-form",ENGRAVING_VIEW:"engraving-view",BUTTONS_CART_OPEN:"buttons-cart-open",POWERED_BY:"powered-by",LCE_ELEMENT:"lce-element",PURCHASE_MIN_ALERT:"purchase-min-alert",ALERT:"alert",PROMO_CODE_TICKER:"promo-code-ticker",ADDRESS:"address",ADDRESS_INPUT:"address-input",ADDRESS_DISPLAY:"address-display",PRODUCT:"product",PRODUCT_IMAGE_CAROUSEL:"product-image-carousel",PRODUCT_OPTIONS:"product-options",PRODUCT_INTERACTIONS:"product-interactions",PRODUCT_DESCRIPTION:"product-description",PRODUCT_RETAILERS:"product-retailers",PRODUCT_RETAILERS_CAROUSEL:"product-retailers-carousel",PRODUCT_RETAILERS_POPUP:"product-retailers-popup",PRODUCT_RETAILERS_POPUP_LIST:"product-retailers-popup-list",PRODUCT_PRICE:"product-price",PRODUCT_ADD_TO_CART_SECTION:"product-add-to-cart-section",PRODUCT_DRAWER:"product-drawer",PRODUCT_LOADING:"product-loading",PRODUCT_LIST:"product-list",PRODUCT_LIST_CARD:"product-list-card",PRODUCT_LIST_FILTERS:"product-list-filters",PRODUCT_LIST_SEARCH:"product-list-search",PRODUCT_LIST_CARD_LOADING:"product-list-card-loading",CART:"cart",CART_RETAILER:"cart-retailer",CART_ITEM:"cart-item",CART_FOOTER:"cart-footer",CART_ITEM_QUANTITY_PRICE:"cart-item-quantity-price",CART_RETAILER_SUBTOTAL:"cart-retailer-subtotal",CART_PROMO_CODE:"cart-promo-code",CART_HEADER:"cart-header",CART_BODY:"cart-body",CART_FULFILLMENT:"cart-fulfillment",CHECKOUT:"checkout",CHECKOUT_INFORMATION:"checkout-information",CHECKOUT_STRIPE_HANDLER:"checkout-stripe-handler",CHECKOUT_STRIPE_FORM:"checkout-stripe-form",CHECKOUT_PAYMENT:"checkout-payment",CHECKOUT_PAYMENT_SUMMARY:"checkout-payment-summary",CHECKOUT_BILLING:"checkout-billing",CHECKOUT_ORDER_SUMMARY:"checkout-order-summary",CHECKOUT_PROMO_CODE:"checkout-promo-code",CHECKOUT_GIFT_CARDS:"checkout-gift-cards",CHECKOUT_AMOUNTS:"checkout-amounts",CHECKOUT_ITEMS:"checkout-items",CHECKOUT_COMPLETED:"checkout-completed",CHECKOUT_DELIVER_TO:"checkout-deliver-to",CHECKOUT_DELIVER_TO_SUMMARY:"checkout-deliver-to-summary",CHECKOUT_BUYER:"checkout-buyer",CHECKOUT_BUYER_SUMMARY:"checkout-buyer-summary",CHECKOUT_TIPS:"checkout-tips",CHECKOUT_PC_GC:"checkout-pc-gc",CHECKOUT_ITEM:"checkout-item",CHECKOUT_ITEM_QUANTITY:"checkout-item-quantity",CHECKOUT_PLACE_ORDER_BUTTON:"checkout-place-order-button",CHECKOUT_HEADER:"checkout-header",CHECKOUT_PRESALE_COUNTDOWN:"checkout-presale-countdown",CHECKOUT_PRESALE_EXPIRED:"checkout-presale-expired",CHECKOUT_SEND_AS_GIFT:"checkout-send-as-gift"},E={ON_DEMAND:"onDemand",SHIPPING:"shipping"},T={NONE:"none",CONSOLE:"console",PANEL:"panel"},A={[b.DEVELOPMENT]:"https://dev-elements.liquidcommerce.us",[b.STAGING]:"https://staging-elements.liquidcommerce.us",[b.PRODUCTION]:"https://elements.liquidcommerce.us"},P={STANDARD:"standard"},_={PERSONALIZATION:"personalization",PRE_ORDER:"pre-order",DELIVERY_OPTIONS:"delivery-options",PRICE:"price",BRANDS:"brands",CATEGORIES:"categories",FLAVOR:"flavor",REGION:"region",VARIETY:"variety",VINTAGE:"vintage",COUNTRY:"country",APPELLATION:"appellation",MATERIALS:"materials",SIZES:"sizes"},N={DRAWER_WRAPPER:2147483640,DRAWER_CONTENT:5952,DRAWER_BACKDROP:5951,ADDRESS_SUGGESTIONS:5850,PRODUCT_DRAWER:5840,CART_LOADING:5750,LOADING_INDICATOR:5730,ERROR_MESSAGE:5650,CAROUSEL_CONTROLS:5580,PROGRESS_BAR:5560,CHECKOUT_HEADER:5920,INDEPENDENT_BUTTON:5910,CART_HEADER:5920,TOGGLE_SLIDER:5150,FORM_CONTROLS:5130,ADDRESS_ACTIONS:5050,SKELETON_WAVE:5040};class SingletonManager{static getInstances(){return"builder"===SingletonManager.currentContext?(SingletonManager.builderClientInstances||(SingletonManager.builderClientInstances=new Map),SingletonManager.builderClientInstances):(SingletonManager.regularClientInstances||(SingletonManager.regularClientInstances=new Map),SingletonManager.regularClientInstances)}constructor(){}static setContext({isBuilder:n}){SingletonManager.currentContext=n?"builder":"regular"}static setClientConstructor(n){SingletonManager.clientConstructor=n}static getClientConstructor(){return SingletonManager.clientConstructor}static getClassInstance(n,i){const r=SingletonManager.getInstances();r.has(n)||r.set(n,i());const s=r.get(n);if(!s)throw new SDKError("ElementsSdk: Instance for class "+n+" could not be created.");return s}static async getClient(n){const i=[n.apiKey,n.env,n.isBuilder,n.debugMode].join("_"),r="LiquidCommerceElementsClient_"+i,s=SingletonManager.getInstances();if(s.has(r))return s.get(r);if(!SingletonManager.clientConstructor)throw new SDKError("LiquidCommerce Elements: Client constructor is not set.");const a=new SingletonManager.clientConstructor(n);return await a.prepare(),s.set(r,a),a}}SingletonManager.clientConstructor=null,SingletonManager.regularClientInstances=null,SingletonManager.builderClientInstances=null,SingletonManager.currentContext="regular";const F="lce",R={identifier:"",id:"",brand:"",category:"",catPath:"",classification:"",type:"",subType:"",salsifyGrouping:"",name:"",description:"",htmlDescription:"",images:[],sizes:{},mainImage:null,region:"",country:"",material:"",abv:"",proof:"",age:"",color:"",flavor:"",variety:"",appellation:"",vintage:"",tastingNotes:"",productHasAvailability:![],fulfillmentHasAvailability:![],quantity:1,selectedFulfillmentType:E.SHIPPING,selectedSizeId:null,selectedFulfillmentId:null,selectedFulfillment:null,loading:![],updating:![],error:null,drawer:{isOpen:![],contentConfig:null},rerender:![]},O={id:null,loading:![],error:null,items:{},retailers:{},totals:{subtotal:0,total:0,shippingFee:0,platformFee:0,engravingFee:0,giftCardTotal:0,deliveryFee:0,discounts:0,quantity:0},promoCode:null,fulfillments:{},rerender:![],shouldReset:![],updatedAt:"",createdAt:"",events:[]},L={token:"",cartId:"",loading:![],updating:![],error:null,warning:[],presale:null,isGift:![],marketingPreferences:{canEmail:![],canSms:![]},customerForm:{data:{firstName:"",lastName:"",email:"",phone:"",birthDate:"",company:""},isEditing:!![],isValid:![],isSaving:![]},giftRecipientForm:{data:{firstName:"",lastName:"",email:"",phone:"",message:""},isEditing:!![],isValid:![],isSaving:![]},paymentForm:{paymentSession:null,paymentMethod:null,data:null,billingSameAsShipping:!![],isEditing:!![],isValid:![],isSaving:![]},shippingAddressTwo:"",promoCode:null,giftCards:[],orderNumber:null,items:{},amounts:{total:0,subtotal:0,shipping:0,discounts:0,delivery:0,platform:0,tax:0,engraving:0,giftCards:0,service:0,tip:0,details:{taxes:{bag:0,bottleDeposits:0,retailDelivery:0,products:0,delivery:0,shipping:0},discounts:{products:0,delivery:0,shipping:0,service:0,engraving:0}}},rerender:![],onDemandFulfillmentTipInfo:{},tipSelection:10,deliveryInstructions:"",giftCardError:null,promoCodeError:null,events:[]},M={drawer:{isOpen:![],contentConfig:null}},B={id:"",formattedAddress:"",address:{one:"",two:"",city:"",state:"",zip:"",country:""},coordinates:{lat:0,long:0}},W={products:{},cart:O,address:B,checkout:L,ui:M};class ClientConfigService{constructor(){this.config=null}static getInstance(){return SingletonManager.getClassInstance("ClientConfigService",()=>new ClientConfigService)}initialize(n,i={}){this.validateInputs(n,i),this.config=Object.freeze(this.buildConfiguration(n,i))}getConfigs(){return{...this.config}}get(n){return this.config[n]}set(n,i){if(!this.config)throw new SDKError("Configuration service is not ready. Please initialize first.");this.config=Object.freeze({...this.config,[n]:i})}isDevelopment(){return this.get("env")===b.DEVELOPMENT}isStaging(){return this.get("env")===b.STAGING}isProduction(){return this.get("env")===b.PRODUCTION}isBuilder(){return this.get("isBuilder")}isDebuggingEnabled(){const n=this.get("debugMode");return n===T.CONSOLE||n===T.PANEL}isDebugPanelEnabled(){return this.get("debugMode")===T.PANEL}debuggingDisabled(){const n=this.get("debugMode");return n===T.NONE}hasCustomTheme(){return null!==this.get("customTheme")}isMobile(){return"mobile"===this.get("deviceType")}isLocalStorageAvailable(){return Boolean(this.get("isLocalStorageAvailable"))}getProxyConfig(){return this.get("proxy")}validateInputs(n,i){if(!(null==n?void 0:n.trim()))throw new SDKError("API key is required. Please provide a valid API key.",!![]);if(i.env&&!Object.values(b).includes(i.env)&&(console.warn('[LiquidCommerce Elements] Invalid environment "'+i.env+'". Using default environment.'),i.env=void 0),void 0!==i.isBuilder&&"boolean"!=typeof i.isBuilder&&(console.warn("[LiquidCommerce Elements] isBuilder must be a boolean. Using default value."),i.isBuilder=void 0),void 0===i.debugMode||Object.values(T).includes(i.debugMode)||(console.warn('[LiquidCommerce Elements] Invalid debugMode "'+i.debugMode+'". Must be one of: '+Object.values(T).join(", ")+". Using default value."),i.debugMode=void 0),i.promoTicker&&"object"!=typeof i.promoTicker&&(console.warn("[LiquidCommerce Elements] promoTicker must be an object. Skipping promoTicker configuration."),i.promoTicker=void 0),i.promoTicker)if(Array.isArray(i.promoTicker)){const n=i.promoTicker.filter((n,i)=>{if("string"!=typeof n.promoCode||!n.promoCode.trim())return console.warn("[LiquidCommerce Elements] promoTicker["+i+"].promoCode is required and must be a non-empty string. Skipping this promo."),![];if(!Array.isArray(n.text)||0===n.text.length||!n.text.every(n=>"string"==typeof n&&n.trim()))return console.warn("[LiquidCommerce Elements] promoTicker["+i+"].text is required and must be a non-empty array of strings. Skipping this promo."),![];if("string"!=typeof n.separator||!n.separator.trim())return console.warn("[LiquidCommerce Elements] promoTicker["+i+"].separator is required and must be a non-empty string. Skipping this promo."),![];if(!n.activeFrom)return console.warn("[LiquidCommerce Elements] promoTicker["+i+"].activeFrom is required. Skipping this promo."),![];const r="string"==typeof n.activeFrom?new Date(n.activeFrom):n.activeFrom;if(!(r instanceof Date)||Number.isNaN(r.getTime()))return console.warn("[LiquidCommerce Elements] promoTicker["+i+"].activeFrom must be a valid Date object or ISO date string. Skipping this promo."),![];if(!n.activeUntil)return console.warn("[LiquidCommerce Elements] promoTicker["+i+"].activeUntil is required. Skipping this promo."),![];const s="string"==typeof n.activeUntil?new Date(n.activeUntil):n.activeUntil;return s instanceof Date&&!Number.isNaN(s.getTime())?r>=s?(console.warn("[LiquidCommerce Elements] promoTicker["+i+"].activeFrom must be earlier than activeUntil. Skipping this promo."),![]):!![]:(console.warn("[LiquidCommerce Elements] promoTicker["+i+"].activeUntil must be a valid Date object or ISO date string. Skipping this promo."),![])});i.promoTicker=n.length>0?n:void 0}else console.warn("[LiquidCommerce Elements] promoTicker must be an array. Skipping promoTicker configuration."),i.promoTicker=void 0;i.proxy&&("object"!=typeof i.proxy?(console.warn("[LiquidCommerce Elements] proxy must be an object. Skipping proxy configuration."),i.proxy=void 0):i.proxy.baseUrl&&"string"==typeof i.proxy.baseUrl?i.proxy.headers&&"object"!=typeof i.proxy.headers&&(console.warn("[LiquidCommerce Elements] proxy.headers must be an object. Skipping proxy configuration."),i.proxy=void 0):(console.warn("[LiquidCommerce Elements] proxy.baseUrl is required and must be a string. Skipping proxy configuration."),i.proxy=void 0))}buildConfiguration(n,i){var r,s,a;const l=i.env||b.PRODUCTION;let d=A[l];const u=l===b.PRODUCTION,f=i.isBuilder||![],g=F+(u?"":"_"+l)+(f?"builder":"");return(null===(r=i.development)||void 0===r?void 0:r.customApiUrl)&&(d=i.development.customApiUrl),{apiKey:n.trim(),env:l,isBuilder:f,debugMode:i.debugMode||T.NONE,baseUrl:d,partnerCode:void 0,partnerName:void 0,customTheme:i.customTheme||null,proxy:i.proxy||null,deviceType:this.detectDeviceType(),userDeviceId:void 0,localStorageKeyPrefix:g,isLocalStorageAvailable:void 0,version:void 0,clientPrepared:![],promoTicker:i.promoTicker||null,paymentMethodId:(null===(s=i.development)||void 0===s?void 0:s.paymentMethodId)||void 0,openShadowDom:u?![]:(null===(a=i.development)||void 0===a?void 0:a.openShadowDom)||![]}}detectDeviceType(){var n,i;if("undefined"==typeof navigator)return"desktop";const r=navigator.userAgent.toLowerCase(),s="ontouchstart"in window||navigator.maxTouchPoints>0,a=(null===(n=window.screen)||void 0===n?void 0:n.width)||0,l=(null===(i=window.screen)||void 0===i?void 0:i.height)||0,d=Math.max(a,l),u=[/ipad/,/android(?!.*mobile)/,/tablet/,/kindle/,/playbook/,/silk/,/gt-p\d{4}/,/nexus (7|9|10)/,/xoom/,/sch-i800/,/galaxy tab/,/surface/,/googletv/,/appletv/,/hbbtv/,/roku/,/smarttv/,/webtv/],f=[/android.*mobile/,/iphone/,/ipod/,/blackberry/,/opera mini/,/opera mobi/,/iemobile/,/mobile/,/webos/,/palm/,/symbian/,/nokia/,/fennec/,/maemo/,/windows phone/,/windows ce/,/htc/,/samsung.*mobile/,/lg.*mobile/,/motorola/,/sony.*mobile/,/watch/,/applewatch/,/wearos/,/tizen/];return u.some(n=>n.test(r))?"tablet":f.some(n=>n.test(r))||s&&d<768?"mobile":s&&d>=768&&d<=1200||s&&/macintosh/i.test(r)&&navigator.maxTouchPoints>1||/android/i.test(r)&&s&&d>=768||/windows nt/i.test(r)&&s&&d>=768?"tablet":(/automotive|carplay|android auto|car browser/i.test(r),"desktop")}}class LoggerService{constructor(n){this.prefix="LiquidCommerce Elements",this.colors={debug:"#9CA3AF",log:"#60A5FA",info:"#22D3EE",warn:"#FB923C",error:"#F87171",prefix:"#C084FC"},this.enableLogging=![],this.telemetryService=null,this.context=n}static getInstance(n){return SingletonManager.getClassInstance("LoggerService_"+n,()=>new LoggerService(n))}setEnableLogging(n){this.enableLogging=n}setTelemetryService(n){this.telemetryService=n}getPrefix(n){if(!this.enableLogging)return[];const i=(new Date).toISOString().slice(11,23);return["%c["+i+"%c "+this.prefix+"%c "+this.context+"%c]","color: "+this.colors[n],"color: "+this.colors.prefix+"; font-weight: bold","color: "+this.colors[n],"color: "+this.colors[n]]}debug(n,i){if(this.sendToTelemetry("debug",n,void 0,i),!this.enableLogging)return;const[r,...s]=this.getPrefix("debug");void 0!==i?console.debug(r,...s,n,i):console.debug(r,...s,n)}info(n,i){if(!this.enableLogging)return;const[r,...s]=this.getPrefix("info");void 0!==i?console.info(r,...s,n,i):console.info(r,...s,n)}warn(n,i){if(this.sendToTelemetry("warn",n,void 0,i),!this.enableLogging)return;const[r,...s]=this.getPrefix("warn");void 0!==i?console.warn(r,...s,n,i):console.warn(r,...s,n)}error(n,i){const r=i instanceof Error,s=r?i:void 0,a=!r&&i?i:void 0;if(this.sendToTelemetry("error",n,s,a),!this.enableLogging)return;const[l,...d]=this.getPrefix("error");void 0!==i?console.error(l,...d,n,i):console.error(l,...d,n)}sendToTelemetry(n,i,r,s){if(this.telemetryService&&this.telemetryService.isEnabled())try{this.telemetryService.captureEvent(n,i,{context:this.context,error:r,data:s})}catch(a){}}}class LoggerFactory{static getInstances(){return LoggerFactory.instances||(LoggerFactory.instances=new Map),LoggerFactory.instances}static get(n){const i=this.getInstances();if(!i.has(n)){const r=LoggerService.getInstance(n);r.setEnableLogging(this.enableLoggingGlobally),this.telemetryService&&r.setTelemetryService(this.telemetryService),i.set(n,r)}return i.get(n)}static setEnableLogging(n){this.enableLoggingGlobally=n;const i=this.getInstances();for(const[,r]of i)r.setEnableLogging(n)}static setTelemetryService(n){this.telemetryService=n;const i=this.getInstances();for(const[,r]of i)r.setTelemetryService(n)}}function componentError({componentType:n,message:i}){const r=document.createElement("div");r.className=n;const s=r.attachShadow({mode:"closed"}),a=document.createElement("style");a.textContent='\n div {\n padding: 10px;\n background-color: #1d4ed81a;\n border-radius: 6px;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;\n }\n\n h3 {\n margin: 0;\n font-size: 16px;\n font-weight: 600;\n color: #d63031;\n line-height: 1.4;\n margin-bottom: 5px;\n }\n\n p {\n margin: 0;\n font-size: 14px;\n font-weight: 400;\n color: #18181B;\n line-height: 1.5;\n max-width: 350px;\n }\n ';const l=document.createElement("div"),d=document.createElement("h3");d.textContent="Component </"+n+">";const u=document.createElement("p");return u.textContent=i,l.appendChild(a),l.appendChild(d),l.appendChild(u),s.appendChild(l),r}function productionComponentError({title:n,message:i,componentType:r}){const s=document.createElement("div");s.setAttribute("data-component-type",r);const a=s.attachShadow({mode:"closed"}),l=document.createElement("style");l.textContent="\n div {\n padding: 20px;\n background-color: #1d4ed81a;\n border-radius: 8px;\n box-sizing: border-box;\n font-family: Poppins, sans-serif;\n max-width: 512px;\n display: block;\n }\n\n h2 {\n color: #18181B;\n margin: 0 0 8px 0;\n font-size: 18px;\n font-style: normal;\n font-weight: 600;\n line-height: 18px;\n text-transform: lowercase;\n }\n\n h2::first-letter {\n text-transform: uppercase;\n }\n\n p {\n color: #18181B;\n font-size: 14px;\n font-style: italic;\n font-weight: 400;\n line-height: 20px;\n margin: 0;\n }\n ";const d=document.createElement("div"),u=document.createElement("h2");u.textContent=n;const f=document.createElement("p");return f.textContent=i,d.appendChild(l),d.appendChild(u),d.appendChild(f),a.appendChild(d),s}LoggerFactory.instances=null,LoggerFactory.enableLoggingGlobally=![],LoggerFactory.telemetryService=null;class ComponentFactoryService{static get logger(){return ComponentFactoryService.t||(ComponentFactoryService.t=LoggerFactory.get("ComponentFactory")),ComponentFactoryService.t}static get clientConfig(){return ComponentFactoryService.i||(ComponentFactoryService.i=ClientConfigService.getInstance()),ComponentFactoryService.i}static getComponentRegistry(){return ComponentFactoryService.componentRegistry||(ComponentFactoryService.componentRegistry=new Map),ComponentFactoryService.componentRegistry}static registerComponent(n,i){ComponentFactoryService.getComponentRegistry().set(n,i)}static createElement(n){try{const i=ComponentFactoryService.getComponentRegistry().get(n.type);if(!i)throw new SDKError("Component type ["+n.type+"] is not registered");const r=ComponentFactoryService.getComponentTagName(n.type);window.customElements.get(r)||window.customElements.define(r,i);const s=document.createElement(r);if(s.initialize){const{type:i,useShadowDom:a,wrapInLceElement:l,...d}=n,u={type:i,tagName:r,useShadowDom:a&&l!==!![]};s.initialize({data:d,config:u})}if(n.wrapInLceElement){const i=ComponentFactoryService.getComponentRegistry().get(C.LCE_ELEMENT),r=ComponentFactoryService.getComponentTagName(C.LCE_ELEMENT);window.customElements.get(r)||window.customElements.define(r,i);const a=document.createElement(r);return a.initialize(n.type,s),a}return s}catch(i){return ComponentFactoryService.logger.error("Failed to create component </"+n.type+">",i),ComponentFactoryService.clientConfig.isProduction()?productionComponentError({title:n.type.replace(/-/g," ")+" is not available.",message:"We're sorry, this element is currently unavailable.",componentType:n.type}):componentError({componentType:n.type,message:(null==i?void 0:i.message)||i})}}static componentError({componentType:n,message:i}){return ComponentFactoryService.logger.error("Component type "+n+" failed to load: "+i),ComponentFactoryService.clientConfig.isProduction()?productionComponentError({title:n.replace(/-/g," ")+" is not available.",message:"We're sorry, this element is currently unavailable.",componentType:n}):componentError({componentType:n,message:i})}static getComponentTagName(n){const i={[C.DRAWER]:"drawer-lc",[C.INPUT]:"input-lc",[C.BIRTHDATE_INPUT]:"birthdate-input-lc",[C.ENGRAVING_FORM]:"engraving-form-lc",[C.ENGRAVING_VIEW]:"engraving-view-lc",[C.BUTTONS_CART_OPEN]:"buttons-cart-open-lc",[C.POWERED_BY]:"powered-by-lc",[C.LCE_ELEMENT]:"lce-element",[C.PURCHASE_MIN_ALERT]:"purchase-min-alert-lc",[C.ALERT]:"alert-lc",[C.PROMO_CODE_TICKER]:"promo-code-ticker-lc",[C.ADDRESS]:"address-lc",[C.ADDRESS_INPUT]:"address-input-lc",[C.ADDRESS_DISPLAY]:"address-display-lc",[C.PRODUCT]:"product-lc",[C.PRODUCT_OPTIONS]:"product-options-lc",[C.PRODUCT_IMAGE_CAROUSEL]:"product-image-carousel-lc",[C.PRODUCT_INTERACTIONS]:"product-interactions-lc",[C.PRODUCT_DESCRIPTION]:"product-description-lc",[C.PRODUCT_ADD_TO_CART_SECTION]:"product-add-to-cart-section-lc",[C.PRODUCT_RETAILERS]:"product-retailers-lc",[C.PRODUCT_RETAILERS_CAROUSEL]:"product-retailers-carousel-lc",[C.PRODUCT_RETAILERS_POPUP]:"product-retailers-popup-lc",[C.PRODUCT_RETAILERS_POPUP_LIST]:"product-retailers-popup-list-lc",[C.PRODUCT_PRICE]:"product-price-lc",[C.PRODUCT_DRAWER]:"product-drawer-lc",[C.PRODUCT_LOADING]:"product-loading-lc",[C.PRODUCT_LIST]:"product-list-lc",[C.PRODUCT_LIST_CARD]:"product-list-card-lc",[C.PRODUCT_LIST_FILTERS]:"product-list-filters-lc",[C.PRODUCT_LIST_SEARCH]:"product-list-search-lc",[C.PRODUCT_LIST_CARD_LOADING]:"product-list-card-loading-lc",[C.CART]:"cart-lc",[C.CART_RETAILER]:"cart-retailer-lc",[C.CART_ITEM]:"cart-item-lc",[C.CART_FOOTER]:"cart-footer-lc",[C.CART_ITEM_QUANTITY_PRICE]:"cart-item-quantity-price-lc",[C.CART_RETAILER_SUBTOTAL]:"cart-retailer-subtotal-lc",[C.CART_PROMO_CODE]:"cart-promo-code-lc",[C.CART_HEADER]:"cart-header-lc",[C.CART_BODY]:"cart-body-lc",[C.CART_FULFILLMENT]:"cart-fulfillment-lc",[C.CHECKOUT]:"checkout-lc",[C.CHECKOUT_INFORMATION]:"checkout-information-lc",[C.CHECKOUT_PAYMENT]:"checkout-payment-lc",[C.CHECKOUT_PAYMENT_SUMMARY]:"checkout-payment-summary-lc",[C.CHECKOUT_STRIPE_HANDLER]:"checkout-stripe-handler-lc",[C.CHECKOUT_STRIPE_FORM]:"checkout-stripe-form-lc",[C.CHECKOUT_BILLING]:"checkout-billing-lc",[C.CHECKOUT_ORDER_SUMMARY]:"checkout-order-summary-lc",[C.CHECKOUT_PROMO_CODE]:"checkout-promo-code-lc",[C.CHECKOUT_GIFT_CARDS]:"checkout-gift-cards-lc",[C.CHECKOUT_AMOUNTS]:"checkout-amounts-lc",[C.CHECKOUT_ITEMS]:"checkout-items-lc",[C.CHECKOUT_COMPLETED]:"checkout-completed-lc",[C.CHECKOUT_DELIVER_TO]:"checkout-deliver-to-lc",[C.CHECKOUT_DELIVER_TO_SUMMARY]:"checkout-deliver-to-summary-lc",[C.CHECKOUT_BUYER]:"checkout-buyer-lc",[C.CHECKOUT_BUYER_SUMMARY]:"checkout-buyer-summary-lc",[C.CHECKOUT_TIPS]:"checkout-tips-lc",[C.CHECKOUT_PC_GC]:"checkout-pc-gc-lc",[C.CHECKOUT_ITEM]:"checkout-item-lc",[C.CHECKOUT_ITEM_QUANTITY]:"checkout-item-quantity-lc",[C.CHECKOUT_PLACE_ORDER_BUTTON]:"checkout-place-order-button-lc",[C.CHECKOUT_HEADER]:"checkout-header-lc",[C.CHECKOUT_PRESALE_COUNTDOWN]:"checkout-presale-countdown-lc",[C.CHECKOUT_PRESALE_EXPIRED]:"checkout-presale-expired-lc",[C.CHECKOUT_SEND_AS_GIFT]:"checkout-send-as-gift-lc"};return i[n]||n.toLowerCase()+"-lc"}}ComponentFactoryService.t=null,ComponentFactoryService.i=null,ComponentFactoryService.componentRegistry=null;class PubSubService{constructor(){this.clientReadyEvent=null,this.eventPrefix="lce",this.logger=LoggerFactory.get("PubSub"),this.setupClientReadyBuffering()}static getInstance(){return SingletonManager.getClassInstance("PubSubService",()=>new PubSubService)}publishAction(n,i){this.publishSpecific("actions."+n,i)}publishForm(n,i){this.publishSpecific("forms."+n,i)}publishSpecific(n,i){const[r,s]=n.includes(".")?n.split(".",2):["actions",n];let a=s.split("_")[0];["product","cart","address","checkout"].includes(a)||(a="other");const l=Date.now(),d={eventId:"evt_"+l+"_"+Math.random().toString(36).slice(2,9),namespace:r,event:s,originalEvent:n,actionNamespace:"actions"===r?a:void 0,timestamp:l},u={data:i,metadata:d};this.dispatchNativeEvents(n,u)}dispatchNativeEvents(n,i){const[r]=n.split(".",2);try{"actions.client_ready"===n&&(this.clientReadyEvent=i);const s=new CustomEvent(this.eventPrefix+":"+n,{detail:i,bubbles:!![],cancelable:!![]});window.dispatchEvent(s);const a=new CustomEvent(this.eventPrefix+":"+r,{detail:i,bubbles:!![],cancelable:!![]});window.dispatchEvent(a)}catch(s){this.logger.error("Error dispatching native events for "+n,s)}}setupClientReadyBuffering(){const n=window.addEventListener,i=this.eventPrefix+":actions.client_ready";window.addEventListener=(r,s,a)=>{if(r!==i)return n.call(window,r,s,a);if(!this.clientReadyEvent)return n.call(window,r,s,a);try{const n=new CustomEvent(i,{detail:this.clientReadyEvent,bubbles:!![],cancelable:!![]});"function"==typeof s?s(n):s&&"function"==typeof s.handleEvent&&s.handleEvent(n)}catch(l){this.logger.error("Error replaying CLIENT_READY event",l)}return n.call(window,r,s,a)}}}function centToDollar(n){return n/100}function formatCentToDollarText(n,i=!![]){const r=Math.floor(n/100),s=n%100;let a="$"+r.toString().replace(/\B(?=(\d{3})+(?!\d))/g,",");return(i||s>0)&&(a+=".",a+=s<10?"0"+s:s.toString()),a}function htmlStringToElement(n){const i=document.createElement("template");return i.innerHTML=n.trim(),i.content.firstElementChild}function format24TimeTo12$1(n){const i=n.match(/^(\d{1,2}):(\d{2})$/);if(!i)throw new SDKError("Invalid time format: "+n);const r=Number.parseInt(i[1],10),s=Number.parseInt(i[2],10);if(r<0||r>23||s<0||s>59)throw new SDKError("Invalid time values: "+n);const a=r>=12?"PM":"AM",l=r%12||12;return l+":"+s.toString().padStart(2,"0")+" "+a}function formatISODateToMMDDYYYY(n){if(!n)return"";try{const i=new Date(n);if(Number.isNaN(i.getTime()))return"";const r=(i.getMonth()+1).toString().padStart(2,"0"),s=i.getDate().toString().padStart(2,"0"),a=i.getFullYear().toString();return r+"/"+s+"/"+a}catch(i){return""}}function buildFormattedAddressString(n){const i=[],r=[];n.one&&n.one.trim()&&r.push(n.one.trim()),n.two&&n.two.trim()&&r.push(n.two.trim()),r.length>0&&i.push(r.join(" ")),n.city&&n.city.trim()&&i.push(n.city.trim());const s=[];return n.state&&n.state.trim()&&s.push(n.state.trim()),n.zip&&n.zip.trim()&&s.push(n.zip.trim()),s.length>0&&i.push(s.join(" ")),n.country&&n.country.trim()&&i.push(n.country.trim()),i.join(", ")}function capitalizeFirstLetter(n){return n?n.toLowerCase().split(" ").map(n=>n.charAt(0).toUpperCase()+n.substring(1)).join(" "):n}function splitCategoryPath(n){const i=(null==n?void 0:n.split(" > ").map(n=>capitalizeFirstLetter(n.trim())))||[];return{category:i[0]||"",category2:i[1]||"",category3:i[2]||""}}class ApiClientService{constructor(){this.client=null,this.logger=LoggerFactory.get("ApiClient")}static getInstance(){return SingletonManager.getClassInstance("ApiClientService",()=>new ApiClientService)}async setClient(n){this.client=n}async getAllConfigs(){try{this.ensureClientInitialized();const n=await this.client.get("/configs");if(!this.validResponseData(n))throw this.logger.error("Invalid response data",n),new SDKError("Failed to fetch all configs: Invalid response data");return n.data}catch(n){throw this.logger.error("Error fetching configs",n),n}}async setPersistedStore(n,i){try{if(this.ensureClientInitialized(),!n)return this.logger.error("User device ID is required to set persisted store"),void 0;if(!i||0===Object.keys(i).length)return this.logger.error("No data provided to set persisted store"),void 0;const r=await this.client.post("/configs/store/"+n,{body:i});200!==r.statusCode&&this.logger.error("Failed to set persisted store",r)}catch(r){this.logger.error("Error setting persisted store",r)}}async getPersistedStore(n){try{if(this.ensureClientInitialized(),!n)return this.logger.error("User device ID is required to get persisted store"),null;const i=await this.client.get("/configs/store/"+n);return 200!==i.statusCode?(this.logger.error("Failed to fetch persisted store",i),null):i.data}catch(i){return this.logger.error("Error fetching persisted store",i),null}}async deletePersistedStore(n){try{if(this.ensureClientInitialized(),!n)return this.logger.error("User device ID is required to delete persisted store"),void 0;const i=await this.client.delete("/configs/store/"+n);200!==i.statusCode&&this.logger.error("Failed to delete persisted store",i)}catch(i){this.logger.error("Error deleting persisted store",i)}}async getProductsData(n,i){try{if(this.ensureClientInitialized(),0===n.length)return this.logger.error("No product identifiers provided"),null;const r={upcs:n,ids:n,grouping:n,shouldShowOffHours:!![],isLegacy:!![],loc:i},s=await this.client.post("/cloud/catalog/availability",{body:r});return 200!==s.statusCode?(this.logger.error("Failed to fetch product data",s),null):{products:s.products,retailers:s.retailers}}catch(r){return this.logger.error("Error fetching product data",r),null}}async getCartData(n){try{this.ensureClientInitialized();const i=await this.client.get("/cloud/cart"+(n?"?id="+n:""));if(200!==i.statusCode)throw this.logger.error("Failed to fetch cart data",i),new SDKError("Failed to fetch cart data: "+i.message);return i.cart}catch(i){throw this.logger.error("Error fetching cart data",i),i}}async updateCart(n){try{this.ensureClientInitialized();const i=await this.client.put("/cloud/cart",{body:n});if(200!==i.statusCode)throw this.logger.error("Failed to update cart",i),new SDKError("Failed to update cart: "+i.message);return i.cart}catch(i){throw this.logger.error("Error updating cart",i),i}}async getAddressSuggestions(n){try{if(this.ensureClientInitialized(),!n||0===n.trim().length)return this.logger.error("Query is required to fetch address suggestions"),[];const i=await this.client.get("/cloud/address/autocomplete?input="+encodeURIComponent(n));return 200!==i.statusCode?(this.logger.error("Failed to fetch address suggestions",i),[]):i.data}catch(i){return this.logger.error("Error fetching address suggestions",i),[]}}async getAddressDetails(n){try{if(this.ensureClientInitialized(),!n||0===n.trim().length)throw this.logger.error("Address ID is required to fetch address details"),new SDKError("Address ID is required to fetch address details");const i=await this.client.get("/cloud/address/details/"+n);if(200!==i.statusCode)throw this.logger.error("Failed to fetch address details",i),new SDKError("Failed to fetch address details: "+i.message);return i.data}catch(i){throw this.logger.error("Error fetching address details",i),i}}async prepareCheckout(n){var i;try{this.ensureClientInitialized();const i=await this.client.post("/cloud/checkout/prepare",{body:n});if(200!==i.statusCode)throw this.logger.error("Failed to fetch prepare checkout data",i),new SDKError("Failed to fetch prepare checkout data: "+i.message);return i.checkout}catch(r){throw this.logger.error("Error fetching prepare checkout data:",null!==(i=null==r?void 0:r.message)&&void 0!==i?i:r),r}}async getPaymentSession(n){var i;try{this.ensureClientInitialized();const i=await this.client.post("/cloud/payment/session",{body:n});if(201!==i.statusCode)throw this.logger.error("Failed to get payment session",i),new SDKError("Failed to get payment session: "+i.message);return i.data}catch(r){throw this.logger.error("Error fetching payment session:",null!==(i=null==r?void 0:r.message)&&void 0!==i?i:r),r}}async confirmPaymentSession(n,i){try{this.ensureClientInitialized();const r=await this.client.post("/cloud/payment/confirm",{body:{confirmationTokenId:n,setupIntentId:i}});if(200!==r.statusCode)throw this.logger.error("Failed to confirm payment session",r),new SDKError("Failed to confirm payment session: "+r.message);return r.data}catch(r){throw this.logger.error("Error confirming payment session",r),r}}async checkoutComplete(n){var i;try{this.ensureClientInitialized();const i=await this.client.post("/cloud/checkout/complete",{body:n});if(200!==i.statusCode)throw this.logger.error("Failed to complete checkout",i),new SDKError("Failed to complete checkout: "+i.message);return i.order}catch(r){if(this.logger.error("Error completing checkout:",null!==(i=null==r?void 0:r.message)&&void 0!==i?i:r),null==r?void 0:r.error)throw new SDKError(r.error);throw r}}async catalogSearch(n){var i;try{this.ensureClientInitialized();const i=await this.client.post("/cloud/catalog/search",{body:n});if(200!==i.statusCode)throw this.logger.error("Failed to fetch catalog search data",i),new SDKError("Failed to fetch catalog search data: "+i.message);return{products:i.products,retailers:i.retailers,navigation:i.navigation}}catch(r){return this.logger.error("Error fetching catalog search data:",null!==(i=null==r?void 0:r.message)&&void 0!==i?i:r),{products:[],retailers:[],navigation:void 0}}}validResponseData(n){return n.data&&"object"==typeof n.data&&Object.keys(n.data).length>0}ensureClientInitialized(){if(!this.client)throw new SDKError("API client is not initialized")}}class HttpClientService{constructor(){this.logger=LoggerFactory.get("HttpClient"),this.defaultShouldRetry=(n,i)=>n||i&&i.status>=500&&i.status<600?!![]:![],this.xhrFetch=(n,i)=>new Promise((r,s)=>{const a=new XMLHttpRequest;a.open(i.method||"GET",n);for(const[n,l]of Object.entries(i.headers))a.setRequestHeader(n,l);a.onload=()=>{const n={ok:a.status>=200&&a.status<300,status:a.status,statusText:a.statusText,headers:a.getAllResponseHeaders().split("\r\n").reduce((n,i)=>{const[r,s]=i.split(": ");return r&&s&&(n[r]=s),n},{}),o:a.responseText,json:()=>Promise.resolve(JSON.parse(a.responseText)),text:()=>Promise.resolve(a.responseText)};r(n)},a.onerror=()=>{s(new TypeError("Network request failed"))},a.ontimeout=()=>{s(new TypeError("Network request timed out"))},a.timeout=3e4,a.send(i.body)}),this.fetchImpl=this.getFetchImplementation()}async request(n){var i,r,s;const{url:a,options:l,retryConfig:d}=n,u=null!==(i=null==d?void 0:d.maxRetries)&&void 0!==i?i:3,f=null!==(r=null==d?void 0:d.retryDelay)&&void 0!==r?r:1e3,g=null!==(s=null==d?void 0:d.shouldRetry)&&void 0!==s?s:this.defaultShouldRetry;let v;const b=Date.now();for(let w=0;w<=u;w++){let n=Date.now();try{n=Date.now();const i=await this.fetchImpl(a,l),r=Date.now()-n;if(i.ok)return i;if(await this.logFailedResponse(a,l,i,r,w,u),w<u&&g(null,i)){await this.delay(f*2**w);continue}return i}catch(x){const i=Date.now()-n;if(v=x,this.logNetworkError(a,l,x,i,w,u),w<u&&g(x,void 0)){await this.delay(f*2**w);continue}throw this.enhanceError(x,a,l,Date.now()-b)}}throw this.enhanceError(v,a,l,Date.now()-b)}async logFailedResponse(n,i,r,s,a,l){const d=a<l;let u,f;try{r.o||(r.o=await r.text());try{u=JSON.parse(r.o)}catch(g){u=r.o}}catch(v){u="[Unable to read response body]"}if(i.body)try{f=JSON.parse(i.body)}catch(b){f=i.body}this.logger.error("HTTP request failed",{method:i.method,url:n,status:r.status,statusText:r.statusText,duration:s+"ms",attempt:a+1+"/"+(l+1),willRetry:d,requestHeaders:this.sanitizeHeaders(i.headers),requestBody:f,responseHeaders:this.sanitizeHeaders(r.headers),responseBody:u})}logNetworkError(n,i,r,s,a,l){var d;const u=a<l;this.logger.error("Network request failed",{method:i.method,url:n,error:(null==r?void 0:r.message)||"Unknown error",errorType:(null===(d=null==r?void 0:r.constructor)||void 0===d?void 0:d.name)||typeof r,duration:s+"ms",attempt:a+1+"/"+(l+1),willRetry:u,possibleCauses:this.diagnosePossibleCauses(r)})}diagnosePossibleCauses(n){var i,r,s,a,l;const d=[];return((null===(i=null==n?void 0:n.message)||void 0===i?void 0:i.includes("timeout"))||(null===(r=null==n?void 0:n.message)||void 0===r?void 0:r.includes("timed out")))&&d.push("Request timeout - server took too long to respond"),((null===(s=null==n?void 0:n.message)||void 0===s?void 0:s.includes("Failed to fetch"))||(null===(a=null==n?void 0:n.message)||void 0===a?void 0:a.includes("Network request failed")))&&(d.push("Network connectivity issue"),d.push("CORS policy blocking the request"),d.push("Server is not responding"),d.push("Request was blocked by browser or firewall")),(null===(l=null==n?void 0:n.message)||void 0===l?void 0:l.includes("aborted"))&&d.push("Request was aborted"),0===d.length&&d.push("Unknown network error"),d}enhanceError(n,i,r,s){const a=new Error((null==n?void 0:n.message)||"Network request failed - no response from server");return a.url=i,a.method=r.method,a.totalDuration=s+"ms",a.isNetworkError=!![],a.originalError=n,a.possibleCauses=this.diagnosePossibleCauses(n),a}sanitizeHeaders(n){const i={...n},r=["authorization","x-liquid-api-key","cookie","set-cookie"];for(const s of Object.keys(i))r.includes(s.toLowerCase())&&(i[s]="[REDACTED]");return i}delay(n){return new Promise(i=>setTimeout(i,n))}getFetchImplementation(){return"undefined"!=typeof fetch?this.fetchAdapter(fetch):"undefined"!=typeof global&&global.fetch?this.fetchAdapter(global.fetch):window.fetch?this.fetchAdapter(window.fetch):this.xhrFetch}fetchAdapter(n){return async(i,r)=>{var s;const a=await n(i,r);let l;if("function"==typeof(null===(s=a.headers)||void 0===s?void 0:s.entries))l=Object.fromEntries(a.headers.entries());else{l={};for(const[n,i]of a.headers)l[n]=i}const d={ok:a.ok,status:a.status,statusText:a.statusText,headers:l,json:async()=>(d.o||(d.o=await a.text()),JSON.parse(d.o)),text:async()=>(d.o||(d.o=await a.text()),d.o)};return d}}}class AuthClientService{constructor(n){this.accessToken=null,this.tokenExpiration=null,this.isAuthenticating=![],this.apiKey=n.apiKey,this.baseUrl=n.baseUrl,this.env=n.env,this.httpClient=new HttpClientService,this.logger=LoggerFactory.get("Auth"),this.clientConfig=ClientConfigService.getInstance()}static getInstance(n){return SingletonManager.getClassInstance("AuthService",()=>new AuthClientService(n))}async authenticate(){var n,i;if(this.isAuthenticating)return await new Promise(n=>{const t=()=>{this.isAuthenticating?setTimeout(t,100):n(void 0)};t()}),!!this.accessToken;this.isAuthenticating=!![];try{const r=await this.request("/auth",{method:"GET"},!![]),s=3e5;return this.accessToken=null===(n=null==r?void 0:r.data)||void 0===n?void 0:n.token,this.tokenExpiration=(null===(i=null==r?void 0:r.data)||void 0===i?void 0:i.exp)-s,!![]}catch(r){return this.logger.error("Authentication failed",r),![]}finally{this.isAuthenticating=![]}}isTokenExpired(){return this.tokenExpiration?Date.now()>=this.tokenExpiration:!![]}async request(n,i,r=![]){var s;r||this.accessToken&&!this.isTokenExpired()||await this.authenticate();const a=this.buildUrl(n),l={"Content-Type":"application/json","X-Liquid-Api-Env":this.env,"X-Liquid-Api-Sdk":window.location.href,"X-Liquid-Sdk-Version":this.clientConfig.get("version")||"unknown","X-Liquid-Timestamp":Date.now(),...this.getProxyHeaders(),...i.headers};r?l["X-Liquid-Api-Key"]=this.apiKey:l.Authorization="Bearer "+this.accessToken,this.clientConfig.isBuilder()&&(l["X-Liquid-Api-Builder"]=!![]);const d={method:i.method,headers:l,body:i.body?JSON.stringify(i.body):void 0},G=(n,i)=>{if(n)return!![];if(!r&&i){const n=i.status;if(401===n||403===n)return this.logger.warn("Authorization error detected, will retry with new token"),this.accessToken=null,this.tokenExpiration=null,!![]}return i&&i.status>=500&&i.status<600?!![]:![]};let u,f;try{u=await this.httpClient.request({url:a,options:d,retryConfig:{maxRetries:2,retryDelay:1e3,shouldRetry:G}})}catch(v){throw this.logger.error("Request failed after all retries",{path:n,method:i.method,authType:r?"API Key":"Bearer Token",error:null==v?void 0:v.message,possibleCauses:null==v?void 0:v.possibleCauses}),{status:0,statusCode:0,message:(null==v?void 0:v.message)||"Network error: Unable to connect to the API",url:a,method:i.method,isNetworkError:!![],originalError:v}}if(u.ok)try{return await u.json()}catch(b){const s=await u.text().catch(()=>"Success");return this.logger.error("Failed to parse successful response JSON",{path:n,method:i.method,status:u.status,authType:r?"API Key":"Bearer Token",responsePreview:s,error:null==b?void 0:b.message}),{message:s}}let g="";try{f=await u.json(),g=JSON.stringify(f)}catch(x){g=await u.text().catch(()=>"HTTP error status: "+u.status),f={message:g||"Unknown error"}}throw this.logger.error("API request failed",{path:n,method:i.method,authType:r?"API Key":"Bearer Token",status:u.status,statusText:u.statusText,statusCode:null==f?void 0:f.statusCode,message:null==f?void 0:f.message,requestId:null===(s=null==f?void 0:f.metadata)||void 0===s?void 0:s.requestId,responseBody:g}),{...f,status:u.status,message:(null==f?void 0:f.message)||"Request failed"}}buildUrl(n){const i=this.clientConfig.getProxyConfig();return new URL("api"+n,i?i.baseUrl:this.baseUrl).toString()}getProxyHeaders(){const n=this.clientConfig.getProxyConfig();return n?{"X-Liquid-Proxy":"true","X-Liquid-Proxy-Target":this.baseUrl,...n.headers}:{}}async get(n,i){return this.request(n,{method:"GET",headers:null==i?void 0:i.headers})}async post(n,i){return this.request(n,{method:"POST",body:null==i?void 0:i.body,headers:null==i?void 0:i.headers})}async put(n,i){return this.request(n,{method:"PUT",body:null==i?void 0:i.body,headers:null==i?void 0:i.headers})}async delete(n,i){return this.request(n,{method:"DELETE",headers:null==i?void 0:i.headers})}}const H="@liquidcommerce/elements-sdk",q="LiquidCommerce Elements SDK",j="UNLICENSED",U="LiquidCommerce Team",V="2.6.0-beta.3",K="https://docs.liquidcommerce.co/elements-sdk",Q={type:"git",url:"git+https://github.com/liquidcommerce/elements-sdk.git"},Z={url:"https://github.com/liquidcommerce/elements-sdk/issues"},X="./dist/index.esm.js",J="./umd/elements.js",$="./dist/types/index.d.ts",tt="pnpm@10.0.0",et={".":{types:"./dist/types/index.d.ts",import:"./dist/index.esm.js",browser:"./umd/elements.js",default:"./dist/index.esm.js"},"./package.json":"./package.json"},nt=["dist","umd","docs","README.md","LICENSE"],it={access:"public",registry:"https://registry.npmjs.org/"},ot="module",rt=["dist/index.esm.js","umd/elements.js","src/index.ts","src/index.umd.ts"],st={build:"rollup -c","build:dev":"rollup -c --environment NODE_ENV:development",dev:"rollup -c -w","type-check":"tsc --noEmit",lint:"pnpm biome lint --write",format:"biome format --write",check:"pnpm biome check --write .",fl:"pnpm check && pnpm build:dev",changelog:"conventional-changelog -p angular -i CHANGELOG.md -s",clean:"rm -rf dist umd","clean:hard":"rm -rf dist umd node_modules && pnpm install && pnpm build",prepublishOnly:"pnpm run build","deprecate:old":'npm deprecate @liquidcommerceteam/elements-sdk@"*" "Package moved to @liquidcommerce/elements-sdk"',prepare:"husky"},at=["liquidcommerce","alcohol","beverage","alcohol tech","elements","custom web components","embeddable components","embeddable web components","embeddable commerce"],lt={"@biomejs/biome":"2.3.5","@commitlint/cli":"^20.1.0","@commitlint/config-conventional":"^20.0.0","@rollup/plugin-alias":"^6.0.0","@rollup/plugin-commonjs":"^29.0.0","@rollup/plugin-json":"^6.1.0","@rollup/plugin-node-resolve":"^16.0.3","@rollup/plugin-replace":"^6.0.3","@rollup/plugin-terser":"^0.4.4","@semantic-release/changelog":"^6.0.3","@semantic-release/commit-analyzer":"^13.0.1","@semantic-release/git":"^10.0.1","@semantic-release/github":"^12.0.2","@semantic-release/npm":"^13.1.2","@semantic-release/release-notes-generator":"^14.1.0","@types/core-js":"^2.5.8","@types/node":"^24.10.1","conventional-changelog-cli":"^5.0.0",husky:"^9.1.7",process:"^0.11.10",rollup:"^4.53.3","rollup-obfuscator":"^4.1.1","rollup-plugin-typescript2":"^0.36.0","semantic-release":"^25.0.2","ts-node":"^10.9.2",typescript:"^5.9.3"},ct={node:">=22"},dt={peerDependencyRules:{ignoreMissing:[]},onlyBuiltDependencies:["@biomejs/biome","javascript-obfuscator"],overrides:{"@conventional-changelog/git-client@<2.0.0":">=2.0.0"}},ut={name:H,description:q,license:j,author:U,version:V,homepage:K,repository:Q,bugs:Z,module:X,browser:J,types:$,packageManager:tt,exports:et,files:nt,publishConfig:it,type:ot,sideEffects:rt,scripts:st,keywords:at,devDependencies:lt,engines:ct,pnpm:dt};class GoogleTagManagerService{constructor(){this.partnerEnableGaTracking=![],this.liquidCommerceEnableGaTracking=![],this.isInitialized=![],this.isInitializing=![],this.currency="USD",this.eventQueue=[],this.logger=LoggerFactory.get("GoogleTagManager"),this.clientConfigService=ClientConfigService.getInstance()}static getInstance(){return SingletonManager.getClassInstance("GoogleTagManagerService",()=>new GoogleTagManagerService)}waitForDOMReady(){return new Promise(n=>{if("loading"!==document.readyState)return n(),void 0;document.addEventListener("DOMContentLoaded",()=>n())})}isGTMAlreadyLoaded(){return"function"==="object".gtag?!![]:Array.from(document.querySelectorAll('script[src*="googletagmanager.com/gtm.js"]')).length>0}isContainerLoaded(n){const i=Array.from(document.querySelectorAll('script[src*="googletagmanager.com/gtm.js"]'));return i.some(i=>{const r=i.src;return r.includes("id="+n)})}isContainerInitialized(n){return window.dataLayer&&Array.isArray(window.dataLayer)&&this.isContainerLoaded(n)?window.dataLayer.some(n=>n&&"object"==typeof n&&("gtm.start"in n||"gtm.js"===n.event)):![]}async loadGTMScript(n){try{if(this.isContainerInitialized(n))return{success:!![],usingExistingGTM:!![],message:"Container "+n+" already loaded"};if(this.isContainerLoaded(n)){const i=await this.waitForContainerInit(n,1e4);return i?{success:!![],usingExistingGTM:!![],message:"Container "+n+" initialized"}:this.checkFallbackGTM(n)}return await this.injectGTMScript(n),{success:!![],usingExistingGTM:![],message:"Container "+n+" loaded successfully"}}catch(i){return this.checkFallbackGTM(n)}}waitForContainerInit(n,i){return new Promise(r=>{let s;const a=setInterval(()=>{this.isContainerInitialized(n)&&(clearInterval(a),clearTimeout(s),r(!![]))},100);s=setTimeout(()=>{clearInterval(a),r(![])},i)})}injectGTMScript(n){return new Promise((i,r)=>{const s=document.createElement("script");s.src="https://www.googletagmanager.com/gtm.js?id="+n,s.async=!![],s.crossOrigin="anonymous";let a=![];const l=setTimeout(()=>{a||(a=!![],this.isContainerInitialized(n)?i():r(new Error("GTM script timeout")))},15e3);s.onload=()=>{a||setTimeout(()=>{a||(a=!![],clearTimeout(l),this.isContainerInitialized(n)||window.dataLayer&&Array.isArray(window.dataLayer)?i():r(new Error("GTM script loaded but failed to initialize")))},500)},s.onerror=()=>{setTimeout(()=>{a||(a=!![],clearTimeout(l),this.isContainerLoaded(n)&&this.isContainerInitialized(n)?i():r(new Error("GTM script failed to load")))},100)},document.head.appendChild(s)})}checkFallbackGTM(n){if(this.isGTMAlreadyLoaded()&&window.dataLayer&&Array.isArray(window.dataLayer)){if(this.partnerGtmId&&this.isContainerInitialized(this.partnerGtmId))return{success:!![],usingExistingGTM:!![],message:"Using partner GTM container"};const n=window.dataLayer.some(n=>n&&"object"==typeof n&&("gtm.start"in n||"gtm.js"===n.event));if(n)return{success:!![],usingExistingGTM:!![],message:"Using existing GTM container"}}return window.dataLayer&&Array.isArray(window.dataLayer)?{success:!![],usingExistingGTM:!![],message:"Using basic dataLayer for event tracking"}:{success:![],usingExistingGTM:![],message:"Failed to load container "+n+" and no fallback available"}}processEventQueue(){const n=Date.now(),i=this.eventQueue.filter(i=>n-i.timestamp<3e4);for(const s of i)try{const n={event:s.eventName,...s.eventData};window.dataLayer.push(n)}catch(r){this.logger.error("Error processing queued event "+s.methodName,r)}this.eventQueue=[],i.length>0&&this.logger.info("Processed "+i.length+" queued GTM events")}getSendToTargets(){const n=[];return this.liquidCommerceEnableGaTracking&&this.liquidCommerceGtmId&&this.isContainerInitialized(this.liquidCommerceGtmId)&&n.push(this.liquidCommerceGtmId),this.partnerEnableGaTracking&&this.partnerGtmId&&this.isContainerInitialized(this.partnerGtmId)&&n.push(this.partnerGtmId),n}async initialize(n){try{if(this.isInitialized)return Promise.resolve();if(this.isInitializing&&this.initializationPromise)return this.initializationPromise;if(0,this.clientConfigService.isBuilder())return;this.isInitializing=!![],this.initializationPromise=this.doInitialize(n),await this.initializationPromise}catch(i){this.isInitializing=![],this.initializationPromise=void 0,this.logger.error("GTM initialization failed",i)}}async doInitialize(n){if(!(null==n?void 0:n.partnerName)||!(null==n?void 0:n.liquidCommerceGtmId))return;if(!n.liquidCommerceEnableGaTracking&&!n.partnerEnableGaTracking)return this.isInitialized=!![],this.isInitializing=![],this.initializationPromise=void 0,void 0;await this.waitForDOMReady(),this.partnerName=n.partnerName,this.partnerGtmId=n.partnerGtmId,this.liquidCommerceGtmId=n.liquidCommerceGtmId,this.partnerEnableGaTracking=n.partnerEnableGaTracking,this.liquidCommerceEnableGaTracking=n.liquidCommerceEnableGaTracking,window.dataLayer||(window.dataLayer=[]),window.gtag||(window.gtag=(...n)=>window.dataLayer.push(n));const i=n.liquidCommerceEnableGaTracking?await this.loadGTMScript(n.liquidCommerceGtmId):{success:!![],message:"Using partner GTM only"};if(!i.success)throw this.isInitializing=![],this.initializationPromise=void 0,new SDKError("GTM initialization failed: "+i.message);this.isInitialized=!![],this.isInitializing=![],this.initializationPromise=void 0,this.logger.info(i.message),this.processEventQueue()}executeEvent(n,i,r){try{if(this.clientConfigService.isBuilder())return;const s=this.getSendToTargets(),a={...r,...s.length>0&&{send_to:s},tenant_source:ut.description+" v"+ut.version,tenant_name:this.partnerName};if(!this.isInitialized)return this.eventQueue.length>=100&&this.eventQueue.shift(),this.eventQueue.push({methodName:n,eventName:i,eventData:a,timestamp:Date.now()}),void 0;if(!window.dataLayer||!Array.isArray(window.dataLayer))return;const l={event:i,...a};window.dataLayer.push(l)}catch(s){this.logger.error("GTM "+n+" error",s)}}calculateValue(n){const i=n.reduce((n,i)=>n+(i.price||0)*(i.quantity||1),0);return Number.parseFloat(i.toFixed(2))}viewItem(n){this.executeEvent("viewItem","view_item",{currency:this.currency,value:this.calculateValue([n]),items:[n]})}viewItemList(n,i,r){this.executeEvent("viewItemList","view_item_list",{currency:this.currency,item_list_id:i,item_list_name:r,items:n})}selectItem(n,i,r){this.executeEvent("selectItem","select_item",{item_list_id:i,item_list_name:r,items:[n]})}addToCart(n){this.executeEvent("addToCart","add_to_cart",{currency:this.currency,value:this.calculateValue([n]),quantity:n.quantity||1,items:[n]})}viewCart(n){this.executeEvent("viewCart","view_cart",{currency:this.currency,value:this.calculateValue(n),items:n})}removeFromCart(n){this.executeEvent("removeFromCart","remove_from_cart",{currency:this.currency,value:this.calculateValue([n]),items:[n]})}beginCheckout(n,i){this.executeEvent("beginCheckout","begin_checkout",{currency:this.currency,value:this.calculateValue(n),coupon:i,items:n})}addShippingInfo(n,i){this.executeEvent("addShippingInfo","add_shipping_info",{currency:this.currency,value:this.calculateValue(n),coupon:i,items:n})}addPaymentInfo(n,i,r){this.executeEvent("addPaymentInfo","add_payment_info",{currency:this.currency,value:this.calculateValue(n),payment_type:i,coupon:r,items:n})}purchase(n){this.executeEvent("purchase","purchase",{transaction_id:n.transaction_id,value:n.value,currency:this.currency,tax:n.tax,shipping:n.shipping,coupon:n.coupon,items:n.items,subtotal:n.subtotal,total:n.total_before_discounts,discounts:n.discounts,gift_cards:n.gift_cards,net_total:n.net_total})}promoCodeAttempt(n){this.executeEvent("promoCodeAttempt","promo_code_attempt",{promo_code:n})}promoCodeApplied(n,i){this.executeEvent("promoCodeApplied","promo_code_applied",{promo_code:n,discount_amount:i})}promoCodeFailed(n,i){this.executeEvent("promoCodeFailed","promo_code_failed",{promo_code:n,reason:i})}giftCardAttempt(n){this.executeEvent("giftCardAttempt","gift_card_attempt",{gift_card_code:n})}giftCardApplied(n,i){this.executeEvent("giftCardApplied","gift_card_applied",{gift_card_code:n,applied_amount:i})}giftCardFailed(n,i){this.executeEvent("giftCardFailed","gift_card_failed",{gift_card_code:n,reason:i})}addressUpdated(n){this.executeEvent("addressUpdated","address_updated",{address_id:n.googlePlacesId,formatted_address:n.formattedAddress,address:n.address,coordinates:n.coordinates})}addressFailed(n){this.executeEvent("addressFailed","address_failed",{address_id:n.googlePlacesId,formatted_address:n.formattedAddress,address:n.address,address_error_message:n.error})}productNoAvailability(n){this.executeEvent("productNoAvailability","product_no_availability",{product_id:n.productId,product_name:n.productName,product_brand:n.productBrand,product_category:n.productCategory,product_category2:n.productCategory2,product_category3:n.productCategory3,product_type:n.productType,product_subtype:n.productSubtype,product_price:n.productPrice,upc:n.upc,grouping_id:n.groupingId,address:n.address,availability_reason:n.reason})}productSizeNoAvailability(n){this.executeEvent("productSizeNoAvailability","product_size_no_availability",{product_id:n.productId,product_name:n.productName,product_brand:n.productBrand,product_category:n.productCategory,product_category2:n.productCategory2,product_category3:n.productCategory3,product_type:n.productType,product_subtype:n.productSubtype,product_price:n.productPrice,size_id:n.sizeId,size_name:n.sizeName,upc:n.upc,grouping_id:n.groupingId,address:n.address,availability_reason:n.reason})}productFulfillmentNoAvailability(n){this.executeEvent("productFulfillmentNoAvailability","product_fulfillment_no_availability",{product_id:n.productId,product_name:n.productName,product_brand:n.productBrand,product_category:n.productCategory,product_category2:n.productCategory2,product_category3:n.productCategory3,product_type:n.productType,product_subtype:n.productSubtype,product_price:n.productPrice,size_id:n.sizeId,size_name:n.sizeName,fulfillment_type:n.fulfillmentType,upc:n.upc,grouping_id:n.groupingId,address:n.address,availability_reason:n.reason})}}class StoreService{constructor(){this.middleware=[],this.isLocalStorageAvailable=![],this.loggingMiddleware=({action:n,payload:i,next:r})=>{const s=performance.now();try{const a=r(),l=performance.now()-s;return this.logger.info("🏪 Store "+n+" ✓ "+l.toFixed(3)+"ms",i),a}catch(a){const r=performance.now()-s;throw this.logger.error("🏪 Store "+n+" ✗ "+r.toFixed(3)+"ms",{payload:i,error:a}),a}},this.performanceMiddleware=({action:n,next:i})=>{const r=performance.now(),s=i(),a=performance.now()-r;return a>16&&this.logger.warn('⚠️ Slow store operation "'+n+'": '+a.toFixed(2)+"ms"),s},this.state=W,this.listeners=new Map,this.logger=LoggerFactory.get("Store"),this.clientConfig=ClientConfigService.getInstance(),this.api=ApiClientService.getInstance(),this.setupMiddleware()}static getInstance(){return SingletonManager.getClassInstance("StoreService",()=>new StoreService)}async initialize({userDeviceId:n,isLocalStorageAvailable:i,persistedStore:r}){this.localStorageKey=this.clientConfig.get("localStorageKeyPrefix")+"_"+n,this.isLocalStorageAvailable=i,i?await this.loadPersistedState():r&&await this.loadFromDBPersistence(r),this.logger.info("Store service initialized successfully",{userDeviceId:n,isLocalStorageAvailable:i,hasPersistedState:null!==r,localStorageKey:this.localStorageKey})}get(n){if(!n)return{...this.state};const i=n.split(".");let r=this.state;for(const s of i){if(null==r)return;r=r[s]}return void 0!==r?Array.isArray(r)?[...r]:"object"==typeof r&&null!==r?{...r}:r:void 0}set(n,i){return this.runWithMiddleware("set",{path:n,value:i},()=>{const r=this.get(n);return this.state=this.immutableSet(this.state,n,i),this.notifyListeners(n,i,r),this.isLocalStorageAvailable&&this.debouncedSave(),!![]})}update(n,i){const r=this.get(n),s=i(r);return this.set(n,s)}remove(n){return this.runWithMiddleware("remove",{path:n},()=>{const i=this.get(n);if(void 0===i)return this.logger.warn('No value found at path "'+n+'" to remove.'),![];const r=n.split(".");let s=this.state;const a=r.pop();for(const l of r){if(void 0===s[l])return this.logger.warn('Path "'+n+'" does not exist in the state.'),![];s=s[l]}if(Array.isArray(s))s=s.filter((n,i)=>i!==Number.parseInt(a,10));else{if("object"!=typeof s||null===s)return this.logger.warn('Cannot remove property "'+a+'" from non-object type at path "'+n+'".'),![];{const{[a]:n,...i}=s;s=i}}return this.state=this.immutableSet(this.state,r.join("."),s),this.notifyListeners(n,void 0,i),this.isLocalStorageAvailable&&this.debouncedSave(),!![]})}batch(n){return this.runWithMiddleware("batch",{updates:n},()=>{const i=[];if("function"==typeof n){const r=n(this.state);for(const[n,s]of Object.entries(r)){const r=this.get(n);i.push({path:n,oldValue:r,newValue:s,timestamp:Date.now()}),this.state=this.immutableSet(this.state,n,s)}}else for(const[r,s]of Object.entries(n)){const n=this.get(r);i.push({path:r,oldValue:n,newValue:s,timestamp:Date.now()}),this.state=this.immutableSet(this.state,r,s)}for(const{path:n,oldValue:r,newValue:s}of i)this.notifyListeners(n,s,r);return this.isLocalStorageAvailable&&this.debouncedSave(),!![]})}watch(n,i){const r=n;return this.listeners.has(r)||this.listeners.set(r,new Set),this.listeners.get(r).add(i),()=>{var n;null===(n=this.listeners.get(r))||void 0===n?void 0:n.delete(i)}}watchMany(n,i){const r=[];let s;const a=n.map(n=>this.watch(n,(a,l)=>{r.push({path:n,value:a,oldValue:l}),clearTimeout(s),s=setTimeout(()=>{r.length>0&&(i([...r]),r.length=0)},0)}));return()=>{for(const n of a)n()}}createProductInstance(n){const i="products."+n,r=this.get(i);return r?!![]:this.set(i,R)}removeProductInstance(n){const i=this.get("products"),{[n]:r,...s}=i;return this.set("products",s)}getProductInstances(){return this.get("products")}getState(){return{...this.state}}setupMiddleware(){this.middleware.push(this.loggingMiddleware),this.middleware.push(this.performanceMiddleware)}runWithMiddleware(n,i,r){let s=0;const y=()=>{if(s>=this.middleware.length)return r();const a=this.middleware[s++];return a({action:n,payload:i,state:this.getState(),next:y})};return y()}immutableSet(n,i,r){const s=i.split(".");if(1===s.length){if(Array.isArray(n)){const i=[...n];return i[s[0]]=r,i}return{...n,[s[0]]:r}}const[a,...l]=s,d=n[a],u=Array.isArray(d)?[]:{};if(Array.isArray(n)){const i=[...n];return i[a]=this.immutableSet(d||u,l.join("."),r),i}return{...n,[a]:this.immutableSet(d||u,l.join("."),r)}}notifyListeners(n,i,r){const s=this.listeners.get(n);if(s)for(const u of s)try{u(i,r)}catch(l){this.logger.error('Error in store listener for path "'+n+'"',l)}const a=n.split(".");for(let u=a.length-1;u>0;u--){const n=a.slice(0,u).join("."),i=this.listeners.get(n);if(i){const s=this.get(n),l=a.slice(u).join("."),f=this.immutableSet(s,l,r);for(const r of i)try{r(s,f)}catch(d){this.logger.error('Error in store listener for parent path "'+n+'"',d)}}}}debouncedSave(){this.saveTimeout&&clearTimeout(this.saveTimeout),this.saveTimeout=setTimeout(()=>this.saveStore(),50)}forceSave(){this.saveTimeout&&(clearTimeout(this.saveTimeout),this.saveTimeout=void 0),this.saveStore()}async persist(){var n;const i=this.get("address.id")||"",r=this.get("cart.id")||"";if(!i&&!r)return this.logger.info("No session data to persist (both IDs are empty), skipping"),void 0;if(this.isLocalStorageAvailable)return this.forceSave(),this.logger.info("Session data persisted to localStorage",{addressId:i,cartId:r}),void 0;try{const s=null!==(n=this.clientConfig.get("userDeviceId"))&&void 0!==n?n:"not_defined";await this.api.setPersistedStore(s,{p:i,c:r}),this.logger.info("Session data persisted to DB",{userDeviceId:s,addressId:i,cartId:r})}catch(s){this.logger.error("Failed to persist session data to DB",s)}}clearLocalStorage(){if(!this.isLocalStorageAvailable||!this.localStorageKey)return this.logger.info("localStorage not available or key not set, skipping clear"),void 0;try{localStorage.removeItem(this.localStorageKey),this.logger.info("localStorage entry completely removed",{key:this.localStorageKey})}catch(ut){this.logger.error("Failed to clear localStorage entry",ut)}}saveStore(){if(this.isLocalStorageAvailable&&this.localStorageKey)try{let n="";if(this.clientConfig.debuggingDisabled()){const i=this.get("address.id")||"",r=this.get("cart.id")||"";(i||r)&&(n=i+":"+r)}else n=this.getState();n&&localStorage.setItem(this.localStorageKey,"string"!=typeof n?JSON.stringify(n):n)}catch(n){this.logger.error("Failed to persist store state",n)}}async loadPersistedState(){if(this.isLocalStorageAvailable&&this.localStorageKey)try{const i=localStorage.getItem(this.localStorageKey);if(!i)return;try{const n=JSON.parse(i);for(const[i,r]of Object.entries(n))this.set(i,r);return}catch(n){if(i.includes(":")){const[n,r]=i.split(":");if(void 0!==n){const i=await this.getAddressDataFromId(n);this.set("address",i)}return void 0!==r&&this.set("cart.id",r||null),void 0}this.logger.warn("Unrecognized localStorage format, skipping load",{saved:i})}}catch(i){this.logger.error("Failed to load persisted state",i),localStorage.removeItem(this.localStorageKey)}}async loadFromDBPersistence(n){try{if(void 0!==n.p){const i=await this.getAddressDataFromId(n.p);this.set("address",i)}void 0!==n.c&&this.set("cart.id",n.c||null),this.logger.info("Session data loaded from DB persistence",{addressId:n.p,cartId:n.c})}catch(i){this.logger.error("Failed to load session data from DB persistence",i)}}async getAddressDataFromId(n){if(!n||""===n.trim())return B;try{const i=await this.api.getAddressDetails(n);return i&&0!==Object.keys(i).length?{id:n,formattedAddress:i.formattedAddress,address:{one:i.address.one,two:i.address.two,city:i.address.city,state:i.address.state,zip:i.address.zip,country:i.address.country||""},coordinates:{lat:i.coords.lat,long:i.coords.long}}:{...B,id:n}}catch(i){return{...B,id:n}}}}const ht=[C.PRODUCT,C.PRODUCT_IMAGE_CAROUSEL,C.PRODUCT_OPTIONS,C.PRODUCT_INTERACTIONS,C.PRODUCT_DESCRIPTION,C.PRODUCT_RETAILERS,C.PRODUCT_RETAILERS_CAROUSEL,C.PRODUCT_RETAILERS_POPUP,C.PRODUCT_RETAILERS_POPUP_LIST,C.PRODUCT_PRICE,C.PRODUCT_ADD_TO_CART_SECTION,C.PRODUCT_DRAWER,C.PRODUCT_LOADING,C.ENGRAVING_FORM,C.ENGRAVING_VIEW,C.PRODUCT_LIST,C.PRODUCT_LIST_CARD,C.PRODUCT_LIST_CARD_LOADING,C.PRODUCT_LIST_FILTERS],pt=[C.ADDRESS_INPUT,C.ADDRESS_DISPLAY],mt=[C.CART,C.CART_RETAILER,C.CART_ITEM,C.CART_FOOTER,C.CART_ITEM_QUANTITY_PRICE,C.CART_RETAILER_SUBTOTAL,C.CART_PROMO_CODE,C.CART_HEADER,C.CART_BODY,C.CART_FULFILLMENT,C.BUTTONS_CART_OPEN],ft=[C.CHECKOUT,C.CHECKOUT_INFORMATION,C.CHECKOUT_STRIPE_HANDLER,C.CHECKOUT_STRIPE_FORM,C.CHECKOUT_PAYMENT,C.CHECKOUT_BILLING,C.CHECKOUT_ORDER_SUMMARY,C.CHECKOUT_PROMO_CODE,C.CHECKOUT_GIFT_CARDS,C.CHECKOUT_AMOUNTS,C.CHECKOUT_ITEMS,C.CHECKOUT_COMPLETED,C.CHECKOUT_DELIVER_TO,C.CHECKOUT_DELIVER_TO_SUMMARY,C.CHECKOUT_BUYER,C.CHECKOUT_TIPS,C.CHECKOUT_PC_GC,C.CHECKOUT_ITEM,C.CHECKOUT_ITEM_QUANTITY,C.CHECKOUT_PLACE_ORDER_BUTTON,C.CHECKOUT_HEADER,C.CHECKOUT_PRESALE_COUNTDOWN,C.CHECKOUT_PRESALE_EXPIRED,C.CHECKOUT_SEND_AS_GIFT];class FontManagerService{constructor(){this.googleFontsUrl="",this.defaultFontFamilies=[{name:"Poppins",weights:[400,500,600,700]}],this.fontsLinkAttribute="data-lce-fonts"}loadGoogleFonts(n,i="swap"){if(!n||0===n.length)return;const r=[...this.defaultFontFamilies,...n],s=r.map(n=>{const i=encodeURIComponent(n.name);return"family="+i+":wght@"+n.weights.join(";")}).join("&"),a="display="+i;this.googleFontsUrl="https://fonts.googleapis.com/css2?"+s+"&"+a,this.injectGoogleFontsResourceHints(),this.injectGoogleFontsLink()}updateGoogleFonts(n,i="swap"){const r=document.querySelector("link["+this.fontsLinkAttribute+"]");this.loadGoogleFonts(n,i),r&&r.remove()}injectGoogleFontsResourceHints(){const n=document.querySelector('link[href="https://fonts.googleapis.com"][rel="preconnect"]'),i=document.querySelector('link[href="https://fonts.gstatic.com"][rel="preconnect"]');if(!n){const n=document.createElement("link");n.rel="preconnect",n.href="https://fonts.googleapis.com",document.head.appendChild(n)}if(!i){const n=document.createElement("link");n.rel="preconnect",n.href="https://fonts.gstatic.com",n.crossOrigin="",document.head.appendChild(n)}}injectGoogleFontsLink(){if(!this.googleFontsUrl)return;const n=document.createElement("link");n.rel="stylesheet",n.href=this.googleFontsUrl,n.setAttribute(this.fontsLinkAttribute,""),document.head.appendChild(n)}}const getProductListStyles=()=>"\n .product-list {\n width: 100%;\n display: flex;\n align-items: center;\n flex-direction: column;\n gap: 24px;\n }\n\n .product-list-search__control-container {\n max-width: 500px;\n width: 100%;\n }\n\n /* Mobile Filter Container */\n .product-list-filter-container {\n display: none;\n align-items: center;\n gap: 8px;\n width: 100%;\n justify-content: flex-start;\n }\n\n .product-list-filter-icon svg {\n display: block;\n color: var(--icon-color, var(--default-text-color, #18181B));\n }\n\n .product-list-filter-icon:hover svg {\n cursor: pointer;\n }\n\n .product-list-filter-text {\n color: var(--default-text-color, #111827);\n font-size: 16px;\n font-weight: 400;\n font-family: var(--paragraph-font-family, Poppins);\n user-select: none;\n }\n\n /* Filters in Drawer */\n .product-list-filters-drawer-content {\n padding: 20px;\n overflow-y: auto;\n max-height: 100%;\n }\n\n .product-list-filters-drawer-content .product-list-filters-container {\n position: static;\n width: 100%;\n top: 0;\n }\n\n .product-list-controls {\n width: 100%;\n display: flex;\n flex-direction: row;\n gap: 24px;\n }\n\n /* Filters Container */\n .product-list-filters-container {\n width: 20%;\n height: fit-content;\n position: sticky;\n top: 24px;\n }\n \n .product-list-filters-container.drawer-mode {\n display: flex;\n flex-direction: column;\n width: 100%;\n padding: 0 24px 24px 24px;\n position: static;\n height: 100%;\n overflow-y: auto;\n padding-bottom: 80px;\n }\n\n .product-list-cards__container {\n width: 100%;\n height: 100%;\n display: flex;\n flex-wrap: wrap;\n align-items: flex-start;\n gap: 24px;\n --gap-per-card: calc(24px * (var(--columns, 4) - 1) / var(--columns, 4));\n }\n\n /* Filters Styles */\n .product-list-filters-header {\n padding: 0px 0px 10px;\n }\n\n .product-list-filters-header.drawer-mode {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 10px 0px;\n border-bottom: 1px solid var(--accent-color, #e5e7eb);\n }\n\n .product-list-filters-personalized,\n .product-list-filters-pre-order,\n .product-list-filters-delivery-options {\n padding: 10px 0px;\n border-bottom: 1px solid var(--accent-color, #f3f4f6);\n }\n \n .product-list-filters-title {\n font-size: 18px;\n font-weight: 600;\n color: var(--default-text-color, #111827);\n font-family: var(--paragraph-font-family, Poppins);\n margin: 0;\n }\n\n .product-list-filters-header.drawer-mode .product-list-filters-title {\n font-size: 14px;\n }\n\n .product-list-filters-close-btn {\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n color: var(--icon-color, var(--default-text-color, #18181B));\n transition: opacity 0.2s ease;\n }\n\n .product-list-filters-personalized,\n .product-list-filters-pre-order {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n }\n\n .product-list-filters-personalized > *:not(:last-child),\n .product-list-filters-pre-order > *:not(:last-child) {\n margin-right: 12px;\n }\n\n .product-list-filters-personalized-label,\n .product-list-filters-pre-order-label {\n font-size: 14px;\n font-weight: 600;\n color: var(--default-text-color, #374151);\n font-family: var(--paragraph-font-family, Poppins);\n margin: 0;\n cursor: pointer;\n display: flex;\n justify-content: space-between;\n align-items: center;\n line-height: 1.5;\n flex: 1;\n }\n\n .product-list-filters-warning {\n font-size: 12px;\n color: var(--default-text-color-70, #9ca3af);\n font-family: var(--paragraph-font-family, Poppins);\n font-style: normal;\n margin: 0;\n padding: 0;\n }\n\n .product-list-filters-delivery-options-header,\n .product-list-filters-price-header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n cursor: pointer;\n user-select: none;\n }\n\n .product-list-filters-delivery-options-header:hover .product-list-filters-delivery-options-label,\n .product-list-filters-price-header:hover .product-list-filters-price-title, \n .product-list-filters-personalized:hover .product-list-filters-personalized-label, \n .product-list-filters-pre-order:hover .product-list-filters-pre-order-label {\n text-decoration: underline;\n }\n\n .product-list-filters-chevron {\n display: flex;\n align-items: center;\n justify-content: center;\n transition: transform 0.2s ease;\n }\n\n .product-list-filters-chevron svg {\n display: block;\n }\n\n .product-list-filters-delivery-options-list,\n .product-list-filters-price-inputs {\n max-height: 500px;\n overflow: hidden;\n transition: max-height 0.3s ease, opacity 0.3s ease, margin 0.3s ease;\n opacity: 1;\n }\n\n .product-list-filters-delivery-options-list.collapsed,\n .product-list-filters-price-inputs.collapsed {\n max-height: 0;\n opacity: 0;\n margin-top: 0;\n }\n\n .product-list-filters-delivery-options-list:not(.collapsed) {\n margin-top: 8px;\n }\n\n .product-list-filters-price-inputs:not(.collapsed) {\n margin-top: 16px;\n }\n\n .product-list-filters-delivery-options {\n border-bottom: 1px solid var(--accent-color, #f3f4f6);\n }\n \n .product-list-filters-delivery-options-label {\n font-size: 14px;\n font-weight: 600;\n color: var(--default-text-color, #111827);\n font-family: var(--heading-font-family, Poppins);\n }\n\n .product-list-filters-delivery-options-list {\n display: flex;\n flex-direction: column;\n }\n\n .product-list-filters-delivery-option {\n display: flex;\n align-items: center;\n padding: 4px 10px;\n border-radius: var(--button-border-radius, 8px);\n cursor: pointer;\n }\n \n .product-list-filters-delivery-option > *:not(:last-child) {\n margin-right: 12px;\n }\n\n .product-list-filters-delivery-option:hover {\n background-color: var(--accent-color-30, #f8fafc);\n }\n\n .product-list-filters-delivery-radio {\n width: 18px;\n height: 18px;\n margin: 0;\n cursor: pointer;\n accent-color: var(--primary-color, #3b82f6);\n }\n\n .product-list-filters-delivery-radio:disabled {\n opacity: 0.4;\n cursor: not-allowed;\n }\n\n .product-list-filters-delivery-radio:focus,\n .product-list-filters-delivery-radio:focus-visible {\n outline: none;\n box-shadow: none;\n }\n\n .product-list-filters-delivery-radio-label {\n font-size: 14px;\n color: var(--default-text-color, #374151);\n font-family: var(--paragraph-font-family, Poppins);\n margin: 0;\n cursor: pointer;\n flex: 1;\n }\n\n .product-list-filters-delivery-radio-label.disabled {\n color: var(--default-text-color-70, #9ca3af);\n cursor: not-allowed;\n }\n\n .product-list-filters-delivery-radio:disabled + .product-list-filters-delivery-radio-label {\n color: var(--default-text-color-70, #9ca3af);\n cursor: not-allowed;\n }\n\n .toggle-switch {\n position: relative;\n width: 40px;\n height: 20px;\n background-color: var(--primary-color-30, #d1d5db);\n border-radius: 12px;\n cursor: pointer;\n transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease, opacity 0.2s ease;\n }\n\n .toggle-switch.active {\n background-color: var(--primary-color, #3b82f6);\n }\n\n .toggle-slider {\n position: absolute;\n top: 2px;\n left: 2px;\n width: 16px;\n height: 16px;\n z-index: "+N.TOGGLE_SLIDER+";\n background-color: var(--accent-color, #ffffff);\n border-radius: 50%;\n transition: transform 0.18s ease-out;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n }\n\n .toggle-switch.active .toggle-slider {\n transform: translateX(20px);\n }\n\n /* Price Inputs */\n .product-list-filters-delivery-options,\n .product-list-filters-price {\n display: flex;\n flex-direction: column;\n padding: 10px 0px 14px;\n border-bottom: 1px solid var(--accent-color, #f3f4f6);\n }\n\n .product-list-filters-price-header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n }\n\n .product-list-filters-price-title {\n font-size: 14px;\n font-weight: 600;\n color: var(--default-text-color, #111827);\n font-family: var(--heading-font-family, Poppins);\n margin: 0;\n }\n\n /* Price Range Slider */\n .product-list-filters-price-slider-container {\n display: flex;\n flex-direction: column;\n max-height: 500px;\n overflow: hidden;\n transition: max-height 0.3s ease, opacity 0.3s ease, margin 0.3s ease;\n opacity: 1;\n }\n\n .product-list-filters-price-slider-container.collapsed {\n max-height: 0;\n opacity: 0;\n margin-top: 0;\n }\n\n .product-list-filters-price-slider-container:not(.collapsed) {\n margin-top: 16px;\n }\n\n /* Range Slider */\n .product-list-filters-price-range-wrapper {\n position: relative;\n width: 100%;\n height: 24px;\n display: flex;\n align-items: center;\n margin-bottom: 8px;\n }\n\n .product-list-filters-price-track {\n position: absolute;\n width: 100%;\n height: 4px;\n background: var(--accent-color, #e5e7eb);\n border-radius: 2px;\n pointer-events: none;\n }\n\n .product-list-filters-price-track-active {\n position: absolute;\n height: 100%;\n background: var(--primary-color, #3b82f6);\n border-radius: 2px;\n }\n\n .product-list-filters-price-range {\n position: absolute;\n width: 100%;\n height: 4px;\n background: transparent;\n pointer-events: none;\n -webkit-appearance: none;\n appearance: none;\n margin: 0;\n padding: 0;\n }\n\n .product-list-filters-price-range::-webkit-slider-thumb {\n -webkit-appearance: none;\n appearance: none;\n width: 20px;\n height: 20px;\n border-radius: 50%;\n background: var(--primary-color, #3b82f6);\n cursor: pointer;\n pointer-events: auto;\n border: 3px solid white;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n transition: transform 0.2s ease;\n }\n\n .product-list-filters-price-range::-webkit-slider-thumb:hover {\n transform: scale(1.1);\n }\n\n .product-list-filters-price-range::-webkit-slider-thumb:active {\n transform: scale(0.95);\n }\n\n .product-list-filters-price-range::-moz-range-thumb {\n width: 20px;\n height: 20px;\n border-radius: 50%;\n background: var(--default-text-color, #111827);\n cursor: pointer;\n pointer-events: auto;\n border: 3px solid white;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n transition: transform 0.2s ease;\n }\n\n .product-list-filters-price-range::-moz-range-thumb:hover {\n transform: scale(1.1);\n }\n\n .product-list-filters-price-range::-moz-range-thumb:active {\n transform: scale(0.95);\n }\n\n .product-list-filters-price-range:focus {\n outline: none;\n }\n\n .product-list-filters-price-range-min {\n z-index: 3;\n }\n\n .product-list-filters-price-range-max {\n z-index: 4;\n }\n\n /* Text Inputs Container */\n .product-list-filters-price-inputs-container {\n display: flex;\n align-items: center;\n justify-content: space-between;\n gap: 8px;\n }\n\n .product-list-filters-price-input-wrapper {\n flex: 1;\n display: flex;\n align-items: center;\n background: var(--accent-color-30, #f9fafb);\n border: 1px solid var(--accent-color, #e5e7eb);\n border-radius: var(--button-border-radius, 8px);\n padding: 8px 12px;\n transition: border-color 0.2s ease;\n }\n\n .product-list-filters-price-input-wrapper:focus-within {\n border-color: var(--default-text-color, #111827);\n }\n\n .product-list-filters-price-input-prefix {\n font-size: 15px;\n font-weight: 500;\n color: var(--default-text-color-70, #9ca3af);\n font-family: var(--paragraph-font-family, Poppins);\n margin-right: 4px;\n }\n\n .product-list-filters-price-input {\n flex: 1;\n border: none;\n background: transparent;\n font-size: 15px;\n font-weight: 500;\n color: var(--default-text-color, #111827);\n font-family: var(--paragraph-font-family, Poppins);\n outline: none;\n width: 100%;\n min-width: 0;\n -moz-appearance: textfield;\n }\n\n .product-list-filters-price-input:focus {\n outline: none;\n border: none;\n box-shadow: none;\n }\n\n .product-list-filters-price-input::-webkit-outer-spin-button,\n .product-list-filters-price-input::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n .product-list-filters-price-input::placeholder {\n color: var(--default-text-color-70, #9ca3af);\n }\n\n .product-list-filters-price-separator {\n font-size: 14px;\n font-weight: 400;\n color: var(--default-text-color-70, #9ca3af);\n font-family: var(--paragraph-font-family, Poppins);\n flex-shrink: 0;\n }\n\n /* Checkbox filters */\n .product-list-checkbox-filter {\n padding: 10px 0px;\n border-bottom: 1px solid var(--accent-color, #f3f4f6);\n }\n\n .product-list-checkbox-filter:last-child {\n border-bottom: none;\n padding-bottom: 0;\n }\n\n .checkbox-filter-container {\n display: flex;\n flex-direction: column;\n }\n\n /* Checkbox Filter Header */\n .checkbox-filter-header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n margin-bottom: 0px;\n }\n\n .checkbox-filter-label {\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n text-align: left;\n user-select: none;\n font-family: inherit;\n }\n\n .checkbox-filter-label:focus,\n .checkbox-filter-label:focus-visible {\n outline: none;\n box-shadow: none;\n }\n\n .checkbox-filter-label:hover span:first-child {\n text-decoration: underline;\n }\n\n .checkbox-filter-label span:first-child {\n font-size: 14px;\n font-weight: 600;\n color: var(--default-text-color, #111827);\n font-family: var(--heading-font-family, Poppins);\n margin: 0;\n }\n\n .checkbox-filter-toggle-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n transition: transform 0.2s ease;\n margin-left: 8px;\n }\n\n .checkbox-filter-toggle-icon svg {\n display: block;\n }\n\n .checkbox-filter-toggle-icon.collapsed {\n transform: rotate(0deg);\n }\n\n .checkbox-filter-toggle-icon.expanded {\n transform: rotate(0deg);\n }\n\n /* Checkbox Filter Content */\n .checkbox-filter-content {\n display: flex;\n flex-direction: column;\n gap: 12px;\n max-height: 500px;\n overflow: hidden;\n transition: max-height 0.3s ease, opacity 0.3s ease, margin 0.3s ease;\n opacity: 1;\n }\n\n .checkbox-filter-content.collapsed {\n max-height: 0;\n opacity: 0;\n margin-top: 0;\n }\n\n .checkbox-filter-content.expanded,\n .checkbox-filter-content:not(.collapsed) {\n margin-top: 8px;\n }\n\n /* Search Input */\n .checkbox-filter-search-wrapper {\n position: relative;\n display: flex;\n align-items: center;\n }\n\n .checkbox-filter-search {\n width: 100%;\n padding: 8px 40px 8px 12px;\n border: 1px solid var(--accent-color, #e5e7eb);\n border-radius: var(--button-border-radius, 8px);\n font-size: 15px;\n font-weight: 400;\n color: var(--default-text-color, #111827);\n font-family: var(--paragraph-font-family, Poppins);\n background: var(--accent-color-30, #f9fafb);\n transition: border-color 0.2s ease;\n }\n\n .checkbox-filter-search:focus,\n .checkbox-filter-search:focus-visible {\n outline: none;\n border-color: var(--accent-color, #e5e7eb);\n box-shadow: none;\n }\n\n .checkbox-filter-search::placeholder {\n color: var(--default-text-color-70, #9ca3af);\n }\n\n .checkbox-filter-search-icon {\n position: absolute;\n right: 12px;\n display: flex;\n align-items: center;\n justify-content: center;\n pointer-events: none;\n color: var(--default-text-color-70, #9ca3af);\n }\n\n .checkbox-filter-search-icon svg {\n display: block;\n }\n\n /* Checkbox List */\n .checkbox-filter-list {\n display: flex;\n flex-direction: column;\n gap: 4px;\n max-height: 280px;\n overflow-y: auto;\n padding-right: 4px;\n }\n\n /* Custom Scrollbar */\n .checkbox-filter-list::-webkit-scrollbar {\n width: 6px;\n }\n\n .checkbox-filter-list::-webkit-scrollbar-track {\n background: var(--accent-color-30, #f3f4f6);\n border-radius: 3px;\n }\n\n .checkbox-filter-list::-webkit-scrollbar-thumb {\n background: var(--accent-color, #d1d5db);\n border-radius: 3px;\n }\n\n .checkbox-filter-list::-webkit-scrollbar-thumb:hover {\n background: var(--default-text-color-70, #9ca3af);\n }\n\n /* Checkbox Items */\n .checkbox-filter-item {\n display: flex;\n align-items: center;\n gap: 8px;\n border-radius: var(--button-border-radius, 8px);\n transition: background-color 0.15s ease;\n cursor: pointer;\n }\n\n .checkbox-filter-checkbox {\n width: 18px;\n height: 18px;\n cursor: pointer;\n flex-shrink: 0;\n margin: 0;\n appearance: none;\n -webkit-appearance: none;\n -moz-appearance: none;\n border: 2px solid var(--accent-color, #d1d5db);\n border-radius: 4px;\n background-color: transparent;\n position: relative;\n transition: all 0.15s ease;\n }\n\n .checkbox-filter-checkbox:checked {\n background-color: var(--primary-color, #3b82f6);\n border-color: var(--primary-color, #3b82f6);\n }\n\n .checkbox-filter-checkbox:checked::after {\n content: '';\n position: absolute;\n left: 5px;\n top: 2px;\n width: 4px;\n height: 8px;\n border: solid white;\n border-width: 0 2px 2px 0;\n transform: rotate(45deg);\n }\n\n .checkbox-filter-checkbox:focus,\n .checkbox-filter-checkbox:focus-visible {\n outline: none;\n box-shadow: none;\n }\n\n .checkbox-filter-item-label {\n display: flex;\n align-items: center;\n justify-content: space-between;\n flex: 1;\n cursor: pointer;\n user-select: none;\n font-size: 15px;\n font-family: var(--paragraph-font-family, Poppins);\n }\n\n .checkbox-filter-item-text {\n color: var(--default-text-color, #374151);\n font-weight: 400;\n flex: 1;\n }\n\n .checkbox-filter-item-count {\n color: var(--default-text-color-70, #9ca3af);\n font-size: 14px;\n margin-left: 8px;\n font-weight: 400;\n }\n\n /* Apply filters button */\n .product-list-filters-apply-container {\n position: fixed;\n bottom: 0;\n left: 0;\n right: 0;\n padding: 12px 24px;\n margin-top: 0;\n background: var(--drawer-background-color, #ffffff);\n }\n\n .product-list-filters-apply-btn {\n width: 100%;\n padding: 12px 16px;\n border: none;\n border-radius: var(--button-border-radius, 8px);\n font-size: 14px;\n font-weight: 600;\n font-family: var(--paragraph-font-family, Poppins);\n cursor: pointer;\n color: var(--selected-text-color, #ffffff);\n background-color: var(--primary-color, #3b82f6);\n transition: background-color 0.15s ease-in-out, transform 0.1s ease-in-out;\n }\n\n .product-list-filters-apply-btn:hover {\n background-color: var(--primary-color, #3b82f6);\n }\n\n .product-list-filters-apply-btn:active {\n transform: translateY(1px);\n background-color: var(--primary-color, #3b82f6);\n }\n\n .product-list-filters-apply-btn:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n\n /* No Results */\n .checkbox-filter-no-results {\n padding: 24px 16px;\n text-align: center;\n color: var(--default-text-color-70, #9ca3af);\n font-size: 14px;\n font-family: var(--paragraph-font-family, Poppins);\n }\n\n /* Search Styles */\n .product-list-search-box {\n position: relative;\n width: 100%;\n display: flex;\n align-items: center;\n }\n\n .product-list-search-icon {\n position: absolute;\n left: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n pointer-events: none;\n color: #9ca3af;\n }\n\n .product-list-search-icon svg {\n width: 20px;\n height: 20px;\n stroke: var(--default-text-color, #18181B) !important;\n }\n\n .product-list-search-icon svg path {\n stroke: var(--default-text-color, #18181B) !important;\n }\n\n .product-list-search-input {\n width: 100%;\n border: 0;\n border-bottom: 1px solid #d1d5db;\n border-radius: 0;\n background-color: transparent;\n color: #374151;\n padding: 0.25rem 2rem;\n font-size: 1rem;\n font-family: var(--paragraph-font-family, Poppins);\n -moz-appearance: none;\n -webkit-appearance: none;\n appearance: none;\n transition: border-color 0.15s ease-in-out;\n }\n\n .product-list-search-input:focus {\n outline: none;\n border-bottom-color: #6b7280;\n border-radius: 0;\n box-shadow: none;\n }\n\n .product-list-search-input::placeholder {\n color: #9ca3af;\n }\n\n .product-list-search-clear-btn {\n position: absolute;\n right: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n background: none;\n border: none;\n border-radius: 0;\n cursor: pointer;\n padding: 0.25rem;\n color: #9ca3af;\n transition: color 0.15s ease-in-out;\n }\n\n .product-list-search-clear-btn:hover {\n color: #374151;\n cursor: pointer;\n }\n\n .product-list-search-clear-btn:focus {\n outline: none;\n box-shadow: none;\n }\n\n .product-list-search-clear-btn svg {\n width: 20px;\n height: 20px;\n }\n\n /* Product List Card Styles */\n .product-list-card.standard {\n height: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n border: 1px solid var(--accent-color, #f3f4f6);\n border-radius: var(--card-border-radius, 0.375rem);\n cursor: pointer;\n overflow: hidden;\n }\n\n .product-list-card.fill {\n background-color: #ffffff;\n }\n\n .product-list-card.standard.not-available {\n cursor: not-allowed;\n }\n\n .product-list-card.standard.not-available:hover {\n cursor: not-allowed;\n }\n\n .product-list-card.standard .plc__image-content {\n width: 100%;\n height: 100%;\n padding: 10px;\n }\n\n .product-list-card.standard .plc__image-wrapper {\n width: 100%;\n height: 14rem;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n border-bottom: 1px solid var(--accent-color, #f3f4f6);\n padding-bottom: 10px;\n }\n\n .product-list-card.standard .plc__image-wrapper .plc__image {\n display: block;\n width: 100%;\n height: 100%;\n object-fit: contain;\n }\n\n .product-list-card.standard .plc__content {\n width: 100%;\n padding: 0 10px;\n display: flex;\n flex-direction: column;\n margin-bottom: 10px;\n }\n\n .product-list-card.standard .plc__content .plc__title {\n width: 100%;\n height: 4.6875rem;\n font-size: 1.125rem;\n font-weight: 600;\n color: var(--default-text-color, #111827);\n font-family: var(--paragraph-font-family, Poppins);\n text-transform: uppercase;\n margin-bottom: 10px;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: auto;\n\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 3;\n overflow: hidden;\n line-height: 1.38;\n word-wrap: break-word;\n word-break: break-word;\n }\n\n .product-list-card.standard .plc__image-link {\n text-decoration: none;\n display: block;\n color: inherit;\n width: 100%;\n }\n\n .product-list-card.standard .plc__image-link:hover {\n text-decoration: none;\n }\n\n .product-list-card.standard .plc__title-link {\n text-decoration: none;\n display: block;\n color: inherit;\n width: 100%;\n }\n\n .product-list-card.standard .plc__title-link:hover {\n text-decoration: underline;\n }\n\n .product-list-card.standard .plc__title-link .plc__title {\n color: var(--default-text-color, #111827);\n }\n\n .plc__size-price-wrapper {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n font-family: var(--paragraph-font-family, Poppins);\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: auto;\n color: var(--default-text-color, #111827);\n }\n\n .plc__size-price-wrapper .plc__size {\n font-size: 1rem;\n font-weight: 600;\n }\n\n .plc__button {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n height: auto;\n white-space: nowrap;\n text-align: center;\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: 600;\n text-transform: capitalize;\n color: var(--selected-text-color, #ffffff);\n background-color: var(--primary-color, #3b82f6);\n padding: 0.5rem 0.375rem;\n transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;\n transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);\n transition-duration: 150ms;\n }\n\n .plc__button:hover {\n background-color: var(--primary-color-70, #3b82f6);\n }\n\n .plc__button:disabled {\n pointer-events: none;\n opacity: 0.5;\n }\n\n /* Infinite Scroll Sentinel Styles */\n .product-list-scroll-sentinel {\n width: 100%;\n flex: 0 0 100%;\n min-height: 80px;\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 24px 16px;\n margin: 16px auto;\n box-sizing: border-box;\n }\n\n .product-list-sentinel-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n }\n \n .product-list-sentinel-container > *:not(:last-child) {\n margin-top: 12px;\n }\n\n .product-list-sentinel-spinner {\n width: 24px;\n height: 24px;\n border: 2px solid var(--primary-color-20, rgba(59, 130, 246, 0.2));\n border-top-color: var(--primary-color, #3b82f6);\n border-radius: 50%;\n animation: product-list-spin 0.8s linear infinite;\n }\n\n @keyframes product-list-spin {\n to {\n transform: rotate(360deg);\n }\n }\n\n .product-list-sentinel-text {\n font-size: 14px;\n color: var(--primary-color, #3b82f6);\n font-weight: 500;\n letter-spacing: 0.3px;\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n }\n\n .product-list-sentinel-icon {\n font-size: 20px;\n color: var(--primary-color-80, rgba(59, 130, 246, 0.8));\n animation: product-list-bounce 2s ease-in-out infinite;\n margin-bottom: 4px;\n }\n\n @keyframes product-list-bounce {\n 0%, 100% {\n transform: translateY(0);\n }\n 50% {\n transform: translateY(4px);\n }\n }\n\n .product-list-sentinel-info-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n }\n\n .product-list-sentinel-divider {\n width: 60px;\n height: 1px;\n background: var(--primary-color-30, rgba(59, 130, 246, 0.3));\n margin-bottom: 8px;\n }\n\n .product-list-sentinel-info-text {\n font-size: 13px;\n font-weight: 400;\n letter-spacing: 0.2px;\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n color: var(--primary-color, rgba(59, 130, 246, 0.67));\n }\n\n .product-list-sentinel-info-text.no-more {\n color: var(--primary-color, rgba(59, 130, 246, 0.8));\n font-weight: 500;\n }\n\n .product-list-sentinel-error-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n }\n\n .product-list-sentinel-error-container > *:not(:last-child) {\n margin-top: 8px;\n }\n\n .product-list-sentinel-error-icon {\n font-size: 18px;\n color: var(--error-color, #ef4444);\n }\n\n .product-list-sentinel-error-text {\n font-size: 13px;\n color: var(--error-color, #ef4444);\n font-weight: 500;\n letter-spacing: 0.2px;\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n }\n\n /* Responsive Styles */\n\n /* Mobile and Tablet - Below 1024px */\n @media (max-width: 1023px) {\n .product-list-filter-container {\n display: flex;\n }\n\n .product-list-controls {\n width: 100%;\n display: flex;\n flex-direction: column;\n gap: 24px;\n }\n\n /* Hide filters in main product list on mobile */\n .product-list-controls .product-list-filters-container {\n display: none;\n }\n\n /* Show filters in drawer on mobile */\n .product-list-filters-drawer-wrapper .product-list-filters-container {\n display: block;\n position: static;\n width: 100%;\n padding: 24px;\n }\n\n .product-list-cards__container {\n width: 100%;\n }\n\n .checkbox-filter-list {\n max-height: 220px;\n }\n \n .checkbox-filter-search {\n font-size: 14px;\n }\n }\n\n /* Mobile - 1 column (up to 639px) */\n @media (max-width: 639px) {\n .product-list-cards__container {\n --columns: 1;\n --gap-per-card: 0px;\n }\n\n .product-list-card.standard {\n width: 100%;\n flex: 0 0 100%;\n }\n }\n\n /* Small tablets - 2 columns (640px to 767px) */\n @media (min-width: 640px) and (max-width: 767px) {\n .product-list-cards__container {\n --columns: 2;\n --gap-per-card: 12px;\n }\n\n .product-list-card.standard {\n width: calc(50% - 12px);\n flex: 0 0 calc(50% - 12px);\n }\n }\n\n /* Tablets - 3 columns (768px to 1023px) */\n @media (min-width: 768px) and (max-width: 1023px) {\n .product-list-cards__container {\n width: 100%;\n --columns: 3;\n --gap-per-card: 16px;\n }\n\n .product-list-card.standard {\n width: calc(33.333% - 16px);\n flex: 0 0 calc(33.333% - 16px);\n }\n }\n\n /* Desktop - Use configured columns (1024px and up) */\n @media (min-width: 1024px) {\n .product-list-filter-container {\n display: none;\n }\n\n .product-list-cards__container {\n --gap-per-card: calc(24px * (var(--columns, 4) - 1) / var(--columns, 4));\n }\n\n .product-list-card.standard {\n width: calc(var(--card-width, 25%) - var(--gap-per-card, 18px));\n flex: 0 0 calc(var(--card-width, 25%) - var(--gap-per-card, 18px));\n }\n }\n",getAddressStyles=()=>"\n .address-input-container {\n width: 100%;\n max-width: 100%;\n min-width: 320px;\n height: 100%;\n font-family: var(--heading-font-family, Poppins);\n position: relative;\n display: flex;\n flex-direction: column;\n }\n\n .address-input-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .address-input-container .input-title {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--heading-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n padding-bottom: 8px;\n text-align: left;\n }\n\n .address-input-container .input-section {\n position: relative;\n }\n\n .address-input-container .input-wrapper {\n display: flex;\n flex-direction: row;\n align-items: center;\n align-self: stretch;\n padding: 4px 12px;\n border-radius: var(--card-border-radius, 6px);\n box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.05);\n }\n\n .address-input-container .input-wrapper.filled {\n background-color: var(--accent-color, #E4E4E7);\n }\n\n .address-input-container .input-wrapper.outlined {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .address-input-container .input-icon {\n display: flex;\n margin-left: 4px;\n }\n\n .address-input-container .input-icon svg {\n stroke: var(--default-text-color, #18181B);\n }\n\n /* Remove bottom border radius when suggestions are shown */\n .address-input-container .suggestions-list.show ~ .input-wrapper,\n .address-input-container .input-section.suggestions-expanded .input-wrapper {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n }\n\n /* Alternative approach using a modifier class */\n .address-input-container .input-wrapper.suggestions-expanded {\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n }\n\n .address-input-container .input-field {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n width: 100%;\n border: none\n }\n\n .address-input-container .input-field:focus {\n outline: none;\n border: none;\n box-shadow: none;\n }\n\n .address-input-container .suggestions-list {\n position: absolute;\n top: 100%;\n left: 0;\n right: 0;\n z-index: "+N.ADDRESS_SUGGESTIONS+";\n list-style: none;\n overflow-y: auto;\n padding: 4px 0;\n align-self: stretch;\n border-radius: 0 0 6px 6px;\n border-right: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n border-left: 1px solid var(--accent-color, #E4E4E7);\n background: var(--drawer-background-color, #FAFAFA);\n }\n\n .address-input-container .suggestions-list.show {\n border-top-left-radius: 0;\n border-top-right-radius: 0;\n }\n\n .address-input-container .suggestions-list.hide {\n display: none;\n }\n\n .address-input-container .suggestions-list.show {\n display: block;\n }\n\n .address-input-container .suggestion-item {\n display: flex;\n padding: 6px 8px;\n align-items: center;\n align-self: stretch;\n cursor: pointer;\n text-align: left;\n }\n\n .address-input-container .suggestion-item > span {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 1;\n flex: 1 0 0;\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n white-space: nowrap;\n text-overflow: ellipsis;\n max-width: 100%;\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n\n .address-input-container .suggestion-item:hover {\n border-radius: 2px;\n background: linear-gradient(0deg, var(--alpha-50, rgba(254, 254, 254, 0.50)) 0%, var(--alpha-50, rgba(254, 254, 254, 0.50)) 100%), var(--default-text-color-50, #E4E4E7);\n }\n\n .address-input-container .suggestion-item.no-suggestions {\n color: var(--warning-color, #6B7280);\n text-align: center;\n cursor: default;\n }\n\n .address-input-container .suggestion-item.no-suggestions:hover {\n background-color: transparent;\n }\n\n .address-input-container .error-message {\n display: flex;\n align-items: center;\n padding: 12px;\n border: 1px solid var(--error-color, #B91C1C);\n border-radius: var(--card-border-radius, 6px);\n color: var(--error-color, #B91C1C);\n font-size: 14px;\n position: relative;\n z-index: "+N.ERROR_MESSAGE+";\n }\n\n .address-input-container .error-icon {\n font-size: 16px;\n margin-right: 8px;\n }\n\n .address-input-container .error-text {\n flex: 1;\n }\n\n .address-input-container .action-buttons {\n display: flex;\n justify-content: space-between;\n position: relative;\n z-index: "+N.ADDRESS_ACTIONS+";\n }\n\n .address-input-container .action-buttons > button {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 8px 16px;\n border-radius: var(--button-border-radius, 6px);\n transition: all 0.2s ease;\n width: 50%;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .address-input-container .action-buttons > button:not(:first-child) {\n margin-left: 8px;\n }\n\n .address-input-container .action-buttons .secondary-button {\n color: var(--default-text-color, #18181B);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .address-input-container .action-buttons .primary-button {\n color: var(--selected-text-color, #18181B);\n background-color: var(--primary-color, #E4E4E7);\n border: 1px solid transparent;\n }\n\n .privacy-notice {\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 11px;\n font-style: normal;\n font-weight: 400;\n color: var(--default-text-color, #18181B);\n text-align: left;\n }\n\n /* Enhanced fallback for browsers without line-clamp */\n @supports not (-webkit-line-clamp: 1) {\n .address-input-container .suggestion-item > span {\n display: block;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n }\n\n .address-display-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .address-display-container > span {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n margin-bottom: 8px;\n }\n\n .address-display-container > button {\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n text-align: left;\n }\n",getCartStyles=()=>"\n .cart-container {\n display: flex;\n width: 100%;\n height: 100%;\n flex-direction: column;\n align-items: center;\n }\n\n .cart-container.no-header .cart-body {\n padding: 0 0 16px 0;\n }\n\n .cart-container.no-header .cart-footer {\n padding: 16px 0 0 0;\n }\n\n .cart-header {\n width: 100%;\n display: flex;\n flex-direction: column;\n position: sticky;\n top: 0;\n background-color: var(--drawer-background-color, #FFFFFF);\n z-index: "+N.CART_HEADER+";\n }\n\n .cart-header-content {\n width: 100%;\n height: 48px;\n display: flex;\n align-items: center;\n align-self: stretch;\n justify-content: space-between;\n padding: 16px;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .cart-title {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n }\n\n .cart-header-close-btn {\n font-size: 1.4rem;\n font-weight: 300;\n border: none;\n background: none;\n }\n\n .cart-header-close-btn:hover {\n cursor: pointer;\n }\n\n .cart-body {\n position: relative;\n flex: 1;\n display: flex;\n padding: 16px;\n flex-direction: column;\n align-self: stretch;\n }\n\n .cart-body > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .empty-cart-container {\n display: flex;\n align-self: center;\n margin: auto;\n }\n\n .retailer-section {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .section-header-label {\n display: flex;\n justify-content: space-between;\n align-items: center;\n cursor: pointer;\n }\n\n .cart-fulfillment-subtotal {\n color: var(--default-text-color, #18181B);\n }\n\n .section-title {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n }\n\n .cart-retailer-header {\n display: flex;\n flex-direction: column;\n padding: 16px;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .retailer-info {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n width: 100%;\n }\n\n .retailer-body-container {\n display: flex;\n align-items: center;\n align-self: stretch;\n flex-direction: column;\n max-height: 2000px;\n overflow: hidden;\n transition: max-height 0.3s ease;\n }\n\n .retailer-subtotal-container {\n display: flex;\n padding: 16px;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .retailer-subtotal-header {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .retailer-subtotal-amount {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .retailer-fulfillment-container {\n display: flex;\n padding: 16px;\n flex-direction: column;\n align-items: center;\n align-self: stretch;\n max-height: 2000px;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .retailer-fulfillment-container > .cart-item-container {\n margin-top: 16px;\n }\n\n .cart-item-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .cart-item-container > *:not(:first-child) {\n margin-top: 12px;\n }\n\n .cart-item {\n display: flex;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .cart-item > *:not(:first-child) {\n margin-left: 16px;\n }\n\n .item-image {\n display: flex;\n width: 56px;\n height: 70px;\n flex-direction: column;\n align-items: center;\n border-radius: var(--card-border-radius, 6px);\n }\n\n .item-image img {\n max-width: 100%;\n max-height: 100%;\n object-fit: contain;\n }\n\n .item-details {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n flex: 1 0 0;\n align-self: stretch;\n }\n\n .item-details > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .quantity-price {\n display: flex;\n height: 36px;\n align-items: center;\n align-content: center;\n align-self: stretch;\n flex-wrap: wrap;\n justify-content: space-between;\n }\n\n .item-title {\n font-weight: 500;\n font-size: 0.95rem;\n word-break: break-word;\n margin: 0;\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .item-specs {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .item-shipping-container {\n width: 100%;\n display: flex;\n flex-wrap: wrap;\n justify-content: space-between;\n }\n\n .cart-add-personalization-span {\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n .item-shipping {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .item-quantity {\n display: flex;\n width: 106px;\n align-items: center;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-weight: 500;\n }\n\n .quantity-btn-increase {\n display: flex;\n width: 36px;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n flex-shrink: 0;\n border-radius: 0px var(--button-border-radius, 6px) var(--button-border-radius, 6px) 0px;\n background: none;\n cursor: pointer;\n }\n\n .item-quantity.outlined .quantity-btn-increase {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .quantity-btn-decrease {\n display: flex;\n width: 36px;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n flex-shrink: 0;\n border-radius: var(--button-border-radius, 6px) 0px 0px var(--button-border-radius, 6px);\n background: none;\n cursor: pointer;\n }\n\n .item-quantity.outlined .quantity-btn-decrease {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .quantity-btn-decrease:disabled,\n .quantity-btn-increase:disabled,\n .quantity-btn-disabled {\n opacity: 0.7;\n cursor: not-allowed;\n }\n\n .quantity-value {\n display: flex;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n align-self: stretch;\n }\n\n .item-quantity.outlined .quantity-value {\n border-top: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .item-price-container {\n display: flex;\n justify-content: flex-end;\n align-items: center;\n align-content: center;\n flex: 1 0 0;\n flex-wrap: wrap;\n }\n\n .item-price-container > *:not(:first-child) {\n margin-left: 6px;\n }\n\n .item-price {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n }\n\n .item-price-per-unit {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n }\n\n .item-header {\n display: flex;\n align-items: flex-start;\n justify-content: space-between;\n align-self: stretch;\n }\n\n .cart-footer {\n margin-top: auto;\n display: flex;\n min-height: 146px;\n padding: 16px;\n flex-direction: column;\n justify-content: flex-end;\n align-items: flex-start;\n align-self: stretch;\n border-top: 1px solid var(--accent-color, #E4E4E7);\n flex-shrink: 0;\n }\n\n .cart-footer > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .cart-footer-header {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n flex: 1 0 0;\n }\n\n .cart-footer-header > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .cart-footer-header .cart-footer-items-price {\n width: 100%;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n }\n\n .cart-footer-header .subtotal-text {\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 14px;\n }\n\n .cart-footer-header .subtotal-price {\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 14px;\n }\n\n .cart-footer-header .taxes-fees-info {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 14px;\n max-width: 85%;\n }\n\n .promo-input {\n display: flex;\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n font-size: 16px;\n align-self: stretch;\n width: 100%;\n border-radius: var(--button-border-radius, 6px);\n }\n\n .promo-input.outlined {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .promo-input.filled {\n background-color: var(--accent-color, #E4E4E7);\n }\n\n .checkout-button {\n display: flex;\n position: relative;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n border: none;\n cursor: pointer;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #F1F5F9);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .checkout-button.loading::after {\n content: '';\n position: absolute;\n right: 16px;\n top: 50%;\n transform: translateY(-50%);\n z-index: "+N.LOADING_INDICATOR+";\n width: 18px;\n height: 18px;\n border: 2px solid transparent;\n border-top: 2px solid var(--selected-text-color);\n border-radius: 50%;\n animation: spin 1s linear infinite;\n }\n\n .checkout-btn-disabled {\n opacity: 0.7;\n cursor: not-allowed;\n }\n\n /* CSS-only accordions */\n .chevron {\n transition: transform 0.3s ease;\n }\n\n /* Product section accordions */\n .section-toggle {\n display: none;\n }\n\n .section-toggle:checked + .section-header-label .chevron {\n transform: rotate(180deg);\n color: var(--default-text-color, #18181B);\n }\n\n .retailer-section.collapsed .retailer-body-container {\n max-height: 0;\n }\n\n .retailer-section.collapsed .cart-retailer-header {\n border-bottom: none;\n }\n\n .shipping-content {\n max-height: 0;\n overflow: hidden;\n transition: max-height 0.3s ease-out;\n padding-left: 20px;\n }\n\n /** * Loading spinner styles */\n .cart-loading-backdrop {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: var(--drawer-background-color-30, #E4E4E7);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: "+N.CART_LOADING+";\n }\n\n /* Modern browsers with backdrop-filter support */\n @supports (backdrop-filter: blur(1px)) {\n .cart-loading-backdrop {\n background-color: var(--drawer-background-color-30, #E4E4E7);\n backdrop-filter: blur(1px);\n }\n }\n\n .cart-loading-spinner-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n text-align: center;\n }\n\n .cart-loading-spinner {\n margin-bottom: 16px;\n }\n\n .cart-spinner {\n animation: cart-spinner-rotate 2s linear infinite;\n color: var(--primary-color, #1D4ED8);\n }\n\n .cart-spinner-path {\n stroke-dasharray: 90, 150;\n stroke-dashoffset: 0;\n stroke-linecap: round;\n animation: cart-spinner-dash 1.5s ease-in-out infinite;\n }\n\n @keyframes cart-spinner-rotate {\n 100% {\n transform: rotate(360deg);\n }\n }\n\n @keyframes cart-spinner-dash {\n 0% {\n stroke-dasharray: 1, 150;\n stroke-dashoffset: 0;\n }\n 50% {\n stroke-dasharray: 90, 150;\n stroke-dashoffset: -35;\n }\n 100% {\n stroke-dasharray: 90, 150;\n stroke-dashoffset: -124;\n }\n }\n\n /*PROMO CODE */\n .promo-container {\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n align-self: stretch;\n flex: 1;\n }\n\n .promo-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .promo-container-wrapper {\n display: flex;\n justify-content: space-between;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .promo-code-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .promo-input-wrapper {\n flex: 1;\n }\n\n /* Style the InputComponent container */\n .promo-input-wrapper .custom-input {\n margin: 0;\n width: 100%;\n }\n\n /* Hide label in promo context since we have placeholder */\n .promo-input-wrapper .custom-input label {\n display: none;\n }\n\n /* Style the actual input inside the InputComponent */\n .promo-input-wrapper .promo-input {\n width: 100%;\n padding: 12px 16px;\n border: 1px solid #ddd;\n border-radius: var(--button-border-radius, 6px);\n font-size: 14px;\n transition: border-color 0.2s ease, box-shadow 0.2s ease;\n box-sizing: border-box;\n }\n\n .promo-input-wrapper .promo-input:focus {\n outline: none;\n border-color: var(--primary-color, #1D4ED8);\n }\n\n .promo-input-wrapper .promo-input:disabled {\n background-color: #f8f9fa;\n cursor: not-allowed;\n opacity: 0.6;\n }\n\n .promo-input-wrapper .promo-input.input-error {\n border-color: #dc3545; }\n\n /* Error container styling from InputComponent */\n .promo-input-wrapper .error-container {\n margin-top: 4px;\n min-height: 20px;\n }\n\n .promo-input-wrapper .error-message {\n color: #dc3545;\n font-size: 12px;\n margin: 2px 0;\n display: block;\n }\n\n /* Apply button styling */\n .apply-button {\n display: flex;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .apply-button:hover:not(:disabled) {\n opacity: 0.9;\n }\n\n .apply-button:disabled {\n cursor: not-allowed;\n opacity: 0.7;\n }\n\n /* Applied promo code display - matches the design */\n .promo-applied-container {\n display: flex;\n justify-content: space-between;\n align-items: flex-start;\n align-self: stretch;\n align-items: center;\n flex: 1;\n }\n\n .promo-code-pill {\n display: flex;\n height: var(--height-h-9, 36px);\n padding: 4px 12px;\n align-items: center;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px\n }\n\n .promo-remove-btn {\n background: none;\n border: none;\n cursor: pointer;\n border-radius: 4px;\n transition: all 0.2s ease;\n text-decoration: underline;\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n }\n\n .error-banner {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n color: var(--default-text-color, #18181B);\n padding: 8px 16px;\n flex-grow: 1;\n\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--error-color, #DC2626);\n border: 1px solid var(--error-color, #DC2626);\n border-radius: var(--card-border-radius, 6px) 0 0 var(--card-border-radius, 6px);\n }\n\n .error-banner > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .close-btn {\n border: none;\n font-size: 16px;\n cursor: pointer;\n color: #fff;\n border-radius: 0 var(--button-border-radius, 6px) var(--button-border-radius, 6px) 0;\n padding: 8px 16px;\n\n background: var(--error-color, #DC2626);\n }\n\n /* Mobile responsive */\n .promo-code-pill {\n align-self: flex-start;\n }\n\n .promo-remove-btn {\n align-self: flex-end;\n padding: 4px 8px;\n }\n }\n\n /* Optional: Add loading indicator styles if needed */\n .promo-input-wrapper.loading::after {\n content: '';\n position: absolute;\n right: 12px;\n top: 50%;\n transform: translateY(-50%);\n z-index: "+N.LOADING_INDICATOR+";\n width: 16px;\n height: 16px;\n border: 2px solid var(--accent-color, #E4E4E7);\n border-top: 2px solid var(--accent-color, #E4E4E7);\n border-radius: 50%;\n animation: spin 1s linear infinite;\n }\n\n @keyframes spin {\n 0% { transform: translateY(-50%) rotate(0deg); }\n 100% { transform: translateY(-50%) rotate(360deg); }\n }\n\n .empty-cart-content {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n",getCheckoutStyles=()=>"\n .checkout-container {\n width: 100%;\n height: auto;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n align-self: stretch;\n gap: 24px;\n }\n\n .checkout-container:not(.independent) {\n padding: 24px;\n }\n\n .checkout-container.independent {\n padding: 24px;\n }\n\n .checkout-container.no-header .checkout-information-section,\n .checkout-container.no-header .checkout-summary-section {\n padding: 0;\n }\n\n .checkout-information-section {\n min-width: 320px;\n max-width: 512px;\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n flex-wrap: wrap;\n flex: 1 0 0;\n }\n\n .checkout-information-section > *:not(:first-child) {\n margin-top: 24px;\n padding-top: 24px;\n border-top: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-delivery-information,\n .checkout-buyer-information,\n .checkout-billing-form {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-delivery-information > *:not(:first-child),\n .checkout-buyer-information > *:not(:first-child),\n .checkout-billing-form > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-billing-form {\n margin-top: 24px;\n }\n\n .checkout-payment-form {\n display: flex;\n flex-direction: column;\n align-self: stretch;\n }\n\n .checkout-payment-form > *:not(:last-child) {\n margin-bottom: 24px;\n }\n\n .delivery-header-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n flex-wrap: wrap;\n }\n\n .delivery-title-container {\n display: flex;\n min-width: 200px;\n flex-direction: column;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .delivery-title-container > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .section-title-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .section-title-container > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .delivery-title-container > .delivery-title,\n .section-title-container > .section-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .delivery-title-container > .delivery-subtitle,\n .section-title-container > .section-subtitle {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .gift-toggle-container {\n display: flex;\n padding: 2px 0px;\n align-self: stretch;\n justify-content: space-between;\n align-items: flex-start;\n }\n\n .gift-toggle-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .gift-toggle-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .gift-label-wrapper {\n display: flex;\n flex-direction: column;\n min-width: 200px;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .gift-toggle-description {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n margin-top: 6px;\n }\n\n .toggle-switch {\n position: relative;\n width: 40px;\n height: 20px;\n background-color: var(--primary-color-30, #d1d5db);\n border-radius: 12px;\n cursor: pointer;\n transition: background-color 0.2s ease;\n }\n\n .toggle-switch.active {\n background-color: var(--primary-color, #3b82f6);\n }\n\n .toggle-slider {\n position: absolute;\n top: 2px;\n left: 2px;\n width: 16px;\n z-index: "+N.TOGGLE_SLIDER+";\n height: 16px;\n background-color: var(--accent-color, #ffffff);\n border-radius: 50%;\n transition: transform 0.2s ease;\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n }\n\n .toggle-switch.active .toggle-slider {\n transform: translateX(20px);\n }\n\n .section-form-container {\n display: flex;\n flex-direction: column;\n align-self: stretch;\n }\n\n .section-form-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .textarea-message-disclaimer {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n margin-top: 6px;\n }\n\n .checkout-tips-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-tips-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-tip-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-tip-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-tip-distribution-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-tip-distribution-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .retailers-tips-list {\n display: none;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .retailers-tips-list > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .retailers-tips-list.show {\n display: flex;\n }\n\n .checkout-tip-distribution-item {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-tip-fulfillment-input-wrapper {\n display: flex;\n align-items: center;\n }\n\n .checkout-tip-fulfillment-input-wrapper > *:not(:first-child) {\n margin-left: 16px;\n }\n\n .checkout-tip-remove-button {\n color: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n .checkout-tip-distribution-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n cursor: pointer;\n }\n\n .checkout-sub-header {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .checkout-tip-disclaimer {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-tip-config-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-tip-config-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-tip-selection-container {\n display: flex;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-tip-selection-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-tip-button {\n display: flex;\n padding: 8px 16px;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n border-radius: var(--button-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .checkout-tip-button.selected {\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n }\n\n .checkout-tip-button > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .checkout-tip-input-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-tip-input-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-tip-input {\n display: flex;\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-sections-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-sections-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-pc-gc-sub-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-pc-gc-sub-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-pc-gc-applied {\n display: flex;\n width: 100%;\n flex-direction: row;\n align-self: stretch;\n display: flex;\n padding: 0px 12px;\n justify-content: space-between;\n align-items: center;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-pc-gc-applied span {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n text-transform: uppercase;\n }\n\n .checkout-pc-gc-applied button {\n display: flex;\n height: 36px;\n padding: 8px 0px;\n justify-content: center;\n align-items: center;\n border-radius: var(--button-border-radius, 6px);\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .checkout-send-as-gift-toggle-container {\n position: absolute;\n top: 16px;\n right: 16px;\n z-index: "+N.FORM_CONTROLS+";\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: flex-end;\n\n cursor: pointer;\n }\n\n .checkout-two-col-container {\n display: flex;\n align-items: flex-start;\n align-content: flex-start;\n align-self: stretch;\n flex-wrap: wrap;\n margin-right: -16px;\n margin-bottom: -16px;\n }\n\n .checkout-two-col-container > * {\n margin-right: 16px;\n margin-bottom: 16px;\n }\n\n .checkout-three-col-container {\n display: flex;\n flex-direction: row;\n }\n\n .checkout-three-col-container > *:not(:first-child) {\n margin-left: 16px;\n }\n\n .checkout-send-to-form.collapsed {\n display: none;\n }\n\n .checkout-send-to-title,\n .checkout-your-info-title,\n .checkout-billing-title,\n .checkout-payment-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .checkout-send-to-subtitle,\n .checkout-your-info-subtitle,\n .checkout-billing-subtitle,\n .checkout-payment-subtitle {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-summary-section {\n min-width: 320px;\n max-width: 400px;\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n }\n\n .checkout-summary-section > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-disclaimer-title,\n .checkout-summary-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .checkout-disclaimer-subtitle,\n .checkout-summary-subtitle {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-promo-code-container,\n .checkout-gift-cards-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-promo-code-container > *:not(:first-child),\n .checkout-gift-cards-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .input-promo-code-container,\n .input-gift-card-container {\n display: flex;\n flex-direction: row;\n align-self: stretch;\n }\n\n .input-promo-code-container > *:not(:first-child),\n .input-gift-card-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .input-promo-code-container .apply-button,\n .input-gift-card-container .apply-button {\n display: flex;\n padding: 8px 16px;\n justify-content: center;\n align-self: flex-start;\n align-items: center;\n\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .input-promo-code-container .apply-button.disabled,\n .input-gift-card-container .apply-button.disabled {\n background: var(--primary-color-50, #1D4ED8);\n }\n\n .checkout-amounts-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-amounts-container > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .checkout-amount-line {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-amount-line span {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-amount-total {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n\n }\n\n .checkout-amount-total span {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .checkout-separator {\n width: 100%;\n height: 1px;\n margin: 0px;\n background: var(--accent-color, #E4E4E7);\n }\n\n .checkout-place-order-button-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-place-order-button {\n display: flex;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n font-family: var(--paragraph-font-family, Poppins);\n align-self: stretch;\n font-weight: 600;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n transition: all 0.2s ease;\n cursor: pointer;\n position: relative;\n }\n\n .checkout-place-order-button-container .alert-container, .checkout-place-order-button-container .alert-wrapper {\n margin-bottom: 24px;\n }\n\n .checkout-place-order-button.ready {\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n }\n\n .checkout-place-order-button.ready:hover {\n filter: brightness(0.9);\n transform: translateY(-1px);\n }\n\n .checkout-place-order-button.ready:active {\n transform: translateY(0);\n }\n\n /* States when things are missing/wrong - use your opacity variants */\n .checkout-place-order-button.form-invalid,\n .checkout-place-order-button.payment-incomplete,\n .checkout-place-order-button.payment-error {\n background: var(--primary-color-70);\n color: var(--selected-text-color);\n }\n\n .checkout-place-order-button.form-invalid:hover,\n .checkout-place-order-button.payment-incomplete:hover,\n .checkout-place-order-button.payment-error:hover {\n background: var(--primary-color-70);\n }\n\n /* Processing state - keep full primary color to show confidence */\n .checkout-place-order-button.processing {\n cursor: not-allowed;\n pointer-events: none;\n }\n\n .checkout-place-order-button.processing::after {\n content: '';\n position: absolute;\n right: 16px;\n top: 50%;\n transform: translateY(-50%);\n z-index: "+N.LOADING_INDICATOR+';\n width: 18px;\n height: 18px;\n border: 2px solid transparent;\n border-top: 2px solid var(--selected-text-color);\n border-radius: 50%;\n animation: spin 1s linear infinite;\n }\n\n /* Disabled state - very muted */\n .checkout-place-order-button.disabled {\n background: var(--primary-color-70, #D1D5DB);\n cursor: not-allowed;\n }\n\n /* Focus states for accessibility */\n .checkout-place-order-button:focus {\n outline: none;\n box-shadow: 0 0 0 3px var(--primary-color-70);\n }\n\n .checkout-place-order-button.disabled:focus {\n box-shadow: none;\n }\n\n .checkout-marketing-opt-ins-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-marketing-opt-ins-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-billing-same-as-shipping-toggle-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: flex-start;\n cursor: pointer;\n }\n\n .checkout-billing-same-as-shipping-toggle-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-items-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-items-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-items-toggler {\n display: flex;\n height: 14px;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n cursor: pointer;\n }\n\n .checkout-items-toggler-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .checkout-items-list {\n display: none;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-items-list > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-items-list.show {\n display: flex;\n }\n\n .checkout-item-card {\n display: flex;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-item-card > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .checkout-item-card-header {\n display: flex;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-item-card-header > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-item-details-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .checkout-item-card-footer {\n display: flex;\n height: 36px;\n align-items: center;\n align-content: center;\n justify-content: space-between;\n align-self: stretch;\n flex-wrap: wrap;\n margin-right: -8px;\n margin-bottom: -8px;\n }\n\n .checkout-item-card-footer > * {\n margin-right: 8px;\n margin-bottom: 8px;\n }\n\n .checkout-item-image {\n display: flex;\n width: 64px;\n height: 70px;\n flex-direction: column;\n align-items: center;\n border-radius: var(--card-border-radius, 6px);\n }\n\n .checkout-item-image img {\n max-width: 100%;\n max-height: 100%;\n object-fit: contain;\n }\n\n .checkout-item-card .checkout-item-subtitle {\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n }\n\n .checkout-item-card .checkout-item-title,\n .checkout-item-card .checkout-item-subtitle > span,\n .checkout-item-price-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n word-break: break-word;\n }\n\n .checkout-item-price-each-text {\n font-weight: 500;\n }\n\n .checkout-item-card .checkout-item-subtitle > span {\n font-weight: 400 !important;\n }\n\n .checkout-item-quantity-container {\n display: flex;\n width: 106px;\n align-items: center;\n }\n\n .billing-checkbox-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n cursor: pointer;\n }\n\n .checkout-item-quantity-container .quantity-decrease,\n .checkout-item-quantity-container .quantity-increase {\n display: flex;\n width: 36px;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n border: 1px solid var(--accent-color, #E4E4E7);\n\n cursor: pointer;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-item-quantity-container .quantity-decrease {\n border-radius: var(--button-border-radius, 6px) 0px 0px var(--button-border-radius, 6px);\n }\n\n .checkout-item-quantity-container .quantity-increase {\n border-radius: 0px var(--button-border-radius, 6px) var(--button-border-radius, 6px) 0px;\n }\n\n .checkout-item-quantity-container .quantity-decrease.disabled,\n .checkout-item-quantity-container .quantity-increase.disabled {\n opacity: 0.7;\n cursor: not-allowed;\n }\n\n .checkout-item-quantity-container .product-count {\n display: flex;\n padding: 6px 8px;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n align-self: stretch;\n\n border-top: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .dollar-input-container {\n display: flex;\n align-items: center;\n border: 1px solid var(--accent-color, #E4E4E7);\n border-radius: var(--button-border-radius, 6px);\n align-self: stretch;\n flex: 1 0 0;\n max-width: 100px;\n\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .dollar-input-container:focus-within {\n outline: none;\n border-color: var(--primary-color, #3b82f6);\n box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);\n }\n\n .dollar-sign {\n font-size: 14px;\n font-weight: 500;\n user-select: none;\n pointer-events: none;\n }\n\n .dollar-input {\n flex: 1;\n border: none;\n outline: none;\n background: transparent;\n }\n\n .dollar-input::placeholder {\n color: var(--default-text-color-70, #18181B);\n }\n\n .dollar-input::-webkit-outer-spin-button,\n .dollar-input::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n .dollar-input[type=number] {\n -moz-appearance: textfield;\n }\n\n .dollar-input:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n }\n\n .dollar-input-container:has(.dollar-input:disabled) {\n opacity: 0.6;\n }\n\n .dollar-input-container:has(.dollar-input:disabled) .dollar-sign {\n color: var(--default-text-color-70, #18181B);\n }\n\n /* Checkout Thank You Page */\n .checkout-completed-container {\n display: flex;\n min-height: 100vh; /* Fallback for browsers that don\'t support dvh */\n min-height: 100dvh;\n min-width: 320px;\n flex-direction: column;\n justify-content: center;\n flex: 1 0 0;\n align-self: stretch;\n }\n\n .checkout-completed-header-container {\n display: flex;\n padding: 24px;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-completed-header-container > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-completed-header-container img {\n width: 200px;\n height: auto;\n object-fit: contain;\n flex-shrink: 0;\n }\n\n .checkout-completed-sub-section {\n display: flex;\n min-width: 216px;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n flex-shrink: 0;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-completed-sub-section > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-completed-sub-section p {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n }\n\n .checkout-completed-section-container {\n display: flex;\n padding: 24px;\n flex-direction: column;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-completed-section-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-completed-help-section > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .checkout-completed-help-section {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 100%;\n text-align: center;\n }\n\n .checkout-completed-section-container button {\n display: flex;\n height: 36px;\n min-width: 182px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n }\n\n .checkout-completed-section-container button svg {\n stroke: var(--selected-text-color, #1D4ED8);\n fill: var(--selected-text-color, #1D4ED8);\n }\n\n .checkout-completed-section-container button span {\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n margin-right: 8px;\n }\n\n .checkout-completed-title-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-completed-title-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .checkout-completed-title-section {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n text-align: center;\n }\n\n .checkout-completed-title-section .presale-expired-title {\n font-family: var(--heading-font-family, Poppins);\n font-size: 24px;\n font-weight: 600;\n line-height: 32px;\n }\n\n .checkout-completed-title-section > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .checkout-completed-title-section\n color: var(--default-text-color, #18181B);\n }\n\n .checkout-completed-title-section p:first-child, .checkout-completed-auto-close-seconds {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 24px;\n font-style: normal;\n font-weight: 600;\n line-height: 32px;\n }\n\n .checkout-completed-title-section h3 {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 24px;\n font-style: normal;\n font-weight: 600;\n line-height: 32px;\n }\n\n .checkout-completed-title-section p, .checkout-completed-auto-close-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 24px;\n }\n\n .checkout-completed-line {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .checkout-completed-line span {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-completed-line:first-child span {\n font-weight: 600;\n }\n\n .checkout-completed-line h3 {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-payment-form-error {\n color: var(--error-color, #EF4444);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n margin-top: 8px;\n }\n\n .checkout-error-wrapper {\n animation: slideIn 0.2s ease-out;\n display: flex;\n align-self: stretch;\n margin-bottom: 8px;\n }\n\n .checkout-error-wrapper > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-error {\n display: flex;\n padding: 12px 16px;\n }\n\n .checkout-error > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-error\n border-radius: var(--button-border-radius, 6px);\n font-size: 14px;\n line-height: 1.5;\n font-family: var(--body-font-family, inherit);\n flex: 1;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n\n background: var(--error-color-30, #DC2626);\n border: 1px solid var(--error-color, #DC2626);\n }\n\n .checkout-error .icon-error {\n flex-shrink: 0;\n width: 16px;\n height: 16px;\n display: inline-block;\n }\n\n .checkout-error .error-text {\n font-family: var(--body-font-family, inherit);\n }\n\n .checkout-error-wrapper[style*="display: none"] {\n display: none !important;\n }\n\n .checkout-checkbox-container {\n display: flex;\n align-items: flex-start;\n }\n\n .checkout-checkbox-container > *:not(:first-child) {\n margin-left: 12px;\n }\n\n .checkout-checkbox-visual {\n width: 16px;\n height: 16px;\n border: 1px solid var(--primary-color, #1D4ED8);\n border-radius: 2px;\n background: var(--primary-color, #1D4ED8);\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n flex-shrink: 0;\n transition: all 0.2s ease;\n margin-top: 3px;\n }\n\n .checkout-checkbox-visual svg {\n opacity: 1;\n transition: opacity 0.2s ease;\n }\n\n .checkout-checkbox-visual:not(.checked) {\n background: transparent;\n }\n\n .checkout-checkbox-visual:not(.checked) svg {\n opacity: 0;\n }\n\n .checkbox-label {\n cursor: pointer;\n user-select: none;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkbox-label a {\n color: var(--link-text-color, #1D4ED8);\n }\n\n .checkbox-label strong {\n font-weight: 600;\n }\n\n .checkbox-label em {\n font-style: italic;\n }\n\n .error-banner-checkout {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n color: var(--default-text-color, #18181B);\n padding: 8px 16px;\n flex-grow: 1;\n align-self: stretch;\n word-break: break-word;\n\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--error-color, #DC2626);\n border: 1px solid var(--error-color, #DC2626);\n border-radius: var(--card-border-radius, 6px);\n }\n\n .error-banner-checkout > *:not(:first-child) {\n margin-left: 8px;\n }\n\n /* It needs background color since it is sticky to cover content behind it\n TODO: for standalone checkout\n */\n .checkout-header-wrapper {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n position: sticky;\n top: 0;\n z-index: '+N.CHECKOUT_HEADER+";\n background-color: var(--drawer-background-color, #F9FAFB);\n }\n\n .checkout-header-container {\n display: flex;\n min-width: 320px;\n flex-direction: row;\n align-items: center;\n align-self: stretch;\n padding: 8px;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .checkout-header-button {\n display: flex;\n height: 36px;\n padding: 12px 16px;\n padding-right: 0px;\n justify-content: center;\n align-items: center;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n stroke: var(--default-text-color, #18181B);\n }\n\n .checkout-header-button > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-header-button-close {\n display: flex;\n height: 36px;\n width: 36px;\n padding: 2px 4px;\n justify-content: center;\n align-items: center;\n stroke: var(--default-text-color, #18181B);\n }\n\n .checkout-header-title {\n display: flex;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n align-self: stretch;\n color: var(--default-text-color, #18181B);\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .checkout-presale-countdown-container {\n display: flex;\n min-width: 320px;\n padding: 12px 24px 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n\n &.is-scrolled {\n box-shadow: 0px 6px 10px -2px var(--primary-color-30);\n }\n\n &.time-warning {\n box-shadow: 0px 6px 10px -2px var(--error-color-30, #FDE68A);\n }\n }\n\n .checkout-presale-countdown {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n border-radius: 0;\n overflow: hidden;\n }\n\n .checkout-presale-countdown.time-warning {\n background: var(--error-color-30, #FDE68A);\n border: 1px solid var(--error-color, #E4E4E7);\n }\n\n .checkout-presale-countdown.time-warning {\n background: transparent;\n border: none;\n }\n\n .checkout-presale-countdown.time-warning .checkout-presale-progress-bar {\n background: var(--error-color-70, #FDE68A);\n }\n\n .checkout-presale-countdown.time-warning .checkout-presale-progress-fill {\n background: var(--error-color, #EF4444);\n }\n\n .checkout-presale-text-container {\n display: flex;\n padding: 0px 0px 6px;\n justify-content: flex-end;\n align-self: stretch;\n flex-direction: column;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .checkout-presale-progress-bar {\n display: flex;\n height: 6px;\n align-items: center;\n align-self: stretch;\n border-radius: 40px;\n background: var(--primary-color-50, #E4E4E7);\n position: relative;\n overflow: hidden;\n }\n\n .checkout-presale-progress-fill {\n position: absolute;\n top: 0;\n left: 0;\n height: 100%;\n z-index: "+N.PROGRESS_BAR+';\n background: var(--primary-color, #16a34a);\n transition: width 0.1s linear;\n border-radius: inherit;\n }\n\n .checkout-presale-heading {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n align-self: stretch;\n }\n\n .checkout-presale-timer {\n font-variant-numeric: tabular-nums;\n letter-spacing: 0.02em;\n font-variant-numeric: tabular-nums;\n font-feature-settings: "tnum" 1, "kern" 0;\n min-width: 76px;\n white-space: nowrap;\n\n &.time-warning {\n color: var(--error-color, #EF4444);\n }\n }\n\n .checkout-presale-subtitle {\n transition: opacity 0.3s ease, max-height 0.3s ease;\n opacity: 1;\n max-height: 100px;\n overflow: hidden;\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n\n .checkout-presale-countdown.is-scrolled .checkout-presale-subtitle {\n opacity: 0;\n max-height: 0;\n }\n\n .checkout-completed-container .powered-by-container {\n margin-top: auto;\n padding: 24px;\n }\n\n .checkout-completed-container .checkout-legal-message {\n padding: 0 24px;\n }\n\n .checkout-legal-message {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-weight: 500;\n line-height: 20px;\n text-align: center;\n word-break: break-word;\n margin: 10px 0 !important;\n }\n\n .checkout-legal-message + .checkout-separator {\n margin-top: 0 !important;\n }\n\n .checkout-legal-message a {\n color: var(--primary-color, #1D4ED8);\n }\n\n .checkout-legal-message strong {\n font-weight: 600;\n }\n\n .checkout-legal-message em {\n font-style: italic;\n }\n\n .checkout-amount-due {\n display: flex;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-amount-due span:first-child {\n color: var(--default-text-color-70, #18181B);\n }\n\n .checkout-amount-due span:last-child {\n color: var(--default-text-color, #1D4ED8);\n }\n\n .checkout-presale-locked-message {\n display: flex;\n align-items: center;\n justify-content: flex-start;\n align-self: stretch;\n }\n\n .checkout-presale-locked-message > *:not(:first-child) {\n margin-left: 8px;\n }\n\n .checkout-presale-locked-message p {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 13px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-presale-locked-message svg {\n width: 16px;\n height: 16px;\n stroke-width: 0.5px;\n stroke: var(--default-text-color, #1D4ED8);\n }\n\n .checkout-zero-amount-container {\n display: flex;\n padding: 0 24px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: italic;\n font-weight: 500;\n line-height: 20px;\n }\n\n .checkout-items-toggler-button .chevron-icon {\n transition: transform 0.3s ease;\n transform-origin: center;\n }\n\n .checkout-items-toggler-button.expanded .chevron-icon {\n transform: rotate(180deg); /* Chevron now points up */\n }\n\n .checkout-summary-form-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .checkout-summary-form-header {\n width: 100%;\n display: flex;\n align-items: flex-start;\n justify-content: space-between;\n margin-bottom: 8px;\n }\n\n .checkout-summary-form-header h2 {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n text-align: left;\n }\n\n .checkout-summary-form-header span {\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n cursor: pointer;\n }\n\n .checkout-summary-form-line {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n text-align: left;\n }\n\n .checkout-summary-form-line-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n margin-top: 8px;\n }\n\n .checkout-summary-form-line-container-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n opacity: 0.7;\n }\n\n .save-form-info-button {\n width: 100%;\n display: flex;\n height: 36px;\n justify-content: center;\n align-items: center;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n box-shadow: 0 1.5px 3px 0 rgba(0, 0, 0, 0.10), 0 1px 2px 0 rgba(0, 0, 0, 0.06);\n }\n\n .save-form-info-button:disabled {\n background: var(--primary-color-70, #D1D5DB);\n cursor: not-allowed;\n }\n\n .stripe-summary-container {\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n }\n\n .stripe-summary-container .stripe-summary-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 24px;\n text-align: left;\n }\n\n .stripe-summary-container .change-payment-link {\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n cursor: pointer;\n }\n\n .payment-error-message {\n color: var(--warning-color, #6B7280);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n margin-top: 16px;\n }\n\n .hardcoded-payment-notice {\n background-color: #fff3cd;\n color: #856404;\n font-family: Poppins;\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n border-radius: 4px;\n padding: 16px;\n border: 1px solid #ffc107;\n word-break: break-all;\n }\n ',getGlobalStyles=()=>"\n html, body, div, span, applet, object, iframe,\n h1, h2, h3, h4, h5, h6, p, blockquote, pre,\n a, abbr, acronym, address, big, cite, code,\n del, dfn, em, img, ins, kbd, q, s, samp,\n small, strike, strong, sub, sup, tt, var,\n b, u, i, center,\n dl, dt, dd, ol, ul, li,\n fieldset, form, label, legend,\n table, caption, tbody, tfoot, thead, tr, th, td,\n article, aside, canvas, details, embed,\n figure, figcaption, footer, header, hgroup,\n menu, nav, output, ruby, section, summary,\n time, mark, audio, video {\n margin: 0;\n padding: 0;\n border: 0;\n font-size: 100%;\n font: inherit;\n vertical-align: baseline;\n }\n\n *, :after, :before {\n box-sizing: border-box;\n }\n\n article, aside, details, figcaption, figure,\n footer, header, hgroup, menu, nav, section {\n display: block;\n }\n body {\n line-height: 1;\n }\n ol, ul {\n list-style: none;\n }\n blockquote, q {\n quotes: none;\n }\n blockquote:before, blockquote:after,\n q:before, q:after {\n content: '';\n content: none;\n }\n table {\n border-collapse: collapse;\n border-spacing: 0;\n }\n\n button {\n background: none;\n border: none;\n padding: 0;\n font: inherit;\n color: inherit;\n cursor: pointer;\n }\n\n input,\n textarea {\n background: none;\n border: none;\n padding: 0;\n resize: none;\n }\n\n input[type=\"checkbox\"] {\n /* Add if not using autoprefixer */\n -webkit-appearance: none;\n appearance: none;\n /* For iOS < 15 to remove gradient background */\n background-color: #fff;\n /* Not removed via appearance */\n margin: 0;\n }\n\n .custom-input {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n justify-content: flex-start;\n align-self: stretch;\n flex: 1 0 0;\n font-family: var(--heading-font-family, Poppins);\n }\n\n .disabled-input {\n opacity: 0.5;\n pointer-events: disable;\n }\n\n .custom-input.birthdate .date-input-container {\n display: flex;\n height: 36px;\n align-items: center;\n align-self: stretch;\n }\n\n .date-input-container .month-field,\n .date-input-container .day-field {\n flex: 0 1 50px;\n max-width: 50px;\n }\n\n .date-input-container .year-field {\n flex: 1 0 70px;\n max-width: 70px;\n }\n\n .date-input-container .date-separator {\n color: var(--accent-color, #18181B);\n font-size: 14px;\n line-height: 24px;\n margin: 0 8px;\n }\n\n .custom-input.birthdate input {\n display: flex;\n flex-direction: column;\n justify-content: flex-end;\n align-items: flex-start;\n font-size: 16px;\n height: 36px;\n font-family: var(--paragraph-font-family, Poppins);\n font-weight: 500;\n padding: 4px 11px;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.05);\n min-width: 53px;\n }\n\n .custom-input.birthdate.outlined input {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .custom-input.birthdate.filled input {\n background-color: var(--accent-color, #E4E4E7);\n }\n\n .custom-input label {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 1;\n color: var(--default-text-color, #18181B);\n text-align: left;\n white-space: nowrap;\n text-overflow: ellipsis;\n max-width: 100%;\n font-family: var(--paragraph-font-family, Poppins);\n text-overflow: ellipsis;\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 14px;\n padding-bottom: 2px;\n margin-bottom: 6px;\n }\n\n /* Enhanced fallback for browsers without line-clamp */\n @supports not (-webkit-line-clamp: 1) {\n .custom-input label {\n display: block;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n }\n\n .custom-input > input,\n .custom-input textarea {\n width: 100%;\n display: flex;\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n font-size: 16px;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-weight: 500;\n }\n\n .custom-input.outlined > input,\n .custom-input.outlined textarea {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .custom-input.filled > input,\n .custom-input.filled textarea {\n background-color: var(--accent-color, #E4E4E7);\n }\n\n .custom-input input:focus,\n .custom-input textarea:focus,\n .custom-input select:focus {\n outline: none;\n border-color: var(--primary-color, #3b82f6);\n }\n\n .custom-input input:disabled,\n .custom-input select:disabled {\n cursor: not-allowed;\n }\n\n .custom-input.textarea textarea {\n height: auto;\n }\n\n .custom-input input.input-error {\n border-color: var(--error-color, #EF4444);\n }\n\n .custom-input .error-container {\n display: none;\n }\n\n .custom-input .error-container.show {\n display: block;\n margin-top: 8px;\n }\n\n .custom-input .error-message {\n color: var(--error-color, #EF4444);\n font-size: 0.875rem;\n margin-bottom: 0.25rem;\n }\n\n p > strong {\n font-weight: 700;\n }\n\n /* Alert Styles\n ** Global styles for alerts\n */\n\n .alert {\n display: flex;\n flex-direction: row;\n padding: 8px 16px;\n align-items: flex-start;\n align-self: stretch;\n border-radius: var(--border-radius-rounded, 6px);\n margin-bottom: 8px;\n }\n\n .alert-warning {\n border: 1px solid var(--warning-color, #EA580C);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--warning-color, #EA580C);\n }\n\n .alert-success {\n border: 1px solid var(--success-color, #10b981);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--success-color, #10b981);\n }\n\n .alert-info {\n border: 1px solid var(--base-blue, #3b82f6);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--base-blue, #3b82f6);\n }\n\n .alert-message {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 13px;\n word-break: break-word;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n flex: 1;\n }\n\n .alert-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 20px;\n height: 20px;\n border-radius: 50%;\n flex-shrink: 0;\n margin-right: 8px;\n }\n\n .alert-icon-warning {\n color: var(--warning-color, #EA580C);\n }\n\n .alert-icon-success {\n color: var(--success-color, #10b981);\n }\n\n .alert-icon-info {\n color: var(--base-blue, #3b82f6);\n }\n\n .alert-icon svg {\n width: 16px;\n height: 16px;\n }\n\n .alert-icon-svg {\n width: 12px;\n height: 12px;\n fill: currentColor;\n }\n\n .alert-details {\n margin-top: 8px;\n padding-left: 24px;\n }\n\n .alert-details-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: var(--typography-base-sizes-small-font-size, 12px);\n font-weight: var(--font-weight-normal, 400);\n opacity: 0.8;\n }\n\n /** Engraving FORM **/\n\n .engraving-form {\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .engraving-form > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .engraving-form .product-info-section,\n .engraving-form .fulfillment-section,\n .engraving-form .engraving-section {\n display: flex;\n padding: 16px 16px;\n align-items: flex-start;\n align-self: stretch;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .engraving-form .product-info-section {\n flex-direction: row;\n align-items: center;\n }\n\n .product-info-section > *:not(:last-child) {\n margin-right: 12px;\n }\n\n .product-details-container {\n width: 100%;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .product-details-container > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .engraving-form .product-info-section .product-image-container {\n display: flex;\n width: 68px;\n height: 68px;\n flex-direction: column;\n align-items: flex-start;\n aspect-ratio: 1/1;\n }\n\n .engraving-form .product-info-section .product-image-container .product-image {\n width: 100%;\n height: 100%;\n object-fit: cover;\n border-radius: var(--card-border-radius, 6px);\n }\n\n .product-details-container .product-header {\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .product-details-container .product-title,\n .product-details-container .product-price {\n color: var(--default-text-color, #18181B);\n font-feature-settings: 'haln' on;\n font-family: var(--heading-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 24px;\n }\n\n .product-details-container .product-price {\n margin-left: 4px;\n white-space: nowrap;\n }\n\n .product-size-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n align-self: stretch;\n text-align: left;\n }\n\n .engraving-fees-disclaimer {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n align-self: stretch;\n text-align: left;\n }\n\n .engraving-form .fulfillment-section .shipping-from-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n margin-bottom: 8px;\n }\n\n .engraving-form .fulfillment-section .shipping-from-text b {\n font-weight: 600;\n }\n\n .engraving-form .fulfillment-section {\n flex-direction: column;\n }\n\n .fulfillment-options-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n max-height: 0;\n overflow: hidden;\n transition: max-height 0.3s ease;\n }\n\n .fulfillment-options-container.expanded {\n max-height: 100%;\n }\n\n .fulfillment-options-container.expanded + .see-more-fulfillments {\n margin-top: 8px;\n }\n\n .fulfillment-options-container .fulfillment-option {\n width: 100%;\n display: flex;\n min-width: 216px;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n cursor: pointer;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n color: var(--default-text-color, #18181B);\n flex-shrink: 0;\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .fulfillment-options-container .fulfillment-option:not(:first-child) {\n margin-top: 8px;\n }\n\n .fulfillment-options-container .fulfillment-option.selected {\n color: var(--selected-text-color, #FAFAFA);\n border-radius: var(--card-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n border: 1px solid transparent;\n box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.06) inset;\n }\n\n .fulfillment-options-container .fulfillment-option .option-row {\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n }\n\n .fulfillment-options-container .fulfillment-option .option-row > *:not(:last-child) {\n margin-right: 8px;\n }\n\n .fulfillment-options-container .fulfillment-option .option-row:first-child span {\n font-weight: 600;\n }\n\n .fulfillment-options-container .fulfillment-option .option-row:last-child {\n margin-top: 8px;\n }\n\n .fulfillment-options-container .fulfillment-option > span {\n width: 50%;\n }\n\n .see-more-fulfillments {\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n .engraving-section {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .engraving-section .engraving-title {\n color: var(--default-text-color, #18181B);\n font-feature-settings: 'haln' on;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .engraving-section .engraving-location-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .engraving-inputs-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n margin-top: 16px;\n }\n\n .engraving-inputs-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .engraving-input-wrapper {\n display: flex;\n height: 36px;\n padding: 4px 12px;\n align-items: center;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);\n }\n\n .engraving-input-wrapper > *:not(:last-child) {\n margin-right: 4px;\n }\n\n .engraving-input-wrapper .engraving-input {\n flex: 1;\n border: none;\n outline: none;\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n text-transform: uppercase;\n }\n\n .engraving-input-wrapper .engraving-char-count {\n color: var(--default-text-color-50, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n white-space: nowrap;\n }\n\n .action-buttons-container {\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n align-content: flex-start;\n align-self: stretch;\n }\n\n .action-buttons-container > *:not(:last-child) {\n margin-right: 16px;\n }\n\n .action-buttons-container .cancel-action-button {\n width: 20%;\n padding: 8px 16px;\n color: var(--primary-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n white-space: nowrap;\n }\n\n .action-buttons-container .add-to-cart-button {\n width: 80%;\n padding: 8px 16px;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0 1.5px 3px 0 rgba(0, 0, 0, 0.10), 0 1px 2px 0 rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n white-space: nowrap;\n }\n\n .action-buttons-container .add-to-cart-button:disabled {\n background: var(--primary-color-70, #E4E4E7);\n cursor: not-allowed;\n }\n\n .engraving-disclaimer {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n }\n\n .engraving-disclaimer b {\n font-weight: 600;\n }\n\n /** Component Error View **/\n .error-view {\n padding: 20px;\n background: #fff5f5;\n border: 1px solid #fed7d7;\n border-radius: 4px;\n color: #c53030;\n text-align: center;\n }\n\n .error-view h3 {\n margin-bottom: 10px;\n }\n\n .error-view p {\n margin-bottom: 20px;\n font-size: 16px;\n font-style: italic;\n }\n\n .error-view button {\n padding: 8px 16px;\n background: #c53030;\n color: white;\n border: none;\n border-radius: 4px;\n cursor: pointer;\n }\n\n .powered-by-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .pb-title-container {\n display: flex;\n justify-content: center;\n align-items: baseline;\n align-self: stretch;\n margin-bottom: 4px;\n padding-bottom: 7px;\n }\n\n .pb-text {\n text-align: center;\n font-family: 'Poppins';\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 100%;\n margin-right: 4px;\n }\n\n .pb-lc {\n font-family: 'Poppins';\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .pb-dot {\n font-family: 'Poppins';\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .light .pb-text,\n .light .pb-lc {\n color: #0F172A;\n }\n\n .light .pb-dot {\n color: #1D4ED8;\n }\n\n .dark .pb-text,\n .dark .pb-lc,\n .dark .pb-dot {\n color: #FAFAFA;\n }\n\n .pb-disclaimer-container {\n align-self: stretch;\n text-align: center;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 11px;\n font-style: normal;\n font-weight: 300;\n line-height: 16px;\n word-break: break-word;\n }\n\n .pb-link {\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 11px;\n font-style: normal;\n font-weight: 300;\n line-height: 16px;\n }\n\n .dark .pb-disclaimer-container, .dark .pb-link {\n color: #FAFAFA;;\n }\n\n .light .pb-disclaimer-container {\n color: #0F172A;\n }\n\n .light .pb-link {\n color: #1D4ED8;\n }\n\n .lce-ui-button {\n display: block;\n position: relative;\n cursor: pointer;\n width: 24px;\n height: 24px;\n }\n\n .lce-ui-button.independent {\n position: absolute;\n top: 12px;\n right: 12px;\n z-index: "+N.INDEPENDENT_BUTTON+';\n }\n\n /* Cart Button Components */\n .lce-cart-button-icon {\n display: block;\n }\n\n .lce-cart-button-badge {\n position: absolute;\n top: -6px;\n right: -6px;\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n border-radius: 50%;\n width: 16px;\n height: 16px;\n display: flex;\n align-items: center;\n justify-content: center;\n font-size: 10px;\n font-weight: bold;\n font-family: var(--heading-font-family, Poppins);\n pointer-events: none;\n z-index: 10;\n line-height: 1;\n }\n\n /* Global Icon Styling - Automatic Accent Color Application */\n svg {\n color: var(--icon-color, var(--accent-color, #E4E4E7));\n }\n\n svg path,\n svg circle,\n svg rect,\n svg line,\n svg polygon,\n svg polyline,\n svg ellipse {\n fill: currentColor;\n stroke: currentColor;\n }\n\n /* Respect explicit fill="none" */\n svg [fill="none"] {\n fill: none !important;\n }\n\n /* Specific icon overrides for semantic colors */\n .checkbox-icon {\n color: var(--icon-color, var(--selected-text-color, #FAFAFA));\n }\n\n .error-info-icon {\n color: var(--icon-color, var(--error-color, #DC2626));\n }\n\n .success-icon {\n color: var(--icon-color, var(--success-color, #10b981));\n }\n\n .warning-icon {\n color: var(--icon-color, var(--warning-color, #EA580C));\n }\n\n .info-icon {\n color: var(--icon-color, var(--accent-color, #E4E4E7));\n }\n\n .search-icon {\n color: var(--icon-color, var(--accent-color, #E4E4E7));\n }\n\n .arrow-right-icon,\n .bag-icon,\n .completed-icon,\n .loading-spinner-icon,\n .trash-icon,\n .chevron-down-icon {\n color: var(--icon-color, var(--accent-color, #E4E4E7));\n }\n\n .chevron-left-icon,\n .close-icon {\n color: var(--icon-color, var(--default-text-color, #18181B));\n }\n\n\n /* Exception for icons that should not inherit color (logos, specific designs) */\n svg[data-no-color-inherit] * {\n fill: initial;\n stroke: initial;\n }\n\n /* Override for stroke-only icons */\n svg[data-stroke-only] * {\n fill: none;\n stroke: currentColor;\n }\n\n /* Override for fill-only icons */\n svg[data-fill-only] * {\n fill: currentColor;\n stroke: none;\n }\n\n /* Tablet and up */\n @media (min-width: 768px) {\n .lce-ui-button.independent {\n top: 16px;\n right: 16px;\n }\n }\n\n /* Desktop */\n @media (min-width: 1024px) {\n .lce-ui-button.independent {\n top: 20px;\n right: 20px;\n }\n }\n\n /** Engraving View Container */\n .engraving-view-container {\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n }\n\n .engraving-view-container {\n width: 100%;\n padding: 16px;\n }\n\n .engraving-view-container.outlined {\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .engraving-view-container.filled {\n border-radius: var(--card-border-radius, 6px);\n background: linear-gradient(0deg, var(--alpha-50, rgba(254, 254, 254, 0.50)) 0%, var(--alpha-50, rgba(254, 254, 254, 0.50)) 100%), var(--accent-color, #E4E4E7);\n }\n\n .engraving-view-container .engraving-header {\n width: 100%;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n align-content: center;\n }\n\n .engraving-view-container .engraving-header {\n margin-bottom: 16px;\n }\n\n .engraving-view-container .engraving-header h3,\n .engraving-view-container .engraving-header span {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .engraving-view-container .engraving-header span.engraving-fee .engraving-fee-each {\n font-weight: 500;\n }\n\n .engraving-view-container .engraving-body {\n display: flex;\n justify-content: space-between;\n align-items: flex-end;\n align-content: flex-end;\n align-self: stretch;\n flex-wrap: wrap;\n }\n\n .engraving-view-container .engraving-lines {\n display: flex;\n min-width: 136px;\n flex-direction: column;\n align-items: flex-start;\n flex: 1 0 0;\n }\n\n .engraving-view-container .engraving-lines .engraving-line {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 100%;\n text-transform: uppercase;\n margin-top: 4px;\n }\n\n .engraving-view-container .engraving-lines .engraving-line:not(:first-child) {\n margin-top: 4px;\n }\n\n .engraving-view-container .engraving-actions {\n display: flex;\n align-items: center;\n }\n\n .engraving-view-container .engraving-actions .edit-button {\n margin-left: 16px;\n }\n\n .engraving-view-container .engraving-actions button {\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n .action-disabled {\n opacity: 0.7;\n cursor: not-allowed;\n }\n\n .disclaimer-header {\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 600;\n line-height: 16px;\n }\n\n .disclaimer-description {\n color: var(--default-text-color-70, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n font-weight: 500;\n line-height: 16px;\n }\n\n /* Alert Container - Simplified version matching existing alert design */\n .alert-container {\n display: flex;\n padding: 8px 16px;\n align-items: flex-start;\n flex-direction: row;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n border: 1px solid var(--error-color, #DC2626);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--error-color, #DC2626);\n }\n\n .alert-wrapper {\n display: flex;\n flex-direction: column;\n align-self: stretch;\n }\n\n .alert-wrapper > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .alert-wrapper.hidden {\n display: none;\n }\n\n .alert-item {\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n }\n\n .alert-container.hidden {\n display: none;\n }\n\n .alert-container.alert-error {\n border-color: var(--error-color, #DC2626);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--error-color, #DC2626);\n }\n\n .alert-container.alert-warning {\n border-color: var(--warning-color, #FBBF24);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--warning-color, #FBBF24);\n }\n\n .alert-container.alert-success {\n border-color: var(--success-color, #4ADE80);\n background: linear-gradient(0deg, var(--alpha-20, rgba(254, 254, 254, 0.80)) 0%, var(--alpha-20, rgba(254, 254, 254, 0.80)) 100%), var(--success-color, #4ADE80);\n }\n\n .alert-container .alert-icon {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 20px;\n height: 20px;\n flex-shrink: 0;\n margin-right: 8px;\n color: var(--error-color, #DC2626);\n }\n\n .alert-container .alert-icon svg {\n width: 16px;\n height: 16px;\n }\n\n .alert-container .alert-text {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 13px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n flex: 1;\n }\n\n\n /*************************\n Animation\n *************************/\n @keyframes spin {\n 0% {\n transform: translateY(-50%) rotate(0deg);\n }\n 100% {\n transform: translateY(-50%) rotate(360deg);\n }\n }\n\n @keyframes slideIn {\n 0% {\n opacity: 0;\n transform: translateY(-8px);\n max-height: 0;\n }\n 100% {\n opacity: 1;\n transform: translateY(0);\n max-height: 100px;\n }\n }\n\n /*************************\n Accessibility - Focus Visible\n *************************/\n\n /* Remove default focus outline for mouse users */\n *:focus {\n outline: none;\n }\n\n /* Show focus only for keyboard navigation */\n *:focus-visible {\n outline: 1px solid var(--warning-color, #1D4ED8);\n outline-offset: 0px;\n border-radius: var(--button-border-radius, 6px);\n box-shadow: 0 0 0 4px rgba(29, 78, 216, 0.1);\n }\n\n /* Screen reader only text */\n .sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border-width: 0;\n }\n',getImageCarouselStyle=()=>"\n .product-image-carousel {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n max-width: 100%;\n height: auto;\n min-height: 350px;\n overflow: hidden;\n }\n\n .product-image-carousel.popup {\n max-height: 474px;\n }\n\n .product-image-carousel.carousel {\n max-height: 594px;\n }\n\n .main-image {\n position: relative;\n width: 100%;\n height: 100%;\n display: flex;\n justify-content: center;\n align-items: flex-start;\n border-radius: var(--card-border-radius, 6px);\n overflow: hidden;\n flex: 1;\n background-image: var(--bg-image, none);\n background-position: center center;\n background-size: contain;\n background-repeat: no-repeat;\n }\n\n .carousel-dots {\n position: absolute;\n bottom: 16px;\n left: 50%;\n transform: translateX(-50%);\n z-index: "+N.CAROUSEL_CONTROLS+";\n display: flex;\n border-radius: 20px;\n }\n\n .carousel-dots .carousel-dot {\n margin-left: 10px;\n }\n\n .carousel-dots .carousel-dot:first-child {\n margin-left: 0;\n }\n\n .carousel-dot {\n width: 10px;\n height: 10px;\n border-radius: 50%;\n border: none;\n background: var(--accent-color, #828a97ff);\n cursor: pointer;\n transition: background-color 0.2s ease;\n }\n\n .carousel-dot.active {\n background: var(--primary-color, #3b82f6);\n }\n\n .gallery-viewport {\n display: none;\n overflow: hidden;\n width: 100%;\n height: 80px;\n flex-shrink: 0;\n margin-top: 12px;\n }\n\n .gallery-container {\n display: flex;\n cursor: grab;\n touch-action: pan-y pinch-zoom;\n }\n\n .gallery-container:active {\n cursor: grabbing;\n }\n\n .gallery-container .gallery-image-wrapper {\n margin-left: 8px;\n }\n\n .gallery-container .gallery-image-wrapper:first-child {\n margin-left: 0;\n }\n\n .gallery-image-wrapper {\n flex: 0 0 auto;\n }\n\n .gallery-image {\n width: 60px;\n height: 60px;\n object-fit: cover;\n border: 1px solid transparent;\n border-radius: var(--card-border-radius, 6px);\n cursor: pointer;\n background: var(--accent-color, #3b82f6);\n opacity: 0.5;\n transition: opacity 0.2s ease;\n user-select: none;\n -webkit-user-drag: none;\n }\n\n .gallery-image-wrapper.selected .gallery-image {\n opacity: 1;\n border-color: var(--primary-color, #3b82f6);\n }\n\n /* Small mobile screens */\n @media (min-width: 480px) {\n .carousel-dot {\n width: 8px;\n height: 8px;\n }\n\n .carousel-dots .carousel-dot {\n margin-left: 8px;\n }\n }\n\n /* Tablet and desktop */\n @media (min-width: 769px) {\n .carousel-dots {\n display: none;\n }\n\n .gallery-viewport {\n display: block;\n }\n\n .gallery-image {\n width: 80px;\n height: 80px;\n }\n }\n\n @media (prefers-reduced-motion: reduce) {\n .gallery-image,\n .carousel-dot {\n transition: none;\n }\n }\n",getProductStyles=()=>"\n .product-content-wrapper {\n width: 100%;\n min-width: 320px;\n height: auto;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n }\n\n .product-content-wrapper .product-image-carousel {\n margin-right: 40px;\n }\n\n .product-content {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n position: relative;\n overflow: hidden;\n }\n\n .product-content > .product-title + .product-options:not(.hide-content) {\n margin-top: 24px;\n }\n\n @media (min-width: 769px) {\n .product-content-wrapper {\n flex-direction: row;\n align-items: stretch;\n }\n\n .product-content-wrapper.has-images .product-image-carousel {\n width: 45%;\n }\n\n .product-content-wrapper.has-images .product-content {\n width: 55%;\n }\n }\n\n .product-interactions {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .product-interactions > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .size-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .size-container .size-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n margin-bottom: 8px;\n }\n\n .size-container .size-buttons-container {\n display: flex;\n align-items: flex-start;\n align-content: flex-start;\n align-self: stretch;\n flex-wrap: wrap;\n margin-bottom: -8px;\n }\n\n .size-container .size-buttons-container .size-button {\n display: flex;\n padding: 8px 16px;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n border-radius: var(--button-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .size-container .size-buttons-container > * {\n margin-right: 8px;\n margin-bottom: 8px;\n }\n\n .size-container .size-buttons-container > *:last-child {\n margin-right: 0;\n }\n\n .size-container .size-buttons-container .size-button.selected {\n background: var(--primary-color, #1D4ED8);\n color: var(--selected-text-color, #FAFAFA);\n border: 1px solid transparent;\n }\n\n .price-personalization-container {\n display: flex;\n align-items: center;\n justify-content: space-between;\n flex-wrap: wrap;\n width: 100%;\n }\n\n .add-personalization-span {\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight:400;\n line-height: 20px;\n text-decoration-line: underline;\n text-decoration-style: solid;\n text-decoration-skip-ink: none;\n text-decoration-thickness: auto;\n text-underline-offset: auto;\n text-underline-position: from-font;\n cursor: pointer;\n }\n\n /** Product Add to Cart Container */\n .add-to-cart-container {\n display: flex;\n align-items: flex-start;\n align-content: flex-start;\n align-self: stretch;\n flex-wrap: wrap;\n }\n\n .add-to-cart-container > *:not(:first-child) {\n margin-left: 16px;\n }\n\n .add-to-cart-container .quantity-container {\n display: flex;\n width: 106px;\n align-items: center;\n }\n\n .add-to-cart-container .quantity-container .quantity-decrease,\n .add-to-cart-container .quantity-container .quantity-increase {\n display: flex;\n width: 36px;\n height: 36px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n\n cursor: pointer;\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .add-to-cart-container .quantity-container.outlined .quantity-decrease,\n .add-to-cart-container .quantity-container.outlined .quantity-increase {\n border: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .add-to-cart-container .quantity-container.outlined .quantity-decrease.disabled,\n .add-to-cart-container .quantity-container.outlined .quantity-increase.disabled {\n cursor: not-allowed;\n }\n\n .add-to-cart-container .quantity-container .quantity-decrease {\n border-radius: var(--button-border-radius, 6px) 0px 0px var(--button-border-radius, 6px);\n }\n\n .add-to-cart-container .quantity-container .quantity-increase {\n border-radius: 0px var(--button-border-radius, 6px) var(--button-border-radius, 6px) 0px;\n }\n\n .add-to-cart-container .quantity-container .product-count {\n display: flex;\n padding: 6px 8px;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n align-self: stretch;\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n\n .add-to-cart-container .quantity-container.outlined .product-count {\n border-top: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .add-to-cart-container .add-to-cart-button {\n display: flex;\n min-width: 182px;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n flex: 1 0 0;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n outline: none;\n cursor: pointer;\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n position: relative;\n }\n\n .add-to-cart-container .add-to-cart-button.loading::after {\n content: '';\n position: absolute;\n right: 16px;\n top: 50%;\n transform: translateY(-50%);\n z-index: "+N.LOADING_INDICATOR+";\n width: 18px;\n height: 18px;\n border: 2px solid transparent;\n border-top: 2px solid var(--selected-text-color);\n border-radius: 50%;\n animation: spin 1s linear infinite;\n }\n\n .add-to-cart-container .add-to-cart-button.processing {\n cursor: not-allowed;\n pointer-events: none;\n }\n\n .add-to-cart-container .add-to-cart-button.disabled {\n background: var(--primary-color-70, #E4E4E7);\n cursor: not-allowed;\n }\n\n .product-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 24px;\n font-style: normal;\n font-weight: 600;\n line-height: 32px;\n transform: translateX(0);\n transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n visibility: visible;\n height: auto;\n }\n\n .product-title.hide {\n transform: translateX(-100%);\n visibility: hidden;\n height: 0;\n }\n\n .main-product-price {\n display: inline-block;\n width: fit-content;\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 30px;\n font-style: normal;\n font-weight: 600;\n line-height: 36px;\n }\n\n .product-presale-notice {\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n text-align: left;\n }\n\n .product-description {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .product-description > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .product-description .title {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 20px;\n }\n\n .product-description .content {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n align-self: stretch;\n\n overflow: hidden;\n color: var(--default-text-color, #18181B);\n text-overflow: ellipsis;\n\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n text-align: left;\n }\n\n .product-description .content.collapsed {\n /* Modern browsers with line-clamp support */\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 3;\n overflow: hidden;\n\n /* Fallback for older browsers */\n max-height: 4.5em; /* 3 lines * 1.5 line-height */\n line-height: 1.5;\n word-wrap: break-word;\n\n /* Additional fallback properties */\n text-overflow: ellipsis;\n white-space: normal;\n }\n\n /* Fallback for browsers without line-clamp support */\n @supports not (-webkit-line-clamp: 3) {\n .product-description .content.collapsed {\n display: block;\n max-height: 4.5em;\n overflow: hidden;\n position: relative;\n }\n\n .product-description .content.collapsed::after {\n content: '...';\n position: absolute;\n right: 0;\n bottom: 0;\n background: linear-gradient(to right, transparent, var(--default-background-color, white) 50%);\n padding-left: 20px;\n }\n }\n\n .product-description .collapse-button {\n border-radius: var(--button-border-radius, 6px);\n cursor: pointer;\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n /* Product Drawer container */\n .product-drawer-container {\n width: 100%;\n height: 0;\n z-index: "+N.PRODUCT_DRAWER+";\n transform: translateX(100%);\n transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n }\n\n /* Opened drawer state */\n .product-drawer-container.open {\n transform: translateX(0);\n height: 100%;\n }\n\n /* Expanded drawer state when address suggestions are shown */\n .product-drawer-container.open:has(.suggestions-expanded) {\n height: 230px;\n }\n\n /* Content area - fills the remaining space */\n .product-drawer-content {\n position: relative;\n display: block;\n width: 100%;\n height: 100%;\n box-sizing: border-box;\n overflow-y: auto;\n }\n\n .product-options {\n width: 100%;\n min-width: 320px;\n transform: translateX(0);\n transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n visibility: visible;\n height: auto;\n }\n\n .product-options.hide-content {\n transform: translateX(-100%);\n visibility: hidden;\n height: 0;\n }\n\n .product-no-availability-message {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n\n .product-options-open-address-button {\n width: 100%;\n display: flex;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n border-radius: var(--button-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0px 1.5px 3px 0px rgba(0, 0, 0, 0.10), 0px 1px 2px 0px rgba(0, 0, 0, 0.06);\n color: var(--selected-text-color, #FAFAFA);\n font-family: var(--heading-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n",getProductRetailersStyles=()=>"\n .product-retailers {\n width: 100%;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n }\n\n .retailers-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .retailers-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n /** Fulfillment Tab Container **/\n .fulfillment-tabs-container {\n display: flex;\n width: 100%;\n align-items: flex-end;\n flex-shrink: 0;\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n }\n\n .fulfillment-tabs-container .fulfillment-tab {\n display: flex;\n padding: 8px 16px;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n }\n\n .fulfillment-tabs-container .fulfillment-tab.selected {\n border-bottom: 2px solid var(--primary-color, #1D4ED8);\n margin-bottom: -1px;\n }\n\n .fulfillment-tabs-container .fulfillment-tab .fulfillment-tab-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .fulfillment-tabs-container .fulfillment-tab .fulfillment-tab-label.selected {\n font-weight: 600;\n }\n\n /** Carousel Mode **/\n .retailers-container .carousel-fulfillment-list-container {\n display: flex;\n flex-direction: row;\n align-self: stretch;\n touch-action: pan-y pinch-zoom;\n cursor: grab;\n }\n\n .retailers-container .carousel-fulfillment-list-container.active {\n cursor: grabbing;\n }\n\n .carousel-fulfillment-list-viewport {\n overflow: hidden;\n width: 100%;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card {\n display: flex;\n width: 200px;\n min-height: 200px;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n justify-content: space-between;\n flex-shrink: 0;\n transition: all 0.2s ease;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n color: var(--default-text-color, #18181B);\n cursor: pointer;\n scroll-snap-align: center;\n\n -webkit-touch-callout:none;\n -webkit-user-select:none;\n -moz-user-select:none;\n -ms-user-select:none;\n user-select:none;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card:not(:first-child) {\n margin-left: 8px;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card.closed {\n opacity: 0.7;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card.selected {\n color: var(--selected-text-color, #FAFAFA);\n background: var(--primary-color, #1D4ED8);\n box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.06) inset;\n border: 1px solid transparent;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-header .name {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 2;\n overflow: hidden;\n text-overflow: ellipsis;\n align-self: stretch;\n /* Cross-browser fallback */\n max-height: 2.8em;\n line-height: 1.4;\n word-wrap: break-word;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-weight: 500;\n font-style: normal;\n line-height: 20px;\n }\n\n .retailers-container .carousel-fulfillment-list-container .carousel-retailer-card.selected .retailer-header .name {\n font-weight: 600;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-header .address {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 2;\n overflow: hidden;\n font-weight: 400;\n text-overflow: ellipsis;\n /* Cross-browser fallback */\n max-height: 2.8em;\n line-height: 1.4;\n word-wrap: break-word;\n align-self: stretch;\n font-family: var(--heading-font-family, Poppins);\n font-size: 12px;\n font-style: normal;\n line-height: 14px;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body .product-price {\n font-family: var(--heading-font-family, Poppins);\n font-size: 24px;\n font-style: normal;\n font-weight: 500;\n line-height: 32px;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card.selected .retailer-body .product-price {\n font-weight: 600;\n }\n\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body .shipping-price,\n .carousel-fulfillment-list-container .carousel-retailer-card .retailer-body .expectation {\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n\n /************************* Popup Mode *************************/\n .retailers-container .header {\n display: flex;\n height: 36px;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .retailers-container .header .header-label {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 600;\n line-height: 100%;\n }\n\n .retailers-container .header .delivery-options {\n color: var(--link-text-color, #1D4ED8);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n /** Popup Fulfillment List Container **/\n .retailers-popup-list-container {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n }\n\n .retailers-popup-list-container > *:not(:first-child) {\n margin-top: 16px;\n }\n\n .retailers-popup-list-container .popup-retailers-section-title {\n color: var(--default-text-color, #18181B);\n font-family: var(--heading-font-family, Poppins);\n font-size: 16px;\n font-style: normal;\n font-weight: 600;\n line-height: 24px;\n }\n\n .popup-fulfillment-list-container {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n overflow-y: auto;\n align-self: stretch;\n max-height: 350px;\n }\n\n .drawer-content .popup-fulfillment-list-container {\n max-height: 100%;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card {\n width: 100%;\n display: flex;\n min-width: 216px;\n padding: 16px;\n flex-direction: column;\n align-items: flex-start;\n align-self: stretch;\n cursor: pointer;\n border-radius: var(--card-border-radius, 6px);\n border: 1px solid var(--accent-color, #E4E4E7);\n color: var(--default-text-color, #18181B);\n flex-shrink: 0;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card:not(:first-child) {\n margin-top: 16px;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card.closed {\n opacity: 0.7;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card.selected {\n color: var(--selected-text-color, #FAFAFA);\n border-radius: var(--card-border-radius, 6px);\n background: var(--primary-color, #1D4ED8);\n border: 1px solid transparent;\n box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.06) inset;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card .row {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n align-self: stretch;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card .name,\n .popup-fulfillment-list-container .popup-retailer-card .price,\n .popup-fulfillment-list-container .popup-retailer-card .expectation,\n .popup-fulfillment-list-container .popup-retailer-card .fee,\n .popup-fulfillment-list-container .popup-retailer-card .address {\n text-overflow: ellipsis;\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 500;\n line-height: 20px;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card .name,\n .popup-fulfillment-list-container .popup-retailer-card .price {\n font-weight: 600;\n }\n\n .popup-fulfillment-list-container .popup-retailer-card .name,\n .popup-fulfillment-list-container .popup-retailer-card .expectation,\n .popup-fulfillment-list-container .popup-retailer-card .address {\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 1;\n overflow: hidden;\n /* Cross-browser single-line fallback */\n white-space: nowrap;\n text-overflow: ellipsis;\n max-width: 100%;\n }\n\n /* Enhanced fallback for browsers without line-clamp */\n @supports not (-webkit-line-clamp: 1) {\n .popup-fulfillment-list-container .popup-retailer-card .name,\n .popup-fulfillment-list-container .popup-retailer-card .expectation,\n .popup-fulfillment-list-container .popup-retailer-card .address {\n display: block;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n }\n\n .fulfillments-no-availability-message {\n color: var(--default-text-color, #18181B);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 14px;\n font-style: normal;\n font-weight: 400;\n line-height: 20px;\n }\n";function getDrawerStyles(){return"\n /* Drawer wrapper container */\n .drawer-wrapper {\n position: fixed;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: "+N.DRAWER_WRAPPER+";\n pointer-events: none;\n }\n\n .drawer-wrapper.open {\n pointer-events: auto;\n }\n\n /* Backdrop overlay */\n .drawer-backdrop {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n background-color: rgba(0, 0, 0, 0.4);\n z-index: "+N.DRAWER_BACKDROP+";\n opacity: 0;\n visibility: hidden;\n transition: opacity 0.3s ease, visibility 0.3s ease;\n pointer-events: none;\n }\n\n .drawer-backdrop.visible {\n opacity: 1;\n visibility: visible;\n pointer-events: auto;\n }\n\n /* Main drawer */\n .drawer {\n position: absolute;\n top: 0;\n right: 0;\n width: 400px;\n height: 100vh; /* Fallback for browsers that don't support dvh */\n height: 100dvh;\n z-index: "+N.DRAWER_CONTENT+";\n background-color: #ffffff;\n overflow: hidden;\n transform: translateX(100%);\n transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n box-shadow: -2px 0 8px rgba(0, 0, 0, 0.1);\n pointer-events: auto;\n }\n\n /* Opened drawer state */\n .drawer.open {\n transform: translateX(0);\n }\n\n .drawer.address-input .drawer-content,\n .drawer.engraving-form .drawer-content,\n .drawer.product-retailers-popup-list .drawer-content {\n padding: 16px;\n }\n\n /* Content area - fills the remaining space */\n .drawer-content {\n position: relative;\n width: 100%;\n height: 100%;\n box-sizing: border-box;\n overflow-y: auto;\n background-color: var(--drawer-background-color, #FAFAFA);\n }\n\n /* Content swap animation classes */\n .drawer-content-fade-out {\n opacity: 1;\n transition: opacity 150ms ease-out;\n }\n\n .drawer-content-fade-out.fading {\n opacity: 0;\n }\n\n .drawer-content-fade-in {\n opacity: 0;\n transition: opacity 150ms ease-in;\n }\n\n .drawer-content-fade-in.visible {\n opacity: 1;\n }\n\n /* Mobile adjustments */\n @media (max-width: 576px) {\n .drawer {\n width: 100%;\n }\n }\n\n /* Accessibility - respect user's motion preferences */\n @media (prefers-reduced-motion: reduce) {\n .drawer,\n .drawer-backdrop,\n .drawer-content-fade-out,\n .drawer-content-fade-in {\n transition: none;\n }\n }\n "}const getProductLoadingStyles=()=>"\n .skeleton-container {\n min-width: 320px;\n width: 100%;\n height: auto;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n }\n\n .skeleton-container > *:not(:first-child) {\n margin-top: 24px;\n }\n\n .skeleton-container .wave {\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .skeleton-container .wave::before {\n content: '';\n position: absolute;\n top: 0;\n left: -100%;\n width: 100%;\n height: 100%;\n background: linear-gradient(\n 90deg,\n transparent 0%,\n rgba(255, 255, 255, 0.8) 50%,\n transparent 100%\n );\n animation: wave 1.8s infinite ease-in-out;\n z-index: "+N.SKELETON_WAVE+";\n }\n\n .sc-title {\n height: 32px;\n width: 100%;\n }\n\n .sc-sizes {\n height: 36px;\n width: 100%;\n display: flex;\n }\n\n .sc-size-button {\n height: 36px;\n width: 30%;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .sc-size-button:not(:first-child) {\n margin-left: 8px;\n }\n\n .sc-row {\n display: flex;\n background: none !important;\n height: auto;\n }\n\n .sc-row > *:not(:first-child) {\n margin-left: 12px;\n }\n\n .sc-price {\n height: 36px;\n width: 30%;\n }\n\n .sc-personalization {\n height: 36px;\n width: 40%;\n margin-right: 0;\n margin-left: auto;\n }\n\n .sc-deliver-to {\n height: 16px;\n width: 25%;\n margin-bottom: -16px;\n }\n\n .sc-address {\n height: 16px;\n width: 75%;\n }\n\n .sc-retailers {\n height: 140px;\n width: 100%;\n }\n\n .sc-quantity {\n height: 36px;\n width: 30%;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .sc-add-to-cart {\n height: 36px;\n flex: 1;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .sc-description-title {\n height: 16px;\n width: 45%;\n margin-bottom: -12px;\n }\n\n .sc-description-line {\n height: 16px;\n width: 100%;\n margin-bottom: -20px;\n }\n\n .sc-description-more {\n height: 16px;\n width: 30%;\n margin-top: 8px;\n }\n\n .sc-title::before { animation-delay: 0s; }\n .sc-price::before { animation-delay: 0.1s; }\n .sc-size-button::before { animation-delay: 0.2s; }\n .sc-price::before { animation-delay: 0.3s; }\n .sc-personalization::before { animation-delay: 0.4s; }\n .sc-deliver-to::before { animation-delay: 0.5s; }\n .sc-address::before { animation-delay: 0.6s; }\n .sc-retailers::before { animation-delay: 0.7s; }\n .sc-quantity::before { animation-delay: 0.8s; }\n .sc-add-to-cart::before { animation-delay: 0.9s; }\n .sc-description-title::before { animation-delay: 1.0s; }\n .sc-description-line:nth-child(10)::before { animation-delay: 1.1s; }\n .sc-description-line:nth-child(11)::before { animation-delay: 1.2s; }\n .sc-description-line:nth-child(12)::before { animation-delay: 1.3s; }\n .sc-description-more::before { animation-delay: 1.4s; }\n\n .sc-main-image {\n width: 100%;\n height: 350px;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n flex: 1;\n }\n\n .sc-carousel-dot {\n width: 10px;\n height: 10px;\n border-radius: 50%;\n background-color: #c4d1e0;\n margin-right: 10px;\n }\n\n .sc-carousel-dot:last-child {\n margin-right: 0;\n }\n\n .sc-gallery-thumbnail {\n width: 60px;\n height: 60px;\n background-color: #c4d1e0;\n border-radius: 6px;\n position: relative;\n overflow: hidden;\n }\n\n .sc-main-image::before { animation-delay: 1.5s; }\n .sc-carousel-dot::before { animation-delay: 1.6s; }\n .sc-gallery-thumbnail::before { animation-delay: 1.7s; }\n\n @media (min-width: 480px) {\n .sc-carousel-dot {\n width: 8px;\n height: 8px;\n margin-right: 8px;\n }\n }\n\n @media (min-width: 769px) {\n .sc-gallery-thumbnail {\n width: 80px;\n height: 80px;\n }\n\n .sc-main-image {\n height: 474px;\n }\n }\n\n @keyframes wave {\n 0% {\n left: -100%;\n }\n 100% {\n left: 100%;\n }\n }\n",getProductListCardLoadingStyles=()=>"\n .product-list-card-loading__container {\n width: 100%;\n height: 100%;\n display: flex;\n flex-wrap: wrap;\n align-items: flex-start;\n gap: 24px;\n --gap-per-card: calc(24px * (var(--columns, 4) - 1) / var(--columns, 4));\n }\n\n .slc__card {\n width: calc(var(--card-width, 25%) - var(--gap-per-card, 18px));\n flex: 0 0 calc(var(--card-width, 25%) - var(--gap-per-card, 18px));\n pointer-events: none;\n background-color: transparent;\n border: none;\n border-radius: var(--card-border-radius, 0.375rem);\n overflow: hidden;\n cursor: default;\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n height: 100%;\n }\n\n .slc__card .wave {\n background-color: #c4d1e0;\n position: relative;\n overflow: hidden;\n }\n\n .slc__card .wave::before {\n content: '';\n position: absolute;\n top: 0;\n left: -100%;\n width: 100%;\n height: 100%;\n background: linear-gradient(\n 90deg,\n transparent 0%,\n rgba(255, 255, 255, 0.8) 50%,\n transparent 100%\n );\n animation: wave 1.8s infinite ease-in-out;\n z-index: "+N.SKELETON_WAVE+";\n }\n\n .slc__image-content {\n width: 100%;\n height: 100%;\n padding: 10px 0;\n }\n\n .slc__image-wrapper {\n width: 100%;\n height: 14rem;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n border-bottom: none;\n padding-bottom: 10px;\n }\n\n .slc__image {\n width: 100%;\n height: 14rem;\n background-color: #c4d1e0;\n }\n\n .slc__content {\n width: 100%;\n display: flex;\n flex-direction: column;\n margin-bottom: 10px;\n }\n\n .slc__title-container {\n display: flex;\n flex-direction: column;\n margin-bottom: 20px;\n width: 100%;\n }\n\n .slc__title-container > *:not(:first-child) {\n margin-top: 8px;\n }\n\n .slc__title {\n height: 18px;\n background-color: #c4d1e0;\n }\n\n .slc__title-line-1 {\n width: 90%;\n }\n\n .slc__title-line-2 {\n width: 75%;\n }\n\n .slc__price {\n width: 60px;\n height: 20px;\n background-color: #c4d1e0;\n }\n\n .slc__size-price-wrapper {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n width: 100%;\n }\n\n .slc__size {\n width: 45px;\n height: 20px;\n background-color: #c4d1e0;\n }\n\n .slc__button {\n width: 100%;\n height: 42px;\n margin-top: 10px;\n background-color: var(--primary-color, #3b82f6);\n opacity: 0.7;\n }\n\n .slc__card:nth-child(1) .slc__image::before { animation-delay: 0s; }\n .slc__card:nth-child(1) .slc__title-line-1::before { animation-delay: 0.05s; }\n .slc__card:nth-child(1) .slc__title-line-2::before { animation-delay: 0.1s; }\n .slc__card:nth-child(1) .slc__price::before { animation-delay: 0.2s; }\n .slc__card:nth-child(1) .slc__size::before { animation-delay: 0.2s; }\n .slc__card:nth-child(1) .slc__button::before { animation-delay: 0.25s; }\n\n .slc__card:nth-child(2) .slc__image::before { animation-delay: 0.05s; }\n .slc__card:nth-child(2) .slc__title-line-1::before { animation-delay: 0.1s; }\n .slc__card:nth-child(2) .slc__title-line-2::before { animation-delay: 0.15s; }\n .slc__card:nth-child(2) .slc__price::before { animation-delay: 0.25s; }\n .slc__card:nth-child(2) .slc__size::before { animation-delay: 0.25s; }\n .slc__card:nth-child(2) .slc__button::before { animation-delay: 0.3s; }\n\n .slc__card:nth-child(3) .slc__image::before { animation-delay: 0.1s; }\n .slc__card:nth-child(3) .slc__title-line-1::before { animation-delay: 0.15s; }\n .slc__card:nth-child(3) .slc__title-line-2::before { animation-delay: 0.2s; }\n .slc__card:nth-child(3) .slc__price::before { animation-delay: 0.3s; }\n .slc__card:nth-child(3) .slc__size::before { animation-delay: 0.3s; }\n .slc__card:nth-child(3) .slc__button::before { animation-delay: 0.35s; }\n\n .slc__card:nth-child(4) .slc__image::before { animation-delay: 0.15s; }\n .slc__card:nth-child(4) .slc__title-line-1::before { animation-delay: 0.2s; }\n .slc__card:nth-child(4) .slc__title-line-2::before { animation-delay: 0.25s; }\n .slc__card:nth-child(4) .slc__price::before { animation-delay: 0.35s; }\n .slc__card:nth-child(4) .slc__size::before { animation-delay: 0.35s; }\n .slc__card:nth-child(4) .slc__button::before { animation-delay: 0.4s; }\n\n .slc__card:nth-child(n+5) .slc__image::before { animation-delay: 0.2s; }\n .slc__card:nth-child(n+5) .slc__title-line-1::before { animation-delay: 0.25s; }\n .slc__card:nth-child(n+5) .slc__title-line-2::before { animation-delay: 0.3s; }\n .slc__card:nth-child(n+5) .slc__price::before { animation-delay: 0.4s; }\n .slc__card:nth-child(n+5) .slc__size::before { animation-delay: 0.4s; }\n .slc__card:nth-child(n+5) .slc__button::before { animation-delay: 0.45s; }\n";function getPromoCodeTickerStyles(){return"\n .promo-ticker {\n display: flex;\n align-items: stretch;\n width: 100%;\n height: 30px;\n background: var(--accent-color-70, #fff);\n position: relative;\n overflow: hidden;\n }\n\n .promo-ticker__content {\n width: calc(100% - 55px);\n display: flex;\n align-items: center;\n overflow: hidden;\n position: relative;\n border-top: 1px solid var(--accent-color, #E4E4E7);\n border-bottom: 1px solid var(--accent-color, #E4E4E7);\n transition: width 0.3s ease;\n }\n\n .promo-ticker:has(.promo-ticker__cta:disabled) .promo-ticker__content {\n width: calc(100% - 60px);\n }\n\n .promo-ticker__content::before,\n .promo-ticker__content::after {\n content: '';\n position: absolute;\n top: 0;\n width: 60px;\n height: 100%;\n z-index: 2;\n pointer-events: none;\n }\n\n .promo-ticker__content::before {\n left: 0;\n background: linear-gradient(90deg, var(--accent-color-70, #fff) 0%, transparent 100%);\n }\n\n .promo-ticker__content::after {\n right: 0;\n background: linear-gradient(90deg, transparent 0%, var(--accent-color-70, #fff) 100%);\n }\n\n .promo-ticker__track {\n display: flex;\n animation: promo-scroll 30s linear infinite;\n will-change: transform;\n }\n\n .promo-ticker__content:hover .promo-ticker__track {\n animation-play-state: paused;\n }\n\n .promo-ticker__text-group {\n display: flex;\n align-items: center;\n color: var(--default-text-color, #fff);\n font-family: var(--paragraph-font-family, Poppins);\n font-size: 12px;\n font-weight: 500;\n white-space: nowrap;\n letter-spacing: 0.5px;\n text-transform: uppercase;\n }\n\n .promo-ticker__text-item {\n display: inline-flex;\n align-items: center;\n }\n\n .promo-ticker__separator {\n margin: 0 16px;\n color: var(--default-text-color, #fff);\n font-size: 12px;\n }\n\n @keyframes promo-scroll {\n 0% { transform: translateX(0); }\n 100% { transform: translateX(-50%); }\n }\n\n .promo-ticker__cta {\n width: 55px;\n height: 100%;\n background-color: var(--primary-color, #FF5733);\n color: var(--selected-text-color, #fff);\n font-family: var(--heading-font-family, Poppins);\n font-size: 12px;\n font-weight: 600;\n text-transform: uppercase;\n user-select: none;\n position: absolute;\n right: 0;\n top: 0;\n transition: width 0.3s ease;\n }\n\n .promo-ticker__cta:disabled {\n width: 60px;\n background-color: var(--primary-color-70, #FF5733);\n cursor: not-allowed;\n }\n "}const gt={"headingFont.name":"--heading-font-family","paragraphFont.name":"--paragraph-font-family",buttonCornerRadius:"--button-border-radius",cardCornerRadius:"--card-border-radius",primaryColor:"--primary-color",accentColor:"--accent-color",defaultTextColor:"--default-text-color",selectedTextColor:"--selected-text-color",linkTextColor:"--link-text-color",errorColor:"--error-color",warningColor:"--warning-color",successColor:"--success-color",drawerBackgroundColor:"--drawer-background-color"},vt={backgroundColor:"--product-background-color"},yt={backgroundColor:"--cart-background-color"},bt={backgroundColor:"--address-background-color"},xt={backgroundColor:"--checkout-background-color"},wt={global:gt,product:vt,cart:yt,address:bt,checkout:xt};function getCSSVariableMapping(n){return wt[n]||{}}class CssVariableProcessorService{constructor(){this.opacityLevels=[{suffix:"30",value:.3},{suffix:"50",value:.5},{suffix:"70",value:.7},{suffix:"90",value:.9}],this.logger=LoggerFactory.get("CssVariableProcessor")}extractVariablesFromTheme(n,i){const r={},s=getCSSVariableMapping(i);for(const[a,l]of Object.entries(s)){const i=this.getValueByPath(n,a);void 0!==i&&this.isCSSValue(i)&&(r[l]=i,this.isColorVariable(l,i)&&this.generateOpacityVariants(r,l,i))}return r}extractVariablesFromPartialTheme(n,i){const r={},s=getCSSVariableMapping(i);for(const[a,l]of Object.entries(s))if(this.hasValueAtPath(n,a)){const i=this.getValueByPath(n,a);void 0!==i&&this.isCSSValue(i)&&(r[l]=i,this.isColorVariable(l,i)&&this.generateOpacityVariants(r,l,i))}return r}generateCSSVariablesString(n){return Object.entries(n).map(([n,i])=>" "+n+": "+i+";").join("\n")}updateCSSVariablesInStylesheet(n,i){if(0!==Object.keys(i).length)try{const r=this.findOrCreateRule(n);for(const[n,s]of Object.entries(i))r.style.setProperty(n,String(s))}catch(r){this.logger.warn("Failed to update CSS variables")}}getValueByPath(n,i){return i.split(".").reduce((n,i)=>n&&void 0!==n[i]?n[i]:void 0,n)}hasValueAtPath(n,i){const r=i.split(".");let s=n;for(const a of r){if(null==s||!(a in s))return![];s=s[a]}return!![]}findOrCreateRule(n){const i=":host";for(const s of Array.from(n.cssRules))if(s instanceof CSSStyleRule&&s.selectorText===i)return s;const r=n.insertRule(i+" {}");return n.cssRules[r]}isCSSValue(n){if("string"==typeof n){if(""===n.trim())return![];if(/^(#[0-9a-f]{3,8}|rgb|rgba|hsl|hsla|\d+px|\d+%|\d+rem|\d+em|auto|none|inherit|initial|unset|rounded|squared)/.test(n.toLowerCase()))return!![];if(/^[a-zA-Z0-9\s\-'"]+$/.test(n))return!![];if(/^[a-z-]+$/.test(n))return!![]}return"number"==typeof n}generateOpacityVariants(n,i,r){for(const s of this.opacityLevels){const a=i+"-"+s.suffix,l=this.addOpacityToHexColor(r,s.value);l&&(n[a]=l)}}isColorVariable(n,i){if("string"!=typeof i)return![];const r=n.toLowerCase().includes("color"),s=/^#[0-9a-f]{3,8}$/i.test(i);return r&&s}addOpacityToHexColor(n,i){if(!n.startsWith("#"))return null;let r=n.slice(1);if(3===r.length&&(r=r.split("").map(n=>n+n).join("")),6!==r.length)return null;const s=Math.round(255*i),a=s.toString(16).padStart(2,"0");return"#"+r+a}}class StylesheetGeneratorService{constructor(){this.cssProcessor=new CssVariableProcessorService,this.styleSheets=new Map}getStylesheet(n){return this.styleSheets.get(n)}generateSpecificStylesheet(n,i){const r=this.cssProcessor.extractVariablesFromTheme(i,n),s=this.cssProcessor.generateCSSVariablesString(r),a=this.getStylesheetStyles(n).join("\n\n"),l=0===s.length?"":":host { "+s+" }",d=("\n "+l+"\n\n "+a+"\n ").trim();this.createStylesheet(n,d)}createStylesheet(n,i){try{if(this.isCSSStyleSheetSupported()){const r=new CSSStyleSheet;r.replaceSync(i),this.styleSheets.set(n,r)}else this.styleSheets.set(n,i)}catch(ut){this.styleSheets.set(n,i)}}isCSSStyleSheetSupported(){try{if("undefined"==typeof CSSStyleSheet)return![];if("function"!=typeof CSSStyleSheet.prototype.replaceSync)return![];const n=new CSSStyleSheet;return n.replaceSync("/* test */"),!![]}catch(n){return![]}}updateVariablesInStylesheet(n,i,r){const s=this.styleSheets.get(n);if(s&&"string"!=typeof s){const n=this.cssProcessor.extractVariablesFromPartialTheme(i,r);this.cssProcessor.updateCSSVariablesInStylesheet(s,n)}}getStylesheetStyles(n){switch(n){case"global":return[getGlobalStyles()];case"ui":return[getDrawerStyles(),getProductLoadingStyles(),getProductListCardLoadingStyles(),getPromoCodeTickerStyles()];case"product":return[getProductStyles(),getImageCarouselStyle(),getAddressStyles(),getProductRetailersStyles(),getProductListStyles()];case"address":return[getAddressStyles()];case"cart":return[getCartStyles()];case"checkout":return[getCheckoutStyles()];default:return[]}}}class ThemeProviderService{constructor(){this.logger=LoggerFactory.get("ThemeProvider"),this.stylesheetGenerator=new StylesheetGeneratorService,this.fontManager=new FontManagerService}static getInstance(){return SingletonManager.getClassInstance("ThemeProviderService",()=>new ThemeProviderService)}async initialize(n){this.data=n,this.fontManager.loadGoogleFonts([this.data.global.theme.headingFont,this.data.global.theme.paragraphFont]),this.stylesheetGenerator.generateSpecificStylesheet("global",this.data.global.theme),this.stylesheetGenerator.generateSpecificStylesheet("ui",{}),this.stylesheetGenerator.generateSpecificStylesheet("product",this.data.product.theme),this.stylesheetGenerator.generateSpecificStylesheet("cart",this.data.cart.theme),this.stylesheetGenerator.generateSpecificStylesheet("checkout",this.data.checkout.theme),this.stylesheetGenerator.generateSpecificStylesheet("address",this.data.address.theme)}updateComponentGlobalConfigs(n){var i,r;const s=this.data.global.layout.showPoweredBy;this.data.global=this.deepMerge(this.getConfigs("global"),n),this.data.global.layout.showPoweredBy=s,((null===(i=n.theme)||void 0===i?void 0:i.headingFont)||(null===(r=n.theme)||void 0===r?void 0:r.paragraphFont))&&this.fontManager.updateGoogleFonts([this.data.global.theme.headingFont,this.data.global.theme.paragraphFont]),n.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("global",n.theme,"global")}updateProductComponent(n){this.data.product=this.deepMerge(this.getConfigs("product"),n),n.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("product",n.theme,"product")}updateAddressComponent(n){this.data.address=this.deepMerge(this.getConfigs("address"),n),n.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("address",n.theme,"address")}updateCartComponent(n){this.data.cart=this.deepMerge(this.getConfigs("cart"),n),n.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("cart",n.theme,"cart")}updateCheckoutComponent(n){this.data.checkout=this.deepMerge(this.getConfigs("checkout"),n),n.theme&&this.stylesheetGenerator.updateVariablesInStylesheet("checkout",n.theme,"checkout")}getConfigs(n){return"all"===n?this.data:this.data[n]}getComponentConfig(n){return-1!==ht.indexOf(n)?this.getConfigs("product"):-1!==pt.indexOf(n)?this.getConfigs("address"):-1!==mt.indexOf(n)?this.getConfigs("cart"):-1!==ft.indexOf(n)?this.getConfigs("checkout"):void 0}getStylesheet(n){const i=this.getBaseStylesheets();if(n===C.DRAWER){const n=[...i],r=this.stylesheetGenerator.getStylesheet("product"),s=this.stylesheetGenerator.getStylesheet("cart"),a=this.stylesheetGenerator.getStylesheet("checkout"),l=this.stylesheetGenerator.getStylesheet("address");return r&&n.push(r),s&&n.push(s),a&&n.push(a),l&&n.push(l),n}let r;if(pt.includes(n)||n===C.ADDRESS)r="address";else if(ht.includes(n)||n===C.PRODUCT)r="product";else if(mt.includes(n)||n===C.CART)r="cart";else{if(!ft.includes(n)&&n!==C.CHECKOUT)return this.logger.warn("No stylesheets found for component type: "+n+", returning base stylesheets only."),i;r="checkout"}const s=this.stylesheetGenerator.getStylesheet(r);return s?[...i,s]:i}getBaseStylesheets(){const n=[],i=this.stylesheetGenerator.getStylesheet("global"),r=this.stylesheetGenerator.getStylesheet("ui");return i&&n.push(i),r&&n.push(r),n}deepMerge(n,i){const r={...n};for(const s in i)null!==i[s]&&void 0!==i[s]&&("object"!=typeof i[s]||Array.isArray(i[s])||"object"!=typeof n[s]||Array.isArray(n[s])?r[s]=i[s]:r[s]=this.deepMerge(n[s],i[s]));return r}}class BaseCommand{constructor(){this.store=StoreService.getInstance(),this.api=ApiClientService.getInstance(),this.logger=LoggerFactory.get("BaseCommand"),this.pubSub=PubSubService.getInstance(),this.googleTagManager=GoogleTagManagerService.getInstance(),this.clientConfig=ClientConfigService.getInstance(),this.themeProvider=ThemeProviderService.getInstance()}getLocation(){const n=this.store.get("address");if(n.address.one&&n.coordinates.long&&n.coordinates.lat)return{coords:n.coordinates,address:n.address}}}const includeCartEvents=(n,i)=>n.filter(n=>i.includes(n.type)),excludeCartEvents=(n,i)=>n.filter(n=>!i.includes(n.type)),eventsForCart=n=>excludeCartEvents(n,["NewCart","ItemsRemoved","CartError","NoId","InvalidId","NoItemsInCart","RemovedExistingCartItems","PartnerProductConfigs","RetailerMinNotMet","AddressChange"]),hasCartAnyPromoCodeEvents=n=>{const i=["CouponProcessingError","CouponNotFound","CouponExpired","NoApplicableDiscount","CouponNotStarted","MinimumOrderValueNotMet","MinimumOrderUnitsNotMet","MinimumDistinctItemsNotMet","QuotaExceeded","UserLimitExceeded","NotFirstPurchase","InvalidCoupon","InvalidMembership","InvalidDomain","InvalidRequirements","InvalidOrganization","ProductNotEligible","NotEnoughPreviousOrders","RetailerDoesNotAllowPromos","RetailersDoNotAllowPromos"],r=includeCartEvents(n,i);return r.length>0},includeCheckoutEvents=(n,i)=>n.filter(n=>i.includes(n.type)),eventsForCheckout=n=>includeCheckoutEvents(n,["RetailerOnDemandHoursNotAvailable","ItemQuantityChange","MaxQuantityPerOrderExceeded"]),promoCodeCheckoutEvents=n=>includeCheckoutEvents(n,["RetailerDoesNotAllowPromos","RetailersDoNotAllowPromos"]),giftCardCheckoutEvents=n=>includeCheckoutEvents(n,["ErrorProcessingGiftCards","InvalidGiftCardCodes","InvalidGiftCardPartner","InactiveGiftCard","GiftCardAlreadyInUse","GiftCardExpired","GiftCardBalanceDepleted","RetailerDoesNotAllowGiftCards","RetailersDoNotAllowGiftCards"]),hasAnyRetailerGiftCardRestriction=n=>{const i=["RetailerDoesNotAllowGiftCards","RetailersDoNotAllowGiftCards"];return n.some(n=>i.includes(n.type))},Ct={OutOfStock:"error",ItemsNotAdded:"warning",ItemsRequestedNotAdded:"warning",ItemEngravingError:"error",AddressChange:"warning",LocationAvailability:"warning",PartnerProductConfigs:"warning",RemovedExistingCartItems:"warning",RetailerMinNotMet:"warning",NoItemsInCart:"warning",InvalidId:"warning",NoId:"warning",CartCheckoutProcessed:"success",NewCart:"warning",CartError:"error",ItemQuantityChange:"warning",ItemIdNotFound:"error",ItemsRemoved:"warning",CouponProcessingError:"error",CouponNotFound:"error",CouponExpired:"error",NoApplicableDiscount:"warning",CouponNotStarted:"error",MinimumOrderValueNotMet:"warning",MinimumOrderUnitsNotMet:"warning",MinimumDistinctItemsNotMet:"warning",QuotaExceeded:"error",UserLimitExceeded:"error",NotFirstPurchase:"warning",InvalidCoupon:"error",InvalidMembership:"error",InvalidDomain:"error",InvalidRequirements:"error",InvalidOrganization:"error",ProductNotEligible:"warning",NotEnoughPreviousOrders:"warning",PresaleItemsNotAllowed:"error",PresaleLimitExceeded:"error",PresaleNotStarted:"error",PresaleExpired:"error",PresaleMixedCart:"error",RetailerDoesNotAllowPromos:"warning",RetailersDoNotAllowPromos:"warning"},kt={ErrorProcessingGiftCards:"error",InvalidGiftCardCodes:"error",InvalidGiftCardPartner:"error",InactiveGiftCard:"error",GiftCardAlreadyInUse:"error",GiftCardExpired:"error",GiftCardBalanceDepleted:"error",RetailerOnDemandHoursNotAvailable:"warning",ItemQuantityChange:"warning",MaxQuantityPerOrderExceeded:"warning",RetailerDoesNotAllowPromos:"warning",RetailersDoNotAllowPromos:"warning",RetailerDoesNotAllowGiftCards:"warning",RetailersDoNotAllowGiftCards:"warning"},transformCartEventsRaw=n=>n.map(n=>({type:n.type,message:n.message,level:Ct[n.type]||"error"})),transformCheckoutEventsRaw=n=>n.map(n=>({type:n.type,message:n.message,level:kt[n.type]||"error"})),transformEventsForCart=n=>{const i=eventsForCart(n);return transformCartEventsRaw(i)},transformEventsForCheckout=n=>{const i=eventsForCheckout(n);return transformCheckoutEventsRaw(i)},transformPromoCodeCheckoutEvents=n=>{const i=promoCodeCheckoutEvents(n);return transformCheckoutEventsRaw(i)},transformGiftCardCheckoutEvents=n=>{const i=giftCardCheckoutEvents(n);return transformCheckoutEventsRaw(i)};function buildCartItemStore(n){return{id:n.id,variantId:n.variantId,liquidId:n.liquidId,retailerId:n.retailerId,partNumber:n.partNumber,fulfillmentId:n.fulfillmentId,upc:n.upc,sku:n.sku,salsifyGrouping:n.salsifyGrouping,catPath:n.catPath,volume:n.volume,uom:n.uom,pack:n.pack,packDesc:n.packDesc,container:n.container,containerType:n.containerType,name:n.name,brand:n.brand,size:n.size,price:n.price,quantity:n.quantity,maxQuantity:n.maxQuantity,unitPrice:n.unitPrice,mainImage:n.mainImage,attributes:n.attributes,loading:![],updating:![],error:null}}function buildCartTotals(n){return{subtotal:n.subtotal||0,total:n.total||0,shippingFee:n.shippingFee||0,platformFee:n.platformFee||0,giftCardTotal:n.giftCardTotal||0,engravingFee:n.engravingFee||0,deliveryFee:n.deliveryFee||0,discounts:n.discounts||0,quantity:n.quantity||0}}function buildRetailerStore(n){var i;return{id:n.id,name:n.name,platformFee:n.platformFee||0,shippingFee:n.shippingFee||0,subtotal:n.subtotal||0,address:n.address,total:n.total||0,deliveryFee:n.deliveryFee||0,engravingFee:n.engravingFee||0,fulfillments:(null===(i=n.fulfillments)||void 0===i?void 0:i.map(n=>n.id))||[]}}function buildFulfillmentStore(n,i){return{id:n.id,canEngrave:n.canEngrave||![],type:n.type,fees:n.fees,expectation:n.expectation,shippingFee:n.shippingFee||0,subtotal:n.subtotal||0,engravingFee:n.engravingFee||0,deliveryFee:n.deliveryFee||0,items:n.items||[],retailerId:i.id,loading:![],error:null,updating:![]}}function cartDataForEventFromStore(n,i){var r;const s=i.formattedAddress?i:{id:"",address:{one:"",two:"",city:"",state:"",zip:"",country:""},coordinates:{lat:0,long:0}},a={};for(const l in n.items||{}){const i=n.items[l];a[l]={id:i.id,variantId:i.variantId,liquidId:i.liquidId,retailerId:i.retailerId,partNumber:i.partNumber,fulfillmentId:i.fulfillmentId,upc:i.upc,sku:i.sku,salsifyGrouping:i.salsifyGrouping,catPath:i.catPath,volume:i.volume,uom:i.uom,pack:i.pack,packDesc:i.packDesc,container:i.container,containerType:i.containerType,name:i.name,brand:i.brand,size:i.size,price:i.price||0,quantity:i.quantity||0,maxQuantity:i.maxQuantity||0,unitPrice:i.unitPrice||0,mainImage:i.mainImage||"",attributes:i.attributes||{}}}return{id:n.id,promoCode:(null===(r=n.promoCode)||void 0===r?void 0:r.code)||"",items:a,location:{placesId:s.id,address:{one:s.address.one,two:s.address.two,city:s.address.city,state:s.address.state,zip:s.address.zip,country:s.address.country},coordinates:{latitude:s.coordinates.lat,longitude:s.coordinates.long}},amounts:{deliveryFee:n.totals.deliveryFee,discounts:n.totals.discounts,engravingFee:n.totals.engravingFee,giftCardTotal:0,platformFee:n.totals.platformFee,shippingFee:n.totals.shippingFee,subtotal:n.totals.subtotal,total:n.totals.total},itemCount:Object.values(a||{}).reduce((n,i)=>n+(i.quantity||0),0),updatedAt:n.updatedAt,createdAt:n.createdAt}}class CommonCommands extends BaseCommand{static getInstance(){return SingletonManager.getClassInstance("CommonCommands",()=>new CommonCommands)}syncCartFromResponse(n,i=![]){var r,s,a,l,d,u;const f=this.store.get("cart");for(const v of Object.keys(f.items||{}))this.store.remove("cart.items."+v);for(const v of Object.keys(f.retailers||{}))this.store.remove("cart.retailers."+v);for(const v of Object.keys(f.fulfillments||{}))this.store.remove("cart.fulfillments."+v);const g={"cart.id":n.id,"cart.error":null,"cart.totals":buildCartTotals(n),"cart.updatedAt":n.updatedAt||(new Date).toISOString(),"cart.createdAt":n.createdAt||(new Date).toISOString(),"cart.events":[],"cart.promoCode":(null===(s=null===(r=n.attributes)||void 0===r?void 0:r.promoCode)||void 0===s?void 0:s.value)?{code:n.attributes.promoCode.value.toUpperCase(),discountAmount:n.attributes.promoCode.discount||0,error:null}:null};if((null===(a=n.items)||void 0===a?void 0:a.length)>0)for(const v of n.items)g["cart.items."+v.id]=buildCartItemStore(v);if((null===(l=n.retailers)||void 0===l?void 0:l.length)>0)for(const v of n.retailers)if(g["cart.retailers."+v.id]=buildRetailerStore(v),(null===(d=v.fulfillments)||void 0===d?void 0:d.length)>0)for(const n of v.fulfillments)g["cart.fulfillments."+n.id]=buildFulfillmentStore(n,v);if((null===(u=n.events)||void 0===u?void 0:u.length)>0&&(g["cart.events"]=transformEventsForCart(n.events||[])),this.store.batch(g),i){const n=this.store.get("cart"),i=this.store.get("address");this.pubSub.publishAction(x.CART_LOADED,cartDataForEventFromStore(n,i))}}async loadCart(){try{this.store.set("cart.loading",!![]);const n=this.store.get("cart"),i=await this.api.getCartData(n.id);this.syncCartFromResponse(i,!![]),i.id!==n.id&&await this.store.persist()}catch(n){const i=(null==n?void 0:n.message)||"Failed to load cart";this.store.set("cart.error",i),this.pubSub.publishAction(x.CART_FAILED,{message:i}),this.logger.error("Load cart failed",n)}finally{this.store.set("cart.loading",![])}}}class UICommands extends BaseCommand{static getInstance(){return SingletonManager.getClassInstance("UICommands",()=>new UICommands)}openDrawer(n,i){const r={type:n,data:i||{}};this.store.set("ui.drawer",{isOpen:!![],contentConfig:r}),n===C.CART&&this.pubSub.publishAction(x.CART_OPENED,!![]),n===C.CHECKOUT&&this.pubSub.publishAction(x.CHECKOUT_OPENED,!![])}closeDrawer(){this.store.set("ui.drawer.isOpen",![]);const n=this.store.get("ui.drawer.contentConfig");(null==n?void 0:n.type)===C.CART&&this.pubSub.publishAction(x.CART_CLOSED,!![]),(null==n?void 0:n.type)===C.CHECKOUT&&this.pubSub.publishAction(x.CHECKOUT_CLOSED,!![])}}class CheckoutCommands extends BaseCommand{constructor(){super(),this.uiCommands=UICommands.getInstance(),this.commonCommands=CommonCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("CheckoutCommands",()=>new CheckoutCommands)}async loadCheckout(n){var i,r,s,a,l,d,u,f,g,v,b,w;try{this.store.set("checkout.loading",!![]);const C=n||this.store.get("cart.id"),T=this.store.get("cart");if(0===(null===(i=Object.values(T.items||{}))||void 0===i?void 0:i.length)&&!n)return;const A=this.themeProvider.getConfigs("checkout"),P={canEmail:A.layout.emailOptIn.checked,canSms:A.layout.smsOptIn.checked};if(!C)return this.store.set("checkout.error","Cart ID is not provided"),void 0;const _={"checkout.error":null,"checkout.onDemandFulfillmentTipInfo":{},"checkout.giftCardError":null,"checkout.promoCodeError":null,"checkout.presale":null,"checkout.updating":![]},N=await this.api.prepareCheckout({cartId:C,marketingPreferences:P});if((null===(r=N.retailers)||void 0===r?void 0:r.length)>0)for(const n of N.retailers)for(const i of n.fulfillments)i.type===E.ON_DEMAND&&(_["checkout.onDemandFulfillmentTipInfo."+i.id]={retailerId:n.id,retailerName:n.name,fulfillmentId:i.id,tip:i.tip,subtotal:i.subtotal});if((null===(s=N.items)||void 0===s?void 0:s.length)>0){this.store.remove("checkout.items");for(const n of N.items){const i=N.retailers.find(i=>i.id===n.retailerId),r=i.fulfillments.find(i=>i.id===n.fulfillmentId);_["checkout.items."+n.cartItemId]=this.buildCheckoutItemStore(n,i,r)}}N.isPresaleLocked&&N.presaleExpiresAt&&(_["checkout.presale"]={isLocked:N.isPresaleLocked,expiresAt:N.presaleExpiresAt}),_["checkout.token"]=N.token,_["checkout.cartId"]=N.cartId,_["checkout.isGift"]=N.isGift,_["checkout.giftRecipientForm.data"]={firstName:((null===(l=null===(a=N.giftOptions)||void 0===a?void 0:a.recipient)||void 0===l?void 0:l.name)||"").split(" ")[0],lastName:((null===(u=null===(d=N.giftOptions)||void 0===d?void 0:d.recipient)||void 0===u?void 0:u.name)||"").split(" ")[1],email:(null===(g=null===(f=N.giftOptions)||void 0===f?void 0:f.recipient)||void 0===g?void 0:g.email)||"",phone:(null===(b=null===(v=N.giftOptions)||void 0===v?void 0:v.recipient)||void 0===b?void 0:b.phone)||"",message:(null===(w=N.giftOptions)||void 0===w?void 0:w.message)||""},_["checkout.paymentForm.billingSameAsShipping"]=N.billingSameAsShipping,_["checkout.marketingPreferences"]=N.marketingPreferences,_["checkout.giftCards"]=N.giftCards.map(n=>({code:n.code,discountAmount:n.applied})),_["checkout.promoCode"]=N.promoCode.value?{code:N.promoCode.value,discountAmount:N.promoCode.discount}:null,_["checkout.amounts"]=N.amounts,_["checkout.events"]=N.events||[],this.store.batch(_),this.pubSub.publishAction(x.CHECKOUT_LOADED,{cartId:N.cartId})}catch(C){this.store.set("checkout.error",C.message),this.pubSub.publishAction(x.CHECKOUT_FAILED,{message:C.message})}finally{this.store.set("checkout.loading",![])}}async toggleIsGift(n){const i=this.store.get("checkout.isGift"),r=null!=n?n:!i,s={firstName:"",lastName:"",email:"",phone:"",message:""};this.store.batch({"checkout.isGift":r,"checkout.customerForm.isEditing":!![],"checkout.giftRecipientForm.isEditing":!![],"checkout.giftRecipientForm.isValid":![],"checkout.giftRecipientForm.data":s}),this.pubSub.publishAction(x.CHECKOUT_IS_GIFT_TOGGLED,{isActive:r})}async toggleBillingSameAsShipping(n){const i=this.store.get("checkout.paymentForm.billingSameAsShipping"),r=null!=n?n:!i;this.store.set("checkout.paymentForm.billingSameAsShipping",r),this.pubSub.publishAction(x.CHECKOUT_BILLING_SAME_AS_SHIPPING_TOGGLED,{isActive:r})}async toggleMarketingPreferences(n,i){const r=this.store.get("checkout.marketingPreferences."+n),s=null!=i?i:!r,a=this.store.get("checkout.marketingPreferences"),l=this.dataForCheckoutPrepare({marketingPreferences:{...a,[n]:s}}),d=await this.api.prepareCheckout(l);this.store.set("checkout.marketingPreferences",d.marketingPreferences),this.pubSub.publishAction(x.CHECKOUT_MARKETING_PREFERENCES_TOGGLED,{fieldName:n,isActive:s})}async getPaymentSession(){try{const n=this.store.get("cart.id"),i=await this.api.getPaymentSession({cartId:n});this.store.batch({"checkout.paymentForm.paymentSession":{key:i.key,secret:i.secret},"checkout.paymentForm.paymentMethod":null})}catch(n){throw this.store.batch({"checkout.error":n.message,"checkout.loading":![]}),n}}async confirmPaymentSession(n,i){var r,s,a,l;try{if(this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId"))return{id:this.clientConfig.get("paymentMethodId"),card:{brand:"visa",last4:"1111",expMonth:"03",expYear:"2035"}};const d=await this.api.confirmPaymentSession(n,i);return d&&d.id&&d.card&&d.card.brand&&d.card.last4&&d.card.expMonth&&d.card.expYear?{id:d.id,card:{brand:null===(r=d.card)||void 0===r?void 0:r.brand,last4:null===(s=d.card)||void 0===s?void 0:s.last4.toString(),expMonth:null===(a=d.card)||void 0===a?void 0:a.expMonth.toString(),expYear:null===(l=d.card)||void 0===l?void 0:l.expYear.toString()}}:(this.store.set("checkout.error","Invalid payment method information received."),null)}catch(d){return this.store.set("checkout.error","Failed to confirm payment method. Please try again."),null}}async applyPromoCode(n){var i;try{this.googleTagManager.promoCodeAttempt(n);const r=this.dataForCheckoutPrepare({}),s=await this.api.prepareCheckout({...r,promoCode:n}),a=0!==s.amounts.discounts,l=null===(i=transformPromoCodeCheckoutEvents(s.events||[]))||void 0===i?void 0:i[0];if(!a)return this.store.set("checkout.promoCodeError",l?l.message:'Code "'+n+'" does not exist'),this.pubSub.publishAction(x.CHECKOUT_PROMO_CODE_FAILED,{error:(null==l?void 0:l.message)||'Code "'+n+'" does not exist'}),this.googleTagManager.promoCodeFailed(n,(null==l?void 0:l.message)||"not_applied"),void 0;this.pubSub.publishAction(x.CHECKOUT_PROMO_CODE_APPLIED,{discountAmount:s.amounts.discounts,newTotal:s.amounts.total}),this.googleTagManager.promoCodeApplied(n,s.amounts.discounts),await this.partialLoadCheckout({response:s})}catch(r){const i=(null==r?void 0:r.message)||"Failed to apply promo code. Please try again.";throw this.store.set("checkout.error",i),this.pubSub.publishAction(x.CHECKOUT_PROMO_CODE_FAILED,{error:i}),this.googleTagManager.promoCodeFailed(n,i),r}}async removePromoCode(){var n,i;try{const r=this.dataForCheckoutPrepare({}),s=(null===(i=null===(n=this.store.get("checkout"))||void 0===n?void 0:n.promoCode)||void 0===i?void 0:i.code)||"",a=await this.api.prepareCheckout({...r,promoCode:""});if(0!==a.amounts.discounts)return this.store.set("checkout.promoCodeError","Failed to remove promo code"),void 0;this.pubSub.publishAction(x.CHECKOUT_PROMO_CODE_REMOVED,{newTotal:a.amounts.total}),this.googleTagManager.promoCodeApplied(s,0),await this.partialLoadCheckout({response:a})}catch(r){const n=(null==r?void 0:r.message)||"Failed to remove promo code. Please try again.";this.store.set("checkout.error",n);const i=this.store.get("checkout.promoCode.code")||"";throw this.pubSub.publishAction(x.CHECKOUT_PROMO_CODE_FAILED,{error:n}),i&&this.googleTagManager.promoCodeFailed(i,n),r}}async clearPromoCodeError(){try{this.store.set("checkout.promoCodeError",null)}catch(ut){const i=ut.message||"Failed to clear promo code error. Please try again.";throw this.store.set("checkout.error",i),ut}}async applyGiftCard(n){var i;const r=n.trim().toUpperCase();try{this.googleTagManager.giftCardAttempt(r);const n=this.dataForCheckoutPrepare({}),s=n.giftCards||[],a=await this.api.prepareCheckout({...n,giftCards:[...s,r]}),l=null===(i=transformGiftCardCheckoutEvents(a.events||[]))||void 0===i?void 0:i[0],d=hasAnyRetailerGiftCardRestriction(a.events||[]);if(l&&(this.store.set("checkout.giftCardError",l.message),!d))return;const u=a.giftCards.find(n=>n.code.toLowerCase()===r.toLowerCase());if(!u)return this.store.set("checkout.giftCardError","Gift card could not be applied"),this.pubSub.publishAction(x.CHECKOUT_GIFT_CARD_FAILED,{error:(null==l?void 0:l.message)||"Gift card could not be applied"}),this.googleTagManager.giftCardFailed(r,(null==l?void 0:l.message)||"not_applied"),void 0;this.pubSub.publishAction(x.CHECKOUT_GIFT_CARD_APPLIED,{newTotal:a.amounts.total}),this.googleTagManager.giftCardApplied(r,u.applied),await this.partialLoadCheckout({response:a})}catch(s){const n=(null==s?void 0:s.message)||"Failed to apply gift card. Please try again.";throw this.store.set("checkout.error",n),this.pubSub.publishAction(x.CHECKOUT_GIFT_CARD_FAILED,{error:n}),this.googleTagManager.giftCardFailed(r,n),s}}async removeGiftCard(n){var i;const r=n.trim().toUpperCase();try{const n=this.dataForCheckoutPrepare({}),s=(null===(i=n.giftCards)||void 0===i?void 0:i.filter(n=>n.toLowerCase()!==r.toLowerCase()))||[],a=await this.api.prepareCheckout({...n,giftCards:s}),l=a.giftCards.find(n=>n.code.toLowerCase()===r.toLowerCase());if(l)return this.store.set("checkout.giftCardError","Failed to remove gift card: "+r),void 0;this.pubSub.publishAction(x.CHECKOUT_GIFT_CARD_REMOVED,{newTotal:a.amounts.total}),this.googleTagManager.giftCardApplied(r,0),await this.partialLoadCheckout({response:a})}catch(s){const n=(null==s?void 0:s.message)||"Failed to remove gift card. Please try again.";throw this.store.set("checkout.error",n),this.pubSub.publishAction(x.CHECKOUT_GIFT_CARD_FAILED,{error:n}),this.googleTagManager.giftCardFailed(r,n),s}}async clearGiftCardError(){try{this.store.set("checkout.giftCardError",null)}catch(ut){throw this.store.set("checkout.error",(null==ut?void 0:ut.message)||"Failed to clear gift card error. Please try again."),ut}}openPresaleExpiredDrawer(){this.uiCommands.openDrawer(C.CHECKOUT_PRESALE_EXPIRED)}rerenderCheckout(){this.store.set("checkout.rerender",!![])}async updateCheckoutItemQuantity(n,i){var r,s,a;try{this.store.set("checkout.items."+n+".updating",!![]);const l=this.store.get("checkout.cartId"),d=this.store.get("checkout.items."+n);if(!d)throw new SDKError("Item not found");const u=d.quantity,f=d.quantity+i;if(f<1)return this.removeItem(n,!![]);const g={id:d.cartItemId,fulfillmentId:d.fulfillmentId,partNumber:d.partNumber,quantity:f},v=(null===(a=null===(s=null===(r=d.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.lines)||void 0===a?void 0:a.filter(n=>""!==n.trim()))||[];v.length>0&&(g.engravingLines=v);const b=await this.api.updateCart({id:l,items:[g],loc:this.getLocation()});this.pubSub.publishAction(i>0?x.CHECKOUT_ITEM_QUANTITY_INCREASE:x.CHECKOUT_ITEM_QUANTITY_DECREASE,{cartItemId:d.cartItemId,quantity:f,previousQuantity:u});const w=splitCategoryPath(d.catPath),C={item_id:d.liquidId,item_name:d.name,item_brand:d.brand,item_size:d.size,item_category:w.category,item_category2:w.category2,item_category3:w.category3,quantity:Math.abs(i),price:centToDollar(d.unitPrice||0),upc:d.upc,grouping_id:d.salsifyGrouping,product_id:d.liquidId};i<0?this.googleTagManager.removeFromCart(C):i>0&&this.googleTagManager.addToCart(C),await this.partialLoadCheckout({cartResponse:b})}catch(l){throw this.store.set("checkout.items."+n+".error",l.message),l}finally{this.store.set("checkout.items."+n+".updating",![])}}async removeItemEngraving(n){var i,r,s;try{const a=this.store.get("checkout.items."+n);if(!a)throw new SDKError("Item not found in checkout");if(!(null===(i=a.attributes)||void 0===i?void 0:i.engraving))return this.logger.warn("No engraving found for checkout item",{productItemId:n}),void 0;const l=(null===(s=null===(r=a.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.lines)||[],d={id:a.cartItemId,fulfillmentId:a.fulfillmentId,partNumber:a.partNumber,quantity:a.quantity,engravingLines:[]},u=this.store.get("checkout.cartId"),f=await this.api.updateCart({id:u,items:[d],loc:this.getLocation()});this.pubSub.publishAction(x.CHECKOUT_ITEM_ENGRAVING_UPDATED,{cartItemId:a.cartItemId,engravingLines:[],previousEngravingLines:l}),await this.partialLoadCheckout({cartResponse:f})}catch(a){throw this.store.set("checkout.items."+n+".error",a.message),this.logger.error("Failed to remove engraving from checkout item",{productItemId:n,error:a.message}),a}}async removeItem(n,i){var r,s,a;try{if(this.clientConfig.isBuilder())return this.logger.warn("Remove item is not available in builder mode"),void 0;i||this.store.set("checkout.items."+n+".updating",!![]);const l=this.store.get("checkout.cartId"),d=this.store.get("checkout.items."+n);if(!d)throw new SDKError("Item not found");const u={id:d.cartItemId,fulfillmentId:d.fulfillmentId,partNumber:d.partNumber,quantity:0},f=(null===(a=null===(s=null===(r=d.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.lines)||void 0===a?void 0:a.filter(n=>""!==n.trim()))||[];f.length>0&&(u.engravingLines=f);const g=await this.api.updateCart({id:l,items:[u],loc:this.getLocation()});this.store.remove("checkout.items."+n),this.pubSub.publishAction(x.CHECKOUT_ITEM_REMOVED,{cartItemId:d.cartItemId}),await this.partialLoadCheckout({cartResponse:g})}catch(l){throw this.store.set("checkout.items."+n+".error",l.message),l}}async updateTips(n){try{this.store.set("checkout.updating",!![]),this.store.set("checkout.tipSelection",n);const i=this.store.get("checkout.onDemandFulfillmentTipInfo"),r=Object.values(i||{}).map(i=>{const r=Math.round(i.subtotal*n/100);return{fulfillmentId:i.fulfillmentId,tip:r}}),s=await this.api.prepareCheckout(this.dataForCheckoutPrepare({deliveryTips:r}));this.updateStoreFromCheckoutResponse(s),this.pubSub.publishAction(x.CHECKOUT_TIP_UPDATED,{deliveryTips:r})}catch(i){throw this.store.set("checkout.error",(null==i?void 0:i.message)||"Failed to update tips. Please try again."),i}finally{this.store.set("checkout.updating",![])}}async updateFulfillmentTip(n,i){try{this.store.set("checkout.updating",!![]);const r=this.store.get("checkout.onDemandFulfillmentTipInfo"),s=Object.values(r||{}).map(r=>({fulfillmentId:r.fulfillmentId,tip:r.fulfillmentId===n?i:r.tip})),a=await this.api.prepareCheckout(this.dataForCheckoutPrepare({deliveryTips:s}));this.updateStoreFromCheckoutResponse(a),this.pubSub.publishAction(x.CHECKOUT_TIP_UPDATED,{deliveryTips:s})}catch(r){throw this.store.set("checkout.error",(null==r?void 0:r.message)||"Failed to update fulfillment tip. Please try again."),r}finally{this.store.set("checkout.updating",![])}}async removeFulfillmentTip(n){try{this.store.set("checkout.updating",!![]);const i=this.store.get("checkout.onDemandFulfillmentTipInfo"),r=Object.values(i||{}).map(i=>({fulfillmentId:i.fulfillmentId,tip:i.fulfillmentId===n?0:i.tip})),s=await this.api.prepareCheckout(this.dataForCheckoutPrepare({deliveryTips:r}));this.updateStoreFromCheckoutResponse(s),this.pubSub.publishAction(x.CHECKOUT_TIP_UPDATED,{deliveryTips:r})}catch(i){throw this.store.set("checkout.error",(null==i?void 0:i.message)||"Failed to remove fulfillment tip. Please try again."),i}finally{this.store.set("checkout.updating",![])}}async clearCheckoutError(){this.store.set("checkout.error",null)}async editCustomerForm(){this.store.set("checkout.customerForm.isEditing",!![])}async saveCustomerForm({shippingAddressTwo:n,deliveryInstructions:i,customerData:r}){var s,a,l,d,u,f,g,v,b;try{this.store.set("checkout.customerForm.isSaving",!![]);const w=this.store.get("checkout.customerForm.data"),C=this.store.get("checkout.isGift"),E=this.dataForCheckoutPrepare({shippingAddressTwo:n,deliveryInstructions:i||void 0,customer:{...w,...r},isGift:C}),T=await this.api.prepareCheckout(E),A={id:(null===(s=T.customer)||void 0===s?void 0:s.id)||"",firstName:(null===(a=T.customer)||void 0===a?void 0:a.firstName)||"",lastName:(null===(l=T.customer)||void 0===l?void 0:l.lastName)||"",email:(null===(d=T.customer)||void 0===d?void 0:d.email)||"",phone:(null===(u=T.customer)||void 0===u?void 0:u.phone)||"",birthDate:(null===(g=null===(f=T.customer)||void 0===f?void 0:f.birthDate)||void 0===g?void 0:g.slice(0,10))||"",company:(null===(v=T.customer)||void 0===v?void 0:v.company)||""};this.store.batch({"checkout.customerForm.data":A,"checkout.customerForm.isEditing":![],"checkout.customerForm.isValid":!![],"checkout.shippingAddressTwo":T.shippingAddress.two,"checkout.deliveryInstructions":i}),this.pubSub.publishAction(x.CHECKOUT_CUSTOMER_INFORMATION_UPDATED,!![]);const P=this.store.get("checkout");this.googleTagManager.addShippingInfo([...Object.values(P.items||{}).map(n=>{const i=splitCategoryPath(n.catPath);return{item_id:n.liquidId,item_name:n.name,item_brand:n.brand,item_size:n.size,item_category:i.category,item_category2:i.category2,item_category3:i.category3,quantity:n.quantity,price:centToDollar(n.unitPrice||0),upc:n.upc,grouping_id:n.salsifyGrouping,product_id:n.liquidId}})],(null===(b=P.promoCode)||void 0===b?void 0:b.code)||void 0)}finally{this.store.set("checkout.customerForm.isSaving",![])}}async editGiftRecipientForm(){this.store.set("checkout.giftRecipientForm.isEditing",!![])}async saveGiftRecipientForm({shippingAddressTwo:n,deliveryInstructions:i,...r}){var s,a,l,d,u,f;try{this.store.set("checkout.giftRecipientForm.isSaving",!![]);const g=this.dataForCheckoutPrepare({shippingAddressTwo:n,deliveryInstructions:i||void 0,isGift:!![],giftRecipient:r}),v=await this.api.prepareCheckout(g),b={firstName:(null==r?void 0:r.firstName)||"",lastName:(null==r?void 0:r.lastName)||"",email:(null===(a=null===(s=v.giftOptions)||void 0===s?void 0:s.recipient)||void 0===a?void 0:a.email)||"",phone:(null===(d=null===(l=v.giftOptions)||void 0===l?void 0:l.recipient)||void 0===d?void 0:d.phone)||"",message:(null===(u=v.giftOptions)||void 0===u?void 0:u.message)||""};this.store.batch({"checkout.giftRecipientForm.data":b,"checkout.giftRecipientForm.isEditing":![],"checkout.giftRecipientForm.isValid":!![],"checkout.shippingAddressTwo":v.shippingAddress.two,"checkout.deliveryInstructions":i}),this.pubSub.publishAction(x.CHECKOUT_GIFT_INFORMATION_UPDATED,!![]);const w=this.store.get("checkout");this.googleTagManager.addShippingInfo([...Object.values(w.items||{}).map(n=>{const i=splitCategoryPath(n.catPath);return{item_id:n.liquidId,item_name:n.name,item_brand:n.brand,item_size:n.size,item_category:i.category,item_category2:i.category2,item_category3:i.category3,quantity:n.quantity,price:centToDollar(n.unitPrice||0),upc:n.upc,grouping_id:n.salsifyGrouping,product_id:n.liquidId}})],(null===(f=w.promoCode)||void 0===f?void 0:f.code)||void 0)}finally{this.store.set("checkout.giftRecipientForm.isSaving",![])}}async editPaymentForm(){this.store.set("checkout.paymentForm.isEditing",!![])}async savePaymentForm({billingFormData:n,paymentSession:i}){var r,s,a;try{this.store.set("checkout.paymentForm.isSaving",!![]);const l=this.store.get("checkout"),d={},u=this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId");let f=null,g=null;if(u||i){const n=await this.confirmPaymentSession((null==i?void 0:i.confirmationTokenId)||"",(null==i?void 0:i.setupIntentId)||"");if(!n)throw new Error("Failed to confirm payment method");f=n.card,g=n.id}const v=this.dataForCheckoutPrepare({billingData:n,paymentMethodId:g||void 0}),b=await this.api.prepareCheckout(v);b.payment&&f&&(d["checkout.paymentForm.paymentMethod"]={id:b.payment,card:f}),n&&b.billingAddress&&(d["checkout.paymentForm.data"]={firstName:b.billingAddress.firstName||"",lastName:b.billingAddress.lastName||"",email:b.billingAddress.email||"",phone:b.billingAddress.phone||"",company:b.billingAddress.company||"",addressOne:b.billingAddress.one||"",addressTwo:b.billingAddress.two||"",city:b.billingAddress.city||"",state:b.billingAddress.state||"",zipCode:b.billingAddress.zip||""},this.pubSub.publishAction(x.CHECKOUT_BILLING_INFORMATION_UPDATED,!![])),d["checkout.paymentForm.isEditing"]=![],d["checkout.paymentForm.isValid"]=!![],this.store.batch(d);const w=d["checkout.paymentForm.paymentMethod"]||(null===(r=l.paymentForm)||void 0===r?void 0:r.paymentMethod),C=(null===(s=null==w?void 0:w.card)||void 0===s?void 0:s.brand)?w.card.brand+" ****"+w.card.last4:"card";this.googleTagManager.addPaymentInfo(Object.values(l.items||{}).map(n=>{const i=splitCategoryPath(n.catPath);return{item_id:n.liquidId,item_name:n.name,item_brand:n.brand,item_size:n.size,item_category:i.category,item_category2:i.category2,item_category3:i.category3,quantity:n.quantity,price:centToDollar(n.unitPrice||0),upc:n.upc,grouping_id:n.salsifyGrouping,product_id:n.liquidId}}),C,(null===(a=l.promoCode)||void 0===a?void 0:a.code)||void 0)}catch(l){throw this.logger.error("Failed to save payment form",l),this.store.set("checkout.error",l.message),l}finally{this.store.set("checkout.paymentForm.isSaving",![])}}async checkoutComplete(){var n,i,r,s,a,l;try{this.store.set("checkout.loading",!![]),this.pubSub.publishAction(x.CHECKOUT_SUBMIT_STARTED,{started:!![]});const d=this.store.get("checkout"),u=await this.api.checkoutComplete({token:d.token}),f=u.legacyOrderNumber||u.referenceId||"N/A";d.presale||this.store.set("cart.shouldReset",!![]),this.uiCommands.openDrawer(C.CHECKOUT_COMPLETED,{orderNumber:f,orderTotal:d.amounts.total,cardLast4:null===(r=null===(i=null===(n=null==d?void 0:d.paymentForm)||void 0===n?void 0:n.paymentMethod)||void 0===i?void 0:i.card)||void 0===r?void 0:r.last4,customerEmail:d.customerForm.data.email,giftRecipientEmail:(null===(a=null===(s=null==d?void 0:d.giftRecipientForm)||void 0===s?void 0:s.data)||void 0===a?void 0:a.email)||null}),this.pubSub.publishAction(x.CHECKOUT_SUBMIT_COMPLETED,{orderNumber:f,orderTotal:d.amounts.total}),this.googleTagManager.purchase({transaction_id:f,tax:centToDollar(d.amounts.tax||0),shipping:centToDollar(d.amounts.shipping||0),coupon:(null===(l=d.promoCode)||void 0===l?void 0:l.code)||void 0,items:[...Object.values(d.items||{}).map(n=>{const i=splitCategoryPath(n.catPath);return{item_id:n.liquidId,item_name:n.name,item_brand:n.brand,item_size:n.size,item_category:i.category,item_category2:i.category2,item_category3:i.category3,quantity:n.quantity,price:centToDollar(n.unitPrice||0),upc:n.upc,grouping_id:n.salsifyGrouping,product_id:n.liquidId}})],value:centToDollar(d.amounts.total),subtotal:centToDollar(d.amounts.subtotal),total_before_discounts:centToDollar(d.amounts.subtotal+d.amounts.tax+d.amounts.shipping+d.amounts.delivery+d.amounts.platform+d.amounts.service),discounts:centToDollar(d.amounts.discounts),gift_cards:centToDollar(d.amounts.giftCards||0),net_total:centToDollar(d.amounts.total)})}catch(d){const n=(null==d?void 0:d.message)||"Checkout complete failed";this.store.batch({"checkout.error":n}),this.pubSub.publishAction(x.CHECKOUT_SUBMIT_FAILED,{message:n})}finally{this.store.set("checkout.loading",![])}}updateStoreFromCheckoutResponse(n){var i;const r={"checkout.amounts":n.amounts,"checkout.warning":n.warning,"checkout.events":transformEventsForCheckout(n.events||[]),"checkout.error":null};if((null===(i=n.retailers)||void 0===i?void 0:i.length)>0)for(const s of n.retailers)for(const n of s.fulfillments)n.type===E.ON_DEMAND&&(r["checkout.onDemandFulfillmentTipInfo."+n.id]={retailerId:s.id,retailerName:s.name,fulfillmentId:n.id,tip:n.tip,subtotal:n.subtotal});this.store.batch(r)}async partialLoadCheckout(n){var i,r,s,a,l;try{let d;if(this.store.set("checkout.updating",!![]),(null==n?void 0:n.cartResponse)?this.commonCommands.syncCartFromResponse(n.cartResponse):await this.commonCommands.loadCart(),null==n?void 0:n.response)d=n.response;else{const r=null!==(i=null==n?void 0:n.cartId)&&void 0!==i?i:this.store.get("checkout.cartId");if(!r)return this.store.set("checkout.error","Cart ID is not provided"),void 0;const s=this.dataForCheckoutPrepare({});d=await this.api.prepareCheckout({...s,cartId:r})}const u={"checkout.token":d.token,"checkout.events":transformEventsForCheckout(d.events||[]),"checkout.amounts":d.amounts,"checkout.error":null,"checkout.promoCodeError":null,"checkout.giftCardError":null,"checkout.giftCards":d.giftCards.map(n=>({code:n.code,discountAmount:n.applied})),"checkout.promoCode":(null===(s=null===(r=null==d?void 0:d.promoCode)||void 0===r?void 0:r.value)||void 0===s?void 0:s.trim())?{code:d.promoCode.value,discountAmount:d.promoCode.discount}:null};if((null===(a=d.retailers)||void 0===a?void 0:a.length)>0){this.store.remove("checkout.onDemandFulfillmentTipInfo");for(const n of d.retailers)for(const i of n.fulfillments)i.type===E.ON_DEMAND&&(u["checkout.onDemandFulfillmentTipInfo."+i.id]={retailerId:n.id,retailerName:n.name,fulfillmentId:i.id,tip:i.tip,subtotal:i.subtotal})}if((null===(l=d.items)||void 0===l?void 0:l.length)>0){this.store.remove("checkout.items");for(const n of d.items){const i=d.retailers.find(i=>i.id===n.retailerId),r=i.fulfillments.find(i=>i.id===n.fulfillmentId);u["checkout.items."+n.cartItemId]=this.buildCheckoutItemStore(n,i,r)}}this.store.batch(u)}catch(d){const n=(null==d?void 0:d.message)||"Failed to load checkout data. Please try again.";throw this.store.set("checkout.error",n),this.pubSub.publishAction(x.CHECKOUT_FAILED,{message:n}),d}finally{this.store.set("checkout.updating",![])}}dataForCheckoutPrepare({customer:n,giftRecipient:i,billingData:r,marketingPreferences:s,shippingAddressTwo:a,deliveryInstructions:l,deliveryTips:d,paymentMethodId:u,isGift:f}){var g,v,b,x,w,C,E,T,A,P,_,N,F,R,O,L,M,B,W,H,q,j,U,V,K,Q;const Z=this.store.get("checkout"),X=null!==(v=null===(g=Z.paymentForm)||void 0===g?void 0:g.billingSameAsShipping)&&void 0!==v?v:!![],J=void 0!==f?f:Z.isGift,$=i?!![]:null!==(x=null===(b=Z.giftRecipientForm)||void 0===b?void 0:b.isValid)&&void 0!==x?x:![],tt=J&&$,et={cartId:Z.cartId,acceptedAccountCreation:![],hasSubstitutionPolicy:![],hasAgeVerify:!![],shippingAddressTwo:a,billingSameAsShipping:X,marketingPreferences:s||Z.marketingPreferences,promoCode:(null===(w=Z.promoCode)||void 0===w?void 0:w.code)||void 0,isGift:tt,giftCards:(null===(C=null==Z?void 0:Z.giftCards)||void 0===C?void 0:C.map(n=>n.code))||[],deliveryTips:d||Object.values(Z.onDemandFulfillmentTipInfo||{}).map(n=>({fulfillmentId:n.fulfillmentId,tip:n.tip}))};u?et.payment=u:(null===(T=null===(E=Z.paymentForm)||void 0===E?void 0:E.paymentMethod)||void 0===T?void 0:T.id)&&(et.payment=Z.paymentForm.paymentMethod.id);const nt=l||Z.deliveryInstructions;if(nt&&(et.deliveryInstructions=Object.values(Z.items||{}).map(n=>({fulfillmentId:n.fulfillmentId,instructions:nt}))),et.customer=n?{...n,id:(null==n?void 0:n.id)||void 0}:(null===(P=null===(A=null==Z?void 0:Z.customerForm)||void 0===A?void 0:A.data)||void 0===P?void 0:P.email)?{id:(null===(N=null===(_=Z.customerForm)||void 0===_?void 0:_.data)||void 0===N?void 0:N.id)||void 0,firstName:null===(R=null===(F=Z.customerForm)||void 0===F?void 0:F.data)||void 0===R?void 0:R.firstName,lastName:null===(L=null===(O=Z.customerForm)||void 0===O?void 0:O.data)||void 0===L?void 0:L.lastName,email:null===(B=null===(M=Z.customerForm)||void 0===M?void 0:M.data)||void 0===B?void 0:B.email,phone:null===(H=null===(W=Z.customerForm)||void 0===W?void 0:W.data)||void 0===H?void 0:H.phone,birthDate:null===(j=null===(q=Z.customerForm)||void 0===q?void 0:q.data)||void 0===j?void 0:j.birthDate,company:null===(V=null===(U=Z.customerForm)||void 0===U?void 0:U.data)||void 0===V?void 0:V.company}:void 0,tt){const n=i||(null===(K=Z.giftRecipientForm)||void 0===K?void 0:K.data);n&&(et.giftOptions={recipient:{name:(n.firstName||"")+" "+(n.lastName||""),email:n.email||"",phone:n.phone||""},message:n.message||""})}if(!X)if(r)et.billingAddress={firstName:r.firstName,lastName:r.lastName,email:r.email,phone:r.phone,company:r.company,one:r.addressOne,two:r.addressTwo,city:r.city,state:r.state,zip:r.zipCode,country:"US"};else{const n=null===(Q=Z.paymentForm)||void 0===Q?void 0:Q.data;et.billingAddress={firstName:null==n?void 0:n.firstName,lastName:null==n?void 0:n.lastName,email:null==n?void 0:n.email,phone:null==n?void 0:n.phone,company:null==n?void 0:n.company,one:null==n?void 0:n.addressOne,two:null==n?void 0:n.addressTwo,city:null==n?void 0:n.city,state:null==n?void 0:n.state,zip:null==n?void 0:n.zipCode,country:"US"}}return et}buildCheckoutItemStore(n,i,r){return{liquidId:n.liquidId,variantId:n.variantId,cartItemId:n.cartItemId,retailerId:n.retailerId,fulfillmentId:n.fulfillmentId,salsifyGrouping:n.salsifyGrouping,name:n.name,catPath:n.catPath,volume:n.volume,uom:n.uom,proof:n.proof,abv:n.abv,containerType:n.containerType,container:n.container,size:n.size,pack:n.pack,packDesc:n.packDesc,mainImage:n.mainImage,brand:n.brand,partNumber:n.partNumber,upc:n.upc,sku:n.sku,price:n.price,unitPrice:n.unitPrice,quantity:n.quantity,unitTax:n.unitTax,bottleDeposits:n.bottleDeposits,attributes:n.attributes,retailerName:i.name,expectationDetail:r.expectation.detail,loading:![],updating:![],error:null}}}class CartCommands extends BaseCommand{constructor(){super(),this.uiCommands=UICommands.getInstance(),this.checkoutCommands=CheckoutCommands.getInstance(),this.commonCommands=CommonCommands.getInstance(),this.store.watch("cart.shouldReset",async n=>{n===!![]&&await this.resetCart()})}static getInstance(){return SingletonManager.getClassInstance("CartCommands",()=>new CartCommands)}async updateItemQuantity(n,i){try{this.store.set("cart.items."+n+".updating",!![]);const r=this.store.get("cart.id"),s=this.store.get("cart.items."+n);if(!s)throw this.logger.error("Cart item not found: "+n+" - cannot update quantity by "+i),new SDKError("Item not found");const a=s.quantity+i;if(a<1)return this.removeItem(n,!![]);const l=this.buildItemUpdate(s,a),d=await this.api.updateCart({id:r,items:[l],loc:this.getLocation()});this.syncItemsFromApiResponse(d,[n]),this.updateFulfillment(s.fulfillmentId,d),this.syncRetailersFromApiResponse(d),this.syncCartMetaFromApiResponse(d),this.pubSub.publishAction(i<0?x.CART_ITEM_QUANTITY_DECREASE:x.CART_ITEM_QUANTITY_INCREASE,{id:s.id,quantity:a,previousQuantity:s.quantity});const u=splitCategoryPath(s.catPath),f={item_id:s.liquidId,item_name:s.name,item_brand:s.brand,item_size:s.size,item_category:u.category,item_category2:u.category2,item_category3:u.category3,quantity:Math.abs(i),price:centToDollar(s.unitPrice||0),upc:s.upc,grouping_id:s.salsifyGrouping,product_id:s.liquidId};i<0?this.googleTagManager.removeFromCart(f):i>0&&this.googleTagManager.addToCart(f)}catch(r){throw this.store.set("cart.items."+n+".error",r.message),this.logger.error("Failed to update item quantity",r),r}finally{this.store.set("cart.items."+n+".updating",![])}}async removeItem(n,i){try{if(this.clientConfig.isBuilder())return this.logger.warn("Remove item is not available in builder mode"),void 0;i||this.store.set("cart.items."+n+".updating",!![]);const r=this.store.get("cart.id"),s=this.store.get("cart.items."+n);if(!s)throw new SDKError("Item not found");const a={itemId:s.id,fulfillmentId:s.fulfillmentId,retailerId:s.retailerId},l=this.buildItemUpdate(s,0),d=await this.api.updateCart({id:r,items:[l],loc:this.getLocation()});this.syncItemsFromApiResponse(d,[]),this.cleanupAfterItemRemoval(a,d),this.syncCartMetaFromApiResponse(d),this.pubSub.publishAction(x.CART_ITEM_REMOVED,{id:s.id});const u=splitCategoryPath(s.catPath);this.googleTagManager.removeFromCart({item_id:s.liquidId,item_name:s.name,item_brand:s.brand,item_size:s.size,item_category:u.category,item_category2:u.category2,item_category3:u.category3,quantity:s.quantity,price:centToDollar(s.unitPrice||0),upc:s.upc,grouping_id:s.salsifyGrouping,product_id:s.liquidId})}catch(r){throw this.store.set("cart.items."+n+".error",r.message),this.logger.error("Failed to remove item",r),r}}async updateItemEngraving(n,i){var r,s,a;try{const l=this.store.get("cart"),d=null===(r=l.items)||void 0===r?void 0:r[n];if(!d)throw new SDKError("Item not found");this.store.set("cart.items."+n+".updating",!![]);const u={id:d.id,fulfillmentId:d.fulfillmentId,partNumber:d.partNumber,quantity:d.quantity,engravingLines:i},f=await this.api.updateCart({id:l.id||"",items:[u],loc:this.getLocation()});this.syncItemsFromApiResponse(f,[n]),this.syncRetailersFromApiResponse(f),this.syncCartMetaFromApiResponse(f);const g=this.store.get("cart"),v=this.store.get("address");this.pubSub.publishAction(x.CART_UPDATED,{previous:cartDataForEventFromStore(l,v),current:cartDataForEventFromStore(g,v)}),this.pubSub.publishAction(x.CART_ITEM_ENGRAVING_UPDATED,{id:d.id,engravingLines:i,previousEngravingLines:(null===(a=null===(s=d.attributes)||void 0===s?void 0:s.engraving)||void 0===a?void 0:a.lines)||[]})}catch(l){throw this.store.set("cart.items."+n+".error",l.message),this.logger.error("Failed to update item engraving",l),l}finally{this.store.set("cart.items."+n+".updating",![])}}async addItem(n){var i,r;try{this.store.set("cart.loading",!![]);const s=this.store.get("cart"),a={...s},l=(null===(i=n.engravingLines)||void 0===i?void 0:i.filter(n=>""!==n.trim()))||[],d=l.length>0,u=Object.values(s.items||{}).find(i=>{var r,s,a,u,f;const g=i.fulfillmentId===n.fulfillmentId&&i.partNumber===n.partNumber;if(!g)return![];if(d){const n=(null===(s=null===(r=i.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.lines)||[];return l.join(",")===n.join(",")}return!(null===(f=null===(u=null===(a=i.attributes)||void 0===a?void 0:a.engraving)||void 0===u?void 0:u.lines)||void 0===f?void 0:f.length)}),f={upc:n.upc,fulfillmentId:n.fulfillmentId,partNumber:n.partNumber,quantity:u?n.quantity+u.quantity:n.quantity};d&&(f.engravingLines=l);const g=await this.api.updateCart({id:s.id||"",items:[f],loc:this.getLocation()}),v=null===(r=g.items)||void 0===r?void 0:r.find(n=>n.fulfillmentId===f.fulfillmentId&&n.partNumber===f.partNumber&&n.upc===f.upc);if(!v)throw new SDKError("Added item not found in cart response");this.syncItemsFromApiResponse(g,[]);const b=this.store.get("cart.fulfillments."+n.fulfillmentId);b?this.updateFulfillment(n.fulfillmentId,g):this.addNewFulfillmentAndRetailer(n.fulfillmentId,g),this.syncRetailersFromApiResponse(g),this.syncCartMetaFromApiResponse(g);const w=this.store.get("cart"),C=this.store.get("address");this.pubSub.publishAction(x.PRODUCT_ADD_TO_CART,{...n}),this.pubSub.publishAction(x.CART_ITEM_ADDED,{id:v.id,upc:n.upc,fulfillmentId:n.fulfillmentId,partNumber:n.partNumber,quantity:n.quantity,engravingLines:n.engravingLines}),this.pubSub.publishAction(x.CART_UPDATED,{previous:cartDataForEventFromStore(a,C),current:cartDataForEventFromStore(w,C)});const E=splitCategoryPath(v.catPath);this.googleTagManager.addToCart({item_id:v.liquidId,item_name:v.name,item_brand:v.brand,item_size:v.size,item_category:E.category,item_category2:E.category2,item_category3:E.category3,item_type:v.type,item_subtype:v.subType,quantity:v.quantity,price:centToDollar(v.unitPrice||0),upc:v.upc,grouping_id:v.salsifyGrouping,product_id:v.liquidId})}catch(s){this.store.set("cart.error",s.message),this.logger.error("Failed to add item to cart",s)}finally{this.store.set("cart.loading",![])}}async addPresaleItem(n){var i;try{const r={upc:n.upc,fulfillmentId:n.fulfillmentId,partNumber:n.partNumber,quantity:n.quantity};(null==n?void 0:n.engravingLines)&&(null===(i=null==n?void 0:n.engravingLines)||void 0===i?void 0:i.length)>0&&(r.engravingLines=n.engravingLines);const s=await this.api.updateCart({id:"",items:[r],loc:this.getLocation()});await this.checkoutCommands.loadCheckout(s.id)}catch(r){throw this.store.set("cart.error",r.message),this.logger.error("Failed to add presale item to cart",r),r}}async handleGoToCheckout(){var n;try{this.store.set("cart.loading",!![]),await this.checkoutCommands.loadCheckout(),this.uiCommands.openDrawer(C.CHECKOUT);const i=this.store.get("cart"),r=(null===(n=i.promoCode)||void 0===n?void 0:n.code)||void 0;this.googleTagManager.beginCheckout([...Object.values(i.items||{}).map(n=>{const i=splitCategoryPath(n.catPath);return{item_id:n.liquidId,item_name:n.name,item_brand:n.brand,item_size:n.size,item_category:i.category,item_category2:i.category2,item_category3:i.category3,quantity:n.quantity,price:centToDollar(n.unitPrice||0),upc:n.upc,grouping_id:n.salsifyGrouping,product_id:n.liquidId}})],r)}catch(i){throw this.store.set("cart.error",i.message),this.logger.error("Failed to proceed to checkout",i),i}finally{this.store.set("cart.loading",![])}}async applyPromoCode(n){var i,r,s;if(!(null==n?void 0:n.trim()))throw new SDKError("Promo code is required");const a=n.trim().toUpperCase();try{const n=this.store.get("cart.id");this.googleTagManager.promoCodeAttempt(a);const l=await this.api.updateCart({id:n,items:[],promoCode:a,loc:this.getLocation()});this.store.set("cart.totals",buildCartTotals(l)),this.store.set("cart.events",transformEventsForCart(l.events||[]));const d=(null===(s=null===(r=null===(i=l.attributes)||void 0===i?void 0:i.promoCode)||void 0===r?void 0:r.value)||void 0===s?void 0:s.toLowerCase())===a.toLowerCase();d?(this.store.set("cart.promoCode",{code:a,discountAmount:l.discounts||0}),this.pubSub.publishAction(x.CART_PROMO_CODE_APPLIED,{discountAmount:l.discounts||0,newTotal:l.total||0}),this.googleTagManager.promoCodeApplied(a,l.discounts||0)):(this.store.set("cart.promoCode",null),this.pubSub.publishAction(x.CART_PROMO_CODE_FAILED,{error:'Code "'+a+'" does not exist'}),this.googleTagManager.promoCodeFailed(a,'Code "'+a+'" does not exist'))}catch(l){const n=(null==l?void 0:l.message)||"Failed to apply promo code. Please try again.";throw this.store.set("cart.error",n),this.pubSub.publishAction(x.CART_PROMO_CODE_FAILED,{error:n}),this.googleTagManager.promoCodeFailed(a,n),this.logger.error("Failed to apply promo code",l),l}}async removePromoCode(){try{const n=this.store.get("cart.id"),i=await this.api.updateCart({id:n,items:[],promoCode:"",loc:this.getLocation()});this.store.batch({"cart.totals":buildCartTotals(i),"cart.promoCode":null}),this.pubSub.publishAction(x.CART_PROMO_CODE_REMOVED,{newTotal:i.total||0}),this.googleTagManager.promoCodeApplied("",0)}catch(n){const i=(null==n?void 0:n.message)||"Failed to remove promo code. Please try again.";this.store.set("cart.error",i);const r=this.store.get("cart.promoCode");throw this.pubSub.publishAction(x.CART_PROMO_CODE_FAILED,{error:i}),(null==r?void 0:r.code)&&this.googleTagManager.promoCodeFailed(r.code,i),this.logger.error("Failed to remove promo code",n),n}}rerenderCart(){this.store.set("cart.rerender",!![])}async resetCart(){this.store.set("checkout",{...L,rerender:!![]}),this.store.set("cart",{...O,rerender:!![]}),await this.commonCommands.loadCart(),this.pubSub.publishAction(x.CART_RESET,!![])}getDetails(){var n;const i=this.store.get("cart"),r=this.store.get("address"),s=r.id?r:{id:"",address:{one:"",two:"",city:"",state:"",zip:"",country:""},coordinates:{lat:0,long:0}},a={};for(const l in i.items||{}){const n=i.items[l];a[l]={id:n.id,variantId:n.variantId,liquidId:n.liquidId,salsifyGrouping:n.salsifyGrouping,retailerId:n.retailerId,partNumber:n.partNumber,fulfillmentId:n.fulfillmentId,upc:n.upc,sku:n.sku,catPath:n.catPath,volume:n.volume,uom:n.uom,pack:n.pack,packDesc:n.packDesc,container:n.container,containerType:n.containerType,name:n.name,brand:n.brand,size:n.size,price:n.price||0,quantity:n.quantity||0,maxQuantity:n.maxQuantity||0,unitPrice:n.unitPrice||0,mainImage:n.mainImage||"",attributes:n.attributes||{}}}return{id:i.id,promoCode:(null===(n=i.promoCode)||void 0===n?void 0:n.code)||"",items:a,location:{placesId:s.id,address:{one:s.address.one,two:s.address.two,city:s.address.city,state:s.address.state,zip:s.address.zip,country:s.address.country},coordinates:{latitude:s.coordinates.lat,longitude:s.coordinates.long}},amounts:{deliveryFee:i.totals.deliveryFee,discounts:i.totals.discounts,engravingFee:i.totals.engravingFee,giftCardTotal:i.totals.giftCardTotal,platformFee:i.totals.platformFee,shippingFee:i.totals.shippingFee,subtotal:i.totals.subtotal,total:i.totals.total},itemCount:Object.values(a||{}).reduce((n,i)=>n+(i.quantity||0),0),updatedAt:i.updatedAt,createdAt:i.createdAt}}buildItemUpdate(n,i){var r,s,a;const l={id:n.id,fulfillmentId:n.fulfillmentId,partNumber:n.partNumber,quantity:i},d=(null===(a=null===(s=null===(r=n.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.lines)||void 0===a?void 0:a.filter(n=>""!==n.trim()))||[];return d.length>0&&(l.engravingLines=d),l}syncItemsFromApiResponse(n,i=[]){var r;const s=this.store.get("cart.items")||{},a=new Set((null===(r=n.items)||void 0===r?void 0:r.map(n=>n.id))||[]);for(const d of Object.keys(s))a.has(d)||this.store.remove("cart.items."+d);const l={};for(const d of n.items)0!==i.length&&!i.includes(d.id)&&s[d.id]||(l["cart.items."+d.id]=buildCartItemStore(d));Object.keys(l).length>0&&this.store.batch(l)}syncCartMetaFromApiResponse(n){var i,r;const s={"cart.totals":buildCartTotals(n),"cart.error":null,"cart.updatedAt":n.updatedAt||(new Date).toISOString(),"cart.createdAt":n.createdAt||(new Date).toISOString(),"cart.events":transformEventsForCart(n.events||[])},a=null===(r=null===(i=n.attributes)||void 0===i?void 0:i.promoCode)||void 0===r?void 0:r.value;if(a)s["cart.promoCode"]={code:a.toUpperCase(),discountAmount:n.discounts||0};else{const n=this.store.get("cart.promoCode");(null==n?void 0:n.code)&&(s["cart.promoCode"]=null)}this.store.batch(s)}syncRetailersFromApiResponse(n){var i;if((null===(i=n.retailers)||void 0===i?void 0:i.length)>0){const i={};for(const r of n.retailers)i["cart.retailers."+r.id]=buildRetailerStore(r);this.store.batch(i)}}updateFulfillment(n,i){var r,s;const a=null===(r=i.retailers)||void 0===r?void 0:r.find(i=>{var r;return null===(r=i.fulfillments)||void 0===r?void 0:r.some(i=>i.id===n)}),l=null===(s=null==a?void 0:a.fulfillments)||void 0===s?void 0:s.find(i=>i.id===n);l&&a&&this.store.set("cart.fulfillments."+n,buildFulfillmentStore(l,a))}addNewFulfillmentAndRetailer(n,i){var r,s;const a=null===(r=i.retailers)||void 0===r?void 0:r.find(i=>{var r;return null===(r=i.fulfillments)||void 0===r?void 0:r.some(i=>i.id===n)}),l=null===(s=null==a?void 0:a.fulfillments)||void 0===s?void 0:s.find(i=>i.id===n);if(l&&a){const i={["cart.fulfillments."+n]:buildFulfillmentStore(l,a),["cart.retailers."+a.id]:buildRetailerStore(a)};this.store.batch(i)}}cleanupAfterItemRemoval(n,i){var r,s,a,l;const d=this.store.get("cart.fulfillments."+n.fulfillmentId),u=this.store.get("cart.retailers."+n.retailerId);if(!d||!u)return;const f=null===(r=i.retailers)||void 0===r?void 0:r.some(i=>{var r;return null===(r=i.fulfillments)||void 0===r?void 0:r.some(i=>i.id===n.fulfillmentId)}),g=null===(s=i.retailers)||void 0===s?void 0:s.some(i=>i.id===n.retailerId);if(f){this.updateFulfillment(n.fulfillmentId,i);const r=null===(l=i.retailers)||void 0===l?void 0:l.find(i=>i.id===n.retailerId);r&&this.store.set("cart.retailers."+n.retailerId,buildRetailerStore(r))}else if(this.store.remove("cart.fulfillments."+n.fulfillmentId),g){const r=null===(a=i.retailers)||void 0===a?void 0:a.find(i=>i.id===n.retailerId);r&&this.store.set("cart.retailers."+n.retailerId,buildRetailerStore(r))}else this.store.remove("cart.retailers."+n.retailerId)}}const Et=["sunday","monday","tuesday","wednesday","thursday","friday","saturday"],St=1440;function timeToMinutes(n){const i=n.match(/^(\d{1,2}):(\d{2})$/);if(!i)throw new SDKError("Invalid time format: "+n);const r=Number.parseInt(i[1],10),s=Number.parseInt(i[2],10);if(r<0||r>47||s<0||s>59)throw new SDKError("Invalid time values: "+n);return 60*r+s}function getCurrentTimeInTimezone$1(n){var i,r,s;const a=new Date,l={timeZone:n,weekday:"long",hour:"2-digit",minute:"2-digit",hour12:![]};try{const n=new Intl.DateTimeFormat("en-US",l),d=n.formatToParts(a),u=(null===(i=d.find(n=>"weekday"===n.type))||void 0===i?void 0:i.value.toLowerCase())||"",f=(null===(r=d.find(n=>"hour"===n.type))||void 0===r?void 0:r.value)||"0",g=(null===(s=d.find(n=>"minute"===n.type))||void 0===s?void 0:s.value)||"0",v=60*Number.parseInt(f,10)+Number.parseInt(g,10);return{weekday:u,timeInMinutes:v}}catch(d){throw new SDKError("Invalid timezone: "+n)}}function format24TimeTo12(n){const i=n.match(/^(\d{1,2}):(\d{2})$/);if(!i||"object"==typeof i)return n;let r=Number.parseInt(i[1],10);const s=i[2];r>=24&&(r-=24);const a=r>=12?"PM":"AM",l=0===r?12:r>12?r-12:r;return l+":"+s+" "+a}function isWithinTimeSlot(n,i){try{const r=timeToMinutes(i.startsAt),s=timeToMinutes(i.endsAt);if(s>St){if(n>=r||n<s-St)return"during"}else if(s<r){if(n>=r||n<s)return"during"}else if(n>=r&&n<s)return"during";return n<r?"before":"after"}catch(r){return"after"}}function getNextOpeningTime(n,i,r=7){var s,a;const l=Et.indexOf(i);for(let u=1;u<=r;u++){const i=(l+u)%7,r=Et[i],f=n[r];if((null==f?void 0:f.active)&&f.times&&f.times.length>0)try{const n=1===u?"tomorrow":r;return"Opens "+n+" at "+format24TimeTo12(null!==(a=null===(s=null==f?void 0:f.times[0])||void 0===s?void 0:s.startsAt)&&void 0!==a?a:"")}catch(d){}}return null}function validateFulfillmentData(n){return n&&"object"==typeof n&&n.hours&&n.timezone?"string"!=typeof n.timezone?![]:!![]:![]}function getRetailerOffHours(n){var i;if(!(null==n?void 0:n.type)||(null==n?void 0:n.type)!==E.ON_DEMAND)return{message:null,isOpen:!![],isClosed:![]};if(!validateFulfillmentData(n))return{message:null,isOpen:![],isClosed:!![]};try{const{weekday:r,timeInMinutes:s}=getCurrentTimeInTimezone$1(n.timezone),a=n.hours[r];if(!(null==a?void 0:a.active)||!(null===(i=a.times)||void 0===i?void 0:i.length)){const i=getNextOpeningTime(n.hours,r);return{message:i,isOpen:![],isClosed:!![]}}for(const n of a.times){const i=isWithinTimeSlot(s,n);switch(i){case"before":return{message:"Opens at "+format24TimeTo12(n.startsAt),isOpen:![],isClosed:!![],openTime:n.startsAt,closeTime:n.endsAt};case"during":{let i=n.endsAt;const r=timeToMinutes(i);if(r>St){const n=Math.floor(r/60)-24,s=r%60;i=n.toString().padStart(2,"0")+":"+s.toString().padStart(2,"0")}return{message:"Closes at "+format24TimeTo12(i),isOpen:!![],isClosed:![],openTime:n.startsAt,closeTime:n.endsAt}}}}const l=getNextOpeningTime(n.hours,r);return{message:l,isOpen:![],isClosed:!![]}}catch(r){return{message:null,isOpen:![],isClosed:!![]}}}class ProductCommands extends BaseCommand{constructor(){super(),this.uiCommands=UICommands.getInstance(),this.cartCommands=CartCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("ProductCommands",()=>new ProductCommands)}async createProductInstance(n,i=![]){this.store.createProductInstance(n),i&&this.store.set("products."+n+".loading",!![])}async loadMultipleProducts(n){var i;if(!Array.isArray(n)||0===n.length)return this.logger.warn("No product IDs provided for loading multiple products."),void 0;this.store.batch(n.reduce((n,i)=>(n["products."+i+".loading"]=!![],n["products."+i+".error"]=null,n),{}));const r=await this.api.getProductsData(n,this.getLocation());if(!r||!r.products||0===r.products.length)return this.logger.warn("No product data found for the provided product IDs."),this.store.batch(n.reduce((n,i)=>(n["products."+i+".loading"]=![],n["products."+i+".error"]=!![],n),{})),void 0;const s=[];for(const l of r.products){const a=l.sizes.filter(i=>n.some(n=>n===(i.upc||i.id||l.salsifyGrouping))),d=n.find(n=>a.some(i=>n===i.upc||n===i.id)||n===l.salsifyGrouping),u=d||(null===(i=null==a?void 0:a[0])||void 0===i?void 0:i.upc);await this.loadProduct(u,{products:[l],retailers:r.retailers}),s.push(u)}const a=n.filter(n=>-1===s.indexOf(n));this.store.batch(a.reduce((n,i)=>(n["products."+i+".loading"]=![],n["products."+i+".error"]="Product data not found",n),{}))}async loadProduct(n,i=null){var r,s;try{const a=this.store.get("products."+n);a.loading||this.store.set("products."+n+".loading",!![]);let l=null;if(i&&(l=i),i||(l=await this.api.getProductsData([n],this.getLocation())),!l||!(null===(r=null==l?void 0:l.products)||void 0===r?void 0:r[0]))return this.store.set("products."+n+".error","Product data not found"),void 0;const d=this.loadProductStoreUpdate(l);if(!d)return this.store.set("products."+n+".error","Failed to process product data"),void 0;this.store.set("products."+n,{...d,identifier:n}),this.pubSub.publishAction(x.PRODUCT_LOADED,this.productDataForEventFromStore(n));const u=l.products[0],f=d.sizes[d.selectedSizeId||""],g=Boolean(this.getLocation()),v=d.selectedFulfillment,b=g&&(null==v?void 0:v.price)?v.price:(null===(s=d.priceInfo)||void 0===s?void 0:s.avg)||0,w=splitCategoryPath(u.catPath);this.googleTagManager.viewItem({item_id:null==f?void 0:f.id,item_name:u.name,item_brand:u.brand,item_size:null==f?void 0:f.size,item_category:w.category,item_category2:w.category2,item_category3:w.category3,price:centToDollar(b),item_type:u.type,item_subtype:u.subType,upc:null==f?void 0:f.upc,grouping_id:u.salsifyGrouping,product_id:null==f?void 0:f.id})}catch(a){this.store.set("products."+n+".error",a.message),this.logger.error("Failed to load product data for ID "+n,a)}finally{this.store.set("products."+n+".loading",![])}}async selectSize(n,i){var r,s,a,l,d,u,f;const g=this.store.get("products."+n);let v=g.selectedFulfillmentType;const b=null===(r=g.sizes[i])||void 0===r?void 0:r.shippingFulfillments,w=null===(s=g.sizes[i])||void 0===s?void 0:s.onDemandFulfillments;let C=null,T=null;if(v!==E.SHIPPING||Object.values(b).length)if(v!==E.ON_DEMAND||Object.values(w).length){const n=v===E.SHIPPING?b:w,i=Object.values(n);C=i[0]||null,T=(null==C?void 0:C.fulfillmentId)||null}else{v=E.SHIPPING;const n=Object.values(b);C=n[0]||null,T=(null==C?void 0:C.fulfillmentId)||null}else{v=E.ON_DEMAND;const n=Object.values(w);C=n[0]||null,T=(null==C?void 0:C.fulfillmentId)||null}const A=v===E.SHIPPING?b:w,P=g.sizes[i],_=splitCategoryPath(g.catPath),N=(null==C?void 0:C.price)||(null===(a=g.priceInfo)||void 0===a?void 0:a.avg)||0;this.googleTagManager.viewItem({item_id:null==P?void 0:P.id,item_name:g.name,item_brand:g.brand,item_size:null==P?void 0:P.size,item_category:_.category,item_category2:_.category2,item_category3:_.category3,price:centToDollar(N),item_type:g.type,item_subtype:g.subType,upc:null==P?void 0:P.upc,grouping_id:g.salsifyGrouping,product_id:null==P?void 0:P.id});const F=Object.keys(b).length>0,R=Object.keys(w).length>0,O=F||R;if(!O){const n=this.store.get("address");this.googleTagManager.productSizeNoAvailability({productId:null==P?void 0:P.id,productName:g.name,productBrand:g.brand,productCategory:_.category,productCategory2:_.category2,productCategory3:_.category3,productType:g.type,productSubtype:g.subType,productPrice:(null===(l=g.priceInfo)||void 0===l?void 0:l.avg)||0,sizeId:i,sizeName:null==P?void 0:P.size,upc:null==P?void 0:P.upc,groupingId:g.salsifyGrouping,address:(null==n?void 0:n.address)?{one:n.address.one,two:n.address.two,city:n.address.city,state:n.address.state,zip:n.address.zip,country:n.address.country||""}:void 0,reason:"No fulfillments available for this size"})}this.pubSub.publishAction(x.PRODUCT_SIZE_CHANGED,{identifier:n,selectedSizeId:i,size:(null===(d=g.sizes[i])||void 0===d?void 0:d.size)||"",previousSizeId:g.selectedSizeId||"",previousSize:(null===(u=g.sizes[g.selectedSizeId])||void 0===u?void 0:u.size)||""}),this.store.batch({["products."+n+".selectedSizeId"]:i,["products."+n+".mainImage"]:(null===(f=g.sizes[i])||void 0===f?void 0:f.image)||null,["products."+n+".productHasAvailability"]:Object.keys(b).length+Object.keys(w).length>0,["products."+n+".fulfillmentHasAvailability"]:Boolean(Object.keys(A).length),["products."+n+".selectedFulfillmentType"]:v,["products."+n+".selectedFulfillment"]:C,["products."+n+".selectedFulfillmentId"]:T})}async selectFulfillment(n,i){var r,s,a;const l=this.store.get("products."+n),d=null===(r=l.sizes[l.selectedSizeId])||void 0===r?void 0:r.shippingFulfillments,u=null===(s=l.sizes[l.selectedSizeId])||void 0===s?void 0:s.onDemandFulfillments,f=l.selectedFulfillmentType===E.SHIPPING?d:u,g=f[i];this.pubSub.publishAction(x.PRODUCT_FULFILLMENT_CHANGED,{identifier:n,selectedFulfillmentId:i,selectedFulfillmentType:l.selectedFulfillmentType,previousFulfillmentId:l.selectedFulfillmentId||"",previousFulfillmentType:l.selectedFulfillmentType});const v=l.sizes[l.selectedSizeId||""],b=splitCategoryPath(l.catPath),w=(null==g?void 0:g.price)||(null===(a=l.priceInfo)||void 0===a?void 0:a.avg)||0;this.googleTagManager.viewItem({item_id:null==v?void 0:v.id,item_name:l.name,item_brand:l.brand,item_size:null==v?void 0:v.size,item_category:b.category,item_category2:b.category2,item_category3:b.category3,price:centToDollar(w),item_type:l.type,item_subtype:l.subType,upc:null==v?void 0:v.upc,grouping_id:l.salsifyGrouping,product_id:null==v?void 0:v.id}),this.store.batch({["products."+n+".selectedFulfillment"]:g,["products."+n+".selectedFulfillmentId"]:i,["products."+n+".quantity"]:1})}async updateQuantity(n,i){var r;const s=this.store.get("products."+n),a=s.quantity,l=a+i,d=1,u=(null===(r=null==s?void 0:s.selectedFulfillment)||void 0===r?void 0:r.stock)||5,f=Math.max(d,Math.min(u,l));this.pubSub.publishAction(i<0?x.PRODUCT_QUANTITY_DECREASE:x.PRODUCT_QUANTITY_INCREASE,{identifier:n,quantity:f,previousQuantity:a}),this.store.set("products."+n+".quantity",f)}async changeFulfillmentType(n,i){var r,s,a;const l=this.store.get("products."+n),{shippingFulfillments:d,onDemandFulfillments:u}=l.sizes[l.selectedSizeId],f=i===E.SHIPPING?d:u,g=Object.values(f);if(0===g.length){const n=this.store.get("address"),a=l.sizes[l.selectedSizeId],d=splitCategoryPath(l.catPath);return this.googleTagManager.productFulfillmentNoAvailability({productId:null==a?void 0:a.id,productName:l.name,productBrand:l.brand,productCategory:d.category,productCategory2:d.category2,productCategory3:d.category3,productType:l.type,productSubtype:l.subType,productPrice:(null===(r=l.priceInfo)||void 0===r?void 0:r.avg)||0,sizeId:null!==(s=l.selectedSizeId)&&void 0!==s?s:void 0,sizeName:null==a?void 0:a.size,fulfillmentType:i,upc:null==a?void 0:a.upc,groupingId:l.salsifyGrouping,address:(null==n?void 0:n.address)?{one:n.address.one,two:n.address.two,city:n.address.city,state:n.address.state,zip:n.address.zip,country:n.address.country||""}:void 0,reason:"No "+i+" fulfillments available for selected size"}),void 0}const v=g[0]||null,b=(null==v?void 0:v.fulfillmentId)||null;this.pubSub.publishAction(x.PRODUCT_FULFILLMENT_TYPE_CHANGED,{identifier:n,selectedFulfillmentType:i,selectedFulfillmentId:b,previousFulfillmentType:l.selectedFulfillmentType,previousFulfillmentId:l.selectedFulfillmentId,fulfillmentHasAvailability:g.length>0});const w=l.sizes[l.selectedSizeId||""],C=splitCategoryPath(l.catPath),T=(null==v?void 0:v.price)||(null===(a=l.priceInfo)||void 0===a?void 0:a.avg)||0;this.googleTagManager.viewItem({item_id:null==w?void 0:w.id,item_name:l.name,item_brand:l.brand,item_size:null==w?void 0:w.size,item_category:C.category,item_category2:C.category2,item_category3:C.category3,price:centToDollar(T),item_type:l.type,item_subtype:l.subType,upc:null==w?void 0:w.upc,grouping_id:l.salsifyGrouping,product_id:null==w?void 0:w.id}),this.store.batch({["products."+n+".selectedFulfillmentType"]:i,["products."+n+".selectedFulfillment"]:v,["products."+n+".selectedFulfillmentId"]:b,["products."+n+".fulfillmentHasAvailability"]:g.length>0})}async removeProduct(n){this.store.removeProductInstance(n)}async openProductDrawer(n,i,r){const s={type:i,data:r||{}};this.store.batch({["products."+n+".drawer.isOpen"]:!![],["products."+n+".drawer.contentConfig"]:s})}async closeProductDrawer(n){this.store.set("products."+n+".drawer.isOpen",![])}async rerenderAllProducts(){const n=this.store.getProductInstances(),i=Object.keys(n);for(const r of i)this.store.set("products."+r+".rerender",!![])}async addToCart(n,i){try{this.store.set("products."+n+".updating",!![]),this.uiCommands.openDrawer(C.CART),await this.cartCommands.addItem(i),this.store.batch({["products."+n+".quantity"]:1,["products."+n+".updating"]:![]});const r=this.store.get("cart");this.googleTagManager.viewCart([...Object.values(r.items||{}).map(n=>{const i=splitCategoryPath(n.catPath);return{item_id:n.liquidId,item_name:n.name,item_brand:n.brand,item_size:n.size,item_category:i.category,item_category2:i.category2,item_category3:i.category3,quantity:n.quantity,price:centToDollar(n.unitPrice||0),upc:n.upc,grouping_id:n.salsifyGrouping,product_id:n.liquidId}})])}catch(r){this.logger.error("Error adding to cart",r),this.store.set("products."+n+".updating",![])}}async addPresaleToCart(n,i){try{this.store.set("products."+n+".updating",!![]),await this.cartCommands.addPresaleItem(i),this.clientConfig.isBuilder()||this.uiCommands.openDrawer(C.CHECKOUT),this.store.batch({["products."+n+".quantity"]:1,["products."+n+".updating"]:![]})}catch(r){this.logger.error("Error adding to cart",r),this.store.set("products."+n+".updating",![])}}productDataForEventFromStore(n){const i=this.store.get("products."+n),r={},fulfillmentEventData=n=>{const i={};for(const r in n){const s=n[r];i[r]={retailerId:s.retailerId,retailerName:s.retailerName,retailerAddress:s.retailerAddress,retailerTimezone:s.timezone,price:s.price,partNumber:s.partNumber,stock:s.stock,isEngravable:s.isVariantEngravable,fulfillmentId:s.fulfillmentId,fulfillmentType:s.fulfillmentType,modalities:s.modalities||[]}}return i};for(const s in i.sizes||{}){const n=i.sizes[s];r[s]={id:n.id,upc:n.upc,size:n.size,pack:n.pack,packDesc:n.packDesc||"",container:n.container,containerType:n.containerType,maxQuantityPerOrder:n.attributes.maxQuantityPerOrder||0,image:n.image,uom:n.uom,volume:n.volume,attributes:{engraving:n.attributes.engraving||void 0,presale:n.attributes.presale||void 0},shippingFulfillments:fulfillmentEventData(n.shippingFulfillments||{}),onDemandFulfillments:fulfillmentEventData(n.onDemandFulfillments||{})}}return{identifier:n,selectedSizeId:i.selectedSizeId||null,selectedFulfillmentId:i.selectedFulfillmentId||null,selectedFulfillmentType:i.selectedFulfillmentType,id:i.id,name:i.name,brand:i.brand,catPath:i.catPath,category:i.category,classification:i.classification,type:i.type,salsifyGrouping:i.salsifyGrouping,subType:i.subType,mainImage:i.mainImage||null,images:i.images||[],region:i.region,country:i.country,material:i.material,abv:i.abv,proof:i.proof,age:i.age,color:i.color,flavor:i.flavor,variety:i.variety,appellation:i.appellation,vintage:i.vintage,description:i.description,htmlDescription:i.htmlDescription,tastingNotes:i.tastingNotes,priceInfo:i.priceInfo||null,sizes:r}}findFirstAvailableSize(n){const i=Object.values(n);for(const r of i){const n=r.shippingFulfillments||{},i=r.onDemandFulfillments||{},s=Object.values(n).length,a=Object.values(i).length;if(s+a>0)return r.id}return null}loadProductStoreUpdate(n){var i,r,s,a,l,d,u,f,g,v,b;try{const{products:[x,...w],retailers:C}=n,T=this.themeProvider.getConfigs("product"),A={};let P=![],_=![],N="",F=null,R=T.layout.enableShippingFulfillment?E.SHIPPING:E.ON_DEMAND,O=null,L=null;const M={};if(C&&Array.isArray(C)&&C.length>0)for(const n of C)for(const i of n.fulfillments){const r={retailerName:n.name,retailerAddress:n.address||null,type:i.type,timezone:i.timezone||"",canEngrave:i.canEngrave||![],expectation:i.expectation,fees:i.fees,hours:i.hours,retailerId:n.id,fulfillmentId:i.id,fulfillmentType:i.type,isVariantEngravable:![],stock:0,price:0,partNumber:"",modalities:[]},s=getRetailerOffHours(r);s.isClosed&&!T.layout.showOffHours||(M[i.id]=r)}if(x.sizes&&Array.isArray(x.sizes)&&x.sizes.length>0)for(const n of x.sizes){const l={},d={};for(const u of n.variants){if((null===(i=null==u?void 0:u.fulfillmentTypes)||void 0===i?void 0:i.onDemand)&&""!==u.fulfillmentTypes.onDemand){const n=u.fulfillmentTypes.onDemand,i=M[n];i?d[n]={...i,isVariantEngravable:u.isEngravable,stock:u.stock,price:u.price,retailerId:u.retailerId,fulfillmentId:n,fulfillmentType:E.ON_DEMAND,modalities:[...i.modalities,...null!==(r=null==u?void 0:u.modalities)&&void 0!==r?r:[]],partNumber:u.partNumber}:this.logger.warn("No retailer info found for onDemand fulfillmentId "+n)}if((null===(s=null==u?void 0:u.fulfillmentTypes)||void 0===s?void 0:s.shipping)&&""!==u.fulfillmentTypes.shipping){const n=u.fulfillmentTypes.shipping,i=M[n];i?l[n]={...i,isVariantEngravable:u.isEngravable,stock:u.stock,price:u.price,retailerId:u.retailerId,fulfillmentId:n,fulfillmentType:E.SHIPPING,modalities:[...i.modalities,...null!==(a=null==u?void 0:u.modalities)&&void 0!==a?a:[]],partNumber:u.partNumber}:this.logger.warn("No retailer info found for shipping fulfillmentId "+n)}}A[n.id]={id:n.id,upc:n.upc,size:n.size,pack:n.pack,packDesc:n.packDesc,container:n.container,containerType:n.containerType,maxQuantityPerOrder:n.attributes.maxQuantityPerOrder||0,image:n.image,uom:n.uom,volume:n.volume,attributes:n.attributes,loading:![],error:null,shippingFulfillments:l,onDemandFulfillments:d}}const B=Object.values(A),W=this.findFirstAvailableSize(A);N=W||B[0]&&B[0].id||"",F=(null===(l=A[N])||void 0===l?void 0:l.image)||null;const H=(null===(d=A[N])||void 0===d?void 0:d.shippingFulfillments)||{},q=(null===(u=A[N])||void 0===u?void 0:u.onDemandFulfillments)||{},j=Object.values(H).length,U=Object.values(q).length;P=j+U>0;const V=R===E.SHIPPING?Object.values(H):Object.values(q);if(_=V.length>0,L=V[0]||null,O=(null==L?void 0:L.fulfillmentId)||null,!_){const n=R===E.SHIPPING?E.ON_DEMAND:E.SHIPPING,i=n===E.SHIPPING?Object.values(H):Object.values(q);i.length>0&&(R=n,L=i[0],O=(null==L?void 0:L.fulfillmentId)||null,_=!![])}if(!P){const n=this.store.get("address"),i=splitCategoryPath(x.catPath),r=A[N];this.googleTagManager.productNoAvailability({productId:null==r?void 0:r.id,productName:x.name,productBrand:x.brand,productCategory:i.category,productCategory2:i.category2,productCategory3:i.category3,productType:x.type,productSubtype:x.subType,productPrice:(null===(f=x.priceInfo)||void 0===f?void 0:f.average)||0,upc:null==r?void 0:r.upc,groupingId:x.salsifyGrouping,address:(null==n?void 0:n.address)?{one:n.address.one,two:n.address.two,city:n.address.city,state:n.address.state,zip:n.address.zip,country:n.address.country||""}:void 0,reason:"No fulfillments available for any size"})}return{identifier:"",id:x.id||"",name:x.name,description:x.description,htmlDescription:x.htmlDescription,images:x.images,priceInfo:{min:(null===(g=x.priceInfo)||void 0===g?void 0:g.minimum)||0,max:(null===(v=x.priceInfo)||void 0===v?void 0:v.maximum)||0,avg:(null===(b=x.priceInfo)||void 0===b?void 0:b.average)||0},brand:x.brand,region:x.region||"",country:x.country||"",material:x.material||"",abv:x.abv||"",proof:x.proof||"",age:x.age||"",color:x.color||"",flavor:x.flavor||"",variety:x.variety||"",appellation:x.appellation||"",vintage:x.vintage||"",tastingNotes:x.tastingNotes||"",catPath:x.catPath,category:x.category,classification:x.classification,type:x.type,subType:x.subType,salsifyGrouping:x.salsifyGrouping,sizes:A,productHasAvailability:P,fulfillmentHasAvailability:_,selectedSizeId:N,mainImage:F,selectedFulfillmentType:R,selectedFulfillmentId:O,selectedFulfillment:L,drawer:{isOpen:![],contentConfig:null},error:null,loading:![],updating:![],quantity:1,rerender:![]}}catch(x){throw this.logger.error("Product data processing error",x),x}}}class AddressCommands extends BaseCommand{constructor(){super(),this.productCommands=ProductCommands.getInstance(),this.cartCommands=CartCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("AddressCommands",()=>new AddressCommands)}async searchAddresses(n){return!n||n.length<3?[]:await this.api.getAddressSuggestions(n)}async getAddressDetails(n){return await this.api.getAddressDetails(n)}async setSelectedAddress(n){try{this.store.batch({"address.id":n.id,"address.formattedAddress":n.formattedAddress,"address.address":n.address,"address.coordinates":n.coordinates});const i=this.store.get("products");await this.productCommands.loadMultipleProducts(Object.keys(i)),await this.cartCommands.resetCart(),await this.store.persist()}catch(i){throw this.googleTagManager.addressFailed({googlePlacesId:n.id,formattedAddress:n.formattedAddress,address:{one:n.address.one,two:n.address.two,city:n.address.city,state:n.address.state,zip:n.address.zip,country:n.address.country||""},error:(null==i?void 0:i.message)||"Failed to update downstream state after address change"}),this.pubSub.publishAction(x.ADDRESS_FAILED,{googlePlacesId:n.id,formattedAddress:n.formattedAddress,address:n.address,coordinates:n.coordinates,error:(null==i?void 0:i.message)||"Failed to update downstream state after address change"}),i}this.googleTagManager.addressUpdated({googlePlacesId:n.id,formattedAddress:n.formattedAddress,address:{one:n.address.one,two:n.address.two,city:n.address.city,state:n.address.state,zip:n.address.zip,country:n.address.country||""},coordinates:n.coordinates}),this.pubSub.publishAction(x.ADDRESS_UPDATED,{googlePlacesId:n.id,address:{one:n.address.one,two:n.address.two,city:n.address.city,state:n.address.state,zip:n.address.zip,country:n.address.country||""},coordinates:n.coordinates,formattedAddress:n.formattedAddress})}async setAddressManually(n,i){try{const r=buildFormattedAddressString(n),s={id:"",formattedAddress:r,address:n,coordinates:i};await this.setSelectedAddress(s)}catch(r){throw this.googleTagManager.addressFailed({googlePlacesId:"",formattedAddress:buildFormattedAddressString(n),address:{one:n.one,two:n.two,city:n.city,state:n.state,zip:n.zip,country:n.country||""},error:(null==r?void 0:r.message)||"Failed to set manual address"}),this.pubSub.publishAction(x.ADDRESS_FAILED,{googlePlacesId:"",formattedAddress:buildFormattedAddressString(n),address:n,coordinates:i,error:(null==r?void 0:r.message)||"Failed to set manual address"}),r}}async clearSelectedAddress(){this.store.set("address",B),this.pubSub.publishAction(x.ADDRESS_CLEARED,!![]),await this.cartCommands.resetCart();const n=this.clientConfig.get("userDeviceId");await this.api.deletePersistedStore(n),this.store.clearLocalStorage()}getDetails(){const n=this.store.get("address");return n.id?{id:n.id,formattedAddress:n.formattedAddress,address:n.address,coordinates:n.coordinates}:null}}class ProductListCommands extends BaseCommand{constructor(){super(),this.uiCommands=UICommands.getInstance(),this.cartCommands=CartCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("ProductListCommands",()=>new ProductListCommands)}async getProductList(n){var i,r;const s=n,a=this.clientConfig.getConfigs();s.entity=null!==(r=null!==(i=window.location.hostname)&&void 0!==i?i:a.partnerName)&&void 0!==r?r:void 0,s.visitorId=a.userDeviceId,s.loc=this.getLocation(),s.isLegacy=!![];const l=await this.api.catalogSearch(s);return l.products&&l.products.length>0&&this.trackViewItemList(l.products),l}async addToCart(n){try{this.uiCommands.openDrawer(C.CART),await this.cartCommands.addItem(n)}catch(i){throw this.logger.error("Error adding product to cart from product list",i),i}}async addPresaleToCart(n){try{await this.cartCommands.addPresaleItem(n),this.clientConfig.isBuilder()||this.uiCommands.openDrawer(C.CHECKOUT)}catch(i){throw this.logger.error("Error adding presale product to cart from product list",i),i}}trackViewItemList(n){if(0!==n.length)try{const i=n.map((n,i)=>({...this.convertProductToBaseItem(n),index:i+1}));this.googleTagManager.viewItemList(i,"product_list","Product List")}catch(i){this.logger.error("Error tracking view_item_list event",i)}}trackSelectItem(n){try{const i=this.convertProductToBaseItem(n);this.googleTagManager.selectItem(i,"product_list","Product List")}catch(i){this.logger.error("Error tracking select_item event",i)}}convertProductToBaseItem(n){var i,r,s;const a=null===(i=n.sizes)||void 0===i?void 0:i[0],l=null===(r=null==a?void 0:a.variants)||void 0===r?void 0:r[0],d=splitCategoryPath(n.catPath);return{item_id:null==a?void 0:a.id,item_name:n.name,item_brand:n.brand,item_size:null==a?void 0:a.size,item_category:d.category,item_category2:d.category2,item_category3:d.category3,price:(null==l?void 0:l.price)?centToDollar(l.price):(null===(s=n.priceInfo)||void 0===s?void 0:s.average)?centToDollar(n.priceInfo.average):void 0,item_type:n.type,item_subtype:n.subType,upc:null==a?void 0:a.upc,grouping_id:n.salsifyGrouping,product_id:null==a?void 0:a.id,item_list_id:"product_list",item_list_name:"Product List"}}}class CommandService{constructor(){this.ui=UICommands.getInstance(),this.address=AddressCommands.getInstance(),this.product=ProductCommands.getInstance(),this.productList=ProductListCommands.getInstance(),this.cart=CartCommands.getInstance(),this.checkout=CheckoutCommands.getInstance(),this.common=CommonCommands.getInstance()}static getInstance(){return SingletonManager.getClassInstance("CommandService",()=>new CommandService)}}class ClientActionService{constructor(){this.pendingCartParams=null,this.pendingCartOpenFlag=![],this.productActions={getDetails:n=>this.command.product.productDataForEventFromStore(n)},this.addressActions={setAddressByPlacesId:async n=>{try{if(!n||""===n.trim())throw new SDKError("Valid Google Places ID is required. Received empty or invalid value.",!![]);const i=await this.command.address.getAddressDetails(n);await this.command.address.setSelectedAddress({id:n,address:i.address,coordinates:i.coords,formattedAddress:i.formattedAddress})}catch(i){throw this.logger.error("Error setting address by placesId:",i),i}},setAddressManually:async(n,i)=>{try{if(!n||!i)throw new SDKError("Both address and coordinates are required.",!![]);if(!(n.one&&n.city&&n.state&&n.zip))throw new SDKError("Address must include street, city, state, and zip code.",!![]);if("number"!=typeof i.lat||"number"!=typeof i.long)throw new SDKError("Coordinates must have numeric latitude and longitude. Received lat: "+typeof i.lat+", long: "+typeof i.long,!![]);if(i.lat<-90||i.lat>90)throw new SDKError("Latitude must be between -90 and 90. Received: "+i.lat,!![]);if(i.long<-180||i.long>180)throw new SDKError("Longitude must be between -180 and 180. Received: "+i.long,!![]);await this.command.address.setAddressManually(n,i)}catch(r){throw this.logger.error("Error setting manual address:",r),r}},clear:async()=>{await this.command.address.clearSelectedAddress()},getDetails:()=>this.command.address.getDetails()},this.cartActions={openCart:()=>{this.command.ui.openDrawer(C.CART)},closeCart:()=>{this.command.ui.closeDrawer()},toggleCart:()=>{const n=this.store.get("ui.drawer.isOpen");n?this.command.ui.closeDrawer():this.command.ui.openDrawer(C.CART)},addProduct:async(n,i)=>{var r,s;try{if(!n||0===n.length)return this.logger.warn("No products provided to add to cart"),void 0;const a=this.getLocation();if(void 0===a)return this.pendingCartParams=n,this.pendingCartOpenFlag=null!=i?i:![],this.logger.info("Location not available, opening address drawer before adding to cart"),this.command.ui.openDrawer(C.ADDRESS_INPUT,{isIndependentComponent:!![]}),void 0;i===!![]&&this.command.ui.openDrawer(C.CART);const l=[...new Set(n.map(n=>n.identifier))],d=await this.api.getProductsData(l,a);if(!d||!d.products||0===d.products.length)return this.logger.warn("No product data found for the provided identifiers"),this.pubSub.publishAction(x.CART_PRODUCT_ADD_FAILED,{identifiers:[],error:"No products provided"}),void 0;for(const i of n){let n=null;for(let r=0;r<d.products.length;r++){const s=d.products[r];let a=![];for(let n=0;n<s.sizes.length;n++){const r=s.sizes[n];if(r.upc===i.identifier||r.id===i.identifier||s.salsifyGrouping===i.identifier){a=!![];break}}if(a){n=s;break}}if(!n){this.logger.warn("No product found for identifier: "+i.identifier);continue}const a=n.sizes[0];if(!a){this.logger.warn("No sizes found for product: "+i.identifier);continue}if((null===(s=null===(r=null==a?void 0:a.attributes)||void 0===r?void 0:r.presale)||void 0===s?void 0:s.isActive)===!![]){this.logger.warn("Product is a presale item and cannot be added to cart: "+i.identifier),this.store.set("cart.error","Presale products cannot be added to cart");continue}let l=null;for(let r=0;r<a.variants.length;r++){const n=a.variants[r];let s=![];if(i.fulfillmentType===E.ON_DEMAND&&(s=!(!n.fulfillmentTypes||!n.fulfillmentTypes.onDemand||""===n.fulfillmentTypes.onDemand)),i.fulfillmentType===E.SHIPPING&&(s=!(!n.fulfillmentTypes||!n.fulfillmentTypes.shipping||""===n.fulfillmentTypes.shipping)),s){l=n;break}}if(!l){this.logger.warn("No supported variant found for product: "+i.identifier+" with fulfillment type: "+i.fulfillmentType),this.store.set("cart.error","Product has no availability");continue}const u=i.fulfillmentType===E.ON_DEMAND?l.fulfillmentTypes.onDemand:l.fulfillmentTypes.shipping;await this.command.cart.addItem({upc:a.upc,fulfillmentId:u,partNumber:l.partNumber,quantity:i.quantity,identifier:i.identifier})}this.clearPendingCartOperation(),this.pubSub.publishAction(x.CART_PRODUCT_ADD_SUCCESS,{itemsAdded:n.length,identifiers:l}),this.logger.info("Products added to cart successfully:",l)}catch(a){throw this.logger.error("Error adding products to cart:",a),this.clearPendingCartOperation(),this.pubSub.publishAction(x.CART_PRODUCT_ADD_FAILED,{identifiers:n.map(n=>n.identifier),error:a.message||"Failed to add products to cart"}),a}},applyPromoCode:async n=>{try{if(!n||""===n.trim())return this.logger.warn("Invalid promo code provided"),this.store.set("cart.error","Invalid promo code provided"),void 0;const i=n.trim().toUpperCase(),r=this.themeProvider.getConfigs("global"),s=r.layout.allowPromoCodes;if(!s)return this.logger.warn("Promo codes are not allowed"),this.store.set("cart.error","Promo codes are not allowed"),void 0;const a=this.store.get("cart.promoCode");if(a&&a.code===i)return this.logger.info("Promo code is already applied"),void 0;await this.command.cart.applyPromoCode(i);const l=this.command.cart.getDetails();this.pubSub.publishAction(x.CART_PROMO_CODE_APPLIED,{discountAmount:l.amounts.discounts,newTotal:l.amounts.total}),this.logger.info("Promo code applied successfully")}catch(i){throw this.logger.error("Failed to apply promo code:",i),this.pubSub.publishAction(x.CART_PROMO_CODE_FAILED,{error:"Promo code could not be applied"}),i}},removePromoCode:async()=>{try{const n=this.themeProvider.getConfigs("global"),i=n.layout.allowPromoCodes;if(!i)return this.logger.warn("Promo codes are not allowed"),this.store.set("cart.error","Promo codes are not allowed"),void 0;await this.command.cart.removePromoCode();const r=this.command.cart.getDetails();this.pubSub.publishAction(x.CART_PROMO_CODE_REMOVED,{newTotal:r.amounts.total}),this.logger.info("Promo code removed successfully")}catch(n){throw this.logger.error("Failed to remove promo code:",n),n}},resetCart:async()=>{await this.command.cart.resetCart(),this.pubSub.publishAction(x.CART_RESET,!![])},getDetails:()=>this.command.cart.getDetails()},this.checkoutActions={openCheckout:()=>{this.command.ui.openDrawer(C.CHECKOUT)},closeCheckout:()=>{this.command.ui.closeDrawer()},toggleCheckout:()=>{const n=this.store.get("ui.drawer.isOpen");n?this.command.ui.closeDrawer():this.command.ui.openDrawer(C.CHECKOUT)},addProduct:async(n,i)=>{try{if(!n||0===n.length)return this.logger.warn("No products provided to add to checkout"),void 0;i===!![]&&this.command.ui.openDrawer(C.CHECKOUT);const r=n.map(n=>n.identifier);await this.cartActions.addProduct(n),await this.command.checkout.loadCheckout(),this.pubSub.publishAction(x.CHECKOUT_PRODUCT_ADD_SUCCESS,{itemsAdded:n.length,identifiers:r}),this.logger.info("Products added to checkout successfully:",r)}catch(r){throw this.logger.error("Error adding products to checkout:",r),this.pubSub.publishAction(x.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:n.map(n=>n.identifier),error:r.message||"Failed to add products to checkout"}),r}},addPresaleProduct:async n=>{var i,r;try{if(!n||"object"!=typeof n||!n.identifier)return this.logger.warn("No presale product provided to add to checkout"),void 0;const s=this.getLocation();if(void 0===s)return this.logger.info("Location not available, opening address drawer before adding presale product to checkout"),this.command.ui.openDrawer(C.ADDRESS_INPUT,{isIndependentComponent:!![]}),void 0;const a=await this.api.getProductsData([n.identifier],s);if(!a||!a.products||0===a.products.length)return this.logger.warn("No product data found for the provided presale identifier"),this.pubSub.publishAction(x.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[n.identifier],error:"No product found",isPresale:!![]}),void 0;const l=a.products[0],d=l.sizes[0];if(!d)return this.logger.warn("No sizes found for presale product: "+n.identifier),this.pubSub.publishAction(x.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[n.identifier],error:"No sizes found for product",isPresale:!![]}),void 0;if((null===(r=null===(i=null==d?void 0:d.attributes)||void 0===i?void 0:i.presale)||void 0===r?void 0:r.isActive)!==!![])return this.logger.warn("Product is not a presale item: "+n.identifier),this.store.set("checkout.error","Product is not available for presale"),this.pubSub.publishAction(x.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[n.identifier],error:"Product is not available for presale",isPresale:!![]}),void 0;let u=null;for(let i=0;i<d.variants.length;i++){const r=d.variants[i];let s=![];if(n.fulfillmentType===E.ON_DEMAND&&(s=!(!r.fulfillmentTypes||!r.fulfillmentTypes.onDemand||""===r.fulfillmentTypes.onDemand)),n.fulfillmentType===E.SHIPPING&&(s=!(!r.fulfillmentTypes||!r.fulfillmentTypes.shipping||""===r.fulfillmentTypes.shipping)),s){u=r;break}}if(!u)return this.logger.warn("No supported variant found for presale product: "+n.identifier+" with fulfillment type: "+n.fulfillmentType),this.store.set("checkout.error","Presale product has no availability"),this.pubSub.publishAction(x.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[n.identifier],error:"Presale product has no availability",isPresale:!![]}),void 0;const f=n.fulfillmentType===E.ON_DEMAND?u.fulfillmentTypes.onDemand:u.fulfillmentTypes.shipping;await this.command.cart.addPresaleItem({upc:d.upc,fulfillmentId:f,partNumber:u.partNumber,quantity:n.quantity,engravingLines:[],identifier:n.identifier}),this.command.ui.openDrawer(C.CHECKOUT),this.pubSub.publishAction(x.CHECKOUT_PRODUCT_ADD_SUCCESS,{itemsAdded:1,identifiers:[n.identifier],isPresale:!![]}),this.logger.info("Presale product added to checkout successfully: "+n.identifier)}catch(s){throw this.logger.error("Error adding presale product to checkout:",s),this.pubSub.publishAction(x.CHECKOUT_PRODUCT_ADD_FAILED,{identifiers:[n.identifier],error:s.message||"Failed to add presale product to checkout",isPresale:!![]}),s}},applyPromoCode:async n=>{var i;try{if(!n||""===n.trim())return this.logger.warn("Invalid promo code provided"),this.store.set("checkout.error","Invalid promo code provided"),void 0;const r=n.trim().toUpperCase(),s=this.themeProvider.getConfigs("global"),a=s.layout.allowPromoCodes;if(!a)return this.logger.warn("Promo codes are not allowed"),this.store.set("checkout.error","Promo codes are not allowed"),void 0;const l=this.store.get("checkout.promoCode");if(l&&l.code===r)return this.logger.info("Promo code is already applied"),void 0;await this.command.checkout.applyPromoCode(n);const d=this.store.get("checkout"),u=null==d?void 0:d.promoCode;this.pubSub.publishAction(x.CHECKOUT_PROMO_CODE_APPLIED,{discountAmount:(null==u?void 0:u.discountAmount)||0,newTotal:(null===(i=null==d?void 0:d.amounts)||void 0===i?void 0:i.total)||0}),this.logger.info("Checkout promo code applied successfully")}catch(r){throw this.logger.error("Failed to apply checkout promo code:",r),this.pubSub.publishAction(x.CHECKOUT_PROMO_CODE_FAILED,{error:"Promo code could not be applied"}),r}},removePromoCode:async()=>{var n;try{const i=this.themeProvider.getConfigs("global"),r=i.layout.allowPromoCodes;if(!r)return this.logger.warn("Promo codes are not allowed"),this.store.set("checkout.error","Promo codes are not allowed"),void 0;await this.command.checkout.removePromoCode();const s=this.store.get("checkout");this.pubSub.publishAction(x.CHECKOUT_PROMO_CODE_REMOVED,{newTotal:(null===(n=null==s?void 0:s.amounts)||void 0===n?void 0:n.total)||0}),this.logger.info("Checkout promo code removed successfully")}catch(i){throw this.logger.error("Failed to remove checkout promo code:",i),i}},applyGiftCard:async n=>{var i;try{const r=this.themeProvider.getConfigs("checkout"),s=r.layout.allowGiftCards;if(!s)return this.logger.warn("Gift cards are not allowed"),this.store.set("checkout.error","Gift cards are not allowed"),void 0;await this.command.checkout.applyGiftCard(n);const a=this.store.get("checkout");this.pubSub.publishAction(x.CHECKOUT_GIFT_CARD_APPLIED,{newTotal:(null===(i=null==a?void 0:a.amounts)||void 0===i?void 0:i.total)||0}),this.logger.info("Gift card applied successfully")}catch(r){throw this.logger.error("Failed to apply gift card:",r),this.pubSub.publishAction(x.CHECKOUT_GIFT_CARD_FAILED,{error:"Gift card could not be applied"}),r}},removeGiftCard:async n=>{var i;try{const r=this.themeProvider.getConfigs("checkout"),s=r.layout.allowGiftCards;if(!s)return this.logger.warn("Gift cards are not allowed"),this.store.set("checkout.error","Gift cards are not allowed"),void 0;await this.command.checkout.removeGiftCard(n);const a=this.store.get("checkout");this.pubSub.publishAction(x.CHECKOUT_GIFT_CARD_REMOVED,{newTotal:(null===(i=null==a?void 0:a.amounts)||void 0===i?void 0:i.total)||0}),this.logger.info("Gift card removed successfully")}catch(r){throw this.logger.error("Failed to remove gift card:",r),this.pubSub.publishAction(x.CHECKOUT_GIFT_CARD_FAILED,{error:"Gift card could not be removed"}),r}},toggleIsGift:async n=>{await this.command.checkout.toggleIsGift(n)},toggleBillingSameAsShipping:async n=>{await this.command.checkout.toggleBillingSameAsShipping(n)},toggleMarketingPreferences:(n,i)=>{this.command.checkout.toggleMarketingPreferences(n,i)},getDetails:()=>{var n,i,r;const s=this.store.get("checkout"),a=s.items||{},l={};for(const[d,u]of Object.entries(a))l[d]={liquidId:u.liquidId,variantId:u.variantId,cartItemId:d,retailerId:u.retailerId,fulfillmentId:u.fulfillmentId,salsifyGrouping:u.salsifyGrouping,name:u.name,catPath:u.catPath,volume:u.volume,uom:u.uom,proof:u.proof,abv:u.abv,containerType:u.containerType,container:u.container,size:u.size,pack:u.pack,packDesc:u.packDesc,mainImage:u.mainImage,brand:u.brand,partNumber:u.partNumber,upc:u.upc,sku:u.sku,price:u.price,unitPrice:u.unitPrice,quantity:u.quantity,unitTax:u.unitTax,bottleDeposits:u.bottleDeposits,attributes:u.attributes,retailerName:u.retailerName,expectationDetail:u.expectationDetail};return{cartId:s.cartId||"",isGift:s.isGift||![],billingSameAsShipping:s.paymentForm.billingSameAsShipping,marketingPreferences:{canEmail:(null===(n=s.marketingPreferences)||void 0===n?void 0:n.canEmail)||![],canSms:(null===(i=s.marketingPreferences)||void 0===i?void 0:i.canSms)||![]},hasPromoCode:!!(null===(r=s.promoCode)||void 0===r?void 0:r.code),hasGiftCards:Array.isArray(s.giftCards)&&s.giftCards.length>0,itemCount:Object.values(l||{}).reduce((n,i)=>n+(i.quantity||0),0),amounts:s.amounts,items:l}}},this.actions={product:this.productActions,address:this.addressActions,cart:this.cartActions,checkout:this.checkoutActions},this.store=StoreService.getInstance(),this.command=CommandService.getInstance(),this.api=ApiClientService.getInstance(),this.pubSub=PubSubService.getInstance(),this.themeProvider=ThemeProviderService.getInstance(),this.logger=LoggerFactory.get("ClientAction"),this.setupAddressUpdateListener()}static getInstance(){return SingletonManager.getClassInstance("ClientActionService",()=>new ClientActionService)}setupAddressUpdateListener(){const m=async()=>{this.pendingCartParams&&(this.logger.info("Address updated, retrying pending cart operation"),await this.retryPendingCartOperation())};window.addEventListener("lce:actions."+x.ADDRESS_UPDATED,m)}async retryPendingCartOperation(){if(this.pendingCartParams)try{const n=this.pendingCartParams,i=this.pendingCartOpenFlag;this.clearPendingCartOperation(),await this.cartActions.addProduct(n,i)}catch(n){this.logger.error("Failed to retry cart operation after address update",n)}}clearPendingCartOperation(){this.pendingCartParams=null,this.pendingCartOpenFlag=![]}getLocation(){const n=this.store.get("address");if(n.address.one&&n.coordinates.long&&n.coordinates.lat)return{coords:n.coordinates,address:n.address}}}const It="\n :host {\n position: fixed;\n z-index: 2147483647;\n display: block;\n }\n\n .panel {\n position: relative;\n background: rgba(15, 23, 42, 0.95);\n backdrop-filter: blur(10px);\n border: 1px solid rgba(148, 163, 184, 0.2);\n border-radius: 12px;\n box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);\n font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace;\n font-size: 12px;\n color: #e2e8f0;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n user-select: none;\n transition: all 0.2s ease;\n width: 100%;\n height: 100%;\n }\n\n .panel:hover {\n border-color: rgba(148, 163, 184, 0.4);\n box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.4);\n }\n\n .header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n padding: 12px 16px;\n border-bottom: 1px solid rgba(148, 163, 184, 0.2);\n background: rgba(30, 41, 59, 0.5);\n cursor: move;\n }\n\n .icon {\n font-size: 14px;\n display: flex;\n align-items: center;\n justify-content: center;\n min-width: 20px;\n }\n\n .title-container {\n display: flex;\n flex-direction: column;\n flex: 1;\n margin: 0 12px;\n }\n \n .title-container > *:not(:first-child) {\n margin-top: 2px;\n }\n\n .title {\n font-weight: 600;\n color: #f1f5f9;\n font-size: 13px;\n }\n\n\n .subtitle {\n font-size: 10px;\n color: #94a3b8;\n }\n\n .minimize {\n background: none;\n border: none;\n color: #94a3b8;\n font-size: 18px;\n cursor: pointer;\n padding: 4px;\n border-radius: 4px;\n transition: all 0.2s ease;\n line-height: 1;\n font-weight: bold;\n }\n\n .minimize:hover {\n background: rgba(148, 163, 184, 0.1);\n color: #cbd5e1;\n }\n\n .toggles {\n display: flex;\n padding: 8px 16px;\n border-bottom: 1px solid rgba(148, 163, 184, 0.2);\n background: rgba(30, 41, 59, 0.3);\n align-items: center;\n }\n\n .toggles > *:not(:last-child) {\n margin-right: 12px;\n }\n\n .toggle {\n display: flex;\n align-items: center;\n cursor: pointer;\n font-size: 11px;\n color: #cbd5e1;\n transition: color 0.2s ease;\n }\n \n .toggle > *:not(:last-child) {\n margin-right: 6px;\n }\n\n .toggle:hover {\n color: #f1f5f9;\n }\n\n .toggle input[type=\"checkbox\"] {\n width: 12px;\n height: 12px;\n accent-color: #3b82f6;\n cursor: pointer;\n }\n\n .clear-btn {\n background: none;\n border: none;\n color: #ef4444;\n font-size: 14px;\n padding: 0;\n cursor: pointer;\n transition: all 0.2s ease;\n margin-left: auto;\n min-width: 20px;\n height: 20px;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n .clear-btn:hover {\n transform: scale(1.1);\n color: #dc2626;\n }\n\n .logs {\n flex: 1;\n overflow-y: auto;\n overflow-x: hidden;\n padding: 8px;\n background: rgba(15, 23, 42, 0.8);\n min-height: 0;\n max-height: 100%;\n }\n\n .log-entry {\n display: flex;\n align-items: flex-start;\n padding: 8px 12px;\n margin-bottom: 2px;\n border-radius: 6px;\n font-size: 11px;\n line-height: 1.4;\n transition: background-color 0.2s ease;\n user-select: text;\n }\n \n .log-entry > *:not(:last-child) {\n margin-right: 8px;\n }\n\n .log-entry:hover {\n background-color: rgba(148, 163, 184, 0.1);\n }\n\n /* Event type background colors */\n .log-entry.event {\n background: rgba(59, 130, 246, 0.1);\n }\n\n .log-entry.action {\n background: rgba(16, 185, 129, 0.1);\n }\n\n .log-entry.gtm {\n background: rgba(245, 158, 11, 0.1);\n }\n\n .log-entry.logger {\n background: rgba(139, 92, 246, 0.1);\n }\n\n\n .log-meta {\n display: flex;\n flex-direction: column;\n align-items: flex-start;\n min-width: 50px;\n }\n \n .log-meta > *:not(:first-child) {\n margin-top: 2px;\n }\n\n .log-type {\n font-weight: 600;\n font-size: 9px;\n padding: 2px 0;\n border-radius: 3px;\n white-space: nowrap;\n text-align: center;\n line-height: 1;\n font-weight: bold;\n letter-spacing: 0.5px;\n }\n\n .log-timestamp {\n color: #64748b;\n font-size: 9px;\n white-space: nowrap;\n line-height: 1;\n }\n\n .log-type.event {\n background: rgba(59, 130, 246, 0.2);\n color: #60a5fa;\n }\n\n .log-type.action {\n color: #34d399;\n }\n\n .log-type.gtm {\n color: #fbbf24;\n }\n\n .log-type.logger {\n color: #a78bfa;\n }\n\n .log-message {\n flex: 1;\n word-break: break-word;\n user-select: text;\n }\n\n .log-context {\n color: #94a3b8;\n font-size: 10px;\n margin-top: 2px;\n font-style: italic;\n }\n\n .log-data {\n background: rgba(30, 41, 59, 0.6);\n border: 1px solid rgba(148, 163, 184, 0.2);\n border-radius: 4px;\n padding: 8px;\n margin-top: 6px;\n font-size: 10px;\n color: #cbd5e1;\n max-height: 120px;\n overflow-y: auto;\n font-family: 'SF Mono', 'Monaco', 'Inconsolata', 'Roboto Mono', monospace;\n user-select: text;\n }\n\n .log-data pre {\n margin: 0;\n white-space: pre-wrap;\n word-break: break-word;\n }\n\n .resize-handle {\n position: absolute;\n bottom: 0;\n right: 0;\n width: 12px;\n height: 12px;\n background: linear-gradient(-45deg, transparent 30%, rgba(148, 163, 184, 0.3) 30%, rgba(148, 163, 184, 0.3) 70%, transparent 70%);\n cursor: nw-resize;\n border-radius: 0 0 12px 0;\n }\n\n .resize-handle:hover {\n background: linear-gradient(-45deg, transparent 30%, rgba(148, 163, 184, 0.7) 30%, rgba(148, 163, 184, 0.7) 70%, transparent 70%);\n transform: scale(1.1);\n }\n\n .resize-handle:active {\n background: linear-gradient(-45deg, transparent 30%, rgba(148, 163, 184, 0.9) 30%, rgba(148, 163, 184, 0.9) 70%, transparent 70%);\n }\n\n /* Scrollbar styling */\n .logs::-webkit-scrollbar {\n width: 6px;\n }\n\n .logs::-webkit-scrollbar-track {\n background: rgba(30, 41, 59, 0.3);\n border-radius: 3px;\n }\n\n .logs::-webkit-scrollbar-thumb {\n background: rgba(148, 163, 184, 0.3);\n border-radius: 3px;\n }\n\n .logs::-webkit-scrollbar-thumb:hover {\n background: rgba(148, 163, 184, 0.5);\n }\n\n .log-data::-webkit-scrollbar {\n width: 4px;\n }\n\n .log-data::-webkit-scrollbar-track {\n background: rgba(30, 41, 59, 0.3);\n border-radius: 2px;\n }\n\n .log-data::-webkit-scrollbar-thumb {\n background: rgba(148, 163, 184, 0.3);\n border-radius: 2px;\n }\n\n .log-data::-webkit-scrollbar-thumb:hover {\n background: rgba(148, 163, 184, 0.5);\n }\n\n /* Floating button styles */\n .floating-btn {\n position: absolute;\n top: 20px;\n left: 20px;\n width: 40px;\n height: 40px;\n background: rgba(15, 23, 42, 0.95);\n border: 1px solid rgba(148, 163, 184, 0.2);\n border-radius: 50%;\n display: none;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n font-size: 18px;\n user-select: none;\n z-index: 1;\n }\n\n .floating-btn:hover {\n background: rgba(30, 41, 59, 0.95);\n border-color: rgba(148, 163, 184, 0.4);\n }\n\n /* Mobile Responsiveness */\n @media (max-width: 768px) {\n .panel {\n font-size: 11px;\n border-radius: 8px;\n }\n\n .header {\n padding: 8px 12px;\n }\n\n .title {\n font-size: 12px;\n }\n\n .subtitle {\n font-size: 9px;\n }\n\n .toggles {\n padding: 6px 12px;\n flex-wrap: wrap;\n }\n \n .toggles > *:not(:last-child) {\n margin-right: 8px;\n }\n\n .toggle {\n font-size: 10px;\n }\n\n .toggle input[type=\"checkbox\"] {\n width: 10px;\n height: 10px;\n }\n\n .logs {\n padding: 6px;\n }\n\n .log-entry {\n padding: 6px 8px;\n font-size: 10px;\n }\n\n .log-type {\n font-size: 8px;\n }\n\n .log-timestamp {\n font-size: 8px;\n }\n\n .log-data {\n font-size: 9px;\n padding: 6px;\n max-height: 80px;\n }\n\n .floating-btn {\n width: 36px;\n height: 36px;\n font-size: 16px;\n top: 15px;\n left: 15px;\n }\n }\n\n @media (max-width: 480px) {\n .panel {\n font-size: 10px;\n border-radius: 6px;\n }\n\n .header {\n padding: 6px 10px;\n }\n\n .title {\n font-size: 11px;\n }\n\n .subtitle {\n font-size: 8px;\n }\n\n .toggles {\n padding: 4px 10px;\n }\n \n .toggles > *:not(:first-child) {\n margin-right: 6px;\n }\n\n .toggle {\n font-size: 9px;\n }\n\n .logs {\n padding: 4px;\n }\n\n .log-entry {\n padding: 4px 6px;\n font-size: 9px;\n }\n \n .log-entry > *:not(:first-child) {\n margin-top: 4px;\n }\n\n .log-meta {\n min-width: 40px;\n }\n\n .log-type {\n font-size: 7px;\n }\n\n .log-timestamp {\n font-size: 7px;\n }\n\n .log-data {\n font-size: 8px;\n padding: 4px;\n max-height: 60px;\n }\n\n .floating-btn {\n width: 32px;\n height: 32px;\n font-size: 14px;\n top: 10px;\n left: 10px;\n }\n }\n",Tt="lce-debug-panel";class DebugPanelService{constructor(){this.panelElement=null,this.panelContainer=null,this.floatingButton=null,this.logContainer=null,this.logs=[],this.isVisible=![],this.showEvents=!![],this.showGtmEvents=!![],this.showLogs=![]}static getInstance(){return SingletonManager.getClassInstance("DebugPanelService",()=>new DebugPanelService)}initialize(){this.createPanel(),this.interceptLoggerService(),this.interceptPubSubEvents(),this.interceptGtmEvents()}toggleVisibility(){if(!this.panelElement)return this.createPanel(),void 0;this.isVisible=!this.isVisible,this.isVisible?this.showPanelContent():this.hidePanelContent()}destroy(){this.panelElement&&(this.panelElement.remove(),this.panelElement=null),this.panelContainer=null,this.floatingButton=null,this.logs=[],this.isVisible=![]}interceptLoggerService(){const n=LoggerFactory,i=n.instances;if(i)for(const[s,a]of i)this.interceptLoggerInstance(a,s);const r=LoggerFactory.get.bind(LoggerFactory);LoggerFactory.get=n=>{const i=r(n);return this.interceptLoggerInstance(i,n),i}}interceptLoggerInstance(n,i){if(n.l)return;const r=n.debug.bind(n),s=n.info.bind(n),a=n.warn.bind(n),l=n.error.bind(n),p=(n,r,s)=>({id:"logger_"+Date.now()+"_"+Math.random().toString(36).slice(2,9),timestamp:Date.now(),type:"logger",level:n,message:r,data:s,context:i});n.debug=(n,i)=>{r(n,i),this.addLogEntry(p("debug",n,i))},n.info=(n,i)=>{s(n,i),this.addLogEntry(p("info",n,i))},n.warn=(n,i)=>{a(n,i),this.addLogEntry(p("warn",n,i))},n.error=(n,i)=>{l(n,i),this.addLogEntry(p("error",n,i))},n.l=!![]}interceptPubSubEvents(){const n=PubSubService.getInstance(),i=n.publishAction.bind(n);n.publishAction=(n,r)=>{i(n,r),this.addLogEntry({id:"action_"+Date.now()+"_"+Math.random().toString(36).slice(2,9),timestamp:Date.now(),type:"event",level:"info",message:"Action: "+n,data:r,context:"PubSub"})};const r=n.publishForm.bind(n);n.publishForm=(n,i)=>{r(n,i),this.addLogEntry({id:"event_"+Date.now()+"_"+Math.random().toString(36).slice(2,9),timestamp:Date.now(),type:"event",level:"info",message:"Form Event: "+n,data:i,context:"PubSub"})}}interceptGtmEvents(){const n=GoogleTagManagerService.getInstance(),i=n.executeEvent.bind(n);n.executeEvent=(n,r,s)=>{i(n,r,s),this.addLogEntry({id:"gtm_"+Date.now()+"_"+Math.random().toString(36).slice(2,9),timestamp:Date.now(),type:"gtm",level:"info",message:"GTM Event: "+r,data:s,context:"GTM."+n})}}addLogEntry(n){this.logs.push(n),this.logs.length>100&&(this.logs=this.logs.slice(-100)),this.renderLogs()}renderLogs(){if(!this.logContainer)return;const n=this.logs.filter(n=>{switch(n.type){case"event":return this.showEvents;case"gtm":return this.showGtmEvents;case"logger":return this.showLogs;default:return!![]}});this.logContainer.innerHTML="",n.forEach(n=>{const i=this.createLogElement(n);this.logContainer.appendChild(i)}),this.logContainer.scrollTop=this.logContainer.scrollHeight}clearLogs(){this.logs=[],this.renderLogs()}createPanel(){const n=document.querySelector(Tt);n&&n.remove(),this.panelElement=document.createElement(Tt);const i=window.innerWidth<=768,r=window.innerWidth<=480;r?(this.panelElement.style.top="10px",this.panelElement.style.left="10px",this.panelElement.style.width="calc(100vw - 20px)",this.panelElement.style.height="40vh"):i?(this.panelElement.style.top="15px",this.panelElement.style.left="15px",this.panelElement.style.width="calc(100vw - 30px)",this.panelElement.style.height="40vh"):(this.panelElement.style.top="20px",this.panelElement.style.left="20px",this.panelElement.style.width="500px",this.panelElement.style.height="600px"),this.createPanelContent(),document.body.appendChild(this.panelElement),this.isVisible=!![]}createPanelContent(){if(!this.panelElement)return;const n=this.panelElement.attachShadow({mode:"closed"}),i=document.createElement("style");i.textContent=It,n.appendChild(i),this.floatingButton=this.createFloatingButton(),n.appendChild(this.floatingButton),this.panelContainer=document.createElement("div"),this.panelContainer.className="panel";const r=this.createHeader();this.panelContainer.appendChild(r);const s=this.createToggles();this.panelContainer.appendChild(s),this.logContainer=document.createElement("div"),this.logContainer.className="logs",this.logContainer.title="Debug logs - scroll to see more",this.panelContainer.appendChild(this.logContainer);const a=this.createResizeHandle();this.panelContainer.appendChild(a),n.appendChild(this.panelContainer),this.setupShadowEventListeners(n)}createHeader(){const n=document.createElement("div");n.className="header",n.title="Drag to move panel";const i=document.createElement("div");i.className="icon",i.innerHTML="🔍",i.title="Elements Debug Console",i.style.cursor="help";const r=document.createElement("div");r.className="title-container";const s=document.createElement("div");s.className="title",s.textContent="Elements Debug Console";const a=document.createElement("div");a.className="subtitle",a.textContent="Live SDK logs, events & GTM tracking",r.appendChild(s),r.appendChild(a);const l=document.createElement("button");return l.className="minimize",l.innerHTML="−",l.title="Minimize debug panel",l.addEventListener("click",()=>this.toggleVisibility()),n.appendChild(i),n.appendChild(r),n.appendChild(l),n}createToggles(){const n=document.createElement("div");n.className="toggles";const i=[{key:"showLogs",label:"Logs",description:"SDK internal logs and debug messages",color:"#8b5cf6"},{key:"showEvents",label:"Events",description:"User actions and form interactions",color:"#10b981"},{key:"showGtmEvents",label:"GTM Events",description:"Google Tag Manager tracking events",color:"#f59e0b"}];i.forEach(({key:i,label:r,description:s,color:a})=>{const l=document.createElement("label");l.className="toggle",l.title=s;const d=document.createElement("input");d.type="checkbox",d.checked="showLogs"!==i,d.addEventListener("change",n=>{const r=n.target;"showEvents"===i&&(this.showEvents=r.checked),"showGtmEvents"===i&&(this.showGtmEvents=r.checked),"showLogs"===i&&(this.showLogs=r.checked),this.renderLogs()});const u=document.createElement("span");u.textContent=r,u.style.color=a,l.appendChild(d),l.appendChild(u),n.appendChild(l)});const r=document.createElement("button");return r.className="clear-btn",r.innerHTML="🗑️",r.title="Clear all logs",r.addEventListener("click",()=>this.clearLogs()),n.appendChild(r),n}createResizeHandle(){const n=document.createElement("div");n.className="resize-handle",n.title="Drag to resize panel",n.style.cursor="nw-resize";let i=![],r=0,s=0,a=0,l=0;n.addEventListener("mousedown",n=>{i=!![],r=n.clientX,s=n.clientY,a=Number.parseInt(this.panelElement.style.width,10)||500,l=Number.parseInt(this.panelElement.style.height,10)||300,document.addEventListener("mousemove",G),document.addEventListener("mouseup",c),n.preventDefault()});const G=n=>{if(!i||!this.panelElement)return;const d=n.clientX-r,u=n.clientY-s,f=window.innerWidth<=768,g=window.innerWidth<=480;let v,b,x,w;g?(v=280,b=window.innerWidth-20,x=200,w=.4*window.innerHeight):f?(v=300,b=window.innerWidth-30,x=200,w=.4*window.innerHeight):(v=300,b=800,x=200,w=600);const C=Math.max(v,Math.min(b,a+d)),E=Math.max(x,Math.min(w,l+u));this.panelElement.style.width=C+"px",this.panelElement.style.height=E+"px"},c=()=>{i=![],document.removeEventListener("mousemove",G),document.removeEventListener("mouseup",c)};return n}setupShadowEventListeners(n){if(!this.panelElement)return;const i=n.querySelector(".header");if(i){let n=![],r=0,s=0,a=0,l=0;i.addEventListener("mousedown",i=>{if(i.target.classList.contains("minimize"))return;n=!![],r=i.clientX,s=i.clientY;const d=this.panelElement.getBoundingClientRect();a=d.left,l=d.top,document.addEventListener("mousemove",G),document.addEventListener("mouseup",c),i.preventDefault()});const G=i=>{if(!n||!this.panelElement)return;const d=i.clientX-r,u=i.clientY-s;this.panelElement.style.left=a+d+"px",this.panelElement.style.top=l+u+"px",this.panelElement.style.right="auto",this.panelElement.style.bottom="auto"},c=()=>{n=![],document.removeEventListener("mousemove",G),document.removeEventListener("mouseup",c)}}}createFloatingButton(){const n=document.createElement("div");return n.className="floating-btn",n.innerHTML="⚙️",n.title="Open Elements Debug Console",n.style.display="none",n.addEventListener("click",()=>{this.toggleVisibility()}),n}showPanelContent(){this.panelContainer&&(this.panelContainer.style.display="flex"),this.floatingButton&&(this.floatingButton.style.display="none")}hidePanelContent(){this.panelContainer&&(this.panelContainer.style.display="none"),this.floatingButton&&(this.floatingButton.style.display="flex")}createLogElement(n){const i=document.createElement("div");i.className="log-entry "+n.type+" "+n.level;const r=new Date(n.timestamp).toLocaleTimeString();return i.innerHTML='\n <div class="log-meta">\n <div class="log-type '+n.type+'">'+n.type.toUpperCase()+'</div>\n <div class="log-timestamp">'+r+'</div>\n </div>\n <div class="log-message">\n '+this.escapeHtml(n.message)+"\n "+(n.context?'<div class="log-context">'+this.escapeHtml(n.context)+"</div>":"")+"\n "+(n.data?'<div class="log-data"><pre>'+this.formatJsonData(n.data)+"</pre></div>":"")+"\n </div>\n ",i}formatJsonData(n){try{return"object"==typeof n&&null!==n?JSON.stringify(n,null,2):String(n)}catch(i){return String(n)}}escapeHtml(n){const i=document.createElement("div");return i.textContent=n,i.innerHTML}}class FingerPrintService{constructor(){this.isLocalStorageAvailable=null,this.cachedFingerprint=null,this.clientConfig=ClientConfigService.getInstance()}static getInstance(){return SingletonManager.getClassInstance("FingerPrintService",()=>new FingerPrintService)}async getId(n){if(this.u()){const i=this.h(n);if(i)return this.m(n,i)}return this.cachedFingerprint||(this.cachedFingerprint=this.v()),this.m(n,this.cachedFingerprint)}getFingerprintData(){return{screen:this.C(),browser:this.k(),timezone:this.S()}}isLocalStorageWebApiAvailable(){return this.u()}m(n,i){return(n+"_"+i).toLowerCase()}u(){if(null!==this.isLocalStorageAvailable)return this.isLocalStorageAvailable;try{0;const n=window.localStorage,i="__localStorage_test_"+Date.now()+"__",r="test";n.setItem(i,r);const s=n.getItem(i);return s!==r?(this.isLocalStorageAvailable=![],![]):(n.removeItem(i),this.isLocalStorageAvailable=!![],!![])}catch(n){const r=n instanceof DOMException&&(22===n.code||1014===n.code||"QuotaExceededError"===n.name||"NS_ERROR_DOM_QUOTA_REACHED"===n.name);if(r)try{const n=window.localStorage;return n&&n.length>0?(this.I()&&console.warn("localStorage is full in webview environment - consider data cleanup"),this.isLocalStorageAvailable=!![],!![]):(console.warn("localStorage reports zero quota - likely Safari private mode or similar restriction"),this.isLocalStorageAvailable=![],![])}catch(i){return this.isLocalStorageAvailable=![],![]}if(this.isLocalStorageAvailable=![],n instanceof DOMException){const i={SecurityError:"Access denied due to security policies (third-party cookies, Firefox cookie settings, or iframe restrictions)",InvalidStateError:"Invalid state error",InvalidAccessError:"Invalid access to storage",NotFoundError:"Storage not found"},r=i[n.name]||"Storage error: "+n.name,s=this.I()?"webview":"browser";console.warn("localStorage unavailable in "+s+": "+r)}else console.warn("localStorage unavailable:",n.message||"Unknown error");return![]}}h(n){try{const i=this.clientConfig.get("localStorageKeyPrefix")+"_"+n.toLowerCase()+"_";for(let n=0;n<localStorage.length;n++){const r=localStorage.key(n);if(null==r?void 0:r.startsWith(i)){const n=r.substring(i.length);if(n&&/^[a-f0-9]+$/.test(n))return n}}return null}catch(i){return null}}v(){const n=this.getFingerprintData(),i=Object.keys(n).sort().map(i=>i+":"+n[i]).join("|");return this.T(i)}C(){try{const n=screen,i=n.colorDepth||24,r=n.pixelDepth||i,s=this.D(),a=Math.round(100*(window.devicePixelRatio||1));return i+"|"+r+"|"+s+"|"+a}catch(n){return"24|24|srgb|100"}}D(){try{if(window.matchMedia&&"function"==="object".matchMedia){if(window.matchMedia("(color-gamut: rec2020)").matches)return"rec2020";if(window.matchMedia("(color-gamut: p3)").matches)return"p3";if(window.matchMedia("(color-gamut: srgb)").matches)return"srgb"}}catch(ut){}return"srgb"}k(){var n;try{const i=navigator,r=[],s=((null===(n=i.languages)||void 0===n?void 0:n[0])||i.language||"en").substring(0,2);r.push(s),r.push(i.hardwareConcurrency||4);const a=(i.platform||"unknown").toLowerCase().replace(/\s+/g,"_").substring(0,10);r.push(a),r.push(i.cookieEnabled?"1":"0"),r.push(i.maxTouchPoints||0),r.push(i.deviceMemory||0),r.push(this.A()),r.push(this.I()?"webview":"browser");const l=["bluetooth"in i?"1":"0","usb"in i?"1":"0","mediaDevices"in i?"1":"0","permissions"in i?"1":"0","credentials"in i?"1":"0","storage"in i?"1":"0","ServiceWorker"in window?"1":"0","PushManager"in window?"1":"0"];return r.push(l.join("")),r.join("|")}catch(i){return"en|4|unknown|1|0|0|unknown|webview|00000000"}}A(){try{const n=navigator.userAgent.toLowerCase();return n.includes("instagram")?"ig_webview":n.includes("fban")||n.includes("fbav")?"fb_webview":n.includes("tiktok")?"tiktok_webview":n.includes("linkedin")?"linkedin_webview":n.includes("snapchat")?"snapchat_webview":n.includes("twitter")?"twitter_webview":n.includes("line/")?"line_webview":n.includes("micromessenger")?"wechat_webview":n.includes("firefox")?"gecko":n.includes("edg/")?"edge":n.includes("opr/")||n.includes("opera")?"opera":n.includes("chrome")&&!n.includes("edg")?"blink":n.includes("safari")&&!n.includes("chrome")?"webkit":"unknown"}catch(n){return"unknown"}}I(){try{const n=navigator.userAgent.toLowerCase(),i=navigator,r=["wv","instagram","fban","fbav","tiktok","linkedin","snapchat","twitter","line/","micromessenger","kakaotalk","telegram"];return r.some(i=>n.includes(i))?!![]:void 0===i.standalone||i.standalone?window.self!==window.top?!![]:![]:!![]}catch(n){return![]}}S(){try{const n=Intl.DateTimeFormat().resolvedOptions().timeZone||"UTC";return n.replace(/\//g,"_").substring(0,30)}catch(n){return"UTC"}}T(n){const i=16777619;let r=2166136261,s=2166136261,a=2166136261,l=2166136261;for(let d=0;d<n.length;d++){const u=n.charCodeAt(d);r^=u,r=Math.imul(r,i),s^=u<<1,s=Math.imul(s,i),a^=u<<2,a=Math.imul(a,i),l^=u<<3,l=Math.imul(l,i)}return r=Math.abs(r),s=Math.abs(s),a=Math.abs(a),l=Math.abs(l),r.toString(16)+s.toString(16)+a.toString(16)+l.toString(16)}}class TelemetryService{constructor(){this.eventQueue=[],this.batchTimer=null,this.stats={totalEvents:0,eventsByLevel:{debug:0,log:0,info:0,warn:0,error:0,fatal:0},batchesSent:0,failedBatches:0,queuedEvents:0,droppedEvents:0},this.isShuttingDown=![],this.clientConfig=ClientConfigService.getInstance(),this.store=StoreService.getInstance();const n=this.clientConfig.get("env"),i=new URL("/api/telemetry",this.clientConfig.get("baseUrl")).toString();this.config={enabled:!![],endpoint:i,batchSize:n===b.PRODUCTION?5:10,batchInterval:n===b.PRODUCTION?5e3:3e3,includeDebugLogs:![],includeWarnings:!![],includeErrors:!![],maxQueueSize:50},window.addEventListener("beforeunload",()=>this.shutdown()),window.addEventListener("pagehide",()=>this.shutdown()),this.config.enabled&&this.startBatchTimer()}static getInstance(){return SingletonManager.getClassInstance("TelemetryService",()=>new TelemetryService)}isEnabled(){return this.config.enabled}captureEvent(n,i,r={}){if(!this.isEnabled()||this.isShuttingDown)return;if(!this.shouldCapture(n))return;const s=Date.now();try{const a={eventId:"event_"+s,timestamp:s,level:n,message:i,context:r.context,error:r.error?this.buildErrorContext(r.error):void 0,component:r.component,data:r.data,metadata:{sdk:this.buildSDKContext(),user:this.buildUserContext(),browser:this.buildBrowserContext()}};this.addToQueue(a)}catch(a){this.handleInternalError(a)}}buildErrorContext(n){return{name:n.name,message:n.message,stack:this.truncateStackTrace(n.stack),code:n.code,statusCode:n.status||n.statusCode}}buildSDKContext(){return{version:this.clientConfig.get("version")||"unknown",env:this.clientConfig.get("env"),isBuilder:this.clientConfig.get("isBuilder"),partnerCode:this.clientConfig.get("partnerCode")}}buildUserContext(){const n=this.store.get("address.formattedAddress");return{deviceId:this.clientConfig.get("userDeviceId")||"not_defined",isLocalStorageAvailable:this.clientConfig.get("isLocalStorageAvailable")||![],selectedAddress:n||void 0}}buildBrowserContext(){return{userAgent:navigator.userAgent,deviceType:this.clientConfig.get("deviceType"),url:window.location.href,referrer:document.referrer||void 0,timezone:Intl.DateTimeFormat().resolvedOptions().timeZone}}shouldCapture(n){switch(n){case"debug":case"log":case"info":return this.config.includeDebugLogs;case"warn":return this.config.includeWarnings;case"error":case"fatal":return this.config.includeErrors;default:return![]}}addToQueue(n){this.eventQueue.length>=this.config.maxQueueSize&&(this.eventQueue.shift(),this.stats.droppedEvents++),this.eventQueue.push(n),this.stats.totalEvents++,this.stats.eventsByLevel[n.level]++,this.stats.queuedEvents=this.eventQueue.length,this.eventQueue.length>=this.config.batchSize&&this.flushQueue()}startBatchTimer(){this.batchTimer&&clearInterval(this.batchTimer),this.batchTimer=setInterval(()=>{this.eventQueue.length>0&&this.flushQueue()},this.config.batchInterval)}flushQueue(){var n;if(0===this.eventQueue.length||!(null===(n=this.config)||void 0===n?void 0:n.endpoint))return;const i=this.eventQueue.splice(0,this.config.batchSize);this.stats.queuedEvents=this.eventQueue.length;const r=this.createBatch(i);try{this.sendBatch(r),this.stats.batchesSent++}catch(s){this.stats.failedBatches++,this.handleInternalError(s),this.eventQueue.unshift(...i),this.stats.queuedEvents=this.eventQueue.length}}createBatch(n){const i=Date.now();return{batchId:"batch_"+i,timestamp:i,events:n}}sendBatch(n){if("undefined"!=typeof navigator&&navigator.sendBeacon)try{const i=new Blob([JSON.stringify(n)],{type:"text/plain"}),r=navigator.sendBeacon(this.config.endpoint,i);if(r)return}catch(i){return this.sendBatchViaXHR(n),void 0}this.sendBatchViaXHR(n)}sendBatchViaXHR(n){try{const i=new XMLHttpRequest;if(i.open("POST",this.config.endpoint,![]),i.setRequestHeader("Content-Type","text/plain"),i.send(JSON.stringify(n)),i.status<200||i.status>=300)throw new SDKError("XHR request failed with status: "+i.status)}catch(i){throw new SDKError("Both sendBeacon and XHR failed: "+i.message)}}truncateStackTrace(n){if(n)return n.split("\n").slice(0,10).join("\n")}handleInternalError(n){this.clientConfig.isProduction()&&!this.clientConfig.isDebuggingEnabled()||console.error("[LiquidCommerce Elements][Telemetry Internal Error]",n)}shutdown(){var n;if(!this.isShuttingDown&&(this.isShuttingDown=!![],this.batchTimer&&(clearInterval(this.batchTimer),this.batchTimer=null),this.eventQueue.length>0&&(null===(n=this.config)||void 0===n?void 0:n.endpoint))){const n=this.createBatch(this.eventQueue);this.eventQueue=[];try{this.sendBatch(n),this.stats.batchesSent++}catch(i){this.stats.failedBatches++}}}}class BaseComponent extends HTMLElement{get hostClasses(){return[]}get hostAttributes(){return{}}constructor(n={}){super(),this.initialized=![],this.isDestroyed=![],this.renderScheduled=![],this.unsubscribers=[],this.lastRenderTrigger="initial",this.renderCount=0,this.store=StoreService.getInstance(),this.commands=CommandService.getInstance(),this.themeProvider=ThemeProviderService.getInstance(),this.pubSub=PubSubService.getInstance(),this.logger=LoggerFactory.get("BaseComponent"),this.clientConfig=ClientConfigService.getInstance(),this.telemetry=TelemetryService.getInstance(),this.reactiveOptions={watchStorePaths:[],watchOnlyStorePaths:[],autoDestroy:![],autoDestroyDelay:0,...n}}initialize({data:n,config:i}){var r;this.P=Object.freeze(n),this._=Object.freeze({type:i.type,tagName:this.tagName.toLowerCase(),useShadowDom:null!==(r=null==i?void 0:i.useShadowDom)&&void 0!==r?r:![]}),this.initialized&&(this.setup(),this.triggerRender("initialize"))}interpolateStorePaths(n){return n.map(n=>this.interpolatePath(n))}interpolatePath(n){if("string"!=typeof n)return n;const i=/\{([^}]+)}/g;return n.replace(i,(i,r)=>{const s=this.P[r];return null==s?(this.logger.warn('Parameter "'+r+'" not found in component params for path "'+n+'"'),i):String(s)})}connectedCallback(){var n,i;try{if(this.isDestroyed)return;this.initialized=!![],this.container=this._.useShadowDom?this.attachShadow({mode:this.clientConfig.get("openShadowDom")?"open":"closed"}):this,this.setup(),this.triggerRender("connected"),null===(n=this.connected)||void 0===n||n.call(this)}catch(r){this.logger.error("Component connectedCallback error in "+((null===(i=this._)||void 0===i?void 0:i.tagName)||"unknown"),r),r instanceof Error&&this.captureComponentError(r,"connectedCallback")}}disconnectedCallback(){var n,i;try{this.cleanup(),null===(n=this.disconnected)||void 0===n||n.call(this)}catch(r){this.logger.error("Component disconnectedCallback error in "+((null===(i=this._)||void 0===i?void 0:i.tagName)||"unknown"),r),r instanceof Error&&this.captureComponentError(r,"disconnectedCallback")}}setup(){var n,i,r;try{this.updateHostClasses(),this.updateHostAttributes(),null===(n=this.beforeSetupStoreWatchers)||void 0===n||n.call(this),this.setupStoreWatchers(),this.setupNonRenderingWatchers(),this.setupAutoDestroy(),null===(i=this.beforeConnected)||void 0===i||i.call(this)}catch(s){this.logger.error("Component setup error in "+((null===(r=this._)||void 0===r?void 0:r.tagName)||"unknown"),s),s instanceof Error&&this.captureComponentError(s,"setup")}}cleanup(){this.isDestroyed=!![],this.renderTimeout&&cancelAnimationFrame(this.renderTimeout),this.autoDestroyTimeout&&clearTimeout(this.autoDestroyTimeout);for(const i of this.unsubscribers)try{i()}catch(n){this.logger.error("Cleanup error during component destruction",n),n instanceof Error&&this.captureComponentError(n,"cleanup")}this.unsubscribers=[]}setupAutoDestroy(){var n;if(!this.reactiveOptions.autoDestroy)return;let i=this.reactiveOptions.autoDestroyPath;if(!i&&(null===(n=this.reactiveOptions.watchStorePaths)||void 0===n?void 0:n.length)&&(i=this.reactiveOptions.watchStorePaths[0]),!i)return this.logger.warn("AutoDestroy enabled but no path specified and no watchStorePaths found"),void 0;const r=this.interpolatePath(i),s=this.store.watch(r,(n,i)=>{this.isDestroyed||void 0===n&&void 0!==i&&this.handleAutoDestroy(r)});this.unsubscribers.push(s)}handleAutoDestroy(n){var i;if(this.isDestroyed)return;null===(i=this.beforeAutoDestroy)||void 0===i?void 0:i.call(this,n);const r=this.reactiveOptions.autoDestroyDelay||0;r>0?this.autoDestroyTimeout=setTimeout(()=>{this.destroyComponent()},r):this.destroyComponent()}destroyComponent(){var n;if(!this.isDestroyed)try{null===(n=this.onAutoDestroy)||void 0===n?void 0:n.call(this),this.remove()}catch(i){this.logger.error("Error during auto-destroy of "+this._.tagName,i),i instanceof Error&&this.captureComponentError(i,"auto-destroy")}}setupStoreWatchers(){var n;try{let n=this.reactiveOptions.watchStorePaths;if(!(null==n?void 0:n.length)||!this.P)return;n=this.interpolateStorePaths(n);const i=this.store.watchMany(n,n=>{var i,r;try{if(this.isDestroyed)return;const r=n.map(n=>n.path).join(", "),s="store:["+r+"]",a=null===(i=this.onStoreChanged)||void 0===i?void 0:i.call(this,n);a!==![]&&this.triggerRender(s)}catch(s){this.logger.error("Store watcher callback error in "+((null===(r=this._)||void 0===r?void 0:r.tagName)||"unknown"),s),s instanceof Error&&this.captureComponentError(s,"storeWatcher")}});this.unsubscribers.push(i)}catch(i){this.logger.error("Store watchers setup error in "+((null===(n=this._)||void 0===n?void 0:n.tagName)||"unknown"),i),i instanceof Error&&this.captureComponentError(i,"setupStoreWatchers")}}setupNonRenderingWatchers(){var n;try{let n=this.reactiveOptions.watchOnlyStorePaths;if(!(null==n?void 0:n.length)||!this.P)return;n=this.interpolateStorePaths(n);const i=this.store.watchMany(n,n=>{var i,r;try{if(this.isDestroyed)return;null===(i=this.onStoreWatch)||void 0===i?void 0:i.call(this,n)}catch(s){this.logger.error("Non-rendering watcher callback error in "+((null===(r=this._)||void 0===r?void 0:r.tagName)||"unknown"),s),s instanceof Error&&this.captureComponentError(s,"nonRenderingWatcher")}});this.unsubscribers.push(i)}catch(i){this.logger.error("Non-rendering watchers setup error in "+((null===(n=this._)||void 0===n?void 0:n.tagName)||"unknown"),i),i instanceof Error&&this.captureComponentError(i,"setupNonRenderingWatchers")}}triggerRender(n){this.lastRenderTrigger=n,this.scheduleRender()}scheduleRender(){this.renderScheduled||this.isDestroyed||(this.renderScheduled=!![],this.renderTimeout=requestAnimationFrame(()=>{this.render(),this.renderScheduled=![]}))}render(){var n,i;if(!this.initialized||this.isDestroyed)return;const r=performance.now();this.renderCount++;try{const i=this.template();"string"==typeof i&&(this.container.innerHTML=i),i instanceof HTMLElement&&safeReplaceChildren(this.container,i),Array.isArray(i)&&safeReplaceChildren(this.container,...i);const a=performance.now()-r;this.logRenderInfo(a);try{null===(n=this.afterRender)||void 0===n?void 0:n.call(this)}catch(s){this.logger.error("❌ afterRender hook error in "+this._.tagName,s),s instanceof Error&&this.captureComponentError(s,"afterRender")}}catch(a){const n=performance.now()-r;this.logger.error("❌ Component render error in "+this._.tagName,a),this.captureComponentError(a,"render",n),safeReplaceChildren(this.container,ComponentFactoryService.componentError({componentType:this._.type,message:a instanceof Error?a.message:String(a)}));try{null===(i=this.onError)||void 0===i?void 0:i.call(this,a,"render")}catch(l){this.logger.error("❌ onError hook error in "+this._.tagName,l)}}}logRenderInfo(n){const i=this._.type,r=this._.tagName,s=n>16?"🐌":n>8?"⚡":"🚀";this.logger.debug("Rendered "+s+" "+i+" </"+r+"> | #"+this.renderCount+" | "+n.toFixed(2)+"ms | "+this.lastRenderTrigger),n>16&&(this.logger.warn("⚠️ Slow render in "+i+"("+r+"): "+n.toFixed(2)+"ms triggered by "+this.lastRenderTrigger,{duration:n,threshold:16,componentType:i,tagName:r,renderTrigger:this.lastRenderTrigger,renderCount:this.renderCount}),this.telemetry.captureEvent("warn","Slow render: "+n.toFixed(2)+"ms",{context:"Component:"+r+":performance",component:{type:i,tagName:r,renderCount:this.renderCount,renderTrigger:this.lastRenderTrigger,renderDuration:n,useShadowDom:this._.useShadowDom}}))}rerender(n){this.triggerRender(n?"manual:rerender:"+n:"manual:rerender()")}captureComponentError(n,i,r){if(this.telemetry.isEnabled())try{this.telemetry.captureEvent("error",n.message,{context:"Component:"+this._.tagName+":"+i,component:{type:this._.type,tagName:this._.tagName,renderCount:this.renderCount,renderTrigger:this.lastRenderTrigger,renderDuration:r,useShadowDom:this._.useShadowDom}})}catch(s){}}updateHostClasses(){const n=this.hostClasses;if(n.length>0){const i=n.filter(n=>n&&"string"==typeof n&&n.trim());i.length>0&&this.classList.add(...i)}}addHostClasses(...n){const i=n.filter(n=>n&&"string"==typeof n&&n.trim());i.length>0&&this.classList.add(...i)}removeHostClasses(...n){const i=n.filter(n=>n&&"string"==typeof n&&n.trim());i.length>0&&this.classList.remove(...i)}toggleHostClasses(...n){const i=n.filter(n=>n&&"string"==typeof n&&n.trim());for(const r of i)this.classList.toggle(r)}addHostAttribute(n,i){n&&"string"==typeof n&&i&&"string"==typeof i&&(this.setAttribute(n,String(i)),this.hostAttributes[n]=String(i))}removeHostAttribute(n){n&&"string"==typeof n&&(this.removeAttribute(n),delete this.hostAttributes[n])}updateHostAttributes(){const n=this.hostAttributes;for(const[i,r]of Object.entries(n))i&&"string"==typeof i&&r&&"string"==typeof r&&this.setAttribute(i,String(r))}get params(){return this.P}get config(){return this.themeProvider.getComponentConfig(this._.type)}get elementConfig(){return this._}getConfigs(n){return this.themeProvider.getConfigs(n)}getStoreValue(n){return this.store.get(n)}setStoreValue(n,i){return this.store.set(n,i)}watchStore(n,i){const r=this.store.watch(n,i);return this.unsubscribers.push(r),r}}class AddressComponent extends BaseComponent{constructor(){super({watchOnlyStorePaths:["address"]})}template(){var n;const i=null!==(n=this.params.options)&&void 0!==n?n:{};return ComponentFactoryService.createElement({type:C.ADDRESS_DISPLAY,isIndependentComponent:!![],options:i})}}class AddressDisplayComponent extends BaseComponent{get hostClasses(){return["address-display-container"]}constructor(){super({watchStorePaths:["address"]})}template(){var n,i,r,s;const a=this.getStoreValue("address"),l=null!==(n=this.params.isIndependentComponent)&&void 0!==n?n:![],d=null!==(i=this.params.productId)&&void 0!==i?i:"",u=null!==(r=this.params.options)&&void 0!==r?r:{},f=null!==(s=u.showLabel)&&void 0!==s?s:!![],g=[];if(f){const n=document.createElement("span");n.textContent="Delivers to:",g.push(n)}const v=document.createElement("button");v.type="button",v.textContent=a.formattedAddress||"Select an address";const b=a.formattedAddress?"Change delivery address, currently set to "+a.formattedAddress:"Select delivery address";return v.setAttribute("aria-label",b),v.addEventListener("click",async()=>{if(l)return this.commands.ui.openDrawer(C.ADDRESS_INPUT,{productId:d,isIndependentComponent:!![]}),void 0;!l&&d&&(this.clientConfig.isMobile()&&this.commands.ui.openDrawer(C.ADDRESS_INPUT,{productId:d}),this.clientConfig.isMobile()||await this.commands.product.openProductDrawer(d,C.ADDRESS_INPUT,{productId:d}))}),g.push(v),g}}const ArrowRightIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="arrow-right-icon '+r+'" style="'+a+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M7.52794 2.86225C7.78829 2.6019 8.2104 2.6019 8.47075 2.86225L13.1374 7.52892C13.3978 7.78927 13.3978 8.21138 13.1374 8.47173L8.47075 13.1384C8.2104 13.3987 7.78829 13.3987 7.52794 13.1384C7.26759 12.878 7.26759 12.4559 7.52794 12.1956L11.0565 8.66699H3.33268C2.96449 8.66699 2.66602 8.36851 2.66602 8.00033C2.66602 7.63214 2.96449 7.33366 3.33268 7.33366H11.0565L7.52794 3.80506C7.26759 3.54471 7.26759 3.1226 7.52794 2.86225Z"/>\n </svg>\n '},BagIcon=({width:n=24,height:i=24,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 489 489" class="bag-icon '+r+'" style="'+a+'" data-fill-only>\n <path d="M440.1,422.7l-28-315.3c-0.6-7-6.5-12.3-13.4-12.3h-57.6C340.3,42.5,297.3,0,244.5,0s-95.8,42.5-96.6,95.1H90.3 c-7,0-12.8,5.3-13.4,12.3l-28,315.3c0,0.4-0.1,0.8-0.1,1.2c0,35.9,32.9,65.1,73.4,65.1h244.6c40.5,0,73.4-29.2,73.4-65.1 C440.2,423.5,440.2,423.1,440.1,422.7z M244.5,27c37.9,0,68.8,30.4,69.6,68.1H174.9C175.7,57.4,206.6,27,244.5,27z M366.8,462 H122.2c-25.4,0-46-16.8-46.4-37.5l26.8-302.3h45.2v41c0,7.5,6,13.5,13.5,13.5s13.5-6,13.5-13.5v-41h139.3v41 c0,7.5,6,13.5,13.5,13.5s13.5-6,13.5-13.5v-41h45.2l26.9,302.3C412.8,445.2,392.1,462,366.8,462z"/>\n </svg>\n'},CheckboxIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="checkbox-icon '+r+'" style="'+a+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M13.8047 3.52885C14.0651 3.7892 14.0651 4.21131 13.8047 4.47166L6.4714 11.805C6.21106 12.0653 5.78894 12.0653 5.5286 11.805L2.19526 8.47166C1.93491 8.21131 1.93491 7.7892 2.19526 7.52885C2.45561 7.2685 2.87772 7.2685 3.13807 7.52885L6 10.3908L12.8619 3.52885C13.1223 3.2685 13.5444 3.2685 13.8047 3.52885Z"/>\n </svg>\n '},ChevronDownIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="'+r+'" style="'+a+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M3.52827 5.52876C3.78862 5.26841 4.21073 5.26841 4.47108 5.52876L7.99967 9.05735L11.5283 5.52876C11.7886 5.26841 12.2107 5.26841 12.4711 5.52876C12.7314 5.78911 12.7314 6.21122 12.4711 6.47157L8.47108 10.4716C8.21073 10.7319 7.78862 10.7319 7.52827 10.4716L3.52827 6.47157C3.26792 6.21122 3.26792 5.78911 3.52827 5.52876Z" fill="#18181B"/>\n </svg>\n '},ChevronLeftIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="chevron-left-icon '+r+'" style="'+a+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M10.4721 3.52864C10.7324 3.78899 10.7324 4.2111 10.4721 4.47145L6.94346 8.00004L10.4721 11.5286C10.7324 11.789 10.7324 12.2111 10.4721 12.4714C10.2117 12.7318 9.7896 12.7318 9.52925 12.4714L5.52925 8.47145C5.2689 8.2111 5.2689 7.78899 5.52925 7.52864L9.52925 3.52864C9.7896 3.26829 10.2117 3.26829 10.4721 3.52864Z"/>\n </svg>\n '},ChevronUpIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="'+r+'" style="'+a+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M3.52827 10.4712C3.78862 10.7316 4.21073 10.7316 4.47108 10.4712L7.99967 6.94265L11.5283 10.4712C11.7886 10.7316 12.2107 10.7316 12.4711 10.4712C12.7314 10.2109 12.7314 9.78878 12.4711 9.52843L8.47108 5.52843C8.21073 5.26808 7.78862 5.26808 7.52827 5.52843L3.52827 9.52843C3.26792 9.78878 3.26792 10.2109 3.52827 10.4712Z" fill="#18181B"/>\n </svg>\n '},CloseIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="close-icon '+r+'" style="'+a+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M3.52925 3.52864C3.7896 3.26829 4.21171 3.26829 4.47206 3.52864L8.00065 7.05723L11.5292 3.52864C11.7896 3.26829 12.2117 3.26829 12.4721 3.52864C12.7324 3.78899 12.7324 4.2111 12.4721 4.47145L8.94346 8.00004L12.4721 11.5286C12.7324 11.789 12.7324 12.2111 12.4721 12.4714C12.2117 12.7318 11.7896 12.7318 11.5292 12.4714L8.00065 8.94285L4.47206 12.4714C4.21171 12.7318 3.7896 12.7318 3.52925 12.4714C3.2689 12.2111 3.2689 11.789 3.52925 11.5286L7.05784 8.00004L3.52925 4.47145C3.2689 4.2111 3.2689 3.78899 3.52925 3.52864Z"/>\n </svg>\n '},ErrorInfoIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'<svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="error-info-icon '+r+'" style="'+a+'" data-fill-only>\n<path fill-rule="evenodd" clip-rule="evenodd" d="M8.00033 1.99996C4.68662 1.99996 2.00033 4.68625 2.00033 7.99996C2.00033 11.3137 4.68662 14 8.00033 14C11.314 14 14.0003 11.3137 14.0003 7.99996C14.0003 4.68625 11.314 1.99996 8.00033 1.99996ZM0.666992 7.99996C0.666992 3.94987 3.95024 0.666626 8.00033 0.666626C12.0504 0.666626 15.3337 3.94987 15.3337 7.99996C15.3337 12.05 12.0504 15.3333 8.00033 15.3333C3.95024 15.3333 0.666992 12.05 0.666992 7.99996ZM8.00033 4.66663C8.36852 4.66663 8.66699 4.9651 8.66699 5.33329V7.99996C8.66699 8.36815 8.36852 8.66663 8.00033 8.66663C7.63213 8.66663 7.33366 8.36815 7.33366 7.99996V5.33329C7.33366 4.9651 7.63213 4.66663 8.00033 4.66663ZM7.33366 10.6666C7.33366 10.2984 7.63213 9.99996 8.00033 9.99996H8.00699C8.37518 9.99996 8.67366 10.2984 8.67366 10.6666C8.67366 11.0348 8.37518 11.3333 8.00699 11.3333H8.00033C7.63213 11.3333 7.33366 11.0348 7.33366 10.6666Z"/>\n</svg>'},InfoIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="info-icon '+r+'" style="'+a+'" data-fill-only>\n <path d="M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0 1A8 8 0 1 0 8 0a8 8 0 0 0 0 16z"/>\n <path d="m8.93 6.588-2.29.287-.082.38.45.083c.294.07.352.176.288.469l-.738 3.468c-.194.897.105 1.319.808 1.319.545 0 1.178-.252 1.465-.598l.088-.416c-.2.176-.492.246-.686.246-.275 0-.375-.193-.304-.533L8.93 6.588zM9 4.5a1 1 0 1 1-2 0 1 1 0 0 1 2 0z"/>\n </svg>\n '},SearchIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s||"currentColor";return'<svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="search-icon '+r+'">\n <path d="M14.0001 14L11.1335 11.1333M12.6667 7.33333C12.6667 10.2789 10.2789 12.6667 7.33333 12.6667C4.38781 12.6667 2 10.2789 2 7.33333C2 4.38781 4.38781 2 7.33333 2C10.2789 2 12.6667 4.38781 12.6667 7.33333Z" fill="none" stroke="'+a+'" stroke-width="1.33" stroke-linecap="round" stroke-linejoin="round"/>\n</svg>'},SuccessIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="success-icon '+r+'" style="'+a+'" data-fill-only>\n <path d="M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z"/>\n </svg>\n '},TrashIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="trash-icon '+r+'" style="'+a+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M6.22157 2.22161C6.06513 2.37804 6.00016 2.55036 6.00016 2.66687V3.33354H10.0002V2.66687C10.0002 2.55036 9.93519 2.37804 9.77876 2.22161C9.62232 2.06517 9.45001 2.0002 9.3335 2.0002H6.66683C6.55032 2.0002 6.378 2.06517 6.22157 2.22161ZM11.3335 3.33354V2.66687C11.3335 2.11672 11.0651 1.62236 10.7216 1.2788C10.378 0.935235 9.88365 0.66687 9.3335 0.66687H6.66683C6.11668 0.66687 5.62232 0.935235 5.27876 1.2788C4.93519 1.62236 4.66683 2.11672 4.66683 2.66687V3.33354H2.00016C1.63197 3.33354 1.3335 3.63201 1.3335 4.0002C1.3335 4.36839 1.63197 4.66687 2.00016 4.66687H2.66683V13.3335C2.66683 13.8837 2.93519 14.378 3.27876 14.7216C3.62232 15.0652 4.11668 15.3335 4.66683 15.3335H11.3335C11.8837 15.3335 12.378 15.0652 12.7216 14.7216C13.0651 14.378 13.3335 13.8837 13.3335 13.3335V4.66687H14.0002C14.3684 4.66687 14.6668 4.36839 14.6668 4.0002C14.6668 3.63201 14.3684 3.33354 14.0002 3.33354H11.3335ZM4.00016 4.66687V13.3335C4.00016 13.45 4.06513 13.6224 4.22157 13.7788C4.378 13.9352 4.55032 14.0002 4.66683 14.0002H11.3335C11.45 14.0002 11.6223 13.9352 11.7788 13.7788C11.9352 13.6224 12.0002 13.45 12.0002 13.3335V4.66687H4.00016ZM6.66683 6.66687C7.03502 6.66687 7.3335 6.96535 7.3335 7.33354V11.3335C7.3335 11.7017 7.03502 12.0002 6.66683 12.0002C6.29864 12.0002 6.00016 11.7017 6.00016 11.3335V7.33354C6.00016 6.96535 6.29864 6.66687 6.66683 6.66687ZM9.3335 6.66687C9.70169 6.66687 10.0002 6.96535 10.0002 7.33354V11.3335C10.0002 11.7017 9.70169 12.0002 9.3335 12.0002C8.96531 12.0002 8.66683 11.7017 8.66683 11.3335V7.33354C8.66683 6.96535 8.96531 6.66687 9.3335 6.66687Z"/>\n </svg>\n '},WarningIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 16 16" class="warning-icon '+r+'" style="'+a+'" data-fill-only>\n <path fill-rule="evenodd" clip-rule="evenodd" d="M7.99984 2.00033C4.68613 2.00033 1.99984 4.68662 1.99984 8.00033C1.99984 11.314 4.68613 14.0003 7.99984 14.0003C11.3135 14.0003 13.9998 11.314 13.9998 8.00033C13.9998 4.68662 11.3135 2.00033 7.99984 2.00033ZM0.666504 8.00033C0.666504 3.95024 3.94975 0.666992 7.99984 0.666992C12.0499 0.666992 15.3332 3.95024 15.3332 8.00033C15.3332 12.0504 12.0499 15.3337 7.99984 15.3337C3.94975 15.3337 0.666504 12.0504 0.666504 8.00033ZM7.99984 4.66699C8.36803 4.66699 8.6665 4.96547 8.6665 5.33366V8.00033C8.6665 8.36852 8.36803 8.66699 7.99984 8.66699C7.63165 8.66699 7.33317 8.36852 7.33317 8.00033V5.33366C7.33317 4.96547 7.63165 4.66699 7.99984 4.66699ZM7.33317 10.667C7.33317 10.2988 7.63165 10.0003 7.99984 10.0003H8.0065C8.37469 10.0003 8.67317 10.2988 8.67317 10.667C8.67317 11.0352 8.37469 11.3337 8.0065 11.3337H7.99984C7.63165 11.3337 7.33317 11.0352 7.33317 10.667Z"/>\n </svg>\n '};class AddressInputComponent extends BaseComponent{constructor(){super({watchStorePaths:["address"]}),this.suggestions=[],this.error=null,this.selectedAddress=null,this.minSearchLength=3,this.isIndependentComponent=()=>{var n;return null!==(n=this.params.isIndependentComponent)&&void 0!==n?n:![]},this.handleInputChange=n=>{const i=n.target,r=i.value.replace(/[^a-zA-Z0-9\s\-.,#'/]/g,"");i.value=r;const s=r.trim();this.searchTimeout&&clearTimeout(this.searchTimeout),this.selectedAddress=null,this.error=null,this.updateErrorDisplay();const a=/^\d/.test(s);if(s.length<this.minSearchLength||!a)return this.suggestions=[],this.hideSuggestions(),void 0;this.searchTimeout=setTimeout(async()=>{await this.searchAddresses(s)},300)},this.closeDrawer=async()=>{const n=this.params.productId,i=this.clientConfig.isMobile(),r=this.isIndependentComponent();(i||r)&&this.commands.ui.closeDrawer(),!i&&n&&await this.commands.product.closeProductDrawer(n)},this.handleCancel=async()=>{try{await this.closeDrawer(),this.suggestions=[],this.error=null,this.hideSuggestions(),this.updateErrorDisplay()}catch(ut){this.logger.error("Address edit cancellation failed",ut)}},this.handleCheckAvailability=async()=>{if(!this.selectedAddress)return this.error="Please select a valid address first",this.updateErrorDisplay(),this.showSuggestions(),void 0;try{this.error=null,this.updateErrorDisplay();const n=this.getStoreValue("address"),i=(null==n?void 0:n.coordinates.lat)!==this.selectedAddress.coordinates.lat||(null==n?void 0:n.coordinates.long)!==this.selectedAddress.coordinates.long;i&&await this.commands.address.setSelectedAddress(this.selectedAddress),await this.closeDrawer()}catch(n){this.logger.error("Address selection and availability check failed",n),this.error="Failed to update address. Please try again.",this.updateErrorDisplay()}},this.handleSuggestionClick=async n=>{const i=n.currentTarget.dataset.suggestionId;if(i)try{this.error=null,this.updateErrorDisplay();const n=await this.commands.address.getAddressDetails(i);if(0===Object.keys(n).length)return this.error="No details found for the selected address.",this.updateErrorDisplay(),void 0;this.selectedAddress={id:i,address:n.address,coordinates:n.coords,formattedAddress:n.formattedAddress},this.inputElement.value=this.selectedAddress.formattedAddress,this.hideSuggestions()}catch(r){this.logger.error("Address details retrieval failed",r),this.error="Failed to get address details. Please try again.",this.updateErrorDisplay()}},this.handleDocumentClick=n=>{this.container.contains(n.target)||this.hideSuggestions()}}get hostClasses(){return["address-input-container"]}beforeConnected(){const n=this.getStoreValue("address");(null==n?void 0:n.formattedAddress)&&(this.selectedAddress=n)}async searchAddresses(n){try{this.error=null,this.updateErrorDisplay(),this.showSuggestions();const i=await this.commands.address.searchAddresses(n);this.suggestions=i.slice(0,5),this.updateSuggestionsDisplay(),this.showSuggestions()}catch(i){this.logger.error("Address search operation failed",i),this.error="Failed to search addresses. Please try again.",this.suggestions=[],this.updateErrorDisplay(),this.updateSuggestionsDisplay()}}updateErrorDisplay(){if(!this.errorContainer)return;if(!this.error)return this.errorContainer.style.display="none",void 0;this.errorContainer.style.display="block";const n=this.errorContainer.querySelector(".error-text");n&&(n.textContent=this.error)}updateSuggestionsDisplay(){if(this.suggestionsContainer){if(this.suggestionsContainer.innerHTML="",0===this.suggestions.length){const n=this.createElement("li",{className:"suggestion-item no-suggestions",textContent:"No matching address found."});return this.suggestionsContainer.appendChild(n),void 0}for(const n of this.suggestions){const i=this.createElement("li",{className:"suggestion-item"}),r=this.createElement("span",{textContent:n.description});i.appendChild(r),i.setAttribute("data-suggestion-id",n.id),i.setAttribute("role","option"),i.setAttribute("aria-label","Select address: "+n.description),i.setAttribute("tabindex","0"),i.addEventListener("click",this.handleSuggestionClick),i.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),i.click())}),this.suggestionsContainer.appendChild(i)}}}showSuggestions(){this.suggestionsContainer&&(this.suggestionsContainer.classList.remove("hide"),this.suggestionsContainer.classList.add("show")),this.inputElement&&this.inputElement.setAttribute("aria-expanded","true"),this.inputContainer&&this.inputContainer.classList.add("suggestions-expanded")}hideSuggestions(){this.suggestionsContainer&&(this.suggestionsContainer.classList.remove("show"),this.suggestionsContainer.classList.add("hide")),this.inputElement&&this.inputElement.setAttribute("aria-expanded","false"),this.inputContainer&&this.inputContainer.classList.remove("suggestions-expanded")}createElement(n,i){const r=document.createElement(n);return i&&Object.assign(r,i),r}createErrorContainer(){const n=this.createElement("div",{className:"error-message"});n.style.display="none",n.setAttribute("role","alert"),n.setAttribute("aria-live","assertive"),n.setAttribute("aria-atomic","true");const i=this.createElement("span",{className:"error-icon",textContent:"⚠️"}),r=this.createElement("span",{className:"error-text"});return n.appendChild(i),n.appendChild(r),n}createCheckButton(){const n=this.createElement("button",{type:"button",className:"primary-button",textContent:"Save"});return n.setAttribute("aria-label","Save and check address availability"),n.addEventListener("click",this.handleCheckAvailability),n}createCancelButton(){const n=this.createElement("button",{type:"button",className:"secondary-button",textContent:"Cancel"});return n.setAttribute("aria-label","Cancel address selection"),n.addEventListener("click",this.handleCancel),n}template(){var n,i,r;const s=this.getConfigs("global"),a=null!==(n=this.params.options)&&void 0!==n?n:{},l=null!==(i=a.showLabel)&&void 0!==i?i:!![];if(this.inputContainer=this.createElement("div",{className:"input-section"}),l){const n=this.createElement("h2",{className:"input-title",textContent:"Enter delivery address"});this.inputContainer.appendChild(n)}const d=this.createElement("div",{className:"input-wrapper "+s.layout.inputFieldStyle});this.inputElement=this.createElement("input",{type:"text",id:"address-input",className:"input-field",value:(null===(r=this.selectedAddress)||void 0===r?void 0:r.formattedAddress)||"",autocomplete:"off",placeholder:"Enter an address"}),this.inputElement.setAttribute("role","combobox"),this.inputElement.setAttribute("aria-label","Enter delivery address"),this.inputElement.setAttribute("aria-autocomplete","list"),this.inputElement.setAttribute("aria-controls","address-suggestions"),this.inputElement.setAttribute("aria-expanded","false"),this.inputElement.setAttribute("aria-haspopup","listbox"),this.inputElement.addEventListener("input",this.handleInputChange),d.appendChild(this.inputElement);const u=this.createElement("span");u.className="input-icon",u.innerHTML=SearchIcon({width:16,height:16,className:""}),d.appendChild(u),this.inputContainer.appendChild(d),this.suggestionsContainer=this.createElement("ul",{className:"suggestions-list hide"}),this.suggestionsContainer.setAttribute("id","address-suggestions"),this.suggestionsContainer.setAttribute("role","listbox"),this.suggestionsContainer.setAttribute("aria-label","Address suggestions"),this.inputContainer.appendChild(this.suggestionsContainer),this.errorContainer=this.createErrorContainer();const f=this.createElement("span",{className:"privacy-notice",textContent:"This site is protected by reCAPTCHA and the Google Privacy Policy and Terms of Service apply."}),g=[this.inputContainer,f,this.errorContainer],v=this.createElement("div",{className:"action-buttons"}),b=this.createCancelButton();v.appendChild(b);const x=this.createCheckButton();return v.appendChild(x),g.push(v),document.addEventListener("click",this.handleDocumentClick),g}disconnected(){this.searchTimeout&&clearTimeout(this.searchTimeout),document.removeEventListener("click",this.handleDocumentClick)}}class CartComponent extends BaseComponent{get hostClasses(){const n=["cart-container"];return this.params.isIndependentComponent&&!this.clientConfig.isBuilder()&&n.push("cart-no-header"),this.params.isIndependentComponent&&n.push("independent"),n}constructor(){super({watchStorePaths:["cart.rerender"]})}template(){const n=[],i=this.params.isIndependentComponent&&!this.clientConfig.isBuilder();if(!i){const i=ComponentFactoryService.createElement({type:C.CART_HEADER});n.push(i)}const r=ComponentFactoryService.createElement({type:C.CART_BODY});n.push(r);const s=ComponentFactoryService.createElement({type:C.CART_FOOTER});return n.push(s),n}}class CartBodyComponent extends BaseComponent{get hostClasses(){return["cart-body"]}constructor(){super({watchStorePaths:["cart.retailers","cart.loading"]})}createEmptyCartElement(){const n=document.createElement("div");n.className="empty-cart-container";const i=document.createElement("h3");return i.className="empty-cart-content",i.textContent="Your cart is empty",n.appendChild(i),n}createLoadingElement(){const n=document.createElement("div");return n.setAttribute("data-component-type","cart-body-loading"),n.innerHTML=this.loadingTemplate(),n}loadingTemplate(){return'\n <div class="cart-loading-backdrop">\n <div class="cart-loading-spinner-container">\n <div class="cart-loading-spinner">\n <svg class="cart-spinner" width="50" height="50" viewBox="0 0 50 50">\n <circle\n class="cart-spinner-path"\n cx="25"\n cy="25"\n r="20"\n fill="none"\n stroke-width="3"\n stroke-linecap="round"\n stroke-dasharray="31.416"\n stroke-dashoffset="31.416"\n />\n </svg>\n </div>\n </div>\n </div>\n '}createRetailerElement(n){try{return ComponentFactoryService.createElement({type:C.CART_RETAILER,retailerId:n.id})}catch(i){return this.logger.error("Cart retailer component creation failed",i),document.createElement("div")}}getRetailerElementById(n){return this.container.querySelector('[data-retailer-id="'+n+'"]')}getLoadingElement(){return this.container.querySelector('[data-component-type="cart-body-loading"]')}showEmptyCartState(){this.container.innerHTML="";const n=this.createEmptyCartElement();this.container.appendChild(n),this.setupEmptyCartListeners()}addLoadingOverlay(){const n=this.getLoadingElement();if(!n){const n=this.createLoadingElement();this.container.appendChild(n)}}removeLoadingOverlay(){const n=this.getLoadingElement();n&&n.remove()}setupEmptyCartListeners(){const n=this.container.querySelector('[data-action="continue-shopping"]');n&&n.addEventListener("click",()=>{this.commands.ui.closeDrawer()})}addRetailerElement(n,i){const r=this.createRetailerElement(i);r.setAttribute("data-retailer-id",n),this.container.appendChild(r)}removeRetailerElement(n){const i=this.getRetailerElementById(n);i&&i.remove()}updateRetailerElement(n,i){const r=this.getRetailerElementById(n);if(r){const s=this.createRetailerElement(i);s.setAttribute("data-retailer-id",n),r.replaceWith(s)}}hasRetailerDataChanged(n,i){return n?![]:!![]}getValidRetailers(n){if(!n)return{};const i={};for(const[r,s]of Object.entries(n))s&&"object"==typeof s&&s.id&&(i[r]=s);return i}getValidRetailerIds(n){const i=this.getValidRetailers(n);return new Set(Object.keys(i))}onStoreChanged(n){const i=n.find(n=>"cart.retailers"===n.path),r=n.find(n=>"cart.loading"===n.path);if(i){const n=this.getValidRetailers(i.oldValue),r=this.getValidRetailers(i.value),s=this.getValidRetailerIds(i.oldValue),a=this.getValidRetailerIds(i.value),l=s.size,d=a.size,u=this.getValidRetailers(this.getStoreValue("cart.retailers")),f=Object.keys(u).length;if(d>0&&0===f)return this.showEmptyCartState(),![];if(this.removeLoadingOverlay(),0===l&&d>0){this.container.innerHTML="";for(const[n,i]of Object.entries(r))this.addRetailerElement(n,i)}else if(l>0&&0===d)this.showEmptyCartState();else if(d>0){for(const n of s)a.has(n)||this.removeRetailerElement(n);for(const i of a){const a=r[i],l=n[i];s.has(i)?this.hasRetailerDataChanged(l,a)&&this.updateRetailerElement(i,a):this.addRetailerElement(i,a)}}else 0===l&&0===d&&this.showEmptyCartState()}if(r){const n=r.value,i=r.oldValue;n!==i&&(n?this.addLoadingOverlay():this.removeLoadingOverlay())}return r||i,![]}afterRender(){this.setupEmptyCartListeners();const n=this.getStoreValue("cart.loading");n&&this.addLoadingOverlay()}template(){const n=this.getStoreValue("cart.retailers")||{},i=Object.values(n);if(0===i.length)return this.createEmptyCartElement();const r=[];for(const s of i){const n=this.createRetailerElement(s);n.setAttribute("data-retailer-id",s.id),r.push(n)}return r}}class CartFooterComponent extends BaseComponent{get hostClasses(){return["cart-footer"]}constructor(){super({watchOnlyStorePaths:["cart.items","cart.totals","cart.fulfillments","cart.loading","cart.retailers"]})}onStoreWatch(n){const i=n.some(n=>n.path.includes("cart.items")),r=n.some(n=>n.path.includes("cart.totals")),s=n.some(n=>n.path.includes("cart.fulfillments")),a=n.some(n=>"cart.loading"===n.path),l=n.some(n=>n.path.includes("cart.retailers"));if(i&&this.updateSubtotalItemsCount(),r&&this.subtotalPrice){const n=this.getStoreValue("cart.totals");this.subtotalPrice.textContent=""+formatCentToDollarText(n.subtotal+n.engravingFee-n.discounts)}(s||r||a||i||l)&&this.updateCheckoutButtonState()}afterRender(){this.updateSubtotalItemsCount(),this.updateCheckoutButtonState()}isAnythingLoading(){const n=this.getStoreValue("cart.loading");if(n)return!![];const i=this.getStoreValue("cart.items")||{},r=Object.values(i).some(n=>n.updating);if(r)return!![];const s=this.getStoreValue("cart.fulfillments")||{},a=Object.values(s).some(n=>n.updating);if(a)return!![];const l=this.getStoreValue("cart.retailers")||{},d=Object.values(l).some(n=>n.updating);return d?!![]:![]}hasUnmetMinimum(n){var i;const r=n.subtotal;if(n.type===E.SHIPPING){const s=n.fees;if((null===(i=s.individual)||void 0===i?void 0:i.active)&&s.individual.min>0&&r<s.individual.min)return!![]}if(n.type===E.ON_DEMAND){const i=n.fees;if(i.min>0&&r<i.min)return!![]}return![]}shouldDisableCheckout(){const n=this.getStoreValue("cart.fulfillments")||{};return Object.values(n).some(n=>this.hasUnmetMinimum(n))}updateCheckoutButtonState(){const n=this.getStoreValue("cart.items")||{},i=Object.keys(n).length>0;if(this.checkoutButton){const n=this.isAnythingLoading(),r=this.shouldDisableCheckout(),s=n||r||!i;this.checkoutButton.disabled=s,this.checkoutButton.classList.toggle("checkout-btn-disabled",s),this.checkoutButton.classList.toggle("loading",n)}}updateSubtotalItemsCount(){const n=this.getStoreValue("cart.items"),i=Object.values(n).reduce((n,i)=>n+i.quantity,0);this.subtotalText&&(this.subtotalText.textContent="Subtotal ("+i+" item"+(1!==i?"s":"")+"):")}async handleCheckout(n){return this.clientConfig.isBuilder()?(n.preventDefault(),this.logger.info("Cart Go To Checkout Button Is Disabled In Builder Mode"),void 0):this.isAnythingLoading()||this.shouldDisableCheckout()?(n.preventDefault(),void 0):(await this.commands.cart.handleGoToCheckout(),void 0)}template(){const n=this.getConfigs("global"),i=this.getStoreValue("cart.totals"),r=[],s=document.createElement("div");s.className="cart-footer-header";const a=document.createElement("div");a.className="cart-footer-items-price",this.subtotalText=document.createElement("span"),this.subtotalText.className="subtotal-text",this.subtotalText.textContent="Subtotal (0 items):",a.appendChild(this.subtotalText),this.subtotalPrice=document.createElement("span"),this.subtotalPrice.className="subtotal-price",this.subtotalPrice.textContent=formatCentToDollarText(i.subtotal+i.engravingFee-i.discounts),a.appendChild(this.subtotalPrice);const l=document.createElement("p");if(l.textContent="Taxes & fees will be calculated at checkout",l.className="taxes-fees-info",s.appendChild(a),s.appendChild(l),r.push(s),n.layout.allowPromoCodes){const n=ComponentFactoryService.createElement({type:C.CART_PROMO_CODE});r.push(n)}const d=ComponentFactoryService.createElement({type:C.ALERT,errorStorePath:"cart.events",fromEvents:!![],showFirstEvent:![]});if(r.push(d),this.checkoutButton=document.createElement("button"),this.checkoutButton.type="button",this.checkoutButton.className="checkout-button",this.checkoutButton.setAttribute("aria-label","Go to checkout"),this.checkoutButton.textContent=this.config.layout.goToCheckoutButtonText||"Go to Checkout",this.checkoutButton.addEventListener("click",async n=>{n.preventDefault(),await this.handleCheckout(n)}),this.checkoutButton.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await this.handleCheckout(n))}),r.push(this.checkoutButton),n.layout.showPoweredBy){const n=ComponentFactoryService.createElement({type:C.POWERED_BY,context:"general"});r.push(n)}return r}}const shouldShowMinimumPurchaseAlert=(n,i=![])=>{var r,s;if(!n)return![];const a=n.subtotal;if(n.type===E.SHIPPING){const l=n.fees;if(i&&(null===(r=l.pack)||void 0===r?void 0:r.active)&&l.pack.min>0&&a<l.pack.min)return!![];if(!i&&(null===(s=l.individual)||void 0===s?void 0:s.active)&&l.individual.min>0&&a<l.individual.min)return!![]}else if(n.type===E.ON_DEMAND){const i=n.fees;if(i.min>0&&a<i.min)return!![]}return![]},getMinimumPurchaseMessage=(n,i=![])=>{var r,s;if(!n)return{message:"",type:"warning"};const a=n.subtotal;if(n.type===E.SHIPPING){const l=n.fees;let d=0;if(i&&(null===(r=l.pack)||void 0===r?void 0:r.active)&&l.pack.min>0?d=l.pack.min:(null===(s=l.individual)||void 0===s?void 0:s.active)&&l.individual.min>0&&(d=l.individual.min),d>0&&a<d)return{message:"+"+formatCentToDollarText(d-a)+" needed for order minimum",type:"warning"}}if(n.type===E.ON_DEMAND){const i=n.fees,r=i.min>0?i.min:0;if(r>0&&a<r)return{message:"+"+formatCentToDollarText(r-a)+" needed for order minimum",type:"warning"}}return{message:"",type:"warning"}},hasUnmetMinimum=(n,i=![])=>{var r,s;if(!n)return![];const a=n.subtotal;if(n.type===E.SHIPPING){const l=n.fees;if(i&&(null===(r=l.pack)||void 0===r?void 0:r.active)&&l.pack.min>0&&a<l.pack.min)return!![];if(!i&&(null===(s=l.individual)||void 0===s?void 0:s.active)&&l.individual.min>0&&a<l.individual.min)return!![]}if(n.type===E.ON_DEMAND){const i=n.fees;if(i.min>0&&a<i.min)return!![]}return![]};class PurchaseMinAlertComponent extends BaseComponent{get hostClasses(){return["alert","alert-"+this.params.messageType]}getIconElement(){const n=this.config||{};if(n.showIcon===![])return null;const i={warning:"warning",success:"success",info:"info"},r={warning:WarningIcon,success:SuccessIcon,info:InfoIcon},s=i[this.params.messageType]||"warning",a=document.createElement("div");return a.className="alert-icon alert-icon-"+this.params.messageType,a.appendChild(htmlStringToElement(r[s]({width:16,height:16,className:"alert-icon-svg"}))),a}template(){var n;const i=[],r=this.getIconElement();r&&i.push(r);const s=document.createElement("span");if(s.className="alert-message",s.textContent=this.params.message,i.push(s),"detailed"===(null===(n=this.config)||void 0===n?void 0:n.alertType)&&this.params.currentTotal){const n=document.createElement("div");n.className="alert-details";const r=document.createElement("small");r.className="alert-details-text",r.textContent="Current subtotal: "+formatCentToDollarText(this.params.currentTotal),n.appendChild(r),i.push(n)}return i}}class CartFulfillmentComponent extends BaseComponent{get hostClasses(){return["retailer-fulfillment-container"]}constructor(){super({watchStorePaths:["cart.fulfillments.{fulfillmentId}","cart.items"],autoDestroy:!![],autoDestroyPath:"cart.fulfillments.{fulfillmentId}"})}getFulfillmentId(){return this.params.fulfillmentId}getProductStore(){const n=this.getFulfillmentId(),i=this.getStoreValue("cart.fulfillments."+n+".items")||{};return Object.values(i).find(i=>i.fulfillmentId===n)}handleItemsUpdate(n,i){const r=new Set(n||[]),s=new Set(i||[]);for(const a of r)if(!s.has(a)){const n=this.container.querySelector('[data-item-id="'+a+'"]');n&&n.remove()}for(const a of s)if(!r.has(a)){const n=ComponentFactoryService.createElement({type:C.CART_ITEM,itemId:a});n.setAttribute("data-item-id",a),this.container.appendChild(n)}}setupItemElements(){const n=this.getFulfillmentId(),i=this.getStoreValue("cart.fulfillments."+n+".items")||[],r=this.container.querySelectorAll("[data-item-id]");for(const s of r)s.remove();for(const s of i){const n=ComponentFactoryService.createElement({type:C.CART_ITEM,itemId:s});n.setAttribute("data-item-id",s),this.container.appendChild(n)}}setupMinimumPurchaseAlert(){var n;const i=this.getFulfillmentId(),r=(null===(n=this.getProductStore())||void 0===n?void 0:n.pack)||![],s=this.getStoreValue("cart.fulfillments."+i),a=this.container.querySelector('[data-component-type="cart-retailer-alert"]');if(a&&a.remove(),s&&shouldShowMinimumPurchaseAlert(s,r)){const n=getMinimumPurchaseMessage(s,r),i=ComponentFactoryService.createElement({type:C.PURCHASE_MIN_ALERT,message:n.message,messageType:n.type,currentTotal:s.subtotal,config:{showIcon:!![],alertType:"minimal"}});i.setAttribute("data-component-type","cart-retailer-alert"),this.container.prepend(i)}}createLoadingOverlay(){const n=document.createElement("div");n.className="cart-loading-backdrop",n.setAttribute("data-loading-id","fulfillment-loading-overlay");const i=document.createElement("div");i.className="cart-loading-spinner-container";const r=document.createElement("div");return r.className="cart-loading-spinner",r.innerHTML='\n <svg class="cart-spinner" width="32" height="32" viewBox="0 0 50 50">\n <circle\n class="cart-spinner-path"\n cx="25"\n cy="25"\n r="20"\n fill="none"\n stroke-width="3"\n stroke-linecap="round"\n stroke-dasharray="31.416"\n stroke-dashoffset="31.416"\n />\n </svg>\n ',i.appendChild(r),n.appendChild(i),n}hasLoadingOverlay(){return!!this.container.querySelector('[data-loading-id="fulfillment-loading-overlay"]')}showLoadingOverlay(){if(this.hasLoadingOverlay())return;const n=this.createLoadingOverlay();this.container.appendChild(n),this.container instanceof HTMLElement&&(this.container.style.position="relative")}hideLoadingOverlay(){const n=this.container.querySelector('[data-loading-id="fulfillment-loading-overlay"]');n&&(n.remove(),this.container instanceof HTMLElement&&(this.container.style.position=""))}isAnyItemUpdating(){var n;const i=this.getFulfillmentId(),r=this.getStoreValue("cart.fulfillments."+i);return(null===(n=null==r?void 0:r.items)||void 0===n?void 0:n.length)?r.items.some(n=>{const i=this.getStoreValue("cart.items."+n);return(null==i?void 0:i.updating)===!![]}):![]}checkAndUpdateLoadingState(){const n=this.isAnyItemUpdating(),i=this.hasLoadingOverlay();n&&!i?this.showLoadingOverlay():!n&&i&&this.hideLoadingOverlay()}onStoreChanged(n){const i=this.getFulfillmentId(),r="cart.fulfillments."+i,s=n.find(n=>n.path===r),a=n.filter(n=>"cart.items"===n.path||n.path.startsWith("cart.items."));if(a.length>0&&this.checkAndUpdateLoadingState(),s){const n=s.oldValue,i=s.value,r=(null==n?void 0:n.items)||[],a=(null==i?void 0:i.items)||[],l=JSON.stringify(r)!==JSON.stringify(a);l&&(this.handleItemsUpdate(r,a),this.checkAndUpdateLoadingState());const d=this.hasFulfillmentFeesChanged(n,i),u=this.hasFulfillmentDataChanged(n,i,["items","updating"]);if(d&&!u&&this.setupMinimumPurchaseAlert(),!u)return![]}return![]}hasFulfillmentFeesChanged(n,i){return n?n.subtotal!==i.subtotal||n.shippingFee!==i.shippingFee||n.deliveryFee!==i.deliveryFee||JSON.stringify(n.fees)!==JSON.stringify(i.fees):!![]}hasFulfillmentDataChanged(n,i,r=[]){if(!n)return!![];const s=["type","canEngrave","retailerId"];for(const a of s)if(!r.includes(a)&&n[a]!==i[a])return!![];return![]}afterRender(){this.setupItemElements(),this.setupMinimumPurchaseAlert(),this.checkAndUpdateLoadingState()}disconnected(){this.hideLoadingOverlay()}template(){return[]}}const Dt={CT:"America/New_York",DE:"America/New_York",FL:"America/New_York",GA:"America/New_York",IN:"America/New_York",KY:"America/New_York",ME:"America/New_York",MD:"America/New_York",MA:"America/New_York",MI:"America/New_York",NH:"America/New_York",NJ:"America/New_York",NY:"America/New_York",NC:"America/New_York",OH:"America/New_York",PA:"America/New_York",RI:"America/New_York",SC:"America/New_York",TN:"America/New_York",VT:"America/New_York",VA:"America/New_York",WV:"America/New_York",AL:"America/Chicago",AR:"America/Chicago",IL:"America/Chicago",IA:"America/Chicago",KS:"America/Chicago",LA:"America/Chicago",MN:"America/Chicago",MS:"America/Chicago",MO:"America/Chicago",NE:"America/Chicago",ND:"America/Chicago",OK:"America/Chicago",SD:"America/Chicago",TX:"America/Chicago",WI:"America/Chicago",AZ:"America/Phoenix",CO:"America/Denver",ID:"America/Denver",MT:"America/Denver",NV:"America/Los_Angeles",NM:"America/Denver",UT:"America/Denver",WY:"America/Denver",CA:"America/Los_Angeles",OR:"America/Los_Angeles",WA:"America/Los_Angeles",AK:"America/Anchorage",HI:"Pacific/Honolulu"},At="America/New_York";function detectUserTimezone(n){try{if(n){const i=n.toUpperCase(),r=Dt[i];return r||At}return Intl.DateTimeFormat().resolvedOptions().timeZone}catch(i){return At}}function getCurrentTimeInTimezone(n){try{const i=new Date,r=i.getTime(),s=6e4*i.getTimezoneOffset(),a=new Date(r+s),l=new Date(a.toLocaleString("en-US",{timeZone:n})),d=a.getTime()-l.getTime();return new Date(r+d)}catch(i){return new Date}}function getCurrentTimeInUserTimezone(n){const i=detectUserTimezone(n);return getCurrentTimeInTimezone(i)}function isDateTimeInRange(n){const{startDate:i,endDate:r,addressState:s}=n;try{const n=getCurrentTimeInUserTimezone(s),a=!i||n>=new Date(i),l=!r||n<=new Date(r);return a&&l}catch(a){return![]}}function filterActiveItems(n,i){return n.filter(n=>isDateTimeInRange({startDate:n.activeFrom,endDate:n.activeUntil,addressState:i}))}function hasActiveItems(n,i){return filterActiveItems(n,i).length>0}class CartHeaderComponent extends BaseComponent{get hostClasses(){return["cart-header"]}template(){var n,i,r;const s=this.config.layout.drawerHeaderText,a=this.getConfigs("global"),l=document.createElement("div");l.className="cart-header-content";const d=document.createElement("h2");d.className="cart-title",d.textContent=s,l.appendChild(d);const u=document.createElement("button");u.type="button",u.className="cart-header-close-btn",u.innerHTML=CloseIcon({width:16,height:16}),u.setAttribute("aria-label","Close cart drawer"),u.addEventListener("click",()=>{this.commands.ui.closeDrawer()}),l.appendChild(u);const f=this.clientConfig.get("promoTicker"),g=null!==(i=null===(n=null==a?void 0:a.experienceFeatures)||void 0===n?void 0:n.promoTicker)&&void 0!==i?i:[],v=null!=f?f:g,b=this.store.get("address"),x=hasActiveItems(v,null===(r=null==b?void 0:b.address)||void 0===r?void 0:r.state);if(!v.length||!x)return[l];const w=ComponentFactoryService.createElement({context:"cart",type:C.PROMO_CODE_TICKER,tickers:v});return[l,w]}}class CartItemComponent extends BaseComponent{get hostClasses(){return["cart-item-container"]}get hostAttributes(){return{"data-item-id":this.params.itemId}}constructor(){super({watchStorePaths:["cart.items.{itemId}"],autoDestroy:!![],autoDestroyPath:"cart.items.{itemId}"})}handleOpenEngravingForm(n,i){var r,s,a,l,d,u,f,g,v,b;this.commands.ui.openDrawer(C.ENGRAVING_FORM,{identifier:n,context:"cart",lines:(null===(s=null===(r=i.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.lines)||[],maxLines:(null===(l=null===(a=i.attributes)||void 0===a?void 0:a.engraving)||void 0===l?void 0:l.maxLines)||1,maxCharsPerLine:(null===(u=null===(d=i.attributes)||void 0===d?void 0:d.engraving)||void 0===u?void 0:u.maxCharsPerLine)||16,fee:(null===(g=null===(f=i.attributes)||void 0===f?void 0:f.engraving)||void 0===g?void 0:g.fee)||0,location:null===(b=null===(v=i.attributes)||void 0===v?void 0:v.engraving)||void 0===b?void 0:b.location})}template(){var n,i,r,s,a,l,d,u,f;const g=this.params.itemId,v=this.getStoreValue("cart.items."+g),b=this.getConfigs("global"),x=this.getStoreValue("cart.fulfillments."+v.fulfillmentId),w=v.attributes.engraving.hasEngraving?"Ships in 10 days":(null===(n=null==x?void 0:x.expectation)||void 0===n?void 0:n.detail)||"",E=document.createElement("article");E.className="cart-item";const T=document.createElement("div");T.className="item-image";const A=document.createElement("img");A.src=v.mainImage,A.alt=v.name,T.appendChild(A);const P=document.createElement("div");P.className="item-details";const _=document.createElement("div");_.className="item-header";const N=document.createElement("h3");N.className="item-title",N.textContent=v.name;const F=document.createElement("button");F.className="item-delete",F.innerHTML=TrashIcon({}),F.setAttribute("role","button"),F.setAttribute("tabindex","0"),F.setAttribute("aria-label","Remove "+v.name+" from cart"),F.setAttribute("aria-expanded","true"),F.addEventListener("click",async()=>{await this.commands.cart.removeItem(g)}),F.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),this.commands.cart.removeItem(g))}),_.appendChild(N),_.appendChild(F);const R=document.createElement("div");R.className="item-specs",R.textContent=v.size+", "+v.container;const O=document.createElement("div");O.className="item-shipping-container";const L=document.createElement("div");if(L.className="item-shipping",L.textContent=w,O.appendChild(L),b.layout.enablePersonalization&&(null===(r=null===(i=null==v?void 0:v.attributes)||void 0===i?void 0:i.engraving)||void 0===r?void 0:r.isEngravable)&&(null===(a=null===(s=null==v?void 0:v.attributes)||void 0===s?void 0:s.engraving)||void 0===a?void 0:a.hasEngraving)===![]&&x.canEngrave){const n=document.createElement("span");n.className="cart-add-personalization-span",n.textContent=b.layout.personalizationText+" +"+formatCentToDollarText((null===(d=null===(l=v.attributes)||void 0===l?void 0:l.engraving)||void 0===d?void 0:d.fee)||0,![]),n.setAttribute("role","button"),n.setAttribute("tabindex","0"),n.setAttribute("aria-label","Add personalization to "+v.name),n.addEventListener("click",()=>this.handleOpenEngravingForm(g,v)),n.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),this.handleOpenEngravingForm(g,v))}),O.appendChild(n)}P.appendChild(_),P.appendChild(R),P.appendChild(O),E.appendChild(T),E.appendChild(P);const M=[E],B=ComponentFactoryService.createElement({type:C.CART_ITEM_QUANTITY_PRICE,itemId:g});if((null===(f=null===(u=null==v?void 0:v.attributes)||void 0===u?void 0:u.engraving)||void 0===f?void 0:f.hasEngraving)===!![]){const n=ComponentFactoryService.createElement({type:C.ENGRAVING_VIEW,identifier:g,context:"cart"});M.push(n)}return M.push(B),M}}class CartItemQuantityPriceComponent extends BaseComponent{get hostClasses(){return["quantity-price"]}constructor(){super({watchStorePaths:["cart.items.{itemId}"],watchOnlyStorePaths:["cart.items"]})}onStoreWatch(n){const i=n.find(n=>"cart.items"===n.path);if(i){const n=this.calculateQuantityLimits();this.updateButtonStates(n)}}getItemStore(){const n=this.params.itemId,i=this.getStoreValue("cart.items."+n);return i||null}calculateQuantityLimits(){const n=this.getItemStore();if(!n)return{currentQuantity:0,availableQuantity:0,canIncrease:![],canDecrease:!![]};const i=n.quantity,r=this.getAvailableQuantity(),s=r>0;return{currentQuantity:i,availableQuantity:r,canIncrease:s,canDecrease:!![]}}getAvailableQuantity(){var n,i,r,s;const a=this.getItemStore();if(!a)return 0;const l=a.partNumber,d=a.fulfillmentId,u=this.getStoreValue("cart.items")||{},f=Object.values(u).filter(n=>n.partNumber===l&&n.fulfillmentId===d),g=f.reduce((n,i)=>n+i.quantity,0),v=this.getStoreValue("products."+a.upc)||this.getStoreValue("products."+a.salsifyGrouping);if(!v)return a.maxQuantity-g;const b=null!==(s=null===(r=null===(i=null===(n=null==v?void 0:v.sizes)||void 0===n?void 0:n[a.liquidId])||void 0===i?void 0:i.attributes)||void 0===r?void 0:r.maxQuantityPerOrder)&&void 0!==s?s:0;return!b||b<=0?a.maxQuantity-g:b-g}updateButtonStates(n){this.qtyDecreaseButton&&(this.qtyDecreaseButton.disabled=!n.canDecrease,this.qtyDecreaseButton.classList.toggle("quantity-btn-disabled",!n.canDecrease)),this.qtyIncreaseButton&&(this.qtyIncreaseButton.disabled=!n.canIncrease,this.qtyIncreaseButton.classList.toggle("quantity-btn-disabled",!n.canIncrease)),this.quantitySpan&&(this.quantitySpan.textContent=n.currentQuantity.toString(),this.quantitySpan.setAttribute("aria-label","Current quantity: "+n.currentQuantity))}async handleQuantityChange(n){const i=this.calculateQuantityLimits();n>0&&!i.canIncrease||await this.commands.cart.updateItemQuantity(this.params.itemId,n)}createQuantityContainer(){const n=this.calculateQuantityLimits(),i=this.getItemStore();if(!i)return document.createElement("div");const r=document.createElement("div");return r.className="item-quantity "+this.config.layout.quantityCounterStyle,this.qtyDecreaseButton=document.createElement("button"),this.qtyDecreaseButton.type="button",this.qtyDecreaseButton.className="quantity-btn-decrease",this.qtyDecreaseButton.textContent="−",this.qtyDecreaseButton.setAttribute("aria-label","Decrease quantity"),this.qtyDecreaseButton.addEventListener("click",async n=>{n.preventDefault(),n.stopPropagation(),await this.handleQuantityChange(-1)}),this.quantitySpan=document.createElement("span"),this.quantitySpan.className="quantity-value",this.qtyIncreaseButton=document.createElement("button"),this.qtyIncreaseButton.type="button",this.qtyIncreaseButton.className="quantity-btn-increase",this.qtyIncreaseButton.textContent="+",this.qtyIncreaseButton.setAttribute("aria-label","Increase quantity"),this.qtyIncreaseButton.addEventListener("click",async n=>{n.preventDefault(),n.stopPropagation(),await this.handleQuantityChange(1)}),this.updateButtonStates(n),r.appendChild(this.qtyDecreaseButton),r.appendChild(this.quantitySpan),r.appendChild(this.qtyIncreaseButton),r}createPriceContainer(){const n=this.getItemStore();if(!n)return document.createElement("div");const i=document.createElement("div");i.className="item-price-container";const r=document.createElement("span");if(r.className="item-price",r.textContent=formatCentToDollarText(n.price),i.appendChild(r),n.quantity>1){const r=document.createElement("span");r.className="item-price-per-unit",r.textContent="("+formatCentToDollarText(n.unitPrice)+" ea)",i.appendChild(r)}return i}template(){const n=[];if(this.config.layout.showQuantityCounter){const i=this.createQuantityContainer();n.push(i)}const i=this.createPriceContainer();return n.push(i),n}}class CartPromoCodeComponent extends BaseComponent{get hostClasses(){return["promo-container-wrapper"]}constructor(){super({watchOnlyStorePaths:["cart.promoCode"]}),this.isApplying=![],this.promoInput=null,this.applyButton=null,this.promoCodePill=null}onStoreWatch(n){const i=n.find(n=>"cart.promoCode"===n.path);if(i){const{value:n,oldValue:r}=i,s=Boolean(null==r?void 0:r.code),a=Boolean(null==n?void 0:n.code);if(!s&&a)return this.container.innerHTML="",this.createAppliedContainer(n),void 0;if(s&&!a)return this.container.innerHTML="",this.createInputContainer(),void 0;if(a&&this.promoCodePill&&n.discountAmount!==(null==r?void 0:r.discountAmount))return this.promoCodePill.textContent=n.code+" (- "+formatCentToDollarText(n.discountAmount)+")",void 0}}createAppliedContainer(n){const i=document.createElement("div");i.classList.add("promo-applied-container"),this.promoCodePill=document.createElement("div"),this.promoCodePill.classList.add("promo-code-pill"),this.promoCodePill.textContent=(null==n?void 0:n.code)+" (- "+formatCentToDollarText((null==n?void 0:n.discountAmount)||0)+")";const r=document.createElement("button");r.type="button",r.classList.add("promo-remove-btn"),r.textContent="Remove",r.setAttribute("role","button"),r.setAttribute("aria-label","Remove promo code "+(null==n?void 0:n.code)),r.setAttribute("tabindex","0"),r.addEventListener("click",async()=>{await this.commands.cart.removePromoCode()}),r.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||this.commands.cart.removePromoCode()}),i.appendChild(this.promoCodePill),i.appendChild(r),this.container.appendChild(i),this.promoInput=null,this.applyButton=null}createInputContainer(){const n=document.createElement("div");n.classList.add("promo-code-container");const i=document.createElement("div");i.classList.add("promo-container"),i.appendChild(this.createPromoInput()),i.appendChild(this.createApplyButton()),n.appendChild(i),this.container.appendChild(n),this.promoCodePill=null}updateApplyButtonState(){if(!this.applyButton||!this.promoInput)return;const n=this.promoInput.getValue().replace(/[^a-zA-Z0-9]/g,"").trim(),i=n.length>=3&&n.length<=255,r=this.getStoreValue("cart.loading"),s=this.getStoreValue("cart.promoCode"),a=this.getStoreValue("cart.events")||[],l=hasCartAnyPromoCodeEvents(a);this.applyButton.disabled=!i||r||Boolean(null==s?void 0:s.discountAmount)||this.isApplying||l}createPromoInput(){const n=this.getConfigs("global");return this.promoInput=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:"promoCode",placeholder:"Enter promo code",autocomplete:![],className:"promo-input "+n.layout.inputFieldStyle,validation:{min:3,max:255},onChange:n=>{const i=n.toUpperCase(),r=this.promoInput;r.setValue(i),this.updateApplyButtonState()}}),this.promoInput}createApplyButton(){this.applyButton=document.createElement("button"),this.applyButton.type="button",this.applyButton.classList.add("apply-button"),this.applyButton.disabled=!![],this.applyButton.textContent="Apply",this.applyButton.setAttribute("tabindex","0"),this.applyButton.setAttribute("role","button"),this.applyButton.setAttribute("aria-label","Apply promo code");const m=async()=>{const n=this.promoInput.getValue().trim().toUpperCase();if(n)try{this.isApplying=!![],this.applyButton.disabled=!![],this.applyButton.setAttribute("aria-label","Applying promo code"),await this.commands.cart.applyPromoCode(n),this.applyButton.setAttribute("aria-label","Apply promo code")}catch(i){this.logger.error("Cart promo code application failed",{promoCode:n,error:i instanceof Error?i.message:String(i)})}};return this.applyButton.addEventListener("click",m),this.applyButton.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),m())}),this.applyButton}template(){const n=this.getStoreValue("cart.promoCode");if(this.promoInput=null,this.applyButton=null,this.promoCodePill=null,null==n?void 0:n.code){const i=document.createElement("div");i.classList.add("promo-applied-container"),this.promoCodePill=document.createElement("div"),this.promoCodePill.classList.add("promo-code-pill"),this.promoCodePill.textContent=n.code+" (- "+formatCentToDollarText(n.discountAmount)+")";const r=document.createElement("button");return r.type="button",r.classList.add("promo-remove-btn"),r.textContent="Remove",r.setAttribute("role","button"),r.setAttribute("aria-label","Remove promo code "+n.code),r.setAttribute("tabindex","0"),r.addEventListener("click",async()=>{await this.commands.cart.removePromoCode()}),r.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||this.commands.cart.removePromoCode()}),i.appendChild(this.promoCodePill),i.appendChild(r),i}const i=document.createElement("div");i.classList.add("promo-code-container");const r=document.createElement("div");return r.classList.add("promo-container"),r.appendChild(this.createPromoInput()),r.appendChild(this.createApplyButton()),i.appendChild(r),i}disconnected(){this.promoInput=null,this.applyButton=null,this.promoCodePill=null}}class CartRetailerComponent extends BaseComponent{constructor(){super({watchStorePaths:["cart.retailers.{retailerId}"],autoDestroy:!![],autoDestroyPath:"cart.retailers.{retailerId}"})}getRetailerId(){return this.params.retailerId}createFulfillmentElement(n){return ComponentFactoryService.createElement({type:C.CART_FULFILLMENT,fulfillmentId:n})}getFulfillmentElementById(n){return this.container.querySelector('[data-fulfillment-id="'+n+'"]')}getFulfillmentContainer(){return this.container.querySelector("#retailer-fulfillment-container")}getFulfillmentInsertionPoint(){const n=this.getFulfillmentContainer();if(n)return{parent:n.parentElement,nextSibling:n.nextElementSibling};const i=this.container.querySelectorAll("[data-fulfillment-id]");if(i.length>0){const n=i[i.length-1];return{parent:n.parentElement,nextSibling:n.nextElementSibling}}return null}addFulfillmentElement(n){const i=this.getFulfillmentInsertionPoint();if(i){const r=this.createFulfillmentElement(n);r.setAttribute("data-fulfillment-id",n);const s=this.getFulfillmentContainer();s&&s.remove(),i.nextSibling?i.parent.insertBefore(r,i.nextSibling):i.parent.appendChild(r)}}removeFulfillmentElement(n){const i=this.getFulfillmentElementById(n);if(i){const n=i.parentElement,r=i.nextElementSibling;i.remove();const s=this.container.querySelectorAll("[data-fulfillment-id]");if(0===s.length){const i=document.createElement("div");i.id="retailer-fulfillment-container",r?n.insertBefore(i,r):n.appendChild(i)}}}handleFulfillmentsUpdate(n,i){const r=new Set(n||[]),s=new Set(i||[]);for(const a of r)s.has(a)||this.removeFulfillmentElement(a);for(const a of s)r.has(a)||this.addFulfillmentElement(a)}setupFulfillmentElements(){const n=this.getRetailerId(),i=this.getStoreValue("cart.retailers."+n+".fulfillments")||[],r=this.container.querySelectorAll("[data-fulfillment-id]");for(const a of r)a.remove();let s=this.getFulfillmentContainer();if(!s){const n=this.container.querySelector(".retailer-body-container"),i=this.container.querySelector("#retailer-subtotal-container");s=document.createElement("div"),s.id="retailer-fulfillment-container",n&&i&&n.insertBefore(s,i)}for(const a of i)this.addFulfillmentElement(a)}setupSubtotalElement(){const n=this.getRetailerId(),i=this.container.querySelector("#retailer-subtotal-container");if(i){const r=ComponentFactoryService.createElement({type:C.CART_RETAILER_SUBTOTAL,retailerId:n});i.replaceWith(r)}}onStoreChanged(n){const i=this.getRetailerId(),r="cart.retailers."+i,s=n.find(n=>n.path===r);if(s){const n=s.oldValue,i=s.value,r=(null==n?void 0:n.fulfillments)||[],a=(null==i?void 0:i.fulfillments)||[];JSON.stringify(r)!==JSON.stringify(a)&&this.handleFulfillmentsUpdate(r,a)}return![]}afterRender(){this.setupFulfillmentElements(),this.setupSubtotalElement(),this.setupSectionToggle()}setupSectionToggle(){const n=this.container.querySelector(".section-toggle"),i=this.container.querySelector(".retailer-section"),r=this.container.querySelector(".section-header-label");if(n&&i&&r){const D=()=>{const i=n.checked;r.setAttribute("aria-label",i?"Expand retailer section":"Collapse retailer section"),r.setAttribute("aria-expanded",i?"false":"true")};n.addEventListener("change",()=>{n.checked?i.classList.add("collapsed"):i.classList.remove("collapsed"),D()}),r.addEventListener("keydown",i=>{"Enter"!==i.key&&" "!==i.key||(i.preventDefault(),n.click())}),n.checked?i.classList.add("collapsed"):i.classList.remove("collapsed"),D()}}template(){const n=this.getRetailerId(),i=this.getStoreValue("cart.retailers."+n),r=document.createElement("section");r.className="retailer-section";const s=document.createElement("div");s.className="cart-retailer-header";const a=document.createElement("div");a.className="retailer-info";const l=document.createElement("h2");l.className="section-title",l.textContent=i.name,a.appendChild(l);const d=document.createElement("input");d.type="checkbox",d.id=i.id,d.className="section-toggle",a.appendChild(d);const u=document.createElement("label");u.htmlFor=i.id,u.className="section-header-label",u.setAttribute("role","button"),u.setAttribute("tabindex","0"),u.setAttribute("aria-label","Collapse retailer section"),u.setAttribute("aria-expanded","true");const f=document.createElement("span");f.className="chevron",f.innerHTML=ChevronDownIcon({width:20,height:20,className:"chevron-down-icon"}),u.appendChild(f),a.appendChild(u),s.appendChild(a),r.appendChild(s);const g=document.createElement("div");g.className="retailer-body-container";const v=document.createElement("div");v.id="retailer-fulfillment-container",g.appendChild(v);const b=document.createElement("div");return b.id="retailer-subtotal-container",g.appendChild(b),r.appendChild(g),r}}class CartRetailerSubtotalComponent extends BaseComponent{get hostClasses(){return["retailer-subtotal-container"]}constructor(){super({watchStorePaths:["cart.retailers.{retailerId}"],autoDestroy:!![],autoDestroyPath:"cart.retailers.{retailerId}"})}getRetailerItemCount(n,i){const r=Object.values(n||{}).filter(n=>n.retailerId===i);let s=0;for(const a of r)s+=a.quantity;return s}template(){const n=this.params.retailerId,i=this.getStoreValue("cart.retailers."+n+".subtotal")||0,r=this.getStoreValue("cart.retailers."+n+".engravingFee")||0,s=this.getStoreValue("cart.items"),a=this.getRetailerItemCount(s,n),l=1===a?"item":"items",d=document.createElement("h3");d.className="retailer-subtotal-header",d.textContent="Subtotal ("+a+" "+l+"):";const u=document.createElement("span");return u.className="retailer-subtotal-amount",u.textContent=formatCentToDollarText(i+r),[d,u]}}class CheckoutComponent extends BaseComponent{constructor(){super({watchStorePaths:["checkout.rerender","checkout.presale"]})}template(){var n,i,r;const s=this.store.get("checkout.presale"),a=this.getConfigs("global"),l=this.clientConfig.get("promoTicker"),d=null!==(i=null===(n=null==a?void 0:a.experienceFeatures)||void 0===n?void 0:n.promoTicker)&&void 0!==i?i:[],u=null!=l?l:d,f=this.store.get("address"),g=hasActiveItems(u,null===(r=null==f?void 0:f.address)||void 0===r?void 0:r.state),v=this.params.isIndependentComponent&&!this.clientConfig.isBuilder(),b=document.createElement("div");b.classList.add("checkout-container"),v&&b.classList.add("no-header"),this.params.isIndependentComponent&&b.classList.add("independent");const x=ComponentFactoryService.createElement({type:C.CHECKOUT_INFORMATION});b.appendChild(x);const w=ComponentFactoryService.createElement({type:C.CHECKOUT_ORDER_SUMMARY});if(b.appendChild(w),!s&&(!u.length||!g)&&v)return[b];const E=document.createElement("div");if(E.classList.add("checkout-header-wrapper"),!v){const n=ComponentFactoryService.createElement({type:C.CHECKOUT_HEADER});E.appendChild(n)}if(u.length&&g&&!s){const n=ComponentFactoryService.createElement({context:"checkout",type:C.PROMO_CODE_TICKER,tickers:u});E.appendChild(n)}if(s){const n=ComponentFactoryService.createElement({type:C.CHECKOUT_PRESALE_COUNTDOWN});E.appendChild(n)}return[E,b]}}class CheckoutAmountsComponent extends BaseComponent{get hostClasses(){return["checkout-amounts-container"]}constructor(){super({watchStorePaths:["checkout.amounts"]})}template(){var n,i,r;const s=this.getStoreValue("checkout"),a=Boolean(s.promoCode),l=Boolean(null===(n=s.giftCards)||void 0===n?void 0:n.length),d=this.getConfigs("global"),u=Object.keys(s.onDemandFulfillmentTipInfo||{}).length>0,f=Object.values(s.items||{}),g=[],v=document.createElement("div");v.classList.add("checkout-amount-line");const b=document.createElement("span");b.textContent="Subtotal ("+f.length+" item"+(f.length>1?"s":"")+")",v.appendChild(b);const x=document.createElement("span");x.textContent=formatCentToDollarText(s.amounts.subtotal),v.appendChild(x),g.push(v);const w=document.createElement("div");w.classList.add("checkout-amount-line");const C=document.createElement("span");C.textContent="Shipping",w.appendChild(C);const E=document.createElement("span");E.textContent=formatCentToDollarText(s.amounts.shipping),w.appendChild(E),g.push(w);const T=document.createElement("div");T.classList.add("checkout-amount-line");const A=document.createElement("span");A.textContent="Delivery",T.appendChild(A);const P=document.createElement("span");if(P.textContent=formatCentToDollarText(s.amounts.delivery),T.appendChild(P),g.push(T),(null===(i=null==s?void 0:s.amounts)||void 0===i?void 0:i.engraving)>0){const n=document.createElement("div");n.classList.add("checkout-amount-line");const i=document.createElement("span");i.textContent="Engraving",n.appendChild(i);const r=document.createElement("span");r.textContent=formatCentToDollarText(s.amounts.engraving),n.appendChild(r),g.push(n)}const _=document.createElement("div");_.classList.add("checkout-amount-line");const N=document.createElement("span");N.textContent="Taxes & Fees",_.appendChild(N);const F=document.createElement("span");if(F.textContent=formatCentToDollarText(s.amounts.tax+s.amounts.service+s.amounts.platform),_.appendChild(F),g.push(_),a){const n=document.createElement("div");n.classList.add("checkout-amount-line");const i=document.createElement("span");i.textContent="Promo Code ("+(null===(r=s.promoCode)||void 0===r?void 0:r.code.toUpperCase())+")",n.appendChild(i);const a=document.createElement("span");a.textContent="-"+formatCentToDollarText(s.amounts.discounts),n.appendChild(a),g.push(n)}if(l){const n=document.createElement("div");n.classList.add("checkout-amount-line");const i=document.createElement("span");i.textContent="Gift Cards Applied",n.appendChild(i);const r=document.createElement("span");r.textContent="-"+formatCentToDollarText(s.amounts.giftCards),n.appendChild(r),g.push(n)}if(u){const n=document.createElement("div");n.classList.add("checkout-amount-line");const i=document.createElement("span");i.textContent="Tips",n.appendChild(i);const r=document.createElement("span");r.textContent=formatCentToDollarText(s.amounts.tip),n.appendChild(r),g.push(n)}const R=document.createElement("div");R.classList.add("checkout-separator"),g.push(R);const O=document.createElement("div");O.classList.add("checkout-amount-total");const L=document.createElement("span");L.textContent="Total",O.appendChild(L);const M=document.createElement("span");if(M.textContent=formatCentToDollarText(s.amounts.total),O.appendChild(M),g.push(O),s.presale){const n=document.createElement("div");n.classList.add("checkout-amount-due");const i=document.createElement("span");i.textContent="Amount due today",n.appendChild(i);const r=document.createElement("span");r.textContent=formatCentToDollarText(0),n.appendChild(r),g.push(n);const s=document.createElement("div");s.classList.add("checkout-presale-locked-message");const a=htmlStringToElement(InfoIcon({color:d.theme.defaultTextColor}));s.appendChild(a);const l=document.createElement("p");l.textContent="Pre-ordered items will be charged when shipped.",s.appendChild(l),g.push(s)}return g}}const Pt="lce-checkout-stripe-slot",_t={firstName:"firstName",lastName:"lastName",email:"email",phone:"phone",birthDate:"birthDate",addressTwo:"addressTwo",company:"company"},Nt={firstName:"firstName",lastName:"lastName",email:"email",phone:"phone",addressTwo:"addressTwo",message:"message"},Ft={firstName:"firstName",lastName:"lastName",email:"email",phone:"phone",company:"company",addressOne:"addressOne",addressTwo:"addressTwo",city:"city",state:"state",zipCode:"zipCode"};class CheckoutBillingComponent extends BaseComponent{get hostClasses(){return["checkout-billing-form"]}constructor(){super({watchStorePaths:["checkout.paymentForm.billingSameAsShipping"]}),this.billingData={firstName:{isValid:![],value:""},lastName:{isValid:![],value:""},email:{isValid:![],value:""},phone:{isValid:![],value:""},company:{isValid:!![],value:""},addressOne:{isValid:![],value:""},addressTwo:{isValid:!![],value:""},city:{isValid:![],value:""},state:{isValid:![],value:""},zipCode:{isValid:![],value:""}}}billingSameAsShippingToggle(){const n=this.getStoreValue("checkout.paymentForm.billingSameAsShipping"),i=document.createElement("div");i.classList.add("checkout-billing-same-as-shipping-toggle-container");const r=document.createElement("div");r.classList.add("checkout-checkbox-container");const s=document.createElement("span");s.id="billingSameAsShipping",s.classList.add("checkout-checkbox-visual"),s.setAttribute("role","checkbox"),s.setAttribute("tabindex","0"),s.setAttribute("aria-label","Billing same as shipping checkbox"),s.setAttribute("aria-checked",n?"true":"false"),n&&s.classList.add("checked"),s.innerHTML=CheckboxIcon({width:16,height:16}),i.addEventListener("click",async()=>{await this.commands.checkout.toggleBillingSameAsShipping()}),i.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await this.commands.checkout.toggleBillingSameAsShipping())});const a=document.createElement("label");return a.textContent="Billing address same as shipping address",a.setAttribute("for","billingSameAsShipping"),a.classList.add("billing-checkbox-label"),r.appendChild(s),r.appendChild(a),i.appendChild(r),i}updateSaveButtonState(){const n=!Object.values(this.billingData).every(n=>n.isValid),i={firstName:this.billingData.firstName.value,lastName:this.billingData.lastName.value,email:this.billingData.email.value,phone:this.billingData.phone.value,company:this.billingData.company.value,addressOne:this.billingData.addressOne.value,addressTwo:this.billingData.addressTwo.value,city:this.billingData.city.value,state:this.billingData.state.value,zipCode:this.billingData.zipCode.value};this.params.isFormValid(!n,i)}template(){const n=this.getStoreValue("checkout.paymentForm"),i=[],r=this.billingSameAsShippingToggle();if(i.push(r),n.billingSameAsShipping)return i;n.data&&(n.data.firstName&&(this.billingData.firstName={isValid:!![],value:n.data.firstName}),n.data.lastName&&(this.billingData.lastName={isValid:!![],value:n.data.lastName}),n.data.email&&(this.billingData.email={isValid:!![],value:n.data.email}),n.data.phone&&(this.billingData.phone={isValid:!![],value:n.data.phone}),n.data.company&&(this.billingData.company={isValid:!![],value:n.data.company}),n.data.addressOne&&(this.billingData.addressOne={isValid:!![],value:n.data.addressOne}),n.data.addressTwo&&(this.billingData.addressTwo={isValid:!![],value:n.data.addressTwo}),n.data.city&&(this.billingData.city={isValid:!![],value:n.data.city}),n.data.state&&(this.billingData.state={isValid:!![],value:n.data.state}),n.data.zipCode&&(this.billingData.zipCode={isValid:!![],value:n.data.zipCode})),this.updateSaveButtonState();const s=document.createElement("div");s.classList.add("section-title-container");const a=document.createElement("h3");a.textContent="Your billing info",a.classList.add("section-title"),s.appendChild(a);const l=document.createElement("p");l.textContent="Provide the info relevant to your payment method",l.classList.add("section-subtitle"),s.appendChild(l),i.push(s);const d=document.createElement("div");d.classList.add("section-form-container");const u=document.createElement("div");u.classList.add("checkout-two-col-container");const f=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:Ft.firstName,label:"First Name",autocomplete:!![],validation:{required:!![]},onChange:async n=>{this.billingData.firstName.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.firstName})},onValidation:n=>{this.billingData.firstName.isValid=n,this.updateSaveButtonState()}});f.setAttribute("aria-label","First name input"),u.appendChild(f);const g=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:Ft.lastName,label:"Last Name",autocomplete:!![],validation:{required:!![]},onChange:async n=>{this.billingData.lastName.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.lastName})},onValidation:n=>{this.billingData.lastName.isValid=n,this.updateSaveButtonState()}});g.setAttribute("aria-label","Last name input"),u.appendChild(g),d.appendChild(u);const v=ComponentFactoryService.createElement({type:C.INPUT,inputType:"email",name:Ft.email,label:"Email",autocomplete:!![],validation:{required:!![]},onChange:async n=>{this.billingData.email.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.email})},onValidation:n=>{this.billingData.email.isValid=n,this.updateSaveButtonState()}});v.setAttribute("aria-label","Email input"),d.appendChild(v);const b=document.createElement("div");b.classList.add("checkout-two-col-container");const x=ComponentFactoryService.createElement({type:C.INPUT,inputType:"tel",name:Ft.phone,label:"Phone",autocomplete:!![],validation:{required:!![]},onChange:async n=>{this.billingData.phone.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.phone})},onValidation:n=>{this.billingData.phone.isValid=n,this.updateSaveButtonState()}});x.setAttribute("aria-label","Phone input"),b.appendChild(x);const E=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:Ft.company,label:"Company (optional)",autocomplete:!![],onChange:async n=>{this.billingData.company.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.company})},onValidation:n=>{this.billingData.company.isValid=n,this.updateSaveButtonState()}});E.setAttribute("aria-label","Company input"),b.appendChild(E),d.appendChild(b);const T=document.createElement("div");T.classList.add("checkout-two-col-container");const A=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:Ft.addressOne,label:"Street Address",autocomplete:!![],validation:{required:!![]},onChange:async n=>{this.billingData.addressOne.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.addressOne})},onValidation:n=>{this.billingData.addressOne.isValid=n,this.updateSaveButtonState()}});A.setAttribute("aria-label","Street address input"),T.appendChild(A);const P=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:Ft.addressTwo,label:"Apt, suite, etc. (optional)",onChange:async n=>{this.billingData.addressTwo.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.addressTwo})},onValidation:n=>{this.billingData.addressTwo.isValid=n,this.updateSaveButtonState()}});P.setAttribute("aria-label","Apt, suite, etc. (optional) input"),T.appendChild(P),d.appendChild(T);const _=document.createElement("div");_.classList.add("checkout-three-col-container");const N=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:Ft.city,label:"City",autocomplete:!![],validation:{required:!![]},onChange:async n=>{this.billingData.city.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.city})},onValidation:n=>{this.billingData.city.isValid=n,this.updateSaveButtonState()}});N.setAttribute("aria-label","City input"),_.appendChild(N);const F=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:Ft.state,label:"State",autocomplete:!![],placeholder:"NY",validation:{required:!![],customValidator:n=>n&&2===n.length&&/^[A-Z]{2}$/.test(n)?null:"State must be 2 uppercase characters"},onChange:async n=>{this.billingData.state.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.state})},onValidation:n=>{this.billingData.state.isValid=n,this.updateSaveButtonState()}});F.setAttribute("aria-label","State input"),_.appendChild(F);const R=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:Ft.zipCode,label:"Zip Code",autocomplete:!![],validation:{required:!![]},onChange:async n=>{this.billingData.zipCode.value=n,this.pubSub.publishForm(w.BILLING,{fieldName:Ft.zipCode})},onValidation:n=>{this.billingData.zipCode.isValid=n,this.updateSaveButtonState()}});return R.setAttribute("aria-label","Zip Code input"),_.appendChild(R),d.appendChild(_),i.push(d),i}}class CheckoutBuyer extends BaseComponent{get hostClasses(){return["checkout-buyer-information"]}constructor(){super({watchStorePaths:["checkout.customerForm.data"],watchOnlyStorePaths:["checkout.customerForm.isSaving"]}),this.customerData={firstName:{isValid:![],value:""},lastName:{isValid:![],value:""},email:{isValid:![],value:""},phone:{isValid:![],value:""},addressTwo:{isValid:![],value:""},company:{isValid:![],value:""},birthDate:{isValid:![],value:""}},this.saveButtonText="Save Buyer Information"}onStoreWatch(n){const i=n.find(n=>"checkout.customerForm.isSaving"===n.path);i&&(i.value?(this.saveButton.textContent="Saving...",this.saveButton.disabled=!![]):(this.saveButton.textContent=this.saveButtonText,this.updateSaveButtonState()))}updateSaveButtonState(){this.saveButton.disabled=!(this.customerData.firstName.isValid&&this.customerData.lastName.isValid&&this.customerData.email.isValid&&this.customerData.phone.isValid&&this.customerData.birthDate.isValid)}template(){const n=this.store.get("checkout.customerForm.data");n.firstName&&(this.customerData.firstName={isValid:!![],value:n.firstName}),n.lastName&&(this.customerData.lastName={isValid:!![],value:n.lastName}),n.email&&(this.customerData.email={isValid:!![],value:n.email}),n.phone&&(this.customerData.phone={isValid:!![],value:n.phone}),n.company&&(this.customerData.company={isValid:!![],value:n.company}),n.birthDate&&(this.customerData.birthDate={isValid:!![],value:n.birthDate});const i=[],r=document.createElement("div");r.classList.add("section-title-container");const s=document.createElement("h3");s.textContent="Buyer Information",s.classList.add("section-title"),r.appendChild(s);const a=document.createElement("p");a.textContent="Buyer information is used to process your order and for delivery purposes.",a.classList.add("section-subtitle"),r.appendChild(a),i.push(r);const l=document.createElement("div");l.classList.add("section-form-container");const d=document.createElement("div");d.classList.add("checkout-two-col-container");const u=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:_t.firstName,label:"First Name",autocomplete:!![],validation:{required:!![]},value:n.firstName,onChange:async n=>{this.customerData.firstName.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.firstName})},onValidation:n=>{this.customerData.firstName.isValid=n,this.updateSaveButtonState()}});d.appendChild(u);const f=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:_t.lastName,label:"Last Name",autocomplete:!![],validation:{required:!![]},value:n.lastName,onChange:async n=>{this.customerData.lastName.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.lastName})},onValidation:n=>{this.customerData.lastName.isValid=n,this.updateSaveButtonState()}});d.appendChild(f),l.appendChild(d);const g=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:_t.company,label:"Company (optional)",autocomplete:!![],value:n.company,onChange:async n=>{this.customerData.company.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.company})},onValidation:n=>{this.customerData.company.isValid=n,this.updateSaveButtonState()}});l.appendChild(g);const v=ComponentFactoryService.createElement({type:C.INPUT,inputType:"email",name:_t.email,label:"Email",autocomplete:!![],validation:{required:!![]},value:n.email,onChange:async n=>{this.customerData.email.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.email})},onValidation:n=>{this.customerData.email.isValid=n,this.updateSaveButtonState()}});l.appendChild(v);const b=ComponentFactoryService.createElement({type:C.INPUT,inputType:"tel",name:_t.phone,label:"Phone",autocomplete:!![],validation:{required:!![]},value:n.phone,onChange:async n=>{this.customerData.phone.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.phone})},onValidation:n=>{this.customerData.phone.isValid=n,this.updateSaveButtonState()}});l.appendChild(b);const x=ComponentFactoryService.createElement({type:C.BIRTHDATE_INPUT,inputType:"date",name:_t.birthDate,label:"Birthdate",validation:{required:!![],minAge:21,minYear:1930},value:n.birthDate,onChange:async n=>{this.customerData.birthDate.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.birthDate})},onValidation:n=>{this.customerData.birthDate.isValid=n,this.updateSaveButtonState()}});return l.appendChild(x),i.push(l),this.saveButton=document.createElement("button"),this.saveButton.type="button",this.saveButton.classList.add("save-form-info-button"),this.saveButton.textContent=this.saveButtonText,this.saveButton.addEventListener("click",async()=>{await this.commands.checkout.saveCustomerForm({customerData:{firstName:this.customerData.firstName.value,lastName:this.customerData.lastName.value,email:this.customerData.email.value,phone:this.customerData.phone.value,company:this.customerData.company.value,birthDate:this.customerData.birthDate.value},shippingAddressTwo:this.customerData.addressTwo.value,deliveryInstructions:""})}),i.push(this.saveButton),this.updateSaveButtonState(),i}}class CheckoutBuyerSummaryComponent extends BaseComponent{get hostClasses(){return["checkout-summary-form-container"]}constructor(){super({watchStorePaths:["checkout.customerForm"]})}template(){const n=[],i=this.getStoreValue("checkout.customerForm.data"),r=document.createElement("div");r.classList.add("checkout-summary-form-header");const s=document.createElement("h2");s.textContent="Buyer: "+i.firstName+" "+i.lastName,r.appendChild(s);const a=document.createElement("span");if(a.textContent="Edit",a.setAttribute("aria-label","Edit Buyer Information"),a.setAttribute("role","button"),a.setAttribute("tabindex","0"),a.addEventListener("click",async()=>{await this.commands.checkout.editCustomerForm()}),a.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await this.commands.checkout.editCustomerForm())}),r.appendChild(a),n.push(r),i.company){const r=document.createElement("p");r.classList.add("checkout-summary-form-line"),r.textContent=i.company,n.push(r)}const l=document.createElement("p");l.classList.add("checkout-summary-form-line"),l.textContent=i.email,n.push(l);const d=document.createElement("p");d.classList.add("checkout-summary-form-line"),d.textContent=i.phone,n.push(d);const u=document.createElement("p");return u.classList.add("checkout-summary-form-line"),u.textContent=formatISODateToMMDDYYYY(i.birthDate),n.push(u),n}}const Rt=["span","p","a","b","i","div","strong","em","u","br","h1","h2","h3","h4","h5","h6","ul","ol","li","blockquote","code","pre","img"],Ot={a:["href","title","target","rel"],img:["src","alt","width","height","title"],blockquote:["cite"],div:["class"],span:["class"],p:["class"],strong:["class"],em:["class"],code:["class"],pre:["class"],h1:["class"],h2:["class"],h3:["class"],h4:["class"],h5:["class"],h6:["class"],ul:["class"],ol:["class"],li:["class"]};function sanitizeAttributeValue(n,i){return"href"===n?/^(https?:\/\/[^\s<>"']+|mailto:[^\s<>"']+|tel:[^\s<>"']+|\/[^\s<>"']*|#[^\s<>"']*)$/i.test(i)?i:null:"src"===n?/^https?:\/\/[^\s<>"']+$/i.test(i)?i:null:"class"===n?i.replace(/[^a-zA-Z0-9\s\-_]/g,"").trim():i.replace(/[<>"']/g,"").trim()}function cleanNode(n){if(n.nodeType===Node.TEXT_NODE){const i=n.textContent||"",r=i.replace(/<[^>]*>/g,"");if(r.trim()){const n=document.createTextNode(r);return n}return null}if(n.nodeType===Node.ELEMENT_NODE){const i=n,r=i.tagName.toLowerCase();if(Rt.includes(r)){const n=document.createElement(r),s=Ot[r]||[];for(const r of Array.from(i.attributes)){const i=r.name.toLowerCase();if(s.includes(i)){const s=sanitizeAttributeValue(i,r.value);null!==s&&n.setAttribute(i,s)}}"a"===r&&(n.setAttribute("target","_blank"),n.setAttribute("rel","noopener noreferrer"));for(const r of Array.from(i.childNodes)){const i=cleanNode(r);i&&n.appendChild(i)}return n}const s=document.createDocumentFragment();for(const n of Array.from(i.childNodes)){const i=cleanNode(n);i&&s.appendChild(i)}return s.childNodes.length>0?s:null}return null}function sanitizeHTML(n){if(!n||"string"!=typeof n)return"";try{const i=new DOMParser,r=i.parseFromString(n,"text/html"),s=r.querySelector("parsererror");if(s)return console.warn("HTML parsing error detected"),"";const a=document.createDocumentFragment();for(const n of Array.from(r.body.childNodes)){const i=cleanNode(n);i&&a.appendChild(i)}const l=document.createElement("div");return l.appendChild(a),l.innerHTML}catch(i){return console.error("HTML sanitization error:",i),""}}class CheckoutCompletedComponent extends BaseComponent{get hostClasses(){return["checkout-completed-container"]}template(){var n,i,r,s,a,l;const d=[],u=this.getConfigs("configurations"),f=this.getConfigs("global"),g=this.getConfigs("checkout"),v=this.config.layout.exitUrl||window.location.host,b=this.config.layout.thankYouButtonText||"Continue Shopping";if(null===(i=null===(n=this.config.layout)||void 0===n?void 0:n.checkoutCompleted)||void 0===i?void 0:i.customLogo){const n=document.createElement("div");n.classList.add("checkout-completed-header-container");const i=document.createElement("img");i.src=null===(s=null===(r=this.config.layout)||void 0===r?void 0:r.checkoutCompleted)||void 0===s?void 0:s.customLogo,i.alt=u.partnerName+" Logo",n.appendChild(i),d.push(n)}const x=document.createElement("div");x.classList.add("checkout-completed-section-container");const w=document.createElement("div");w.classList.add("checkout-completed-title-container");const E=document.createElement("div");E.classList.add("checkout-completed-title-section");const T=document.createElement("h3");T.innerHTML=(null===(l=null===(a=this.config.layout)||void 0===a?void 0:a.checkoutCompleted)||void 0===l?void 0:l.customText)||"Thank You for Your Order!",E.appendChild(T);const A=document.createElement("p");A.textContent="Your payment has been successfully processed.",E.appendChild(A),w.appendChild(E),x.appendChild(w);const P=document.createElement("div");P.classList.add("checkout-completed-sub-section");const _=document.createElement("div");_.classList.add("checkout-completed-line");const N=document.createElement("h3");N.textContent="Order Number",_.appendChild(N);const F=document.createElement("span");F.textContent=this.params.orderNumber,_.appendChild(F),P.appendChild(_);const R=document.createElement("div");R.classList.add("checkout-completed-line");const O=document.createElement("h3");O.textContent="Order Amount",R.appendChild(O);const L=document.createElement("span");L.textContent=""+formatCentToDollarText(this.params.orderTotal),R.appendChild(L),P.appendChild(R);const M=document.createElement("div");M.classList.add("checkout-completed-line");const B=document.createElement("h3");B.textContent="Payment Method",M.appendChild(B);const W=document.createElement("span");W.textContent="** "+this.params.cardLast4,M.appendChild(W),P.appendChild(M),x.appendChild(P);const H=document.createElement("div");H.classList.add("checkout-completed-sub-section");const q=document.createElement("p");q.innerHTML=this.params.giftRecipientEmail?"Order updates and your gift message will be sent to <strong>"+this.params.giftRecipientEmail+"</strong>.<br><br>A confirmation email and receipt has been sent to <strong>"+this.params.customerEmail+"</strong>.":"A confirmation email and receipt has been sent to <strong>"+this.params.customerEmail+"</strong>.",H.appendChild(q),x.appendChild(H),d.push(x);const j=document.createElement("div");j.classList.add("checkout-completed-section-container");const U=document.createElement("button");U.type="button";const V=document.createElement("span");V.textContent=b,U.setAttribute("tabindex","0"),U.setAttribute("role","button"),U.setAttribute("aria-label",b),U.appendChild(V);const K=htmlStringToElement(ArrowRightIcon({width:16,height:16,color:f.theme.selectedTextColor}));U.appendChild(K),U.addEventListener("click",()=>{window.location.href=v}),U.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),window.location.href=v)}),j.appendChild(U),d.push(j);const Q=document.createElement("div");Q.classList.add("checkout-completed-section-container");const Z=document.createElement("div");Z.classList.add("checkout-completed-help-section"),Q.appendChild(Z);const X=document.createElement("p");X.textContent="Questions about your order? Contact us at ";const J=document.createElement("a");J.href="mailto:"+u.supportEmail,J.textContent=u.supportEmail,X.appendChild(J),Z.appendChild(X);const $=document.createElement("p"),tt=(new Date).toLocaleDateString("en-US",{month:"2-digit",day:"2-digit",year:"numeric"});if($.textContent="Order placed on "+tt,Z.appendChild($),d.push(Q),g.layout.legalMessage.show){const n=document.createElement("div");n.classList.add("checkout-separator");const i=document.createElement("div");i.classList.add("checkout-legal-message"),i.innerHTML=sanitizeHTML(g.layout.legalMessage.text);const r=document.createElement("div");r.classList.add("checkout-separator"),d.push(n),d.push(i),d.push(r)}if(f.layout.showPoweredBy){const n=ComponentFactoryService.createElement({type:C.POWERED_BY,context:"general"});d.push(n)}return d}}class CheckoutDeliverToComponent extends BaseComponent{get hostClasses(){return["checkout-delivery-information"]}constructor(){super({watchStorePaths:["checkout.isGift"],watchOnlyStorePaths:["checkout.customerForm.isSaving","checkout.giftRecipientForm.isSaving"]}),this.customerData={firstName:{isValid:![],value:""},lastName:{isValid:![],value:""},email:{isValid:![],value:""},phone:{isValid:![],value:""},company:{isValid:!![],value:""},birthDate:{isValid:![],value:""},addressTwo:{isValid:!![],value:""},deliveryInstructions:{isValid:!![],value:""}},this.giftData={firstName:{isValid:![],value:""},lastName:{isValid:![],value:""},email:{isValid:![],value:""},phone:{isValid:![],value:""},message:{isValid:![],value:""},addressTwo:{isValid:!![],value:""},deliveryInstructions:{isValid:!![],value:""}},this.saveButtonText="Save Delivery Information"}onStoreWatch(n){const i=n.find(n=>"checkout.customerForm.isSaving"===n.path),r=n.find(n=>"checkout.giftRecipientForm.isSaving"===n.path);(null==i?void 0:i.value)||(null==r?void 0:r.value)?(this.saveButton.textContent="Saving...",this.saveButton.disabled=!![]):(this.saveButton.textContent=this.saveButtonText,this.updateSaveButtonState())}updateSaveButtonState(){const n=this.getStoreValue("checkout.isGift")||![];let i;i=n?!(this.giftData.firstName.isValid&&this.giftData.lastName.isValid&&this.giftData.email.isValid&&this.giftData.phone.isValid&&this.giftData.message.isValid&&this.giftData.addressTwo.isValid):!(this.customerData.firstName.isValid&&this.customerData.lastName.isValid&&this.customerData.email.isValid&&this.customerData.phone.isValid&&this.customerData.birthDate.isValid),this.saveButton.disabled=i}template(){const n=this.getConfigs("global"),i=this.getStoreValue("checkout.isGift"),r=this.store.get("checkout.giftRecipientForm.data"),s=this.store.get("checkout.customerForm.data"),a=this.store.get("address.formattedAddress"),l=i?r:s,d=this.store.get("checkout.shippingAddressTwo"),u=this.store.get("checkout.deliveryInstructions");s.firstName&&(this.customerData.firstName={isValid:!![],value:s.firstName}),s.lastName&&(this.customerData.lastName={isValid:!![],value:s.lastName}),s.email&&(this.customerData.email={isValid:!![],value:s.email}),s.phone&&(this.customerData.phone={isValid:!![],value:s.phone}),s.company&&(this.customerData.company={isValid:!![],value:s.company}),s.birthDate&&(this.customerData.birthDate={isValid:!![],value:s.birthDate}),r.firstName&&(this.giftData.firstName={isValid:!![],value:r.firstName}),r.lastName&&(this.giftData.lastName={isValid:!![],value:r.lastName}),r.email&&(this.giftData.email={isValid:!![],value:r.email}),r.phone&&(this.giftData.phone={isValid:!![],value:r.phone}),r.message&&(this.giftData.message={isValid:!![],value:r.message}),d&&(this.customerData.addressTwo={isValid:!![],value:d},this.giftData.addressTwo={isValid:!![],value:d}),u&&(this.customerData.deliveryInstructions={isValid:!![],value:u},this.giftData.deliveryInstructions={isValid:!![],value:u});const f=Object.keys(this.store.get("checkout.onDemandFulfillmentTipInfo")||{}).length>0,g=[],v=document.createElement("div");v.classList.add("delivery-header-container");const b=document.createElement("div");b.classList.add("delivery-header-content");const x=document.createElement("div");x.classList.add("delivery-title-container");const E=document.createElement("h3");E.textContent="Deliver to",E.classList.add("delivery-title");const T=document.createElement("p");T.textContent="Package recipient must be 21+",T.classList.add("delivery-subtitle"),x.appendChild(E),x.appendChild(T),v.appendChild(x),g.push(v);const A=document.createElement("div");A.classList.add("section-form-container");const P=document.createElement("div");P.classList.add("checkout-two-col-container");const _=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:i?Nt.firstName:_t.firstName,label:"First Name",autocomplete:!![],validation:{required:!![]},value:l.firstName,onChange:n=>{i?(this.giftData.firstName.value=n,this.pubSub.publishForm(w.GIFT,{fieldName:Nt.firstName})):(this.customerData.firstName.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.firstName}))},onValidation:n=>{i?this.giftData.firstName.isValid=n:this.customerData.firstName.isValid=n,this.updateSaveButtonState()}});_.setAttribute("aria-label","First Name Input"),P.appendChild(_);const N=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:i?Nt.lastName:_t.lastName,label:"Last Name",autocomplete:!![],validation:{required:!![]},value:l.lastName,onChange:n=>{i?(this.giftData.lastName.value=n,this.pubSub.publishForm(w.GIFT,{fieldName:Nt.lastName})):(this.customerData.lastName.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.lastName}))},onValidation:n=>{i?this.giftData.lastName.isValid=n:this.customerData.lastName.isValid=n,this.updateSaveButtonState()}});if(N.setAttribute("aria-label","Last Name Input"),P.appendChild(N),A.appendChild(P),!i){const n=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:_t.company,label:"Company (optional)",autocomplete:!![],value:l.company,onChange:async n=>{this.customerData.company.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.company})},onValidation:n=>{this.customerData.company.isValid=n,this.updateSaveButtonState()}});n.setAttribute("aria-label","Company Input"),A.appendChild(n)}const F=ComponentFactoryService.createElement({type:C.INPUT,inputType:"email",name:i?Nt.email:_t.email,label:"Email",autocomplete:!![],validation:{required:!![]},value:l.email,onChange:n=>{i?(this.giftData.email.value=n,this.pubSub.publishForm(w.GIFT,{fieldName:Nt.email})):(this.customerData.email.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.email}))},onValidation:n=>{i?this.giftData.email.isValid=n:this.customerData.email.isValid=n,this.updateSaveButtonState()}});F.setAttribute("aria-label","Email Input"),A.appendChild(F);const R=ComponentFactoryService.createElement({type:C.INPUT,inputType:"tel",name:i?Nt.phone:_t.phone,label:"Phone",autocomplete:!![],validation:{required:!![]},value:l.phone,onChange:n=>{i?(this.giftData.phone.value=n,this.pubSub.publishForm(w.GIFT,{fieldName:Nt.phone})):(this.customerData.phone.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.phone}))},onValidation:n=>{i?this.giftData.phone.isValid=n:this.customerData.phone.isValid=n,this.updateSaveButtonState()}});if(R.setAttribute("aria-label","Phone Input"),A.appendChild(R),!i){const n=ComponentFactoryService.createElement({type:C.BIRTHDATE_INPUT,inputType:"date",name:_t.birthDate,label:"Birthdate",validation:{required:!![],minAge:21,minYear:1930},value:l.birthDate,onChange:async n=>{this.customerData.birthDate.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.birthDate})},onValidation:n=>{this.customerData.birthDate.isValid=n,this.updateSaveButtonState()}});n.setAttribute("aria-label","Birthdate Input"),A.appendChild(n)}const O=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:"address_one",label:"Delivery address",value:a,disabled:!![],className:"disabled-input"});O.setAttribute("aria-label","Delivery Address Input"),A.appendChild(O);const L=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:i?Nt.addressTwo:_t.addressTwo,label:"Apt, suite, etc. (optional)",value:d,onChange:n=>{i?(this.giftData.addressTwo.value=n,this.pubSub.publishForm(w.GIFT,{fieldName:Nt.addressTwo})):(this.customerData.addressTwo.value=n,this.pubSub.publishForm(w.CUSTOMER,{fieldName:_t.addressTwo}))},onValidation:n=>{i?this.giftData.addressTwo.isValid=n:this.customerData.addressTwo.isValid=n,this.updateSaveButtonState()}});if(L.setAttribute("aria-label","Address Line 2 Input"),A.appendChild(L),i){const i=document.createElement("div");i.classList.add("custom-input","textarea",n.layout.inputFieldStyle);const s=document.createElement("label");s.textContent="Gift Message*",s.setAttribute("for",Nt.message);const a=document.createElement("textarea");a.name=Nt.message,a.id=Nt.message,a.rows=4,a.value=r.message||"",a.setAttribute("aria-label","Gift Message Textarea"),a.addEventListener("input",async n=>{const i=n.target.value;this.giftData.message.value=i,this.giftData.message.isValid=i.length>0,this.pubSub.publishForm(w.GIFT,{fieldName:Nt.message}),this.updateSaveButtonState()});const l=document.createElement("p");l.textContent="Your gift message will be emailed to the recipient along with delivery details.",l.classList.add("textarea-message-disclaimer"),i.appendChild(s),i.appendChild(a),i.appendChild(l),A.appendChild(i)}if(f){const r=document.createElement("div");r.classList.add("custom-input","textarea",n.layout.inputFieldStyle);const s=document.createElement("label");s.textContent="Delivery Instructions",s.setAttribute("for","delivery_instructions");const a=document.createElement("textarea");a.id="delivery_instructions",a.name="delivery_instructions",a.rows=4,a.setAttribute("aria-label","Delivery Instructions Textarea"),a.value=u,a.addEventListener("input",async n=>{const r=n.target.value;i?(this.giftData.deliveryInstructions.value=r,this.giftData.deliveryInstructions.isValid=r.length>0):(this.customerData.deliveryInstructions.value=r,this.customerData.deliveryInstructions.isValid=r.length>0)});const l=document.createElement("p");l.textContent="Include gate codes, apartment numbers, or preferred drop-off locations for your driver.",l.classList.add("textarea-message-disclaimer"),r.appendChild(s),r.appendChild(a),r.appendChild(l),A.appendChild(r)}g.push(A),this.saveButton=document.createElement("button"),this.saveButton.type="button",this.saveButton.classList.add("save-form-info-button"),this.saveButton.textContent=this.saveButtonText,this.saveButton.setAttribute("aria-label","Save Delivery Information"),this.saveButton.setAttribute("role","button"),this.saveButton.setAttribute("tabindex","0");const e=async()=>{i?await this.commands.checkout.saveGiftRecipientForm({firstName:this.giftData.firstName.value,lastName:this.giftData.lastName.value,email:this.giftData.email.value,phone:this.giftData.phone.value,message:this.giftData.message.value,shippingAddressTwo:this.giftData.addressTwo.value,deliveryInstructions:this.giftData.deliveryInstructions.value}):await this.commands.checkout.saveCustomerForm({customerData:{firstName:this.customerData.firstName.value,lastName:this.customerData.lastName.value,email:this.customerData.email.value,phone:this.customerData.phone.value,company:this.customerData.company.value,birthDate:this.customerData.birthDate.value},shippingAddressTwo:this.customerData.addressTwo.value,deliveryInstructions:this.customerData.deliveryInstructions.value})};return this.saveButton.addEventListener("click",e),this.saveButton.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await e())}),g.push(this.saveButton),this.updateSaveButtonState(),g}}class CheckoutDeliverToSummaryComponent extends BaseComponent{get hostClasses(){return["checkout-summary-form-container"]}constructor(){super({watchStorePaths:["checkout.isGift","checkout.customerForm","checkout.giftRecipientForm","checkout.deliveryInstructions"]})}template(){const n=[],i=this.getStoreValue("checkout.isGift"),r=this.getStoreValue("checkout.customerForm.data"),s=this.getStoreValue("checkout.giftRecipientForm.data"),a=this.getStoreValue("address"),l=this.getStoreValue("checkout.deliveryInstructions"),d=this.getStoreValue("checkout.shippingAddressTwo"),u=document.createElement("div");u.classList.add("checkout-summary-form-header");const f=document.createElement("h2");f.textContent=i?"Delivering to "+s.firstName+" "+s.lastName:"Delivering to "+r.firstName+" "+r.lastName,u.appendChild(f);const g=document.createElement("span");g.textContent="Edit",g.setAttribute("aria-label","Edit Delivery Information"),g.setAttribute("role","button"),g.setAttribute("tabindex","0");const p=async()=>{i?await this.commands.checkout.editGiftRecipientForm():await this.commands.checkout.editCustomerForm()};if(g.addEventListener("click",p),g.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await p())}),u.appendChild(g),n.push(u),!i&&r.company){const i=document.createElement("p");i.classList.add("checkout-summary-form-line"),i.textContent=r.company,n.push(i)}const v=document.createElement("p");v.classList.add("checkout-summary-form-line"),v.textContent=a.address.one+(d?", "+d:"")+", "+a.address.city+", "+a.address.state+", "+a.address.zip,n.push(v);const b=document.createElement("p");b.classList.add("checkout-summary-form-line"),b.textContent=i?s.email:r.email,n.push(b);const x=document.createElement("p");if(x.classList.add("checkout-summary-form-line"),x.textContent=i?s.phone:r.phone,n.push(x),!i&&r.birthDate){const i=document.createElement("p");i.classList.add("checkout-summary-form-line"),i.textContent=formatISODateToMMDDYYYY(r.birthDate),n.push(i)}if(i){const i=document.createElement("div");i.classList.add("checkout-summary-form-line-container");const r=document.createElement("span");r.classList.add("checkout-summary-form-line-container-label"),r.textContent="Gift Message:",i.appendChild(r);const a=document.createElement("span");a.classList.add("checkout-summary-form-line"),a.textContent=s.message||"No message provided.",i.appendChild(a),n.push(i)}if(l){const i=document.createElement("div");i.classList.add("checkout-summary-form-line-container");const r=document.createElement("span");r.classList.add("checkout-summary-form-line-container-label"),r.textContent="Delivery Instructions:",i.appendChild(r);const s=document.createElement("span");s.classList.add("checkout-summary-form-line"),s.textContent=l||"No instructions provided.",i.appendChild(s),n.push(i)}return n}}class CheckoutGiftCardsComponent extends BaseComponent{get hostClasses(){return["input-gift-card-container"]}constructor(){super({watchOnlyStorePaths:["checkout.giftCards","checkout.giftCardError","checkout.loading"]}),this.isApplying=![],this.giftCardInput=null,this.applyButton=null}onStoreWatch(n){var i;const r=n.find(n=>"checkout.giftCards"===n.path),s=n.find(n=>"checkout.loading"===n.path);r&&r.value.length>((null===(i=r.oldValue)||void 0===i?void 0:i.length)||0)&&this.giftCardInput&&this.giftCardInput.setValue(""),s&&this.updateApplyButtonState()}updateApplyButtonState(){if(!this.applyButton||!this.giftCardInput)return;const n=this.giftCardInput.getValue().trim(),i=n.length>=3&&n.length<=255,r=this.getStoreValue("checkout.loading"),s=this.getStoreValue("checkout.giftCardError");this.applyButton.disabled=!i||r||Boolean(s)||this.isApplying}createGiftCardInput(){return this.giftCardInput=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:"giftCards",placeholder:"Enter gift card code",autocomplete:![],validation:{min:3,max:255},onChange:n=>{const i=n.toUpperCase(),r=this.giftCardInput;r.setValue(i),this.updateApplyButtonState()}}),this.giftCardInput}createApplyButton(){this.applyButton=document.createElement("button"),this.applyButton.type="button",this.applyButton.classList.add("apply-button"),this.applyButton.disabled=!![],this.applyButton.textContent="Apply",this.applyButton.setAttribute("tabindex","0"),this.applyButton.setAttribute("role","button"),this.applyButton.setAttribute("aria-label","Apply gift card");const m=async()=>{const n=this.giftCardInput.getValue().trim().toUpperCase();if(n)try{this.isApplying=!![],this.updateApplyButtonState(),await this.commands.checkout.applyGiftCard(n)}catch(i){this.logger.error("Checkout gift card application failed",{giftCardCode:n,error:i instanceof Error?i.message:String(i)})}finally{this.isApplying=![],this.updateApplyButtonState()}};return this.applyButton.addEventListener("click",m),this.applyButton.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),m())}),this.applyButton}template(){this.giftCardInput=null,this.applyButton=null;const n=[];return n.push(this.createGiftCardInput()),n.push(this.createApplyButton()),n}disconnected(){this.giftCardInput=null,this.applyButton=null}}class CheckoutHeaderComponent extends BaseComponent{get hostClasses(){return["checkout-header-container"]}template(){const n=this.store.get("checkout.presale"),i=this.getConfigs("checkout");let r=null;if(!n){r=document.createElement("button"),r.classList.add("checkout-header-button"),r.setAttribute("aria-label","Back to Cart"),r.addEventListener("click",()=>{if(this.clientConfig.isBuilder())return this.logger.info("Back To Cart Button Is Disabled In Builder Mode"),void 0;this.commands.ui.openDrawer(C.CART)});const n=document.createElement("span");n.innerHTML=ChevronLeftIcon({}),r.appendChild(n)}const s=document.createElement("h1");s.textContent=(null==i?void 0:i.layout.drawerHeaderText)||"Checkout",s.classList.add("checkout-header-title"),s.setAttribute("aria-label","Checkout Page");const a=document.createElement("button");return a.innerHTML=CloseIcon({width:16,height:16}),a.classList.add("checkout-header-button-close"),a.setAttribute("aria-label","Close Checkout"),a.addEventListener("click",()=>{this.commands.ui.closeDrawer()}),r?[r,s,a]:[s,a]}}class CheckoutInformationComponent extends BaseComponent{get hostClasses(){return["checkout-information-section"]}constructor(){super({watchOnlyStorePaths:["checkout.isGift","checkout.customerForm.isEditing","checkout.giftRecipientForm.isEditing","checkout.paymentForm.isEditing"]})}onStoreWatch(){const n=this.getStoreValue("checkout.isGift"),i=this.getStoreValue("checkout.customerForm.isEditing"),r=this.getStoreValue("checkout.giftRecipientForm.isEditing"),s=this.getStoreValue("checkout.paymentForm.isEditing");n?(this.buyerForm.style.display=i?"block":"none",this.buyerSummary.style.display=i?"none":"block",this.deliveryToForm.style.display=r?"block":"none",this.deliverToSummary.style.display=r?"none":"block"):(this.deliveryToForm.style.display=i?"block":"none",this.deliverToSummary.style.display=i?"none":"block",this.buyerForm.style.display="none",this.buyerSummary.style.display="none"),this.paymentForm.style.display=s?"block":"none",this.paymentSummary.style.display=s?"none":"block"}template(){const n=[],i=this.getStoreValue("checkout.isGift"),r=this.getStoreValue("checkout.customerForm"),s=this.getStoreValue("checkout.giftRecipientForm"),a=this.getStoreValue("checkout.paymentForm"),l=ComponentFactoryService.createElement({type:C.CHECKOUT_SEND_AS_GIFT});return n.push(l),this.deliveryToForm=ComponentFactoryService.createElement({type:C.CHECKOUT_DELIVER_TO}),this.deliveryToForm.style.display=i?s.isEditing?"block":"none":r.isEditing?"block":"none",n.push(this.deliveryToForm),this.deliverToSummary=ComponentFactoryService.createElement({type:C.CHECKOUT_DELIVER_TO_SUMMARY}),this.deliverToSummary.style.display=i?s.isEditing?"none":"block":r.isEditing?"none":"block",n.push(this.deliverToSummary),this.buyerForm=ComponentFactoryService.createElement({type:C.CHECKOUT_BUYER}),this.buyerForm.style.display=i&&r.isEditing?"block":"none",n.push(this.buyerForm),this.buyerSummary=ComponentFactoryService.createElement({type:C.CHECKOUT_BUYER_SUMMARY}),this.buyerSummary.style.display=i&&!r.isEditing?"block":"none",n.push(this.buyerSummary),this.paymentForm=ComponentFactoryService.createElement({type:C.CHECKOUT_PAYMENT}),this.paymentForm.style.display=a.isEditing?"block":"none",n.push(this.paymentForm),this.paymentSummary=ComponentFactoryService.createElement({type:C.CHECKOUT_PAYMENT_SUMMARY}),this.paymentSummary.style.display=a.isEditing?"none":"block",n.push(this.paymentSummary),n}}class CheckoutItemComponent extends BaseComponent{get hostClasses(){return["checkout-item-card"]}constructor(){super({autoDestroy:!![],autoDestroyPath:"checkout.items.{itemId}",watchStorePaths:["checkout.items.{itemId}","checkout.items"]}),this.trashButton=null}onStoreChanged(n){var i,r,s,a;const l=n.find(n=>"checkout.items"===n.path);l&&(this.updateTrashButtonState(),this.setupMinimumPurchaseAlert(),this.checkAndUpdateLoadingState());const d=n.find(n=>n.path==="checkout.items."+this.params.itemId);if(d){const n=d.oldValue,l=d.value;if(l.updating)return![];const u=(null==n?void 0:n.quantity)!==(null==l?void 0:l.quantity),f=(null===(r=null===(i=null==n?void 0:n.attributes)||void 0===i?void 0:i.engraving)||void 0===r?void 0:r.lines)||[],g=(null===(a=null===(s=null==l?void 0:l.attributes)||void 0===s?void 0:s.engraving)||void 0===a?void 0:a.lines)||[],v=JSON.stringify(f)!==JSON.stringify(g);(u||v)&&this.updateEngravingElement(l)}return![]}updateEngravingElement(n){var i,r;const s=this.getConfigs("global"),a=this.container.querySelector(".engraving-view-container");if(a&&a.remove(),(null===(r=null===(i=null==n?void 0:n.attributes)||void 0===i?void 0:i.engraving)||void 0===r?void 0:r.hasEngraving)===!![]&&s.layout.enablePersonalization){const i=ComponentFactoryService.createElement({type:C.ENGRAVING_VIEW,identifier:n.cartItemId,context:"checkout"}),r=this.container.querySelector(".checkout-item-card-footer");r&&r.before(i)}}setupMinimumPurchaseAlert(){const n=this.getStoreValue("checkout.items."+this.params.itemId);if(!n)return;const i=n.fulfillmentId;if(!i)return;if(!this.container)return;const r=this.container.querySelector(".checkout-item-card-header");if(r){const s=this.getStoreValue("cart.fulfillments."+i),a=this.container.querySelector('[data-component-type="checkout-retailer-alert"]');if(a&&a.remove(),s&&shouldShowMinimumPurchaseAlert(s,n.pack)){const i=getMinimumPurchaseMessage(s,n.pack),a=ComponentFactoryService.createElement({type:C.PURCHASE_MIN_ALERT,message:i.message,messageType:i.type,currentTotal:s.subtotal,config:{showIcon:!![],alertType:"minimal"}});a.setAttribute("data-component-type","checkout-retailer-alert"),r.before(a)}}}updateTrashButtonState(){if(!this.trashButton)return;const n=this.getStoreValue("checkout"),i=Object.keys(n.items).length,r=1===i;this.trashButton.disabled=r,r?this.trashButton.classList.add("action-disabled"):this.trashButton.classList.remove("action-disabled")}createLoadingOverlay(){const n=document.createElement("div");n.className="cart-loading-backdrop",n.setAttribute("data-loading-id","item-loading-overlay");const i=document.createElement("div");i.className="cart-loading-spinner-container";const r=document.createElement("div");return r.className="cart-loading-spinner",r.innerHTML='\n <svg class="cart-spinner" width="32" height="32" viewBox="0 0 50 50">\n <circle\n class="cart-spinner-path"\n cx="25"\n cy="25"\n r="20"\n fill="none"\n stroke-width="3"\n stroke-linecap="round"\n stroke-dasharray="31.416"\n stroke-dashoffset="31.416"\n />\n </svg>\n ',i.appendChild(r),n.appendChild(i),n}hasLoadingOverlay(){return!!this.container.querySelector('[data-loading-id="item-loading-overlay"]')}showLoadingOverlay(){if(this.hasLoadingOverlay())return;const n=this.createLoadingOverlay();this.container.appendChild(n),this.container instanceof HTMLElement&&(this.container.style.position="relative")}hideLoadingOverlay(){const n=this.container.querySelector('[data-loading-id="item-loading-overlay"]');n&&(n.remove(),this.container instanceof HTMLElement&&(this.container.style.position=""))}isItemUpdating(){const n=this.getStoreValue("checkout.items."+this.params.itemId);return n?n.updating===!![]:![]}checkAndUpdateLoadingState(){const n=this.isItemUpdating(),i=this.hasLoadingOverlay();n&&!i?this.showLoadingOverlay():!n&&i&&this.hideLoadingOverlay()}afterRender(){this.updateTrashButtonState(),this.checkAndUpdateLoadingState()}template(){var n,i,r;const s=this.getConfigs("global"),a=this.getStoreValue("checkout.items."+this.params.itemId),l=null===(n=null==a?void 0:a.attributes)||void 0===n?void 0:n.presale,d=(null==l?void 0:l.isActive)&&(null==l?void 0:l.estimatedShipBy)?"Ships by "+formatISODateToMMDDYYYY(l.estimatedShipBy):"";if(!a)return[];const u=document.createElement("div");u.classList.add("checkout-item-card-header");const f=document.createElement("div");f.classList.add("checkout-item-image");const g=document.createElement("img");g.src=a.mainImage,g.alt=a.name,g.loading="lazy",f.appendChild(g),u.appendChild(f);const v=document.createElement("div");v.classList.add("checkout-item-details-container");const b=document.createElement("h4");b.classList.add("checkout-item-title"),b.textContent=a.name,v.appendChild(b);const x=document.createElement("div");x.classList.add("checkout-item-subtitle");const w=document.createElement("span");w.textContent=l.isActive?""+d:((null==a?void 0:a.expectationDetail)||"")+",",x.appendChild(w);const E=document.createElement("span");E.textContent="From "+((null==a?void 0:a.retailerName)||""),x.appendChild(E),v.appendChild(x),u.appendChild(v),this.trashButton=document.createElement("button"),this.trashButton.type="button",this.trashButton.innerHTML=TrashIcon({}),this.trashButton.addEventListener("click",async n=>{var i;if(n.preventDefault(),n.stopPropagation(),!(null===(i=this.trashButton)||void 0===i?void 0:i.disabled))try{await this.commands.checkout.removeItem(a.cartItemId)}catch(r){this.logger.error("Checkout item removal failed",r)}}),u.appendChild(this.trashButton);const T=ComponentFactoryService.createElement({type:C.CHECKOUT_ITEM_QUANTITY,itemId:a.cartItemId}),A=[];if(A.push(u),s.layout.enablePersonalization&&(null===(r=null===(i=null==a?void 0:a.attributes)||void 0===i?void 0:i.engraving)||void 0===r?void 0:r.hasEngraving)===!![]){const n=ComponentFactoryService.createElement({type:C.ENGRAVING_VIEW,identifier:a.cartItemId,context:"checkout"});A.push(n)}return A.push(T),A}disconnected(){this.hideLoadingOverlay()}}class CheckoutItemQuantityComponent extends BaseComponent{get hostClasses(){return["checkout-item-card-footer"]}constructor(){super({watchStorePaths:["checkout.items.{itemId}"],watchOnlyStorePaths:["checkout.items"],autoDestroy:!![],autoDestroyPath:"checkout.items.{itemId}"})}onStoreWatch(n){const i=n.find(n=>"checkout.items"===n.path);if(i){const n=this.calculateQuantityLimits();this.updateButtonStates(n)}}getAvailableQuantity(){var n,i,r;const s=this.getStoreValue("checkout.items."+this.params.itemId);if(!s)return 0;const a=this.getStoreValue("products");if(!a)return 0;const l=s.partNumber,d=s.fulfillmentId,u=null===(r=null===(i=null===(n=Object.values(a).find(n=>n.sizes[s.liquidId]))||void 0===n?void 0:n.sizes)||void 0===i?void 0:i[s.liquidId])||void 0===r?void 0:r.attributes.maxQuantityPerOrder;if(!u)return 0;const f=this.getStoreValue("checkout.items")||{},g=Object.values(f).filter(n=>n.partNumber===l&&n.fulfillmentId===d),v=g.reduce((n,i)=>n+i.quantity,0);return u-v}calculateQuantityLimits(){var n;const i=this.getStoreValue("checkout.items."+this.params.itemId);if(!i)return{currentQuantity:0,availableQuantity:0,isTheOnlyItem:![],canIncrease:![],canDecrease:![]};const r=this.getStoreValue("checkout"),s=1===(null===(n=Object.values(r.items))||void 0===n?void 0:n.length),a=i.quantity,l=this.getAvailableQuantity(),d=l>0,u=!(s&&1===a);return{currentQuantity:a,availableQuantity:l,isTheOnlyItem:s,canIncrease:d,canDecrease:u}}updateButtonStates(n){this.decreaseButton&&(this.decreaseButton.disabled=!n.canDecrease,this.decreaseButton.classList.toggle("disabled",!n.canDecrease)),this.increaseButton&&(this.increaseButton.disabled=!n.canIncrease,this.increaseButton.classList.toggle("disabled",!n.canIncrease),n.canIncrease?this.increaseButton.setAttribute("aria-label","Increase quantity"):this.increaseButton.setAttribute("aria-label","Cannot increase quantity above maximum")),this.quantitySpan&&(this.quantitySpan.textContent=n.currentQuantity.toString(),this.quantitySpan.setAttribute("aria-label","Current quantity: "+n.currentQuantity))}async handleQuantityChange(n){const i=this.calculateQuantityLimits(),r=this.params.itemId;if((!(n<0)||i.canDecrease)&&(!(n>0)||i.canIncrease)){if(!r)return this.logger.error("Checkout item quantity change failed: Item ID not found in component params",{componentParams:this.params,delta:n}),void 0;try{await this.commands.checkout.updateCheckoutItemQuantity(r,n)}catch(s){this.logger.error("Checkout item quantity change operation failed",s)}}}template(){const n=this.getStoreValue("checkout.items."+this.params.itemId);if(!n)return this.logger.warn("Checkout item not found during template render",{itemId:this.params.itemId}),[];const i=this.calculateQuantityLimits(),r=document.createElement("div");r.classList.add("checkout-item-quantity-container"),this.decreaseButton=document.createElement("button"),this.decreaseButton.type="button",this.decreaseButton.classList.add("quantity-decrease"),this.decreaseButton.textContent="-",this.decreaseButton.setAttribute("aria-label","Decrease quantity"),this.decreaseButton.addEventListener("click",async n=>{n.preventDefault(),n.stopPropagation(),await this.handleQuantityChange(-1)}),r.appendChild(this.decreaseButton),this.quantitySpan=document.createElement("span"),this.quantitySpan.classList.add("product-count"),r.appendChild(this.quantitySpan),this.increaseButton=document.createElement("button"),this.increaseButton.type="button",this.increaseButton.classList.add("quantity-increase"),this.increaseButton.textContent="+",this.increaseButton.addEventListener("click",async n=>{n.preventDefault(),n.stopPropagation(),await this.handleQuantityChange(1)}),r.appendChild(this.increaseButton),this.updateButtonStates(i);const s=document.createElement("span");if(s.classList.add("checkout-item-price-text"),s.textContent=formatCentToDollarText(n.price),n.quantity>1){const i=document.createElement("span");i.classList.add("checkout-item-price-each-text"),i.textContent=" ("+formatCentToDollarText(n.unitPrice)+" ea)",s.appendChild(i)}return[r,s]}}class CheckoutItemsComponent extends BaseComponent{get hostClasses(){return["checkout-items-container"]}constructor(){super({watchStorePaths:["checkout.items"]})}createItemElement(n){return ComponentFactoryService.createElement({type:C.CHECKOUT_ITEM,itemId:n})}getItemsListContainer(){return this.container.querySelector(".checkout-items-list")}getTogglerLabel(){return this.container.querySelector(".checkout-items-toggler-label")}getCurrentItemsMap(){const n=this.getStoreValue("checkout.items")||{},i=new Map;for(const r of Object.values(n))r&&r.cartItemId&&i.set(r.cartItemId,r);return i}syncItemsWithStore(){const n=this.getItemsListContainer();if(!n)return;const i=this.getCurrentItemsMap(),r=n.querySelectorAll("[data-item-id]"),s=new Set;for(const a of r){const n=a.getAttribute("data-item-id");n&&s.add(n)}for(const a of r){const n=a.getAttribute("data-item-id");n&&!i.has(n)&&a.remove()}for(const[a]of i)if(!s.has(a)){const i=this.createItemElement(a);i.setAttribute("data-item-id",a),n.appendChild(i)}this.updateItemCount()}updateItemCount(){const n=this.getTogglerLabel();if(!n)return;const i=this.getCurrentItemsMap(),r=i.size;n.textContent=r+" item"+(1!==r?"s":"")}onStoreChanged(n){let i;for(let r=0;r<n.length;r++){const s=n[r];if("checkout"===s.path||"checkout.items"===s.path||"checkout.items."===s.path.substring(0,15)){i=s;break}}return i?(this.syncItemsWithStore(),![]):![]}handleToggle(){const n=this.container.querySelector(".checkout-items-toggler-button"),i=this.container.querySelector(".checkout-items-list");if(n&&i){const r=i.classList.contains("show");i.classList.toggle("show"),n.classList.toggle("expanded"),r?(n.setAttribute("aria-expanded","false"),n.setAttribute("aria-label","Expand checkout items")):(n.setAttribute("aria-expanded","true"),n.setAttribute("aria-label","Collapse checkout items"))}}setupToggler(){const n=this.container.querySelector(".checkout-items-toggler"),i=this.container.querySelector(".checkout-items-toggler-button"),r=this.container.querySelector(".checkout-items-list");if(n&&i&&r){const s=r.classList.contains("show");i.setAttribute("tabindex","0"),i.setAttribute("aria-expanded",s?"true":"false"),i.setAttribute("aria-label",s?"Collapse checkout items":"Expand checkout items"),n.addEventListener("click",()=>this.handleToggle()),n.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),this.handleToggle())})}}afterRender(){this.setupToggler(),this.syncItemsWithStore()}template(){const n=this.getStoreValue("checkout.items"),i=Object.values(n||{}),r=document.createElement("div");r.classList.add("checkout-items-toggler");const s=document.createElement("span");s.classList.add("checkout-items-toggler-label"),s.textContent=i.length+" item"+(1!==i.length?"s":""),r.appendChild(s);const a=document.createElement("button");a.type="button",a.classList.add("checkout-items-toggler-button"),a.innerHTML=ChevronDownIcon({width:20,height:20,className:"chevron-icon"}),r.appendChild(a);const l=document.createElement("div");l.classList.add("checkout-items-list","show");for(const d of i){const n=this.createItemElement(d.cartItemId);n.setAttribute("data-item-id",d.cartItemId),l.appendChild(n)}return[r,l]}}class CheckoutOrderSummaryComponent extends BaseComponent{get hostClasses(){return["checkout-summary-section"]}constructor(){super({watchOnlyStorePaths:["checkout.amounts"]})}onStoreWatch(n){const i=n.find(n=>"checkout.amounts"===n.path);if(i){const n=this.getStoreValue("checkout"),i=Object.values(n.items||{}).length;this.updateZeroAmountElement(0===n.amounts.total&&i>0)}}updateZeroAmountElement(n){const i=this.container.querySelector(".checkout-zero-amount-container");if(n&&!i){const n=document.createElement("div");n.classList.add("checkout-zero-amount-container"),n.textContent="Credit card required to complete order (even when fully covered by gift card)";const i=this.container.querySelector("checkout-amounts-lc, .checkout-amounts-container");i&&i.after(n)}else!n&&i&&i.remove()}afterRender(){const n=this.getStoreValue("checkout.amounts");n&&this.updateZeroAmountElement(0===n.total)}handleEmailToggle(n){this.commands.checkout.toggleMarketingPreferences("canEmail"),n.classList.toggle("checked");const i=n.classList.contains("checked");n.setAttribute("aria-checked",i?"true":"false")}handleSmsToggle(n){this.commands.checkout.toggleMarketingPreferences("canSms"),n.classList.toggle("checked");const i=n.classList.contains("checked");n.setAttribute("aria-checked",i?"true":"false")}marketingOptInsContainer(){const n=this.config.layout.emailOptIn,i=this.config.layout.smsOptIn;if(!n.show&&!i.show)return null;const r=document.createElement("div");if(r.classList.add("checkout-marketing-opt-ins-container"),n.show){const i=document.createElement("div");let s;i.classList.add("checkout-checkbox-container"),s=this.clientConfig.isBuilder()?n.checked:this.store.get("checkout.marketingPreferences.canEmail");const a=document.createElement("span");a.id="emailOptIn",a.classList.add("checkout-checkbox-visual"),s&&a.classList.add("checked"),a.innerHTML=CheckboxIcon({width:16,height:16}),a.setAttribute("role","checkbox"),a.setAttribute("tabindex","0"),a.setAttribute("aria-label","Email opt-in checkbox"),a.setAttribute("aria-checked",s?"true":"false"),a.addEventListener("click",()=>this.handleEmailToggle(a)),a.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),this.handleEmailToggle(a))});const l=document.createElement("label");l.setAttribute("for","emailOptIn"),l.classList.add("checkbox-label"),l.innerHTML=sanitizeHTML(n.text),l.addEventListener("click",n=>{const i=n.target,r="A"===i.tagName||i.closest("a");r||(this.commands.checkout.toggleMarketingPreferences("canEmail"),a.classList.toggle("checked"))}),i.appendChild(a),i.appendChild(l),r.appendChild(i)}if(i.show){const n=document.createElement("div");let s;n.classList.add("checkout-checkbox-container"),s=this.clientConfig.isBuilder()?i.checked:this.store.get("checkout.marketingPreferences.canSms");const a=document.createElement("span");a.classList.add("checkout-checkbox-visual"),a.id="smsOptIn",s&&a.classList.add("checked"),a.innerHTML=CheckboxIcon({width:16,height:16}),a.setAttribute("role","checkbox"),a.setAttribute("tabindex","0"),a.setAttribute("aria-label","SMS opt-in checkbox"),a.setAttribute("aria-checked",s?"true":"false"),a.addEventListener("click",()=>this.handleSmsToggle(a)),a.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),this.handleSmsToggle(a))});const l=document.createElement("label");l.setAttribute("for","smsOptIn"),l.classList.add("checkbox-label"),l.innerHTML=sanitizeHTML(i.text),l.addEventListener("click",n=>{const i=n.target,r="A"===i.tagName||i.closest("a");r||(this.commands.checkout.toggleMarketingPreferences("canSms"),a.classList.toggle("checked"))}),n.appendChild(a),n.appendChild(l),r.appendChild(n)}return r}hasOnDemandOrder(){const n=this.getStoreValue("checkout.onDemandFulfillmentTipInfo")||{};return Object.keys(n).length>0}template(){var n;const i=[],r=this.getConfigs("global"),s=this.getConfigs("checkout"),a=this.getConfigs("global"),l=s.layout.allowGiftCards,d=null===(n=null==a?void 0:a.layout)||void 0===n?void 0:n.allowPromoCodes,u=document.createElement("div");u.classList.add("section-title-container");const f=document.createElement("h3");f.textContent="Order Summary",f.classList.add("section-title"),u.appendChild(f),i.push(u);const g=ComponentFactoryService.createElement({type:C.CHECKOUT_ITEMS});i.push(g);const v=document.createElement("div");v.classList.add("checkout-separator");const b=document.createElement("div");if(b.classList.add("checkout-separator"),i.push(v),l||d){const n=ComponentFactoryService.createElement({type:C.CHECKOUT_PC_GC});i.push(n)}if(this.hasOnDemandOrder()){const n=ComponentFactoryService.createElement({type:C.CHECKOUT_TIPS});i.push(n),i.push(b)}const x=document.createElement("div");x.classList.add("section-title-container");const w=document.createElement("h3");w.textContent="100% Secure Payments",w.classList.add("disclaimer-header"),x.appendChild(w);const E=document.createElement("p");E.textContent="If a person over 21 is not available to receive this order, it will be returned for a $20 restocking fee. Valid Government ID required.",E.classList.add("disclaimer-description"),x.appendChild(E),i.push(x);const T=ComponentFactoryService.createElement({type:C.CHECKOUT_AMOUNTS});i.push(T);const A=ComponentFactoryService.createElement({type:C.CHECKOUT_PLACE_ORDER_BUTTON});i.push(A);const P=this.marketingOptInsContainer();if(P&&i.push(P),s.layout.legalMessage.show){const n=document.createElement("div");n.classList.add("checkout-separator");const r=document.createElement("div");r.classList.add("checkout-legal-message"),r.innerHTML=sanitizeHTML(s.layout.legalMessage.text),i.push(n),i.push(r)}const _=document.createElement("div");if(_.classList.add("checkout-separator"),i.push(_),r.layout.showPoweredBy){const n=ComponentFactoryService.createElement({type:C.POWERED_BY,context:"checkout"});i.push(n)}return i}}class CheckoutPaymentComponent extends BaseComponent{get hostClasses(){return["checkout-payment-form"]}constructor(){super({watchOnlyStorePaths:["checkout.paymentForm.isSaving","checkout.paymentForm.billingSameAsShipping"]}),this.stripeHandlerElement=null,this.hardcodedPaymentElement=null,this.billingFormData=null,this.isValidBillingForm=![],this.isBillingSameAsShipping=!![],this.stripeFormStatus={isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null},this.savedCardInfo=null,this.showingStripeSummary=![],this.isSavingPayment=![]}onStoreWatch(n){for(const i of n)switch(i.path){case"checkout.paymentForm.isSaving":this.isSavingPayment=i.value,this.updateSaveButtonState();break;case"checkout.paymentForm.billingSameAsShipping":this.handleBillingSameAsShippingChange(i.value)}}handleBillingSameAsShippingChange(n){this.isBillingSameAsShipping=n,n&&(this.billingFormData=null,this.isValidBillingForm=![]),this.updateSaveButtonState(),this.updateErrorMessage()}async afterRender(){var n;this.isBillingSameAsShipping=null!==(n=this.getStoreValue("checkout.paymentForm.billingSameAsShipping"))&&void 0!==n?n:!![],this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId")&&(this.stripeFormStatus={isFormComplete:!![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null}),this.updateSaveButtonState()}updateSaveButtonState(){if(!this.saveButton)return;let n=!![],i="Save Payment Information";if(this.isSavingPayment||this.stripeFormStatus.isProcessing)i="Saving...",n=!![];else if(this.stripeFormStatus.hasError)i="Fix Errors and Retry",n=![];else if(this.showingStripeSummary&&this.savedCardInfo){const i=this.isBillingSameAsShipping||this.isValidBillingForm;n=!i}else{const i=this.stripeFormStatus.isFormComplete,r=this.isBillingSameAsShipping||this.isValidBillingForm;n=!(i&&r)}this.saveButton.disabled=n,this.saveButton.textContent=i,this.saveButton.classList.toggle("processing",this.isSavingPayment||this.stripeFormStatus.isProcessing),this.saveButton.classList.toggle("error",this.stripeFormStatus.hasError)}updateErrorMessage(){if(!this.errorMessageElement)return;let n="";this.stripeFormStatus.hasError&&this.stripeFormStatus.errorMessage?n=this.stripeFormStatus.errorMessage:this.isBillingSameAsShipping||this.isValidBillingForm||!this.stripeFormStatus.isFormComplete||(n="Please complete the billing address form"),n?(this.errorMessageElement.textContent=n,this.errorMessageElement.style.display="block"):(this.errorMessageElement.textContent="",this.errorMessageElement.style.display="none")}showError(n){this.errorMessageElement&&(this.errorMessageElement.textContent=n,this.errorMessageElement.style.display="block",setTimeout(()=>{this.errorMessageElement&&this.errorMessageElement.textContent===n&&(this.errorMessageElement.style.display="none")},5e3))}template(){const n=[],i=document.createElement("div");i.classList.add("section-title-container");const r=document.createElement("h3");r.textContent="Payment",r.classList.add("section-title"),i.appendChild(r);const s=document.createElement("p");if(s.textContent="All transactions are secure and encrypted.",s.classList.add("section-subtitle"),i.appendChild(s),n.push(i),this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId")){this.hardcodedPaymentElement=document.createElement("div"),this.hardcodedPaymentElement.classList.add("hardcoded-payment-notice");const i=document.createElement("p");i.innerHTML="⚠️ Development Mode<br/>Payment Method: "+this.clientConfig.get("paymentMethodId"),this.hardcodedPaymentElement.appendChild(i),n.push(this.hardcodedPaymentElement)}else this.stripeHandlerElement=ComponentFactoryService.createElement({type:C.CHECKOUT_STRIPE_HANDLER,callbacks:{onStripeFormStatusChanged:n=>{this.stripeFormStatus=n,this.updateSaveButtonState(),this.updateErrorMessage()},onSavedCardInfoChanged:n=>{this.savedCardInfo=n},onEditModeVisibilityChanged:n=>{this.showingStripeSummary=n,this.updateSaveButtonState()},onPaymentSessionConfirmed:async(n,i)=>{const r={paymentSession:{confirmationTokenId:n,setupIntentId:i}};!this.isBillingSameAsShipping&&this.billingFormData&&(r.billingFormData=this.billingFormData),await this.commands.checkout.savePaymentForm(r)}}}),n.push(this.stripeHandlerElement);this.errorMessageElement=document.createElement("div"),this.errorMessageElement.classList.add("payment-error-message"),this.errorMessageElement.style.display="none",this.errorMessageElement.setAttribute("role","alert"),n.push(this.errorMessageElement);const a=ComponentFactoryService.createElement({type:C.CHECKOUT_BILLING,isFormValid:(n,i)=>{this.billingFormData=i,this.isValidBillingForm=n,this.updateSaveButtonState(),this.updateErrorMessage()}});return n.push(a),this.saveButton=document.createElement("button"),this.saveButton.type="button",this.saveButton.classList.add("save-form-info-button"),this.saveButton.textContent="Save Payment Information",this.saveButton.setAttribute("aria-label","Save payment information"),this.saveButton.setAttribute("role","button"),this.saveButton.setAttribute("tabindex","0"),this.saveButton.addEventListener("click",async()=>{await this.handleSaveButtonClick()}),this.saveButton.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await this.handleSaveButtonClick())}),n.push(this.saveButton),n}async handleSaveButtonClick(){var n;if(!this.isSavingPayment&&!this.stripeFormStatus.isProcessing)if(this.showingStripeSummary&&this.savedCardInfo)try{const n={};!this.isBillingSameAsShipping&&this.isValidBillingForm&&this.billingFormData&&(n.billingFormData=this.billingFormData),await this.commands.checkout.savePaymentForm(n)}catch(i){this.logger.error("Failed to save payment form in edit mode",i),this.showError("Failed to save payment information.")}else if(this.clientConfig.isDevelopment()&&this.clientConfig.get("paymentMethodId"))try{const n={};!this.isBillingSameAsShipping&&this.isValidBillingForm&&this.billingFormData&&(n.billingFormData=this.billingFormData),await this.commands.checkout.savePaymentForm(n)}catch(r){this.logger.error("Failed to save payment form in beta mode",r),this.showError("Failed to save payment information.")}else this.updateErrorMessage(),this.validatePrerequisites()&&(null===(n=this.stripeHandlerElement)||void 0===n||n.submitStripeForm())}validatePrerequisites(){return this.isBillingSameAsShipping||this.isValidBillingForm?this.stripeFormStatus.isFormComplete?!![]:(this.showError("Please complete all required payment fields."),![]):(this.showError("Please complete the billing address form before saving."),![])}disconnected(){var n;this.isSavingPayment=![],null===(n=super.disconnected)||void 0===n||n.call(this)}}class CheckoutPaymentSummaryComponent extends BaseComponent{get hostClasses(){return["checkout-summary-form-container"]}constructor(){super({watchStorePaths:["checkout.paymentForm"]})}template(){var n,i,r,s,a,l,d,u,f,g;const v=[],b=this.getStoreValue("checkout.paymentForm"),x=document.createElement("div");x.classList.add("checkout-summary-form-header");const w=document.createElement("h2");w.textContent="Paying with "+capitalizeFirstLetter(null!==(r=null===(i=null===(n=b.paymentMethod)||void 0===n?void 0:n.card)||void 0===i?void 0:i.brand)&&void 0!==r?r:"")+" "+(null===(a=null===(s=b.paymentMethod)||void 0===s?void 0:s.card)||void 0===a?void 0:a.last4),x.appendChild(w);const C=document.createElement("span");C.textContent="Edit",C.setAttribute("aria-label","Edit Payment Information"),C.setAttribute("role","button"),C.setAttribute("tabindex","0"),C.addEventListener("click",async()=>{await this.commands.checkout.editPaymentForm()}),C.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await this.commands.checkout.editPaymentForm())}),x.appendChild(C),v.push(x);const E=document.createElement("p");return E.classList.add("checkout-summary-form-line"),E.textContent="Exp. "+(null===(d=null===(l=b.paymentMethod)||void 0===l?void 0:l.card)||void 0===d?void 0:d.expMonth)+"/"+(null===(g=null===(f=null===(u=b.paymentMethod)||void 0===u?void 0:u.card)||void 0===f?void 0:f.expYear)||void 0===g?void 0:g.slice(-2)),v.push(E),v}}class CheckoutPlaceOrderButtonComponent extends BaseComponent{get hostClasses(){return["checkout-place-order-button-container"]}constructor(){super({watchOnlyStorePaths:["checkout.loading","checkout.error","checkout.customerForm.isValid","checkout.giftRecipientForm.isValid","checkout.paymentForm.isValid"]}),this.errorTimeoutId=null}afterRender(){this.placeOrderButton=this.container.querySelector(".checkout-place-order-button"),this.errorContainer=this.container.querySelector(".checkout-error-wrapper"),this.updateButtonState()}disconnected(){this.clearErrorTimeout()}onStoreWatch(n){const i=n.some(n=>"checkout.loading"===n.path||"checkout.error"===n.path||"checkout.customerForm.isValid"===n.path||"checkout.giftRecipientForm.isValid"===n.path||"checkout.paymentForm.isValid"===n.path);i&&this.updateButtonState()}updateButtonState(){if(!this.placeOrderButton)return;const n=this.store.get("checkout.loading")||![],i=this.store.get("checkout.error")||null;this.updateErrorDisplay(i);const r=this.determineButtonState({isCheckoutLoading:n,hasCheckoutError:!!i});this.placeOrderButton.classList.remove("processing","ready","disabled"),this.placeOrderButton.classList.add(r.state),this.placeOrderButton.disabled=r.disabled,this.placeOrderButton.textContent=r.text}clearErrorTimeout(){null!==this.errorTimeoutId&&(clearTimeout(this.errorTimeoutId),this.errorTimeoutId=null)}updateErrorDisplay(n){if(!this.errorContainer)return;const i=this.errorContainer.querySelector(".error-text");i&&(this.clearErrorTimeout(),n?(i.textContent=n,this.errorContainer.style.display="block",this.errorTimeoutId=setTimeout(async()=>{this.errorTimeoutId=null,await this.commands.checkout.clearCheckoutError()},3e3)):(i.textContent="",this.errorContainer.style.display="none"))}determineButtonState({isCheckoutLoading:n,hasCheckoutError:i}){const r=this.config.layout.placeOrderButtonText,s=this.store.get("checkout.presale");let a=![];if(!s){const n=this.getStoreValue("cart.fulfillments")||{};a=Object.values(n).some(n=>hasUnmetMinimum(n))}const l=this.store.get("checkout.isGift"),d=this.store.get("checkout.customerForm.isValid"),u=this.store.get("checkout.giftRecipientForm.isValid"),f=this.store.get("checkout.paymentForm.isValid");return a||l&&!u||!d||!f?{state:"disabled",text:r,disabled:!![]}:n?{state:"processing",text:"Placing Order...",disabled:!![]}:i?{state:"disabled",text:r,disabled:!![]}:{state:"ready",text:r,disabled:![]}}async handlePlaceOrderClick(){try{if(this.clientConfig.isBuilder())return this.logger.info("Checkout Place Order Button Is Disabled In Builder Mode"),void 0;const n=this.store.get("checkout.loading");if(n)return;await this.commands.checkout.checkoutComplete()}catch(n){this.logger.error("Error handling place order click",n)}}template(){const n=document.createElement("button");n.type="button",n.textContent=this.config.layout.placeOrderButtonText,n.classList.add("checkout-place-order-button"),n.disabled=!![],n.setAttribute("tabindex","0"),n.setAttribute("role","button"),n.setAttribute("aria-label","Place Order"),n.addEventListener("click",this.handlePlaceOrderClick.bind(this)),n.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await this.handlePlaceOrderClick())});const i=document.createElement("div");i.classList.add("checkout-error-wrapper"),i.setAttribute("role","alert"),i.style.display="none";const r=document.createElement("div");r.classList.add("checkout-error");const s=document.createElement("span");s.classList.add("icon-error"),s.innerHTML=ErrorInfoIcon({});const a=document.createElement("span");a.classList.add("error-text"),r.appendChild(s),r.appendChild(a),i.appendChild(r);const l=ComponentFactoryService.createElement({type:C.ALERT,errorStorePath:"checkout.events",fromEvents:!![],showFirstEvent:![]});return[i,l,n]}}class CheckoutPresaleCountdownComponent extends BaseComponent{get hostClasses(){return["checkout-presale-countdown-container"]}constructor(){super({watchStorePaths:["checkout.presale","ui.drawer"]}),this.countdownInterval=null,this.expiresAt=null,this.totalDuration=300,this.rootElement=null,this.scrollHandler=null,this.scrollContainer=null,this.isCurrentlyScrolled=![],this.isUnderOneMinute=![]}onStoreChanged(n){var i;const r=n.find(n=>"checkout.presale"===n.path);if(null==r?void 0:r.value)return this.updateExpiresAt(r.value.expiresAt),!![];const s=n.find(n=>"ui.drawer"===n.path);return(null===(i=null==s?void 0:s.value)||void 0===i?void 0:i.isOpen)===![]&&(this.stopCountdown(),this.cleanupScrollListener(),this.isCurrentlyScrolled=![],this.isUnderOneMinute=![]),![]}afterRender(){const n=this.store.get("checkout.presale");(null==n?void 0:n.expiresAt)&&this.updateExpiresAt(n.expiresAt),this.setupDrawerScrollDetection()}disconnected(){this.stopCountdown(),this.cleanupScrollListener()}setupDrawerScrollDetection(){const findScrollContainer=()=>{var n,i;const r=[".drawer-content"];for(const a of r){const i=null===(n=this.rootElement)||void 0===n?void 0:n.closest(a);if(i&&this.isScrollable(i))return i}let s=null===(i=this.rootElement)||void 0===i?void 0:i.parentElement;for(;s&&s!==document.body;){if(this.isScrollable(s))return s;s=s.parentElement}return null};if(this.scrollContainer=findScrollContainer(),!this.scrollContainer)return this.logger.warn("Could not find scrollable drawer container"),void 0;this.scrollHandler=()=>{var n,i;if(!this.scrollContainer)return;const r=this.scrollContainer.scrollTop,s=70,a=10;!this.isCurrentlyScrolled&&r>s?(this.isCurrentlyScrolled=!![],null===(n=this.rootElement)||void 0===n||n.classList.add("is-scrolled"),this.addHostClasses("is-scrolled")):this.isCurrentlyScrolled&&r<a&&(this.isCurrentlyScrolled=![],null===(i=this.rootElement)||void 0===i||i.classList.remove("is-scrolled"),this.removeHostClasses("is-scrolled"))},this.scrollContainer.addEventListener("scroll",this.scrollHandler,{passive:!![]}),this.scrollHandler()}isScrollable(n){const i=window.getComputedStyle(n),r=i.overflowY;return n.scrollHeight>=n.clientHeight&&("auto"===r||"scroll"===r||"overlay"===r)}cleanupScrollListener(){this.scrollHandler&&this.scrollContainer&&(this.scrollContainer.removeEventListener("scroll",this.scrollHandler),this.scrollHandler=null,this.scrollContainer=null)}updateExpiresAt(n){this.stopCountdown();try{if(this.expiresAt=new Date(n),Number.isNaN(this.expiresAt.getTime()))return this.logger.error("Invalid presale expiration date",{expiresAtString:n}),this.handleExpire(),void 0;if(this.expiresAt<=new Date)return this.handleExpire(),void 0;const i=new Date,r=Math.floor((this.expiresAt.getTime()-i.getTime())/1e3);r<this.totalDuration&&(this.totalDuration=Math.max(r,240)),this.startCountdown()}catch(i){this.logger.error("Failed to parse presale expiration date",i),this.handleExpire()}}startCountdown(){this.updateCountdown(),this.countdownInterval=window.setInterval(()=>{this.updateCountdown()},10)}stopCountdown(){this.countdownInterval&&(clearInterval(this.countdownInterval),this.countdownInterval=null)}updateCountdown(){if(!this.expiresAt||!this.rootElement)return;const n=new Date,i=Math.max(0,this.expiresAt.getTime()-n.getTime()),r=i/1e3,s=this.totalDuration-r,a=Math.max(0,Math.min(100,s/this.totalDuration*100)),l=r<60;if(l!==this.isUnderOneMinute){this.isUnderOneMinute=l;const n=this.rootElement.querySelector(".checkout-presale-timer");this.isUnderOneMinute?(this.rootElement.classList.add("time-warning"),null==n||n.classList.add("time-warning"),this.addHostClasses("time-warning")):(this.rootElement.classList.remove("time-warning"),null==n||n.classList.remove("time-warning"),this.removeHostClasses("time-warning"))}const d=this.rootElement.querySelector("[data-timer]");d&&(d.textContent=this.formatTime(i));const u=this.rootElement.querySelector("[data-progress-fill]");u&&(u.style.width=a+"%"),0===i&&this.handleExpire()}formatTime(n){const i=Math.floor(n/1e3),r=Math.floor(i/60),s=i%60,a=Math.floor(n%1e3/10);return r.toString().padStart(2,"0")+":"+s.toString().padStart(2,"0")+":"+a.toString().padStart(2,"0")}handleExpire(){this.clientConfig.isBuilder()||(this.stopCountdown(),this.commands.checkout.openPresaleExpiredDrawer())}template(){const n=document.createElement("div");n.classList.add("checkout-presale-countdown"),this.rootElement=n;const i=document.createElement("div");i.classList.add("checkout-presale-text-container");const r=document.createElement("div");r.classList.add("checkout-presale-heading");const s=document.createElement("h2");s.textContent="LIMITED PRE-ORDER:";const a=document.createElement("div");a.classList.add("checkout-presale-timer"),a.setAttribute("data-timer",""),a.textContent="00:00:00",r.appendChild(s),r.appendChild(a);const l=document.createElement("p");l.textContent="Please complete your transaction within the time limit. Time expiration or page refresh will release the product to other customers.",l.classList.add("checkout-presale-subtitle"),i.appendChild(r),i.appendChild(l);const d=document.createElement("div");d.className="checkout-presale-progress-bar",d.setAttribute("data-progress","");const u=document.createElement("div");return u.className="checkout-presale-progress-fill",u.setAttribute("data-progress-fill",""),u.style.width="0%",d.appendChild(u),n.appendChild(i),n.appendChild(d),n}}class CheckoutPresaleExpiredComponent extends BaseComponent{constructor(){super(...arguments),this.autoCloseInterval=null,this.autoCloseSeconds=10,this.autoCloseElement=null}get hostClasses(){return["checkout-completed-container"]}get hostAttributes(){return{role:"alert","aria-live":"assertive"}}afterRender(){this.startAutoCloseCountdown()}disconnected(){this.stopAutoCloseCountdown()}handleExit(){this.stopAutoCloseCountdown(),this.commands.ui.closeDrawer()}startAutoCloseCountdown(){this.updateAutoCloseDisplay(),this.autoCloseInterval=window.setInterval(()=>{this.autoCloseSeconds--,this.updateAutoCloseDisplay(),this.autoCloseSeconds<=0&&this.handleExit()},1e3)}stopAutoCloseCountdown(){null!==this.autoCloseInterval&&(clearInterval(this.autoCloseInterval),this.autoCloseInterval=null)}updateAutoCloseDisplay(){this.autoCloseElement&&(this.autoCloseElement.textContent=""+this.autoCloseSeconds)}template(){const n=[],i=this.getConfigs("global"),r=document.createElement("div");r.classList.add("checkout-completed-section-container");const s=document.createElement("div");s.classList.add("checkout-completed-title-section");const a=document.createElement("div");a.classList.add("checkout-completed-title-section");const l=document.createElement("p");l.classList.add("presale-expired-title"),l.textContent="Session Expired",a.appendChild(l);const d=document.createElement("p");d.textContent="Your reservation time has ended. The item has been released for other customers.",a.appendChild(d),s.appendChild(a),r.appendChild(s);const u=document.createElement("div");u.classList.add("checkout-completed-help-section"),u.textContent="To ensure fair access for all customers, we can only hold items for a limited time. You can try to reserve the item again if it's still available.",r.appendChild(u),n.push(r);const f=document.createElement("div");f.classList.add("checkout-completed-section-container");const g=document.createElement("button");g.setAttribute("aria-label","Continue shopping"),g.type="button";const v=document.createElement("span");v.textContent="Continue Shopping",g.setAttribute("tabindex","0"),g.setAttribute("role","button"),g.setAttribute("aria-label","Continue Shopping"),g.appendChild(v);const b=htmlStringToElement(ArrowRightIcon({width:16,height:16}));g.appendChild(b),g.addEventListener("click",()=>this.handleExit()),g.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),this.handleExit())}),f.appendChild(g),n.push(f);const x=document.createElement("div");x.classList.add("checkout-completed-section-container");const w=document.createElement("p");w.classList.add("checkout-completed-auto-close-text"),w.textContent="This view will close automatically in:",this.autoCloseElement=document.createElement("div"),this.autoCloseElement.classList.add("checkout-completed-auto-close-seconds"),this.autoCloseElement.setAttribute("aria-live","polite"),this.autoCloseElement.setAttribute("aria-atomic","true"),this.autoCloseElement.textContent=""+this.autoCloseSeconds;const E=document.createElement("span");if(E.classList.add("checkout-completed-auto-close-text"),E.textContent="seconds",x.appendChild(w),x.appendChild(this.autoCloseElement),x.appendChild(E),n.push(x),i.layout.showPoweredBy){const i=document.createElement("div");i.classList.add("checkout-completed-powered-by-container");const r=ComponentFactoryService.createElement({type:C.POWERED_BY,context:"checkout"});i.appendChild(r),n.push(i)}return n}}class CheckoutPromoCodeComponent extends BaseComponent{get hostClasses(){return["input-promo-code-container"]}constructor(){super({watchOnlyStorePaths:["checkout.promoCode","checkout.loading"]}),this.isApplying=![],this.promoInput=null,this.applyButton=null,this.promoCodeText=null}onStoreWatch(n){const i=n.find(n=>"checkout.promoCode"===n.path),r=n.find(n=>"checkout.loading"===n.path);if(i){const{value:n,oldValue:r}=i,s=Boolean(r),a=Boolean(n);if(!s&&a)return this.container.innerHTML="",this.createAppliedContainer(n),void 0;if(s&&!a)return this.container.innerHTML="",this.createInputContainer(),void 0;a&&this.promoCodeText&&n.discountAmount!==(null==r?void 0:r.discountAmount)&&(this.promoCodeText.textContent=n.code+" (- "+formatCentToDollarText(n.discountAmount)+")")}r&&this.updateApplyButtonState()}updateApplyButtonState(){if(!this.applyButton||!this.promoInput)return;const n=this.promoInput.getValue().trim(),i=n.length>=3&&n.length<=255,r=this.getStoreValue("checkout.loading"),s=this.getStoreValue("checkout.promoCode"),a=this.getStoreValue("checkout.promoCodeError");this.applyButton.disabled=!i||r||Boolean(s)||Boolean(a)||this.isApplying}createPromoInput(){return this.promoInput=ComponentFactoryService.createElement({type:C.INPUT,inputType:"text",name:"promoCode",placeholder:"Enter promo code",autocomplete:![],validation:{min:3,max:255},onChange:n=>{const i=n.toUpperCase(),r=this.promoInput;r.setValue(i),this.updateApplyButtonState()}}),this.promoInput}createApplyButton(){this.applyButton=document.createElement("button"),this.applyButton.type="button",this.applyButton.classList.add("apply-button"),this.applyButton.disabled=!![],this.applyButton.textContent="Apply",this.applyButton.setAttribute("tabindex","0"),this.applyButton.setAttribute("role","button"),this.applyButton.setAttribute("aria-label","Apply promo code");const m=async()=>{const n=this.promoInput.getValue().trim().toUpperCase();if(n)try{this.isApplying=!![],this.updateApplyButtonState(),await this.commands.checkout.applyPromoCode(n)}catch(i){this.logger.error("Checkout promo code application failed",{promoCode:n,error:i instanceof Error?i.message:String(i)})}finally{this.isApplying=![],this.updateApplyButtonState()}};return this.applyButton.addEventListener("click",m),this.applyButton.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),m())}),this.applyButton}createAppliedContainer(n){const i=document.createElement("div");i.classList.add("checkout-pc-gc-applied"),this.promoCodeText=document.createElement("span"),this.promoCodeText.textContent=(null==n?void 0:n.code)+" (- "+formatCentToDollarText((null==n?void 0:n.discountAmount)||0)+")";const r=document.createElement("button");r.type="button",r.classList.add("remove-button"),r.textContent="Remove",r.addEventListener("click",async()=>{await this.commands.checkout.removePromoCode()}),i.appendChild(this.promoCodeText),i.appendChild(r),this.container.appendChild(i),this.promoInput=null,this.applyButton=null}createInputContainer(){this.container.appendChild(this.createPromoInput()),this.container.appendChild(this.createApplyButton()),this.promoCodeText=null}template(){const n=this.getStoreValue("checkout.promoCode");if(this.promoInput=null,this.applyButton=null,this.promoCodeText=null,n){const i=document.createElement("div");i.classList.add("checkout-pc-gc-applied"),this.promoCodeText=document.createElement("span"),this.promoCodeText.textContent=n.code+" (- "+formatCentToDollarText(n.discountAmount)+")";const r=document.createElement("button");return r.type="button",r.classList.add("remove-button"),r.textContent="Remove",r.addEventListener("click",async()=>{await this.commands.checkout.removePromoCode()}),i.appendChild(this.promoCodeText),i.appendChild(r),i}const i=[];return i.push(this.createPromoInput()),i.push(this.createApplyButton()),i}disconnected(){this.promoInput=null,this.applyButton=null,this.promoCodeText=null}}class CheckoutSendAsGiftComponent extends BaseComponent{get hostClasses(){return["gift-toggle-container"]}constructor(){super({watchStorePaths:["checkout.isGift"]})}template(){const n=this.getStoreValue("checkout.isGift"),i=document.createElement("div");i.classList.add("gift-label-wrapper");const r=document.createElement("span");r.textContent="Send as Gift? (Free)",r.classList.add("gift-toggle-label"),i.appendChild(r);const s=document.createElement("span");s.textContent="With personalized note & gift receipt.",s.classList.add("gift-toggle-description"),i.appendChild(s);const a=document.createElement("div");a.classList.add("toggle-switch"),a.classList.toggle("active",n);const l=document.createElement("div");return l.classList.add("toggle-slider"),a.setAttribute("tabindex","0"),a.setAttribute("aria-label","Toggle Gift Option"),a.setAttribute("role","switch"),a.setAttribute("aria-checked",n?"true":"false"),a.appendChild(l),a.addEventListener("click",async()=>{await this.commands.checkout.toggleIsGift()}),a.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await this.commands.checkout.toggleIsGift())}),[i,a]}}class CheckoutStripeFormComponent extends HTMLElement{constructor(){super(...arguments),this.N=![],this.F=null,this.R=null,this.O=null,this.L=![],this.M=![],this.B=![],this.W=null}async initialize({data:n}){if(this.N)return console.warn("Stripe form already initialized, ignoring subsequent calls"),void 0;this.H=n.stripeConfig,await this.initializeStripe(),this.setupEventListeners(),this.N=!![],await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}async initializeStripe(){try{window.Stripe||await this.loadStripeJS();const n=this.H;this.F=window.Stripe(n.publishableKey),this.R=this.F.elements({clientSecret:n.clientSecret,appearance:n.appearance}),this.O=this.R.create("payment",n.elementOptions),this.O.mount(this),this.O.on("change",async n=>{const i=!!n.error,r=n.complete,s=i?n.error.message:null;this.M=r,this.L||await this.updateStripeFormStatus({isFormComplete:r,isProcessing:![],hasCompletedPayment:![],errorMessage:s,hasError:i})}),this.O.on("focus",async()=>{this.L||await this.updateStripeFormStatus({isFormComplete:this.M,isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}),this.B=![]}catch(n){throw await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:"Failed to initialize payment form"}),n}}setupEventListeners(){this.addEventListener("lce:s:submit",async()=>{await this.handleSubmit()}),this.addEventListener("lce:s:refreshSession",this.handleRefreshSession.bind(this)),this.addEventListener("lce:s:reset",async()=>{await this.resetForm()})}async handleRefreshSession(n){const{stripeConfig:i}=n.detail;i&&(this.H=i,await this.refreshPaymentSession())}async handleSubmit(){var n,i;if(this.L)return console.warn("Payment already processing, ignoring duplicate submission"),void 0;if(!this.M)return await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:"Please complete all required payment fields"}),void 0;this.L=!![],await this.updateStripeFormStatus({isFormComplete:this.M,isProcessing:!![],hasCompletedPayment:![],hasError:![],errorMessage:"Processing payment..."});try{this.B&&(console.log("Session already used, requesting refresh..."),await this.requestSessionRefresh());const n=await this.createConfirmationTokenId(),i=this.H.clientSecret,r=i.split("_secret_")[0];this.B=!![],this.dispatchEvent(new CustomEvent("lce:s:ps-confirmed",{detail:{confirmationTokenId:n,setupIntentId:r},bubbles:!![],composed:!![]})),await this.updateStripeFormStatus({isFormComplete:!![],isProcessing:![],hasCompletedPayment:!![],hasError:![],errorMessage:null})}catch(r){console.error("Payment submission error:",r),this.B=!![],await this.updateStripeFormStatus({isFormComplete:this.M,isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:(null==r?void 0:r.message)||"Payment processing failed. Please try again."}),((null===(n=null==r?void 0:r.message)||void 0===n?void 0:n.includes("expired"))||(null===(i=null==r?void 0:r.message)||void 0===i?void 0:i.includes("invalid")))&&setTimeout(()=>this.requestSessionRefresh(),1e3)}finally{this.L=![]}}async requestSessionRefresh(){return this.W||(this.W=new Promise((n,i)=>{const r=setTimeout(()=>{this.removeEventListener("lce:s:refreshSession",I),this.W=null,i(new Error("Session refresh timeout"))},1e4),I=()=>{clearTimeout(r),this.removeEventListener("lce:s:refreshSession",I),this.W=null,n()};this.addEventListener("lce:s:refreshSession",I,{once:!![]}),this.dispatchEvent(new CustomEvent("lce:s:requestSessionRefresh",{bubbles:!![],composed:!![]}))})),this.W}async refreshPaymentSession(){try{this.R&&this.R.update({clientSecret:this.H.clientSecret}),this.B=![],await this.updateStripeFormStatus({isFormComplete:this.M,isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}catch(ut){console.error("Failed to refresh payment session:",ut),await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:"Failed to refresh payment session"})}}async resetForm(){try{this.O&&this.O.clear(),this.M=![],this.B=![],await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}catch(ut){console.error("Failed to reset form:",ut)}}async updateStripeFormStatus(n){this.dispatchEvent(new CustomEvent("lce:s:updateStripeFormStatus",{detail:{status:n},bubbles:!![],composed:!![]}))}async createConfirmationTokenId(){if(!this.R)throw new SDKError("Payment elements not initialized");try{const{error:n}=await this.R.submit();if(n)throw new SDKError(n.message||"Failed to submit payment information");const i={elements:this.R,params:{payment_method_data:{allow_redisplay:"always",billing_details:{name:"Guest",address:{country:"US"}}},shipping:{name:"Guest",address:{country:"US",city:null,line1:null,line2:null,postal_code:null,state:null}}}},{error:r,confirmationToken:s}=await this.F.createConfirmationToken(i);if(r)throw new SDKError(r.message||"Failed to create confirmation token");if(!s||!s.id)throw new SDKError("Invalid confirmation token received");return s.id}catch(n){if(n instanceof SDKError)throw n;throw new SDKError("Payment processing error: "+(n.message||"Unknown error"))}}async disconnected(){await this.cleanupForm()}disconnectedCallback(){this.cleanupForm().catch(n=>{console.error("Error during Stripe form disconnection cleanup:",n)})}async cleanupForm(){var n,i;try{this.W=null,this.O&&(this.O.unmount(),this.O=null),this.R&&(null===(i=(n=this.R).destroy)||void 0===i?void 0:i.call(n),this.R=null),this.F=null,this.L=![],this.M=![],this.B=![],this.N=![],this.isConnected&&await this.updateStripeFormStatus({isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null})}catch(r){console.warn("Error during Stripe form cleanup:",r)}}loadStripeJS(){return new Promise((n,i)=>{const r=document.querySelector('script[src*="stripe.com"]');if(r)return r.addEventListener("load",()=>n()),r.addEventListener("error",()=>i(new Error("Failed to load Stripe.js"))),void 0;const s=document.createElement("script");s.src="https://js.stripe.com/basil/stripe.js",s.async=!![],s.onload=()=>n(),s.onerror=()=>i(new Error("Failed to load Stripe.js")),document.head.appendChild(s)})}}class CheckoutStripeHandlerComponent extends BaseComponent{get hostClasses(){return["checkout-stripe-handler"]}constructor(){super({watchOnlyStorePaths:["checkout.paymentForm.paymentMethod","checkout.paymentForm.isEditing"]}),this.stripeFormElement=null,this.rootComponent=null,this.isCreatingStripeForm=![],this.stripeFormStatus={isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null},this.isInEditMode=![],this.savedCardInfo=null,this.isChangingPayment=![],this.callbacks={}}beforeConnected(){this.callbacks=this.params.callbacks||{}}onStoreWatch(n){for(const i of n)switch(i.path){case"checkout.paymentForm.paymentMethod":this.handleSavedCardChange(i.value);break;case"checkout.paymentForm.isEditing":this.handleEditModeChange(i.value)}}handleSavedCardChange(n){var i,r,s,a;(null===(i=null==n?void 0:n.card)||void 0===i?void 0:i.brand)&&(null===(r=null==n?void 0:n.card)||void 0===r?void 0:r.last4)?this.savedCardInfo={brand:n.card.brand,last4:n.card.last4}:this.savedCardInfo=null,null===(a=(s=this.callbacks).onSavedCardInfoChanged)||void 0===a||a.call(s,this.savedCardInfo),this.updateDisplayState()}handleEditModeChange(n){this.isInEditMode=n,this.updateDisplayState()}updateDisplayState(){var n,i,r,s,a,l;this.isInEditMode&&this.savedCardInfo&&!this.isChangingPayment?(this.showStripeSummary(),this.hideStripeForm(),null===(i=(n=this.callbacks).onEditModeVisibilityChanged)||void 0===i||i.call(n,!![])):this.isInEditMode||this.isChangingPayment?(this.hideStripeSummary(),this.showStripeForm(),null===(s=(r=this.callbacks).onEditModeVisibilityChanged)||void 0===s||s.call(r,![]),this.stripeFormElement||this.isCreatingStripeForm||this.createAndMountStripeForm().catch(n=>{this.logger.error("Failed to create stripe form in updateDisplayState",n)})):(this.hideStripeSummary(),this.hideStripeForm(),null===(l=(a=this.callbacks).onEditModeVisibilityChanged)||void 0===l||l.call(a,![]))}async afterRender(){var n,i,r,s;this.isInEditMode=null!==(n=this.getStoreValue("checkout.paymentForm.isEditing"))&&void 0!==n?n:![];const a=this.getStoreValue("checkout.paymentForm.paymentMethod");(null===(i=null==a?void 0:a.card)||void 0===i?void 0:i.brand)&&a.card.last4&&(this.savedCardInfo={brand:a.card.brand,last4:a.card.last4}),null===(s=(r=this.callbacks).onSavedCardInfoChanged)||void 0===s||s.call(r,this.savedCardInfo),this.updateDisplayState(),(this.isInEditMode&&!this.savedCardInfo||this.isChangingPayment)&&await this.createAndMountStripeForm()}setupStripeFormEventListeners(){if(!this.stripeFormElement)return this.logger.warn("Cannot set up event listeners: Stripe form element is null"),void 0;this.stripeFormElement.addEventListener("lce:s:updateStripeFormStatus",n=>{var i,r;this.stripeFormStatus=n.detail.status,null===(r=(i=this.callbacks).onStripeFormStatusChanged)||void 0===r||r.call(i,this.stripeFormStatus)}),this.stripeFormElement.addEventListener("lce:s:ps-confirmed",async n=>{var i,r,s,a,l;try{const{confirmationTokenId:s,setupIntentId:a}=n.detail;await(null===(r=(i=this.callbacks).onPaymentSessionConfirmed)||void 0===r?void 0:r.call(i,s,a)),this.isChangingPayment=![]}catch(d){this.logger.error("Failed to save payment form",d),this.stripeFormStatus={isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:!![],errorMessage:(null==d?void 0:d.message)||"Failed to save payment information. Please try again."},null===(a=(s=this.callbacks).onStripeFormStatusChanged)||void 0===a||a.call(s,this.stripeFormStatus),null===(l=this.stripeFormElement)||void 0===l||l.dispatchEvent(new CustomEvent("lce:s:reset",{bubbles:!![],composed:!![]}))}}),this.stripeFormElement.addEventListener("lce:s:requestSessionRefresh",async()=>{var n;try{const i=await this.doStripeConfig();null===(n=this.stripeFormElement)||void 0===n?void 0:n.dispatchEvent(new CustomEvent("lce:s:refreshSession",{detail:{stripeConfig:i}}))}catch(i){this.logger.error("Failed to refresh payment session",i)}})}showStripeSummary(){if(!this.stripeSummaryContainer||!this.savedCardInfo)return;this.stripeSummaryContainer.innerHTML="";const n=document.createElement("span");n.classList.add("stripe-summary-text"),n.textContent=capitalizeFirstLetter(this.savedCardInfo.brand||"")+" ending in "+this.savedCardInfo.last4;const i=document.createElement("button");i.type="button",i.classList.add("change-payment-link"),i.textContent="Change",i.setAttribute("aria-label","Change Payment Method"),i.setAttribute("role","button"),i.setAttribute("tabindex","0"),i.addEventListener("click",()=>this.handleChangePayment()),i.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),this.handleChangePayment())}),this.stripeSummaryContainer.append(n,i),this.stripeSummaryContainer.style.display="flex"}hideStripeSummary(){this.stripeSummaryContainer&&(this.stripeSummaryContainer.style.display="none",this.stripeSummaryContainer.innerHTML="")}showStripeForm(){this.stripeFormContainer&&(this.stripeFormContainer.style.display="block")}hideStripeForm(){this.stripeFormContainer&&(this.stripeFormContainer.style.display="none"),this.removeExistingStripeForm()}async handleChangePayment(){var n,i;this.isChangingPayment=!![],this.stripeFormStatus={isFormComplete:![],isProcessing:![],hasCompletedPayment:![],hasError:![],errorMessage:null},null===(i=(n=this.callbacks).onStripeFormStatusChanged)||void 0===i||i.call(n,this.stripeFormStatus),this.updateDisplayState()}template(){const n=[];this.stripeSummaryContainer=document.createElement("div"),this.stripeSummaryContainer.classList.add("stripe-summary-container"),this.stripeSummaryContainer.style.display="none",n.push(this.stripeSummaryContainer),this.stripeFormContainer=document.createElement("div"),this.stripeFormContainer.classList.add("stripe-form-container");const i=document.createElement("slot");return i.setAttribute("name",Pt),this.stripeFormContainer.appendChild(i),n.push(this.stripeFormContainer),n}submitStripeForm(){this.stripeFormElement&&this.stripeFormStatus.isFormComplete&&!this.stripeFormStatus.hasCompletedPayment&&this.stripeFormElement.dispatchEvent(new CustomEvent("lce:s:submit"))}getStripeFormStatus(){return{...this.stripeFormStatus}}findRootComponent(){if(this.rootComponent)return this.rootComponent;let n=this,i=null;for(;n&&n!==document.body;){const r=n.hasAttribute("checkout"),s=n.tagName.toLowerCase()===ComponentFactoryService.getComponentTagName(C.LCE_ELEMENT),a=n.hasAttribute("drawer"),l=(null==i?void 0:i.tagName.toLowerCase())===ComponentFactoryService.getComponentTagName(C.DRAWER),d="checkout"===(null==i?void 0:i.getAttribute("data-target"));if(r||s&&a&&l&&d)return this.rootComponent=n,n;i=n,n=n.parentElement||n.getRootNode().host}return null}removeExistingStripeForm(){this.stripeFormElement&&(this.stripeFormElement.remove(),this.stripeFormElement=null)}async doStripeConfig(){const n=this.store.get("checkout.paymentForm.paymentSession");!this.isChangingPayment&&(null==n?void 0:n.key)&&(null==n?void 0:n.secret)||await this.commands.checkout.getPaymentSession();const i=this.store.get("checkout.paymentForm.paymentSession"),r=this.getConfigs("global");return{publishableKey:i.key,clientSecret:i.secret,appearance:{theme:"stripe",variables:{fontFamily:r.theme.paragraphFont.name+", system-ui, sans-serif",borderRadius:r.theme.buttonCornerRadius},rules:{".Input":{border:"filled"===r.layout.inputFieldStyle?"none":"1px solid "+r.theme.accentColor,backgroundColor:"filled"===r.layout.inputFieldStyle?r.theme.accentColor:"transparent"}}},elementOptions:{layout:"tabs",defaultValues:{billingDetails:{name:"Guest",address:{country:"US"}}},fields:{billingDetails:{address:{postalCode:"auto",country:"never"}}},terms:{applePay:"never",auBecsDebit:"never",bancontact:"never",card:"never",cashapp:"never",googlePay:"never",ideal:"never",paypal:"never",sepaDebit:"never",sofort:"never",usBankAccount:"never"}}}}async createAndMountStripeForm(){var n,i,r;if(this.isCreatingStripeForm)return this.logger.info("Stripe form creation already in progress, skipping"),void 0;if(this.isInEditMode&&this.savedCardInfo&&!this.isChangingPayment)return this.logger.info("In edit mode with saved card, skipping stripe form creation"),void 0;const s=this.findRootComponent();if(!s)return this.logger.error("Could not find root component for Stripe form"),void 0;if(null===(n=this.stripeFormElement)||void 0===n?void 0:n.isConnected)return this.logger.info("Stripe form already exists and is connected, skipping creation"),void 0;const a=s.querySelectorAll('[slot="'+Pt+'"]');if(a.length>0)for(const d of a)d.remove();this.isCreatingStripeForm=!![];try{const n=await this.doStripeConfig();this.stripeFormElement=ComponentFactoryService.createElement({type:C.CHECKOUT_STRIPE_FORM,stripeConfig:n}),this.setupStripeFormEventListeners(),this.stripeFormElement.setAttribute("slot",Pt),s.appendChild(this.stripeFormElement)}catch(l){this.logger.error("Stripe form element creation failed",l),this.stripeFormStatus={...this.stripeFormStatus,hasError:!![],errorMessage:"Failed to initialize payment form. Please reload the page."},null===(r=(i=this.callbacks).onStripeFormStatusChanged)||void 0===r||r.call(i,this.stripeFormStatus),this.stripeFormElement=null}finally{this.isCreatingStripeForm=![]}}disconnected(){var n;this.removeExistingStripeForm(),this.rootComponent=null,this.isCreatingStripeForm=![],this.isChangingPayment=![],null===(n=super.disconnected)||void 0===n||n.call(this)}}class CheckoutTipsComponent extends BaseComponent{get hostClasses(){return["checkout-tips-container"]}constructor(){super({watchStorePaths:["checkout.onDemandFulfillmentTipInfo","checkout.tipSelection","checkout.updating","checkout.amounts"]}),this.isInitialized=![]}afterRender(){this.setupToggler()}getTipSelection(){const n=this.getStoreValue("checkout.tipSelection");return null!=n?n:10}getOnDemandFulfillmentTipInfo(){return this.getStoreValue("checkout.onDemandFulfillmentTipInfo")||{}}getFulfillmentTipInfoArray(){return Object.values(this.getOnDemandFulfillmentTipInfo())}async handlePercentageSelect(n){const i=this.getStoreValue("checkout.updating")||![];if(!i)try{await this.commands.checkout.updateTips(n)}catch(r){this.logger.error("Checkout tips update failed",r)}}async handleFulfillmentTipInput(n,i){const r=this.getStoreValue("checkout.updating")||![];if(r)return;const s=this.getOnDemandFulfillmentTipInfo();if(!s[n])return;const a=Math.round(100*i);try{await this.commands.checkout.updateFulfillmentTip(n,a)}catch(l){this.logger.error("Checkout fulfillment tip update failed",l)}}async removeTipFromFulfillment(n){const i=this.getStoreValue("checkout.updating")||![];if(i)return;const r=this.getOnDemandFulfillmentTipInfo();if(r[n])try{await this.commands.checkout.removeFulfillmentTip(n)}catch(s){this.logger.error("Checkout fulfillment tip removal failed",s)}}createTipSelectionButtons(){const n=document.createElement("div");n.classList.add("checkout-tip-selection-container");const i=[10,18,20],r=this.getStoreValue("checkout.updating")||![],s=this.getTipSelection();for(const a of i){const i=document.createElement("button");i.type="button",i.textContent=a+"%",i.classList.add("checkout-tip-button"),i.disabled=r,s===a&&i.classList.add("selected"),i.addEventListener("click",()=>this.handlePercentageSelect(a)),n.appendChild(i)}return n}setupToggler(){const n=this.container.querySelector(".checkout-tip-distribution-header"),i=this.container.querySelector(".checkout-items-toggler-button"),r=this.container.querySelector(".retailers-tips-list");n&&i&&r&&n.addEventListener("click",()=>{const n=r.classList.contains("show");r.classList.toggle("show"),n?(i.setAttribute("aria-expanded","false"),i.setAttribute("aria-label","Expand tips section")):(i.setAttribute("aria-expanded","true"),i.setAttribute("aria-label","Collapse tips section")),i.classList.toggle("expanded")})}createTipDistribution(){const n=document.createElement("section");n.classList.add("checkout-tip-distribution-container");const i=this.getFulfillmentTipInfoArray();if(0===i.length)return n;const r=document.createElement("div");r.classList.add("checkout-tip-distribution-header");const s=document.createElement("h3");s.textContent="View Tip Distribution",s.classList.add("checkout-sub-header"),r.appendChild(s);const a=document.createElement("button");a.type="button",a.classList.add("checkout-items-toggler-button"),a.innerHTML=ChevronDownIcon({width:20,height:20,className:"chevron-icon"}),r.appendChild(a),n.appendChild(r);const l=document.createElement("div");l.classList.add("retailers-tips-list","show");for(const d of i){const n=document.createElement("div");n.classList.add("checkout-tip-distribution-item");const i=document.createElement("h4");i.textContent=d.retailerName,i.classList.add("checkout-sub-header"),n.appendChild(i);const r=document.createElement("div");r.classList.add("checkout-tip-fulfillment-input-wrapper");const s=document.createElement("div");s.classList.add("dollar-input-container");const a=document.createElement("span");a.classList.add("dollar-sign"),a.textContent="$";const u=document.createElement("input");let f;u.type="number",u.id="tip-input-"+d.fulfillmentId,u.name="tip-"+d.fulfillmentId,u.min="0",u.step="0.01",u.placeholder="0.00",u.classList.add("dollar-input"),u.value=d.tip>0?(d.tip/100).toFixed(2):"",u.disabled=this.getStoreValue("checkout.updating")||![],u.addEventListener("wheel",n=>{n.preventDefault()}),u.addEventListener("keydown",n=>{"-"!==n.key&&"+"!==n.key||n.preventDefault()}),u.addEventListener("keydown",n=>{"ArrowUp"!==n.key&&"ArrowDown"!==n.key||n.preventDefault()}),u.addEventListener("paste",n=>{n.preventDefault()}),u.addEventListener("contextmenu",n=>{n.preventDefault()}),u.addEventListener("input",n=>{const i=n.target;let r=i.value;if(Number.parseFloat(r)<0&&(i.value=Math.abs(Number.parseFloat(r)).toString(),r=i.value),r.includes(".")){const n=r.split(".");n.length>1&&n[1].length>2&&(i.value=n[0]+"."+n[1].substring(0,2))}}),u.addEventListener("input",n=>{const i=n.target,r=Number.parseFloat(i.value)||0;f&&clearTimeout(f),f=setTimeout(()=>{this.handleFulfillmentTipInput(d.fulfillmentId,r)},500)}),s.appendChild(a),s.appendChild(u),r.appendChild(s);const g=document.createElement("button");g.type="button",g.textContent="Remove",g.classList.add("checkout-tip-remove-button"),g.disabled=this.getStoreValue("checkout.updating")||![],g.addEventListener("click",()=>this.removeTipFromFulfillment(d.fulfillmentId)),r.appendChild(g),n.appendChild(r),l.appendChild(n)}return n.appendChild(l),n}async initializeDefaultTip(){if(this.isInitialized)return;const n=this.getStoreValue("checkout.tipSelection"),i=this.getFulfillmentTipInfoArray();if(n&&i.length>0){const n=i.some(n=>n.tip>0);if(n)this.isInitialized=!![];else try{this.isInitialized=!![],await this.commands.checkout.updateTips(10)}catch(r){this.logger.error("Default tip initialization failed",r),this.isInitialized=![]}}if(null==n)try{this.isInitialized=!![],await this.commands.checkout.updateTips(10)}catch(s){this.logger.error("Default tip initialization failed during fallback",s),this.isInitialized=![]}}template(){const n=[],i=this.getFulfillmentTipInfoArray();if(0===i.length)return n;i.length>0&&this.initializeDefaultTip();const r=document.createElement("section");r.classList.add("checkout-tip-container");const s=document.createElement("h3");s.classList.add("checkout-sub-header"),s.textContent="Add a tip",r.appendChild(s);const a=document.createElement("div");a.classList.add("checkout-tip-config-container");const l=this.createTipSelectionButtons();a.appendChild(l),r.appendChild(a);const d=document.createElement("p");d.classList.add("checkout-tip-disclaimer"),d.textContent="Tips will be split proportionally between retailers.",r.appendChild(d);const u=this.createTipDistribution();return n.push(r,u),n}}class CheckoutPcGcComponent extends BaseComponent{get hostClasses(){return["checkout-sections-container"]}constructor(){super({watchOnlyStorePaths:["checkout.loading","checkout.giftCardError","checkout.promoCodeError","checkout.giftCards"]}),this.appliedGiftCardsContainer=null}onStoreWatch(n){var i,r;const s=n.find(n=>"checkout.giftCardError"===n.path),a=n.find(n=>"checkout.promoCodeError"===n.path),l=n.find(n=>"checkout.giftCards"===n.path);if(l&&this.updateAppliedGiftCards(l.value),s){const n=this.container.querySelector(".input-gift-card-container");if(n){const r=n.nextElementSibling;if((null===(i=null==r?void 0:r.classList)||void 0===i?void 0:i.contains("error-banner-checkout"))&&(null==r?void 0:r.remove()),s.value){const i=this.createErrorElement(s.value);n.after(i)}const a=n.querySelector(".apply-button");a&&(a.disabled=Boolean(s.value))}}if(a){const n=this.container.querySelector(".input-promo-code-container");if(n){const i=n.nextElementSibling;if((null===(r=null==i?void 0:i.classList)||void 0===r?void 0:r.contains("error-banner-checkout"))&&(null==i?void 0:i.remove()),a.value){const i=this.createErrorElement(a.value);n.after(i)}const s=n.querySelector(".apply-button");s&&(s.disabled=Boolean(a.value))}}}updateAppliedGiftCards(n){const i=n&&n.length>0;if(!i)return this.appliedGiftCardsContainer&&(this.appliedGiftCardsContainer.remove(),this.appliedGiftCardsContainer=null),void 0;this.appliedGiftCardsContainer||(this.appliedGiftCardsContainer=document.createElement("div"),this.appliedGiftCardsContainer.classList.add("checkout-pc-gc-sub-container"),this.container.appendChild(this.appliedGiftCardsContainer)),this.appliedGiftCardsContainer.innerHTML="",n.forEach(n=>{const i=this.createAppliedGiftCardElement(n);this.appliedGiftCardsContainer.appendChild(i)})}createAppliedGiftCardElement(n){const i=document.createElement("div");i.classList.add("checkout-pc-gc-applied"),i.setAttribute("data-gift-card-code",n.code);const r=document.createElement("span");r.textContent=n.code+" (- "+formatCentToDollarText(n.discountAmount)+")",i.appendChild(r);const s=document.createElement("button");return s.type="button",s.textContent="Remove",s.addEventListener("click",async()=>{await this.commands.checkout.removeGiftCard(n.code)}),i.appendChild(s),i}pcInputContainer(){const n=ComponentFactoryService.createElement({type:C.CHECKOUT_PROMO_CODE,classList:["input-promo-code-container"]});return n}gcInputContainer(){const n=ComponentFactoryService.createElement({type:C.CHECKOUT_GIFT_CARDS});return n}inputContainer(){var n;const i=this.getConfigs("checkout"),r=this.getConfigs("global"),s=i.layout.allowGiftCards,a=null===(n=null==r?void 0:r.layout)||void 0===n?void 0:n.allowPromoCodes,l=document.createElement("div");l.classList.add("checkout-pc-gc-sub-container");const d=this.pcInputContainer(),u=this.gcInputContainer();a&&l.appendChild(d);const f=this.getStoreValue("checkout.promoCodeError");if(f){const n=this.createErrorElement(f);n.classList.add("promo-code-error-wrapper"),l.appendChild(n)}s&&l.appendChild(u);const g=this.getStoreValue("checkout.giftCardError");if(g){const n=this.createErrorElement(g);l.appendChild(n)}return l}createErrorElement(n){const i=document.createElement("div");i.classList.add("error-banner-checkout");const r=document.createElement("div");r.innerHTML=ErrorInfoIcon({});const s=document.createElement("p");return s.textContent=n.toString(),i.appendChild(r),i.appendChild(s),setTimeout(async()=>{await this.commands.checkout.clearPromoCodeError(),await this.commands.checkout.clearGiftCardError(),i.remove()},3e3),i}template(){const n=this.getStoreValue("checkout.giftCards");this.appliedGiftCardsContainer=null;const i=[];return i.push(this.inputContainer()),n&&n.length>0&&(this.appliedGiftCardsContainer=document.createElement("div"),this.appliedGiftCardsContainer.classList.add("checkout-pc-gc-sub-container"),n.forEach(n=>{const i=this.createAppliedGiftCardElement(n);this.appliedGiftCardsContainer.appendChild(i)}),i.push(this.appliedGiftCardsContainer)),i}disconnected(){this.appliedGiftCardsContainer=null}}function fulfillmentAddress(n,i){if(!n)return"";if(i===E.SHIPPING){const i=[n.city,n.state].filter(Boolean);return i.join(", ")}const r=[n.one,n.two,n.city,n.state].filter(Boolean);return r.join(", ")}function renderPopupRetailerCard({fulfillment:n,selectedFulfillmentType:i,isSelected:r,fulfillmentStatus:s,selectedSizeAttributes:a}){var l,d,u,f,g;let v=0;const b=null==a?void 0:a.presale,x=(null==b?void 0:b.isActive)&&(null==b?void 0:b.estimatedShipBy)?"Ships by "+formatISODateToMMDDYYYY(b.estimatedShipBy):"",w=i===E.SHIPPING,C=i===E.ON_DEMAND;w&&(v=(null===(d=null===(l=null==n?void 0:n.fees)||void 0===l?void 0:l.individual)||void 0===d?void 0:d.fee)||0),C&&(v=(null===(u=null==n?void 0:n.fees)||void 0===u?void 0:u.fee)||0);const T=fulfillmentAddress(n.retailerAddress,i);let A=null;i===E.ON_DEMAND&&s.openTime&&(null==s?void 0:s.closeTime)&&(A=s.isOpen?"Closes at "+format24TimeTo12$1(null==s?void 0:s.closeTime):"Opens at "+format24TimeTo12$1(null==s?void 0:s.openTime));const P=i===E.ON_DEMAND&&s&&s.isClosed?"closed":"",_=document.createElement("div");_.className="popup-retailer-card "+(r?"selected":"")+" "+P,_.setAttribute("data-fulfillment-id",n.fulfillmentId),_.setAttribute("role","button"),_.setAttribute("tabindex","0"),_.setAttribute("aria-pressed",r?"true":"false");const N=i===E.SHIPPING?"Shipping":"Same-day delivery";_.setAttribute("aria-label",N+" from "+n.retailerName+", "+formatCentToDollarText(null!==(f=n.price)&&void 0!==f?f:0));const F=document.createElement("div");F.className="row";const R=document.createElement("span");R.className="name",R.textContent=n.retailerName,F.appendChild(R);const O=document.createElement("span");O.className="price",O.textContent=formatCentToDollarText(null!==(g=n.price)&&void 0!==g?g:0),F.appendChild(O),_.appendChild(F);const L=document.createElement("div");L.className="row";const M=document.createElement("span");M.className="expectation",M.textContent=s.isClosed?A:(null==b?void 0:b.isActive)?x:(null==n?void 0:n.expectation.detail)||"No expectation available",L.appendChild(M);const B=document.createElement("span");if(B.className="fee",B.textContent=v>0?formatCentToDollarText(v):"Free Delivery",L.appendChild(B),_.appendChild(L),C){const n=document.createElement("div");n.className="row";const i=document.createElement("span");i.className="address",i.textContent=T,n.appendChild(i),_.appendChild(n)}return _}function renderFulfillmentTabsContainer({shippingFulfillments:n,onDemandFulfillments:i,shippingSelected:r,onDemandSelected:s,onTabClick:a,enableShippingFulfillment:l,enableOnDemandFulfillment:d}){const u=i.length>0,f=document.createElement("div");if(f.className="fulfillment-tabs-container",f.setAttribute("role","tablist"),f.setAttribute("aria-label","Delivery method options"),l){const i=document.createElement("div");i.className="fulfillment-tab "+(r?"selected":""),i.setAttribute("data-fulfillment-type",E.SHIPPING),i.setAttribute("role","tab"),i.setAttribute("tabindex","0"),i.setAttribute("aria-selected",r?"true":"false"),i.setAttribute("aria-label","Shipping, "+n.length+" options"),i.addEventListener("click",a),i.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),i.click())});const s=document.createElement("span");s.className="fulfillment-tab-label "+(r?"selected":""),s.textContent="Shipping ("+n.length+")",i.appendChild(s),f.appendChild(i)}if(d){const n=document.createElement("div");n.className="fulfillment-tab "+(s?"selected":"")+" "+(u?"":"disabled"),n.setAttribute("data-fulfillment-type",E.ON_DEMAND),n.setAttribute("role","tab"),n.setAttribute("tabindex","0"),n.setAttribute("aria-selected",s?"true":"false"),n.setAttribute("aria-label","Same-day delivery, "+i.length+" options"),u||n.setAttribute("aria-disabled","true"),n.addEventListener("click",a),n.addEventListener("keydown",i=>{"Enter"!==i.key&&" "!==i.key||(i.preventDefault(),n.click())});const r=document.createElement("span");r.className="fulfillment-tab-label "+(s?"selected":""),r.textContent="Same-Day Delivery ("+i.length+")",n.appendChild(r),f.appendChild(n)}return f}class ProductAddToCartSectionComponent extends BaseComponent{get hostClasses(){return["add-to-cart-container"]}get hostAttributes(){return{role:"region","aria-live":"polite","aria-atomic":"false","aria-label":"Add to cart section"}}constructor(){super({watchStorePaths:["products.{productId}.quantity","products.{productId}.selectedFulfillment","products.{productId}.fulfillmentHasAvailability","cart.items","products.{productId}.updating"]})}getProductId(){return this.params.productId}getAvailableQuantity(){var n;const i=this.getProductId(),r=this.getStoreValue("products."+i);if(!r.selectedFulfillment||!r.selectedSizeId)return 0;const s=r.selectedFulfillment.partNumber,a=r.selectedFulfillment.fulfillmentId,l=null===(n=r.sizes[r.selectedSizeId].attributes)||void 0===n?void 0:n.maxQuantityPerOrder;if(!l)return 0;const d=this.getStoreValue("cart.items")||{},u=Object.values(d).filter(n=>n.partNumber===s&&n.fulfillmentId===a),f=u.reduce((n,i)=>n+i.quantity,0);return l-f}isFulfillmentClosed(){const n=this.getProductId(),i=this.getStoreValue("products."+n);if(!i.selectedFulfillment)return![];const r=getRetailerOffHours(i.selectedFulfillment);return i.selectedFulfillmentType===E.ON_DEMAND&&r&&r.isClosed}isButtonLoading(){const n=this.getProductId();return this.getStoreValue("products."+n+".updating")}calculateQuantityLimits(){const{quantity:n}=this.calculateTotalPrice(),i=this.getAvailableQuantity(),r=n<i;return{currentQuantity:n,availableQuantity:i,canIncrease:r,canDecrease:n>1}}async handleAddToCart(){var n,i,r;const s=this.getProductId(),a=this.getStoreValue("products."+s);if(!a.selectedFulfillment)return this.logger.error("Product add to cart failed: No fulfillment option selected",{productId:s,selectedSizeId:a.selectedSizeId}),void 0;const l=this.getSizeAttributes(),d=(null===(n=null==l?void 0:l.presale)||void 0===n?void 0:n.isActive)===!![],u=this.isPresaleActive(l);d&&u?await this.commands.product.addPresaleToCart(s,{upc:a.sizes[a.selectedSizeId].upc,fulfillmentId:a.selectedFulfillment.fulfillmentId,partNumber:null===(i=a.selectedFulfillment)||void 0===i?void 0:i.partNumber,quantity:a.quantity,identifier:s}):await this.commands.product.addToCart(s,{upc:a.sizes[a.selectedSizeId].upc,fulfillmentId:a.selectedFulfillment.fulfillmentId,partNumber:null===(r=a.selectedFulfillment)||void 0===r?void 0:r.partNumber,quantity:a.quantity,identifier:s})}async handleQuantityChange(n){const i=this.getProductId();await this.commands.product.updateQuantity(i,n)}calculateTotalPrice(){const n=this.getProductId(),i=this.getStoreValue("products."+n),r=i.selectedFulfillment,s=r.price*i.quantity;return{quantity:i.quantity,totalPrice:s}}createQuantityContainer(n){const i=this.calculateQuantityLimits(),r=document.createElement("div");return r.className="quantity-container "+n,this.qtyDecreaseButton=document.createElement("button"),this.qtyDecreaseButton.type="button",this.qtyDecreaseButton.className="quantity-decrease",this.qtyDecreaseButton.textContent="−",this.qtyDecreaseButton.disabled=!i.canDecrease,this.qtyDecreaseButton.setAttribute("aria-label","Decrease quantity"),this.qtyDecreaseButton.setAttribute("aria-disabled",(!i.canDecrease).toString()),i.canDecrease||(this.qtyDecreaseButton.disabled=!![],this.qtyDecreaseButton.classList.add("disabled")),this.qtyDecreaseButton.addEventListener("click",async n=>{n.preventDefault(),await this.handleQuantityChange(-1)}),this.quantityText=document.createElement("span"),this.quantityText.className="product-count",this.quantityText.textContent=i.currentQuantity.toString(),this.quantityText.setAttribute("role","status"),this.quantityText.setAttribute("aria-label","Current quantity: "+i.currentQuantity),this.qtyIncreaseButton=document.createElement("button"),this.qtyIncreaseButton.type="button",this.qtyIncreaseButton.className="quantity-increase",this.qtyIncreaseButton.textContent="+",this.qtyIncreaseButton.disabled=!i.canIncrease,this.qtyIncreaseButton.setAttribute("aria-label","Increase quantity"),this.qtyIncreaseButton.setAttribute("aria-disabled",(!i.canIncrease).toString()),i.canIncrease||(this.qtyIncreaseButton.disabled=!![],this.qtyIncreaseButton.classList.add("disabled")),this.qtyIncreaseButton.addEventListener("click",async n=>{n.preventDefault(),await this.handleQuantityChange(1)}),r.appendChild(this.qtyDecreaseButton),r.appendChild(this.quantityText),r.appendChild(this.qtyIncreaseButton),r}getSizeAttributes(){const n=this.getProductId(),i=this.getStoreValue("products."+n+".selectedSizeId"),r=this.getStoreValue("products."+n+".sizes."+i);return(null==r?void 0:r.attributes)||{}}isPresaleActive(n){const i=null==n?void 0:n.presale;if(!i)return![];if(!i.isActive)return![];if(i.canPurchaseOn){const n=new Date(i.canPurchaseOn),r=new Date;if(r.getTime()<n.getTime())return![]}return!![]}createAddToCartButton(){var n;const{totalPrice:i}=this.calculateTotalPrice(),r=this.getSizeAttributes(),s=this.calculateQuantityLimits(),a=(null===(n=null==r?void 0:r.presale)||void 0===n?void 0:n.isActive)===!![],l=this.isPresaleActive(r),d=a?this.config.layout.preSaleButtonText:this.config.layout.addToCartButtonText;this.addToCartButton=document.createElement("button"),this.addToCartButton.type="button",this.addToCartButton.className="add-to-cart-button",this.addToCartButton.textContent=this.config.layout.addToCartButtonShowTotalPrice?d+" - "+formatCentToDollarText(i):d;const u=a&&!l||0===s.availableQuantity||this.isFulfillmentClosed(),f=this.isButtonLoading(),g=this.config.layout.addToCartButtonShowTotalPrice?d+" for "+formatCentToDollarText(i):d;return this.addToCartButton.setAttribute("aria-label",g),this.addToCartButton.setAttribute("aria-busy",f.toString()),this.addToCartButton.setAttribute("aria-disabled",u.toString()),u&&(this.addToCartButton.disabled=!![],this.addToCartButton.classList.add("disabled")),f&&(this.addToCartButton.disabled=!![],this.addToCartButton.classList.add("loading")),this.addToCartButton.addEventListener("click",async n=>{if(n.preventDefault(),this.clientConfig.isBuilder())return this.logger.info("Product Add To Cart Button Is Disabled In Builder Mode"),void 0;await this.handleAddToCart()}),this.addToCartButton}template(){const n=this.getProductId(),i=this.getStoreValue("products."+n+".fulfillmentHasAvailability"),r=this.getConfigs("configurations");if(!i||!r.isElementsEnabled)return[];const s=[];if(this.config.layout.showQuantityCounter){const n=this.createQuantityContainer(this.config.layout.quantityCounterStyle);s.push(n)}const a=this.createAddToCartButton();return s.push(a),s}}class ProductDescriptionComponent extends BaseComponent{constructor(){super(...arguments),this.isCollapsed=!![]}get hostClasses(){return["product-description"]}template(){const n=this.params.productId,i=this.getStoreValue("products."+n+".description"),r=this.getStoreValue("products."+n+".htmlDescription"),s="About this product:",a="See More",l="See Less",d=document.createElement("h3");d.className="title",d.textContent=s;const u=document.createElement("div");u.className="content collapsed",u.innerHTML=""===(null==r?void 0:r.trim())?i:sanitizeHTML(r);const f=document.createElement("span");f.className="collapse-button",f.textContent=a,f.setAttribute("role","button"),f.setAttribute("tabindex","0"),f.setAttribute("aria-label","Show more product information"),f.setAttribute("aria-expanded","false");const toggleContent=()=>{this.isCollapsed=!this.isCollapsed,u.classList.toggle("collapsed"),f.textContent=this.isCollapsed?a:l,f.setAttribute("aria-label",this.isCollapsed?"Show more product information":"Show less product information"),f.setAttribute("aria-expanded",this.isCollapsed?"false":"true")};return f.addEventListener("click",toggleContent),f.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),toggleContent())}),[d,u,f]}}class ProductDrawerComponent extends BaseComponent{get hostClasses(){return["product-drawer-container"]}constructor(){super({watchStorePaths:["products.{productId}.drawer"]}),this.isOpen=![],this.contentContainer=null,this.currentContentType=null}getProductId(){return this.params.productId}onStoreChanged(n){var i;const r=n.find(n=>n.path==="products."+this.getProductId()+".drawer");if(!r)return![];const s=r.value,a=s.isOpen,l=null===(i=s.contentConfig)||void 0===i?void 0:i.type,d=l!==this.currentContentType;return a&&!this.isOpen?(this.currentContentType=l,this.openWithContent(s),![]):a&&this.isOpen&&!d?![]:a&&this.isOpen&&d?(this.currentContentType=l,this.openWithContent(s),![]):!a&&this.isOpen?(this.close(),this.currentContentType=null,![]):![]}openWithContent({contentConfig:n}){const i=this.getProductId();try{if(this.contentContainer&&(this.contentContainer.innerHTML=""),!n)return this.logger.warn("Product drawer opening attempted without content configuration",{productId:i}),void 0;const{type:r,data:s}=n||{},a=ComponentFactoryService.createElement({type:r,...s});this.contentContainer&&this.contentContainer.appendChild(a),this.open()}catch(r){this.logger.error("Failed to open product drawer",r),this.commands.product.closeProductDrawer(i)}}open(){this.isOpen=!![],this.updateDrawerState()}close(){this.isOpen=![],this.updateDrawerState()}updateDrawerState(){this.isOpen&&this.container.classList.add("open"),this.isOpen||this.container.classList.remove("open")}template(){const n=document.createElement("div");return n.classList.add("product-drawer-content"),this.contentContainer=n,n}}class ProductImageCarouselComponent extends BaseComponent{get hostClasses(){const n=this.config.layout.fulfillmentDisplay;return["product-image-carousel",n]}constructor(){super({watchOnlyStorePaths:["products.{productId}.mainImage"]}),this.mainImageElement=null,this.galleryViewport=null,this.galleryContainer=null,this.thumbnails=[],this.currentImageIndex=0,this.isDragging=![],this.hasMoved=![],this.startX=0,this.currentTranslateX=0,this.translateX=0}afterRender(){this.cacheElements(),this.setupEventListeners(),this.scrollToIndex(0)}onStoreWatch(n){const i=this.params.productId,r=n.find(n=>n.path==="products."+i+".mainImage");if(null==r?void 0:r.value){const n=this.params.images.indexOf(null==r?void 0:r.value);-1!==n?this.selectImage(n):this.mainImageElement&&(this.mainImageElement.style="--bg-image: url('"+r.value+"')")}}cacheElements(){this.galleryViewport=this.container.querySelector(".gallery-viewport"),this.galleryContainer=this.container.querySelector(".gallery-container"),this.thumbnails=Array.from(this.container.querySelectorAll(".gallery-image-wrapper"))}setupEventListeners(){for(let i=0;i<this.thumbnails.length;i++){const n=this.thumbnails[i];n.addEventListener("click",()=>{this.hasMoved||this.selectImage(i)})}const n=this.container.querySelectorAll(".carousel-dot");for(let i=0;i<n.length;i++){const r=n[i];r.addEventListener("click",()=>this.selectImage(i))}this.setupMainImageSwipe(),this.galleryContainer&&this.setupGalleryDrag()}selectImage(n){var i,r;if(n<0||n>=this.params.images.length)return;this.mainImageElement&&(this.mainImageElement.style="--bg-image: url('"+this.params.images[n]+"')",this.mainImageElement.title="Product image "+(n+1)),null===(i=this.thumbnails[this.currentImageIndex])||void 0===i||i.classList.remove("selected"),null===(r=this.thumbnails[n])||void 0===r||r.classList.add("selected");const s=this.container.querySelectorAll(".carousel-dot");for(let a=0;a<s.length;a++){const i=s[a];i.classList.toggle("active",a===n)}this.currentImageIndex=n,this.galleryViewport&&this.scrollToIndex(n)}scrollToIndex(n){if(!this.galleryViewport||!this.thumbnails[n])return;const i=this.thumbnails[n],r=this.galleryViewport.offsetWidth,s=i.offsetLeft+i.offsetWidth/2,a=r/2,l=a-s,d=0,u=-(this.galleryContainer.scrollWidth-r);this.translateX=Math.max(u,Math.min(d,l)),this.updateTransform(!![])}setupMainImageSwipe(){var n,i;let r=0,s=0;null===(n=this.mainImageElement)||void 0===n?void 0:n.addEventListener("touchstart",n=>{r=n.touches[0].clientX,s=n.touches[0].clientY},{passive:!![]}),null===(i=this.mainImageElement)||void 0===i||i.addEventListener("touchend",n=>{const i=n.changedTouches[0].clientX-r,a=n.changedTouches[0].clientY-s;Math.abs(i)>Math.abs(a)&&Math.abs(i)>50&&(i>0?this.previousImage():this.nextImage())},{passive:!![]})}setupGalleryDrag(){if(this.galleryContainer){this.galleryContainer.addEventListener("mousedown",this.handleDragStart.bind(this)),window.addEventListener("mousemove",this.handleDragMove.bind(this)),window.addEventListener("mouseup",this.handleDragEnd.bind(this)),this.galleryContainer.addEventListener("touchstart",this.handleDragStart.bind(this),{passive:!![]}),window.addEventListener("touchmove",this.handleDragMove.bind(this),{passive:![]}),window.addEventListener("touchend",this.handleDragEnd.bind(this));for(const n of this.galleryContainer.querySelectorAll("img"))n.addEventListener("dragstart",n=>n.preventDefault())}}handleDragStart(n){this.isDragging=!![],this.hasMoved=![],this.startX="touches"in n?n.touches[0].clientX:n.clientX,this.currentTranslateX=this.translateX,this.galleryContainer&&(this.galleryContainer.style.cursor="grabbing")}handleDragMove(n){if(!this.isDragging||!this.galleryViewport)return;"touchmove"===n.type&&n.preventDefault();const i="touches"in n?n.touches[0].clientX:n.clientX,r=i-this.startX;Math.abs(r)>5&&(this.hasMoved=!![]);const s=this.currentTranslateX+r,a=0,l=-(this.galleryContainer.scrollWidth-this.galleryViewport.offsetWidth);this.translateX=Math.max(l,Math.min(a,s)),this.updateTransform(![])}handleDragEnd(){this.isDragging=![],this.galleryContainer&&(this.galleryContainer.style.cursor=""),setTimeout(()=>{this.hasMoved=![]},10)}updateTransform(n){this.galleryContainer&&(this.galleryContainer.style.transition=n?"transform 0.3s ease":"none",this.galleryContainer.style.transform="translate3d("+this.translateX+"px, 0, 0)")}nextImage(){this.selectImage((this.currentImageIndex+1)%this.params.images.length)}previousImage(){this.selectImage(0===this.currentImageIndex?this.params.images.length-1:this.currentImageIndex-1)}template(){const n=[],i=this.params.images.length>1,r=document.createElement("div");if(r.className="main-image",r.title="Product main image",r.style="--bg-image: url('"+(this.params.mainImage||this.params.images[0])+"')",i){const n=document.createElement("div");n.className="carousel-dots";for(let i=0;i<this.params.images.length;i++){const r=document.createElement("button");r.type="button",r.className="carousel-dot "+(0===i?"active":""),r.setAttribute("data-index",i.toString()),n.appendChild(r)}r.appendChild(n)}this.mainImageElement=r,n.push(r);const s=document.createElement("div");s.className="gallery-viewport";const a=document.createElement("div");a.className="gallery-container";for(let l=0;l<this.params.images.length;l++){const n=this.params.images[l],i=document.createElement("div");i.className="gallery-image-wrapper "+(0===l?"selected":"");const r=document.createElement("img");r.src=n,r.className="gallery-image",r.alt="Product thumbnail "+(l+1),r.loading="lazy",i.appendChild(r),a.appendChild(i)}return s.appendChild(a),n.push(s),n}}class ProductInteractionsComponent extends BaseComponent{get hostClasses(){return["product-interactions"]}constructor(){super({watchOnlyStorePaths:["products.{productId}.selectedFulfillmentType"]}),this.addPersonalizationSpan=null}onStoreWatch(n){var i,r,s,a;const l=this.getProductId();if(!n.some(n=>n.path==="products."+l+".selectedFulfillmentType"))return;const d=this.getStoreValue("products."+l),u=d.sizes[d.selectedSizeId],f=this.getConfigs("global");this.addPersonalizationSpan&&(d.selectedFulfillmentType===E.SHIPPING&&f.layout.enablePersonalization&&d.productHasAvailability&&(null===(r=null===(i=null==u?void 0:u.attributes)||void 0===i?void 0:i.engraving)||void 0===r?void 0:r.status)===!![]&&(null===(s=null==d?void 0:d.selectedFulfillment)||void 0===s?void 0:s.isVariantEngravable)===!![]&&(null===(a=null==d?void 0:d.selectedFulfillment)||void 0===a?void 0:a.canEngrave)===!![]?this.addPersonalizationSpan.style.display="inline":this.addPersonalizationSpan.style.display="none")}getProductId(){return this.params.productId}afterRender(){this.setupSizeButtonsEventListener()}setupSizeButtonsEventListener(){const n=this.getProductId(),i=this.container.querySelectorAll("[select-size]");for(const r of i){const s=r.textContent||"",a=r.classList.contains("selected");r.setAttribute("role","button"),r.setAttribute("tabindex","0"),r.setAttribute("aria-label","Select "+s),r.setAttribute("aria-pressed",a?"true":"false"),r.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),r.click())}),r.addEventListener("click",async()=>{var s,a,l,d;const u=r.dataset.sizeId;if(!u)return this.logger.warn("Product size selection failed: Size ID not found in button element",{productId:n,buttonElement:r.outerHTML.substring(0,100)}),void 0;await this.commands.product.selectSize(n,u);for(const n of i)n.classList.remove("selected"),n.setAttribute("aria-pressed","false");r.classList.add("selected"),r.setAttribute("aria-pressed","true");const f=this.getStoreValue("products."+n),g=f.sizes[u],v=this.getConfigs("global");this.addPersonalizationSpan&&(v.layout.enablePersonalization&&(null===(a=null===(s=null==g?void 0:g.attributes)||void 0===s?void 0:s.engraving)||void 0===a?void 0:a.status)===!![]&&f.productHasAvailability&&(null===(l=f.selectedFulfillment)||void 0===l?void 0:l.isVariantEngravable)===!![]&&(null===(d=f.selectedFulfillment)||void 0===d?void 0:d.canEngrave)===!![]?this.addPersonalizationSpan.style.display="inline":this.addPersonalizationSpan.style.display="none")})}}renderProductSizes(n,i){const r=document.createElement("div");r.className="size-container";const s=document.createElement("h3");s.className="size-label",s.textContent="Size",s.id="size-label",r.appendChild(s);const a=document.createElement("div");a.className="size-buttons-container",a.setAttribute("role","group"),a.setAttribute("aria-labelledby","size-label");for(const l of Object.values(i)){const i=document.createElement("span");i.setAttribute("data-size-id",l.id),i.setAttribute("select-size",""),i.className="size-button "+(l.id===n?"selected":"");const r=l.packDesc?" ("+l.packDesc+")":"";i.textContent=""+l.size+r,a.appendChild(i)}return r.appendChild(a),r}hasIndependentAddressComponent(){var n;return(null===(n=null===document||void 0===document?void 0:document.querySelectorAll("lce-element[address]"))||void 0===n?void 0:n.length)>0}template(){var n,i,r,s,a;const l=this.getProductId(),d=this.getStoreValue("products."+l),u=d.sizes[d.selectedSizeId],f=this.getConfigs("global"),g=[],v=document.createElement("div");v.className="price-personalization-container";const b=ComponentFactoryService.createElement({type:C.PRODUCT_PRICE,productId:l});if(v.appendChild(b),f.layout.enablePersonalization&&d.productHasAvailability&&(null===(i=null===(n=null==u?void 0:u.attributes)||void 0===n?void 0:n.engraving)||void 0===i?void 0:i.status)===!![]&&(null===(r=null==d?void 0:d.selectedFulfillment)||void 0===r?void 0:r.canEngrave)===!![]&&(null===(s=null==d?void 0:d.selectedFulfillment)||void 0===s?void 0:s.isVariantEngravable)===!![]){this.addPersonalizationSpan=document.createElement("span"),this.addPersonalizationSpan.className="add-personalization-span",this.addPersonalizationSpan.textContent="Personalize Your Bottle",this.addPersonalizationSpan.setAttribute("role","button"),this.addPersonalizationSpan.setAttribute("tabindex","0"),this.addPersonalizationSpan.setAttribute("aria-label","Personalize Your Bottle");const addPersonalization=async()=>{var n,i,r,s,a,u,f,g;const v=d.sizes[d.selectedSizeId];await this.commands.product.openProductDrawer(l,C.ENGRAVING_FORM,{identifier:l,context:"product",lines:[],maxLines:(null===(i=null===(n=v.attributes)||void 0===n?void 0:n.engraving)||void 0===i?void 0:i.maxLines)||1,maxCharsPerLine:(null===(s=null===(r=v.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.maxCharsPerLine)||16,fee:(null===(u=null===(a=v.attributes)||void 0===a?void 0:a.engraving)||void 0===u?void 0:u.fee)||0,location:null===(g=null===(f=v.attributes)||void 0===f?void 0:f.engraving)||void 0===g?void 0:g.location})};this.addPersonalizationSpan.addEventListener("click",async()=>{await addPersonalization()}),this.addPersonalizationSpan.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await addPersonalization())}),v.appendChild(this.addPersonalizationSpan)}g.push(v);const x=this.renderProductSizes(d.selectedSizeId,d.sizes);if(g.push(x),!this.hasIndependentAddressComponent()){const n=ComponentFactoryService.createElement({type:C.ADDRESS_DISPLAY,productId:l});g.push(n)}const w=ComponentFactoryService.createElement({type:C.PRODUCT_RETAILERS,productId:l});g.push(w);const E=ComponentFactoryService.createElement({type:C.PRODUCT_ADD_TO_CART_SECTION,productId:l});g.push(E);const T=null===(a=null==u?void 0:u.attributes)||void 0===a?void 0:a.presale;if((null==T?void 0:T.isActive)===!![]&&(null==T?void 0:T.language)){const n=document.createElement("div");n.className="product-presale-notice",n.innerHTML=sanitizeHTML((null==T?void 0:T.language)||""),g.push(n)}if(this.config.layout.showDescription&&(d.description.trim().length>0||d.htmlDescription.trim().length>0)){const n=ComponentFactoryService.createElement({type:C.PRODUCT_DESCRIPTION,productId:l});g.push(n)}return g}}class ProductLoadingComponent extends BaseComponent{template(){const n=Boolean(this.getStoreValue("address")),{showTitle:i,showDescription:r,showQuantityCounter:s,fulfillmentDisplay:a,showImages:l}=this.config.layout,d=document.createElement("div");d.classList.add("product-content-wrapper");const u=document.createElement("div");if(u.classList.add("skeleton-container"),i){const n=document.createElement("div");n.classList.add("wave","sc-title"),u.appendChild(n)}if(!n){const n=document.createElement("div");return n.classList.add("wave","sc-add-to-cart"),u.appendChild(n),u}const f=document.createElement("div");f.classList.add("wave","sc-price"),u.appendChild(f);const g=document.createElement("div");g.classList.add("sc-sizes");const v=document.createElement("div");v.classList.add("wave","sc-size-button"),g.appendChild(v);const b=document.createElement("div");b.classList.add("wave","sc-size-button"),g.appendChild(b);const x=document.createElement("div");x.classList.add("wave","sc-size-button"),g.appendChild(x);const w=document.createElement("div");w.classList.add("wave","sc-size-button"),g.appendChild(w);const C=document.createElement("div");C.classList.add("wave","sc-size-button"),g.appendChild(C),u.appendChild(g);const E=document.createElement("div");E.classList.add("sc-row");const T=document.createElement("div");T.classList.add("wave","sc-price"),E.appendChild(T);const A=document.createElement("div");A.classList.add("wave","sc-personalization"),E.appendChild(A),u.appendChild(E);const P=document.createElement("div");P.classList.add("wave","sc-deliver-to"),u.appendChild(P);const _=document.createElement("div");_.classList.add("wave","sc-address"),u.appendChild(_);const N=document.createElement("div");N.classList.add("wave","sc-retailers",a),u.appendChild(N);const F=document.createElement("div");if(F.classList.add("sc-row"),s){const n=document.createElement("div");n.classList.add("wave","sc-quantity"),F.appendChild(n)}const R=document.createElement("div");if(R.classList.add("wave","sc-add-to-cart"),F.appendChild(R),u.appendChild(F),r){const n=document.createElement("div");n.classList.add("wave","sc-description-title"),u.appendChild(n);const i=document.createElement("div");i.classList.add("wave","sc-description-line"),u.appendChild(i);const r=document.createElement("div");r.classList.add("wave","sc-description-line"),u.appendChild(r);const s=document.createElement("div");s.classList.add("wave","sc-description-line"),u.appendChild(s);const a=document.createElement("div");a.classList.add("wave","sc-description-more"),u.appendChild(a)}const O=document.createElement("div");if(O.classList.add("product-content"),O.appendChild(u),d.appendChild(O),l){d.classList.add("has-images");const n=this.createImageSkeletons();d.prepend(n)}return d}createImageSkeletons(){const n=document.createElement("div");n.classList.add("product-image-carousel","skeleton");const i=document.createElement("div");i.classList.add("wave","sc-main-image"),i.title="Product main image loading";const r=document.createElement("div");r.classList.add("carousel-dots");for(let l=0;l<3;l++){const n=document.createElement("div");n.classList.add("wave","sc-carousel-dot"),r.appendChild(n)}i.appendChild(r),n.appendChild(i);const s=document.createElement("div");s.classList.add("gallery-viewport");const a=document.createElement("div");a.classList.add("gallery-container");for(let l=0;l<4;l++){const n=document.createElement("div");n.classList.add("gallery-image-wrapper");const i=document.createElement("div");i.classList.add("wave","sc-gallery-thumbnail"),n.appendChild(i),a.appendChild(n)}return s.appendChild(a),n.appendChild(s),n}}class ProductOptionsComponent extends BaseComponent{get hostClasses(){return["product-options"]}constructor(){super({watchStorePaths:["address"],watchOnlyStorePaths:["products.{productId}.drawer.isOpen"]})}getProductId(){return this.params.productId}onStoreWatch(n){const i=this.getProductId(),r=n.find(n=>n.path==="products."+i+".drawer.isOpen");if(r){const n=r.value===!![];n&&this.addHostClasses("hide-content"),n||this.removeHostClasses("hide-content")}}template(){const n=this.getProductId(),i=this.getStoreValue("address.formattedAddress");if(i)return ComponentFactoryService.createElement({type:C.PRODUCT_INTERACTIONS,productId:this.getProductId()});const r=document.createElement("button");return r.type="button",r.className="product-options-open-address-button",r.textContent=this.config.layout.buyNowButtonText,r.addEventListener("click",async()=>{this.clientConfig.isMobile()&&this.commands.ui.openDrawer(C.ADDRESS_INPUT,{productId:n}),this.clientConfig.isMobile()||await this.commands.product.openProductDrawer(n,C.ADDRESS_INPUT,{productId:n})}),r}}class ProductPriceComponent extends BaseComponent{get hostClasses(){return["main-product-price"]}get hostAttributes(){return{role:"status","aria-live":"polite","aria-atomic":"true","aria-label":"Product price"}}constructor(){super({watchStorePaths:["products.{productId}.selectedSizeId","products.{productId}.selectedFulfillmentType","products.{productId}.selectedFulfillment","products.{productId}.selectedFulfillmentId","products.{productId}.fulfillmentHasAvailability"]})}getProductId(){return this.params.productId}template(){var n;const i=this.getProductId(),r=this.getStoreValue("products."+i);let s=(null===(n=r.priceInfo)||void 0===n?void 0:n.avg)||0;return r.selectedFulfillment&&(s=r.selectedFulfillment.price),formatCentToDollarText(s)}}class ProductRetailersComponent extends BaseComponent{get hostClasses(){return["product-retailers"]}constructor(){super({watchStorePaths:["products.{productId}.productHasAvailability"]})}get hostAttributes(){return{role:"status","aria-live":"polite","aria-atomic":"true","aria-label":"Retailer information"}}getProductId(){return this.params.productId}template(){const n=this.getProductId(),i=this.getStoreValue("products."+n),r=this.getConfigs("product"),s=[],a=this.getConfigs("configurations");if(!i.productHasAvailability||!a.isElementsEnabled){const n=document.createElement("p");return n.className="product-no-availability-message",n.innerHTML=sanitizeHTML(this.config.layout.noAvailabilityText),s.push(n),s}const l="carousel"===r.layout.fulfillmentDisplay?C.PRODUCT_RETAILERS_CAROUSEL:C.PRODUCT_RETAILERS_POPUP,d=ComponentFactoryService.createElement({type:l,productId:n});return s.push(d),s}}class ProductRetailersCarouselComponent extends BaseComponent{get hostClasses(){return["retailers-container","carousel"]}constructor(){super({watchStorePaths:["products.{productId}.selectedSizeId","products.{productId}.selectedFulfillmentType","products.{productId}.fulfillmentHasAvailability"],watchOnlyStorePaths:["products.{productId}.selectedFulfillmentId"]}),this.listViewport=null,this.listContainer=null,this.retailerCards=[],this.isDragging=![],this.hasMoved=![],this.startX=0,this.currentTranslateX=0,this.translateX=0}afterRender(){this.cacheElements(),this.setupDrag();const n=this.retailerCards.findIndex(n=>n.classList.contains("selected"));-1!==n&&this.scrollToIndex(n)}cacheElements(){this.retailerCards=Array.from(this.container.querySelectorAll(".carousel-retailer-card"))}getProductId(){return this.params.productId}onStoreWatch(n){const i=this.getProductId(),r=n.find(n=>n.path==="products."+i+".selectedFulfillmentId");(null==r?void 0:r.value)&&this.updateSelectedCard(r.value)}updateSelectedCard(n){for(const r of this.retailerCards)r.classList.remove("selected"),r.setAttribute("aria-pressed","false");const i=this.retailerCards.findIndex(i=>i.dataset.fulfillmentId===n);-1!==i&&(this.retailerCards[i].classList.add("selected"),this.retailerCards[i].setAttribute("aria-pressed","true"),this.scrollToIndex(i))}scrollToIndex(n){if(!this.listViewport||!this.retailerCards[n])return;const i=this.retailerCards[n],r=this.listViewport.offsetWidth,s=i.offsetLeft+i.offsetWidth/2,a=r/2,l=a-s,d=0,u=-(this.listContainer.scrollWidth-r);this.translateX=Math.max(u,Math.min(d,l)),this.updateTransform(!![])}setupDrag(){this.listContainer&&(this.listContainer.addEventListener("mousedown",this.handleDragStart.bind(this)),window.addEventListener("mousemove",this.handleDragMove.bind(this)),window.addEventListener("mouseup",this.handleDragEnd.bind(this)),this.listContainer.addEventListener("touchstart",this.handleDragStart.bind(this),{passive:!![]}),window.addEventListener("touchmove",this.handleDragMove.bind(this),{passive:![]}),window.addEventListener("touchend",this.handleDragEnd.bind(this)))}handleDragStart(n){this.isDragging=!![],this.hasMoved=![],this.startX="touches"in n?n.touches[0].clientX:n.clientX,this.currentTranslateX=this.translateX,this.listContainer&&(this.listContainer.style.cursor="grabbing")}handleDragMove(n){if(!this.isDragging||!this.listViewport)return;"touchmove"===n.type&&n.preventDefault();const i="touches"in n?n.touches[0].clientX:n.clientX,r=i-this.startX;Math.abs(r)>5&&(this.hasMoved=!![]);const s=this.currentTranslateX+r,a=0,l=-(this.listContainer.scrollWidth-this.listViewport.offsetWidth);this.translateX=Math.max(l,Math.min(a,s)),this.updateTransform(![])}handleDragEnd(){this.isDragging=![],this.listContainer&&(this.listContainer.style.cursor=""),setTimeout(()=>{this.hasMoved=![]},10)}updateTransform(n){this.listContainer&&(this.listContainer.style.transition=n?"transform 0.3s ease":"none",this.listContainer.style.transform="translate3d("+this.translateX+"px, 0, 0)")}async onFulfillmentTabClick(n){const i=this.getProductId(),r=n.currentTarget.dataset.fulfillmentType;if(!r)return this.logger.warn("Product fulfillment type selection failed: Type not found in target element",{productId:i,targetElement:n.currentTarget.outerHTML.substring(0,100)}),void 0;await this.commands.product.changeFulfillmentType(i,r)}async onRetailerCardClick(n){if(this.hasMoved)return;const i=this.getProductId(),r=n.currentTarget.dataset.fulfillmentId;if(!r)return this.logger.warn("Product retailer selection failed: Fulfillment ID not found in target element",{productId:i,targetElement:n.currentTarget.outerHTML.substring(0,100)}),void 0;const s=this.getStoreValue("products."+i+".selectedFulfillment");if(s&&s.fulfillmentId===r)return this.logger.info("Product retailer selection skipped: Same fulfillment already selected",{productId:i,fulfillmentId:r}),void 0;await this.commands.product.selectFulfillment(i,r)}generateRetailerCard({fulfillment:n,selectedFulfillmentType:i,isSelected:r,fulfillmentStatus:s,selectedSizeAttributes:a}){var l,d,u,f,g;let v=0;const b=null==a?void 0:a.presale,x=(null==b?void 0:b.isActive)&&(null==b?void 0:b.estimatedShipBy)?"Ships by "+formatISODateToMMDDYYYY(b.estimatedShipBy):"",w=i===E.SHIPPING,C=i===E.ON_DEMAND;w&&(v=(null===(d=null===(l=null==n?void 0:n.fees)||void 0===l?void 0:l.individual)||void 0===d?void 0:d.fee)||0),C&&(v=(null===(u=null==n?void 0:n.fees)||void 0===u?void 0:u.fee)||0);const T=fulfillmentAddress(n.retailerAddress,i);let A=null;i===E.ON_DEMAND&&s.openTime&&(null==s?void 0:s.closeTime)&&(A=s.isOpen?"Closes at "+format24TimeTo12$1(null==s?void 0:s.closeTime):"Opens at "+format24TimeTo12$1(null==s?void 0:s.openTime));const P=i===E.ON_DEMAND&&s&&s.isClosed?"closed":"",_=document.createElement("div");_.className="carousel-retailer-card "+(r?"selected":"")+" "+P,_.setAttribute("data-fulfillment-id",n.fulfillmentId),_.setAttribute("role","button"),_.setAttribute("tabindex","0"),_.setAttribute("aria-pressed",r?"true":"false");const N=i===E.SHIPPING?"Shipping":"Same-day delivery";_.setAttribute("aria-label",N+" from "+n.retailerName+", "+formatCentToDollarText(null!==(f=n.price)&&void 0!==f?f:0));const F=document.createElement("div");F.className="retailer-header";const R=document.createElement("h3");if(R.className="name",R.textContent=n.retailerName,F.appendChild(R),C){const n=document.createElement("h3");n.className="address",n.textContent=T,F.appendChild(n)}const O=document.createElement("div");O.className="retailer-body";const L=document.createElement("span");L.className="product-price",L.textContent=formatCentToDollarText(null!==(g=n.price)&&void 0!==g?g:0);const M=document.createElement("span");M.className="shipping-price",M.textContent=v>0?"+ "+formatCentToDollarText(v):"FREE Delivery";const B=document.createElement("span");return B.className="expectation",B.textContent=s.isClosed?A:(null==b?void 0:b.isActive)?x:(null==n?void 0:n.expectation.detail)||"No expectation available",O.append(L,M,B),_.append(F,O),_}template(){const n=this.getProductId(),i=this.getStoreValue("products."+n),r=this.getStoreValue("products."+n+".sizes."+i.selectedSizeId),s=(null==r?void 0:r.attributes)||null,a=[];for(const v in r.shippingFulfillments)Object.prototype.hasOwnProperty.call(r.shippingFulfillments,v)&&a.push(r.shippingFulfillments[v]);const l=[];for(const v in r.onDemandFulfillments)Object.prototype.hasOwnProperty.call(r.onDemandFulfillments,v)&&l.push(r.onDemandFulfillments[v]);const d=i.selectedFulfillmentType===E.SHIPPING,u=i.selectedFulfillmentType===E.ON_DEMAND,f=d?a:l,g=renderFulfillmentTabsContainer({shippingFulfillments:a,onDemandFulfillments:l,shippingSelected:d,onDemandSelected:u,onTabClick:this.onFulfillmentTabClick.bind(this),enableShippingFulfillment:this.config.layout.enableShippingFulfillment,enableOnDemandFulfillment:this.config.layout.enableOnDemandFulfillment});if(!i.fulfillmentHasAvailability||0===f.length){const n=document.createElement("p");return n.className="product-no-availability-message",n.innerHTML=sanitizeHTML(this.config.layout.noAvailabilityText),[g,n]}this.listViewport=document.createElement("div"),this.listViewport.className="carousel-fulfillment-list-viewport",this.listContainer=document.createElement("div"),this.listContainer.className="carousel-fulfillment-list-container";for(const v of f){const n=getRetailerOffHours(v),r=this.generateRetailerCard({fulfillment:v,selectedFulfillmentType:i.selectedFulfillmentType,isSelected:v.fulfillmentId===i.selectedFulfillmentId,fulfillmentStatus:n,selectedSizeAttributes:s}),a=i.selectedFulfillmentType===E.ON_DEMAND&&n&&n.isClosed;a?r.setAttribute("aria-disabled","true"):(r.addEventListener("click",this.onRetailerCardClick.bind(this)),r.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),r.click())})),this.listContainer.appendChild(r)}return this.listViewport.appendChild(this.listContainer),[g,this.listViewport]}}class ProductRetailersPopupComponent extends BaseComponent{get hostClasses(){return["retailers-container","popup"]}constructor(){super({watchStorePaths:["products.{productId}.selectedSizeId","products.{productId}.selectedFulfillmentType","products.{productId}.selectedFulfillment","products.{productId}.fulfillmentHasAvailability"]})}getProductId(){return this.params.productId}template(){const n=this.getProductId(),i=this.getStoreValue("products."+n),r=this.getStoreValue("products."+n+".sizes."+i.selectedSizeId),s=(null==r?void 0:r.attributes)||null,a=this.config.layout.enableShippingFulfillment,l=this.config.layout.enableOnDemandFulfillment,d=Object.values(r.shippingFulfillments),u=Object.values(r.onDemandFulfillments),f=(a?d.length:0)+(l?u.length:0),g=document.createElement("div");g.className="header";const v=document.createElement("span");v.className="header-label",v.textContent=i.selectedFulfillmentType===E.SHIPPING?"Shipping From:":"Delivering From:";const b=document.createElement("button");if(b.className="delivery-options",b.type="button",b.textContent="See Delivery Options ("+f+")",b.setAttribute("aria-label","View all "+f+" delivery options"),b.addEventListener("click",async()=>{0!==f&&(this.clientConfig.isMobile()&&this.commands.ui.openDrawer(C.PRODUCT_RETAILERS_POPUP_LIST,{productId:n}),this.clientConfig.isMobile()||await this.commands.product.openProductDrawer(n,C.PRODUCT_RETAILERS_POPUP_LIST,{productId:n}))}),g.appendChild(v),g.appendChild(b),!i.fulfillmentHasAvailability){const n=document.createElement("p");return n.className="fulfillments-no-availability-message",n.innerHTML=sanitizeHTML(this.config.layout.noAvailabilityText),[g,n]}const x=document.createElement("div");x.className="popup-fulfillment-list-container";const w=getRetailerOffHours(i.selectedFulfillment),T=renderPopupRetailerCard({fulfillment:i.selectedFulfillment,selectedFulfillmentType:i.selectedFulfillmentType,isSelected:![],fulfillmentStatus:w,selectedSizeAttributes:s});return x.appendChild(T),[g,x]}}class ProductRetailersPopupListComponent extends BaseComponent{get hostClasses(){return["retailers-popup-list-container"]}constructor(){super({watchStorePaths:["products.{productId}.selectedSizeId","products.{productId}.selectedFulfillmentType","products.{productId}.selectedFulfillment","products.{productId}.fulfillmentHasAvailability"]})}getProductId(){return this.params.productId}async onFulfillmentTabClick(n){const i=this.getProductId(),r=n.currentTarget.dataset.fulfillmentType;if(!r)return this.logger.warn("Product fulfillment type selection failed: Type not found in target element",{productId:i,targetElement:n.currentTarget.outerHTML.substring(0,100)}),void 0;await this.commands.product.changeFulfillmentType(i,r)}async onRetailerCardClick(n){const i=this.getProductId(),r=n.currentTarget.dataset.fulfillmentId;if(!r)return this.logger.warn("Product retailer selection failed: Fulfillment ID not found in target element",{productId:i,targetElement:n.currentTarget.outerHTML.substring(0,100)}),void 0;const D=async()=>{this.clientConfig.isMobile()||await this.commands.product.closeProductDrawer(i),this.clientConfig.isMobile()&&this.commands.ui.closeDrawer()},s=this.getStoreValue("products."+i+".selectedFulfillment");if(s&&s.fulfillmentId===r)return await D(),void 0;await this.commands.product.selectFulfillment(i,r),await D()}template(){const n=this.getProductId(),i=this.getStoreValue("products."+n),r=this.getStoreValue("products."+n+".sizes."+i.selectedSizeId),s=(null==r?void 0:r.attributes)||null,a=[];for(const x in r.shippingFulfillments)Object.prototype.hasOwnProperty.call(r.shippingFulfillments,x)&&a.push(r.shippingFulfillments[x]);const l=[];for(const x in r.onDemandFulfillments)Object.prototype.hasOwnProperty.call(r.onDemandFulfillments,x)&&l.push(r.onDemandFulfillments[x]);const d=i.selectedFulfillmentType===E.SHIPPING,u=i.selectedFulfillmentType===E.ON_DEMAND,f=d?a:l,g=document.createElement("h5");g.className="popup-retailers-section-title",g.textContent="Delivery Options";const v=renderFulfillmentTabsContainer({shippingFulfillments:a,onDemandFulfillments:l,shippingSelected:d,onDemandSelected:u,onTabClick:this.onFulfillmentTabClick.bind(this),enableShippingFulfillment:this.config.layout.enableShippingFulfillment,enableOnDemandFulfillment:this.config.layout.enableOnDemandFulfillment});if(!i.fulfillmentHasAvailability||0===f.length){const n=document.createElement("p");return n.className="fulfillments-no-availability-message",n.innerHTML=sanitizeHTML(this.config.layout.noAvailabilityText),[g,v,n]}const b=document.createElement("div");b.className="popup-fulfillment-list-container";for(const x of f){const n=getRetailerOffHours(x),r=renderPopupRetailerCard({fulfillment:x,selectedFulfillmentType:i.selectedFulfillmentType,isSelected:x.fulfillmentId===i.selectedFulfillmentId,fulfillmentStatus:n,selectedSizeAttributes:s});r.addEventListener("click",this.onRetailerCardClick.bind(this)),r.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),r.click())}),b.appendChild(r)}return[g,v,b]}}class ProductComponent extends BaseComponent{constructor(){super({watchStorePaths:["products.{productId}.loading","products.{productId}.error"],watchOnlyStorePaths:["products.{productId}.drawer.isOpen","products.{productId}.rerender"]}),this.titleElement=null}getProductId(){return this.params.productId}onStoreWatch(n){const i=this.getProductId(),r=n.find(n=>n.path==="products."+i+".drawer.isOpen"),s=n.find(n=>n.path==="products."+i+".rerender");r&&this.titleElement&&this.titleElement.classList.toggle("hide",r.value),(null==s?void 0:s.value)===!![]&&this.rerender("ProductComponentRerender")}template(){var n;const i=this.getProductId(),r=this.getStoreValue("products."+i);if(!r)return ComponentFactoryService.createElement({type:C.PRODUCT_LOADING});if(r.error)return productionComponentError({title:"Product Unavailable",message:"We're sorry, this product is currently unavailable.",componentType:C.PRODUCT});if(r.loading)return ComponentFactoryService.createElement({type:C.PRODUCT_LOADING});const s=r.sizes[r.selectedSizeId],a=document.createElement("div");a.classList.add("product-content-wrapper"),a.setAttribute("role","region"),a.setAttribute("aria-label",""+r.name);const l=document.createElement("div");if(l.classList.add("product-content"),l.setAttribute("role","region"),l.setAttribute("aria-label",""+r.name),this.config.layout.showTitle){const n=document.createElement("h1");n.classList.add("product-title"),n.textContent=r.name,this.titleElement=n,l.appendChild(n)}const d=ComponentFactoryService.createElement({type:C.PRODUCT_OPTIONS,productId:i});l.appendChild(d);const u=ComponentFactoryService.createElement({type:C.PRODUCT_DRAWER,productId:i});if(l.appendChild(u),a.appendChild(l),!this.config.layout.showImages||!(null===(n=r.images)||void 0===n?void 0:n.length))return a;a.classList.add("has-images");const f=ComponentFactoryService.createElement({type:C.PRODUCT_IMAGE_CAROUSEL,images:r.images,mainImage:s.image,productId:i});return a.prepend(f),f.setAttribute("aria-label","Product images"),a}async disconnected(){const n=this.getProductId();n&&await this.commands.product.removeProduct(n)}}class ProductListCardComponent extends BaseComponent{get hostClasses(){return["product-list-card",this.params.variant,this.params.fillCard?"fill":""]}getAvailabilityData(){var n,i,r;const s=this.params.product,a=this.getStoreValue("address.address"),l={hasAvailability:![],upc:"",fulfillmentId:"",partNumber:"",quantity:1,state:(null==a?void 0:a.state)||"",isPresale:![],isPresaleActive:![]},d=s.sizes[0];if(!d)return l;const u=d.variants[0];if(!u)return l;l.upc=d.upc;const f=d.attributes||{};l.isPresale=(null===(n=f.presale)||void 0===n?void 0:n.isActive)===!![],l.isPresaleActive=this.isPresaleActive(f);for(const g of this.params.fulfillments){const n=u.fulfillments.some(n=>n===g.id);if(n){const n="shipping"===g.type&&(null===(i=u.fulfillmentTypes)||void 0===i?void 0:i.shipping)||"onDemand"===g.type&&(null===(r=u.fulfillmentTypes)||void 0===r?void 0:r.onDemand);if(n&&u.stock>0){l.hasAvailability=!![],l.fulfillmentId=g.id,l.partNumber=u.partNumber;break}}}return l}isPresaleActive(n){const i=null==n?void 0:n.presale;if(!i)return![];if(!i.isActive)return![];if(i.canPurchaseOn){const n=new Date(i.canPurchaseOn),r=new Date;if(r.getTime()<n.getTime())return![]}return!![]}async handleAddToCart(n){if(!n.hasAvailability)return;const i=this.params.product.salsifyGrouping||this.params.product.id||"";n.isPresale&&n.isPresaleActive?await this.commands.productList.addPresaleToCart({upc:n.upc,fulfillmentId:n.fulfillmentId,partNumber:n.partNumber,quantity:n.quantity,identifier:i}):await this.commands.productList.addToCart({upc:n.upc,fulfillmentId:n.fulfillmentId,partNumber:n.partNumber,quantity:n.quantity,identifier:i})}template(){var n,i,r,s;const a=this.params.product,l=a.sizes[0],d=l?l.image:a.images[0],u=a.name,f=l?l.size:null,g=null!==(r=null===(i=null===(n=null==l?void 0:l.variants)||void 0===n?void 0:n[0])||void 0===i?void 0:i.price)&&void 0!==r?r:(null===(s=a.priceInfo)||void 0===s?void 0:s.average)||0,v=this.getAvailabilityData();return this.createVariantStandard({image:d,name:u,size:f,price:g,availability:v})}generateProductUrl(){var n;if(!this.params.productUrl)return null;const i=this.params.product,r=null===(n=i.sizes)||void 0===n?void 0:n[0],s=this.params.productUrl;if(s.includes("{upc}")){const n=(null==r?void 0:r.upc)||"";return n?s.replace("{upc}",n):(this.logger.warn("Product URL template requires {upc} but product has no UPC"),null)}if(s.includes("{grouping}")){const n=i.salsifyGrouping||"";return n?s.replace("{grouping}",n):(this.logger.warn("Product URL template requires {grouping} but product has no salsifyGrouping"),null)}return null}createVariantStandard(n){const{image:i,name:r,size:s,price:a,availability:l}=n,d=[],u=this.generateProductUrl(),f=document.createElement("div");f.className="plc__image-content";const g=document.createElement("div");g.className="plc__image-wrapper";const v=document.createElement("img");if(v.className="plc__image",v.src=i,v.alt=r,v.loading="lazy",g.appendChild(v),f.appendChild(g),u){const n=document.createElement("a");n.href=u,n.className="plc__image-link",n.target="_blank",n.rel="noopener noreferrer",n.addEventListener("click",()=>{this.commands.productList.trackSelectItem(this.params.product)}),n.appendChild(f),d.push(n)}else d.push(f);const b=document.createElement("div");b.className="plc__content";const x=document.createElement("h3");if(x.className="plc__title",x.textContent=r,u){const n=document.createElement("a");n.href=u,n.className="plc__title-link",n.target="_blank",n.rel="noopener noreferrer",n.addEventListener("click",()=>{this.commands.productList.trackSelectItem(this.params.product)}),n.appendChild(x),b.appendChild(n)}else b.appendChild(x);const w=document.createElement("div");w.className="plc__size-price-wrapper";const C=document.createElement("div");C.className="plc__price",C.textContent=formatCentToDollarText(a),w.appendChild(C);const E=document.createElement("div");E.className="plc__size",E.textContent=s||"",w.appendChild(E),b.appendChild(w),d.push(b);const T=document.createElement("button");return T.type="button",T.className="plc__button",T.disabled=!l.hasAvailability,l.isPresale?T.textContent="Pre Order":l.hasAvailability?T.textContent="Add to Cart":(T.textContent="Not Available In "+l.state.toUpperCase(),this.addHostClasses("not-available")),T.addEventListener("click",async n=>{n.preventDefault(),n.stopPropagation(),await this.handleAddToCart(l)}),d.push(T),d}}class ProductListCardLoadingComponent extends BaseComponent{get hostClasses(){return["product-list-card-loading__container"]}createSkeletonCard(n){const i=document.createElement("div");i.classList.add("slc__card");const r=document.createElement("div");r.className="slc__image-content";const s=document.createElement("div");s.className="slc__image-wrapper";const a=document.createElement("div");a.classList.add("wave","slc__image"),s.appendChild(a),r.appendChild(s);const l=document.createElement("div");l.className="slc__content";const d=document.createElement("div");d.className="slc__title-container";const u=document.createElement("div");u.classList.add("wave","slc__title","slc__title-line-1"),d.appendChild(u);const f=document.createElement("div");f.classList.add("wave","slc__title","slc__title-line-2"),d.appendChild(f),l.appendChild(d);const g=document.createElement("div");g.className="slc__size-price-wrapper";const v=document.createElement("div");v.classList.add("wave","slc__price"),g.appendChild(v);const b=document.createElement("div");b.classList.add("wave","slc__size"),g.appendChild(b),l.appendChild(g);const x=document.createElement("div");return x.classList.add("wave","slc__button"),i.appendChild(r),i.appendChild(l),i.appendChild(x),i}template(){const n=[],i=100/this.params.columns;this.container.style.setProperty("--card-width",i+"%"),this.container.style.setProperty("--columns",""+this.params.columns);const r=this.params.rows*this.params.columns;for(let s=0;s<r;s++){const i=this.createSkeletonCard(s);n.push(i)}return n}}function createApplyFiltersButton(n){const i=document.createElement("div");i.className="product-list-filters-apply-container";const r=document.createElement("button");return r.className="product-list-filters-apply-btn",r.textContent="Apply Filters",r.addEventListener("click",()=>n()),i.appendChild(r),i}function createCheckboxItem(n){const{filter:i,state:r,item:s,onChange:a}=n,l=document.createElement("div");l.className="checkbox-filter-item";const d=document.createElement("input");d.type="checkbox",d.id=i.bucket+"-"+s.value,d.value=s.value.toString(),d.className="checkbox-filter-checkbox",d.checked=r.selectedValues.has(s.value.toString()),d.addEventListener("change",a);const u=document.createElement("label");u.htmlFor=d.id,u.className="checkbox-filter-item-label";const f=s.formattedValue||s.value.toString(),g=s.count||0,v=document.createElement("span");v.className="checkbox-filter-item-text",v.textContent=f;const b=document.createElement("span");return b.className="checkbox-filter-item-count",b.textContent="("+g+")",u.appendChild(v),u.appendChild(b),l.appendChild(d),l.appendChild(u),l}function handleCheckboxFilterSearch(n){const{filter:i,state:r,searchTerm:s,renderCheckboxItems:a}=n,l=s.toLowerCase().trim();r.filteredItems=l?i.values.filter(n=>{const i=(n.formattedValue||n.value.toString()).toLowerCase();return i.includes(l)}):[...i.values],a()}function createCheckboxFilterHeader(n){const{filter:i,state:r,onToggle:s}=n,a=document.createElement("div");a.className="checkbox-filter-header";const l=document.createElement("button");l.className="checkbox-filter-label",l.type="button";const d=document.createElement("span");d.textContent=formatFilterLabel(i.bucket);const u=document.createElement("span");return u.className="checkbox-filter-toggle-icon "+(r.isExpanded?"expanded":"collapsed"),u.innerHTML=r.isExpanded?ChevronUpIcon({width:20,height:20,color:"#374151"}):ChevronDownIcon({width:20,height:20,color:"#374151"}),r.iconElement=u,l.appendChild(d),l.appendChild(u),l.addEventListener("click",()=>s(i.bucket)),a.appendChild(l),a}function createCheckboxFilterSearchContainer(n){const{state:i,onSearch:r}=n,s=document.createElement("div");s.className="checkbox-filter-search-wrapper",i.searchInput=document.createElement("input"),i.searchInput.type="text",i.searchInput.className="checkbox-filter-search",i.searchInput.placeholder="Search";const a=document.createElement("span");return a.className="checkbox-filter-search-icon",a.innerHTML=SearchIcon({}),i.searchInput.addEventListener("input",n=>{const i=n.target;r(i.value)}),s.appendChild(i.searchInput),s.appendChild(a),s}function renderCheckboxItems(n){const{filter:i,state:r,onCheckboxChange:s}=n;if(r.checkboxList&&(r.checkboxList.innerHTML="",r.filteredItems.forEach(n=>{const a=createCheckboxItem({filter:i,state:r,item:n,onChange:()=>{const i=a.querySelector("input");s(n.value.toString(),i.checked)}});r.checkboxList.appendChild(a)}),0===r.filteredItems.length)){const n=document.createElement("div");n.className="checkbox-filter-no-results",n.textContent="No results found",r.checkboxList.appendChild(n)}}function updateFilterExpandState(n){n.contentElement&&(n.contentElement.className="checkbox-filter-content "+(n.isExpanded?"expanded":"collapsed")),n.iconElement&&(n.iconElement.className="checkbox-filter-toggle-icon "+(n.isExpanded?"expanded":"collapsed"),n.iconElement.innerHTML=n.isExpanded?ChevronUpIcon({width:20,height:20,color:"#374151"}):ChevronDownIcon({width:20,height:20,color:"#374151"}))}function formatFilterLabel(n){return n.charAt(0).toUpperCase()+n.slice(1).replace(/_/g," ")}function createDeliveryOptionsFilter(n){const{currentFilters:i,deliveryCollapsed:r,isSameDayDeliveryDisabled:s,onDeliveryOptionsChange:a,onToggleCollapse:l}=n,d=[],u=document.createElement("div");u.className="product-list-filters-delivery-options";const f=[{value:"all",label:"All"},{value:"shipping",label:"Shipping"},{value:"onDemand",label:"Same-Day Delivery"}],g=document.createElement("div");g.className="product-list-filters-delivery-options-header",g.style.cursor="pointer";const v=document.createElement("h3");v.className="product-list-filters-delivery-options-label",v.textContent="Delivery Options";const b=document.createElement("div");b.className="product-list-filters-chevron",b.innerHTML=r?ChevronDownIcon({width:20,height:20,color:"#374151"}):ChevronUpIcon({width:20,height:20,color:"#374151"}),g.appendChild(v),g.appendChild(b),u.appendChild(g);const x=document.createElement("div");x.className="product-list-filters-delivery-options-list",r&&x.classList.add("collapsed");for(const w of f){const n=document.createElement("div");n.className="product-list-filters-delivery-option";const r=document.createElement("input");r.type="radio",r.id="delivery-"+w.value,r.name="delivery-options",r.value=w.value,r.className="product-list-filters-delivery-radio";const l="onDemand"===w.value&&s;r.disabled=l,r.checked=w.value===(null==i?void 0:i.deliveryOptions),r.addEventListener("change",n=>{const i=n.target;null==a?void 0:a(i.value)});const d=document.createElement("label");d.htmlFor="delivery-"+w.value,d.className="product-list-filters-delivery-radio-label "+(l?"disabled":""),d.textContent=w.label,n.appendChild(r),n.appendChild(d),x.appendChild(n)}return u.appendChild(x),g.addEventListener("click",()=>{l()}),d.push(u),{elements:d,chevronContainer:b,deliveryOptionsList:x}}function createPriceFilter(n){var i,r,s,a,l,d,u,f;const{priceConfig:g,currentFilters:v,priceCollapsed:b,onPriceChange:x,onToggleCollapse:w,DEFAULT_MIN:C,DEFAULT_MAX:E}=n,T=[],A=document.createElement("div");A.className="product-list-filters-price";const P=Number.parseInt(null!==(i=null==g?void 0:g.min)&&void 0!==i?i:C,10),_=Number.parseInt(null!==(r=null==g?void 0:g.max)&&void 0!==r?r:E,10),N=Number.parseInt(null!==(l=null!==(a=null===(s=null==v?void 0:v.price)||void 0===s?void 0:s.min)&&void 0!==a?a:null==g?void 0:g.min)&&void 0!==l?l:C,10),F=Number.parseInt(null!==(f=null!==(u=null===(d=null==v?void 0:v.price)||void 0===d?void 0:d.max)&&void 0!==u?u:null==g?void 0:g.max)&&void 0!==f?f:E,10),R=document.createElement("div");R.className="product-list-filters-price-header",R.style.cursor="pointer";const O=document.createElement("h3");O.className="product-list-filters-price-title",O.textContent="Price Range",R.appendChild(O);const L=document.createElement("div");L.className="product-list-filters-chevron",L.innerHTML=b?ChevronDownIcon({width:20,height:20,color:"#374151"}):ChevronUpIcon({width:20,height:20,color:"#374151"}),R.appendChild(L),A.appendChild(R);const M=document.createElement("div");M.className="product-list-filters-price-slider-container",b&&M.classList.add("collapsed");const B=document.createElement("div");B.className="product-list-filters-price-range-wrapper";const W=document.createElement("div");W.className="product-list-filters-price-track";const H=document.createElement("div");H.className="product-list-filters-price-track-active",W.appendChild(H),B.appendChild(W);const q=document.createElement("input");q.type="range",q.min=P.toString(),q.max=_.toString(),q.value=N.toString(),q.step="1",q.className="product-list-filters-price-range product-list-filters-price-range-min",B.appendChild(q);const j=document.createElement("input");j.type="range",j.min=P.toString(),j.max=_.toString(),j.value=F.toString(),j.step="1",j.className="product-list-filters-price-range product-list-filters-price-range-max",B.appendChild(j),M.appendChild(B);const U=document.createElement("div");U.className="product-list-filters-price-inputs-container";const V=document.createElement("div");V.className="product-list-filters-price-input-wrapper";const K=document.createElement("span");K.className="product-list-filters-price-input-prefix",K.textContent="$";const Q=document.createElement("input");Q.type="number",Q.min=P.toString(),Q.max=_.toString(),Q.value=N.toString(),Q.className="product-list-filters-price-input",Q.placeholder=P.toString(),V.appendChild(K),V.appendChild(Q);const Z=document.createElement("span");Z.className="product-list-filters-price-separator",Z.textContent="to";const X=document.createElement("div");X.className="product-list-filters-price-input-wrapper";const J=document.createElement("span");J.className="product-list-filters-price-input-prefix",J.textContent="$";const $=document.createElement("input");$.type="number",$.min=P.toString(),$.max=_.toString(),$.value=F.toString(),$.className="product-list-filters-price-input",$.placeholder=_+"+",X.appendChild(J),X.appendChild($),U.appendChild(V),U.appendChild(Z),U.appendChild(X),M.appendChild(U),A.appendChild(M);const Y=()=>{const n=Number.parseInt(q.value,10),i=Number.parseInt(j.value,10),r=_-P,s=(n-P)/r*100,a=(i-P)/r*100;H.style.left=s+"%",H.style.width=a-s+"%"},k=(n,i)=>{q.value=n.toString(),j.value=i.toString(),Q.value=n.toString(),$.value=i.toString(),Y()};return q.addEventListener("input",()=>{let n=Number.parseInt(q.value,10);const i=Number.parseInt(j.value,10);n>i&&(n=i),k(n,i)}),q.addEventListener("change",()=>{const n=Number.parseInt(q.value,10),i=Number.parseInt(j.value,10);null==x?void 0:x(n.toString(),i.toString())}),j.addEventListener("input",()=>{const n=Number.parseInt(q.value,10);let i=Number.parseInt(j.value,10);i<n&&(i=n),k(n,i)}),j.addEventListener("change",()=>{const n=Number.parseInt(q.value,10),i=Number.parseInt(j.value,10);null==x?void 0:x(n.toString(),i.toString())}),Q.addEventListener("input",()=>{let n=Number.parseInt(Q.value,10)||P;const i=Number.parseInt($.value,10)||_;n=Math.max(P,Math.min(n,_)),n>i&&(n=i),k(n,i),null==x||x(n.toString(),i.toString())}),$.addEventListener("input",()=>{const n=Number.parseInt(Q.value,10)||P;let i=Number.parseInt($.value,10)||_;i=Math.max(P,Math.min(i,_)),i<n&&(i=n),k(n,i),null==x||x(n.toString(),i.toString())}),Y(),R.addEventListener("click",()=>{w()}),T.push(A),{elements:T,chevronContainer:L,sliderContainer:M}}class ProductListSearchComponent extends BaseComponent{constructor(){super(...arguments),this.ALLOWED_CHARACTERS=/[^a-zA-Z0-9\s\-_'.,&()]/g,this.MAX_LENGTH=100}get hostClasses(){return["product-list-search-container"]}template(){const n=[],i=document.createElement("div");i.className="product-list-search-box";const r=document.createElement("span");return r.className="product-list-search-icon",r.innerHTML=SearchIcon({}),r.setAttribute("aria-hidden","true"),this.searchInput=document.createElement("input"),this.searchInput.type="text",this.searchInput.className="product-list-search-input",this.searchInput.placeholder="Search",this.searchInput.setAttribute("aria-label","Search products"),this.searchInput.setAttribute("maxlength",this.MAX_LENGTH.toString()),this.params.searchTerm&&(this.searchInput.value=this.sanitizeInput(this.params.searchTerm)),this.searchInput.addEventListener("input",n=>{const i=n.target,r=i.value,s=this.sanitizeInput(r);s!==r&&(i.value=s),this.updateClearButtonVisibility(s),this.params.handleInputChange&&this.params.handleInputChange(s)}),this.clearButton=document.createElement("button"),this.clearButton.type="button",this.clearButton.className="product-list-search-clear-btn",this.clearButton.innerHTML=CloseIcon({}),this.clearButton.setAttribute("aria-label","Clear search"),this.clearButton.style.display=this.params.searchTerm?"flex":"none",this.clearButton.addEventListener("click",()=>{this.searchInput&&(this.searchInput.value="",this.searchInput.focus()),this.updateClearButtonVisibility(""),this.params.clearSearch&&this.params.clearSearch(),this.params.handleInputChange&&this.params.handleInputChange("")}),i.appendChild(r),i.appendChild(this.searchInput),i.appendChild(this.clearButton),n.push(i),n}sanitizeInput(n){if(!n)return"";let i=n.replace(this.ALLOWED_CHARACTERS,"");return i=i.trim(),i=i.replace(/\s+/g," "),i.length>this.MAX_LENGTH&&(i=i.substring(0,this.MAX_LENGTH)),i}updateClearButtonVisibility(n){this.clearButton&&(this.clearButton.style.display=n?"flex":"none")}}function createPersonalizedFilter(n){const{currentFilters:i,isPersonalizationDisabled:r,onPersonalizedChange:s}=n,a=[],l=document.createElement("div");l.className="product-list-filters-personalized";const d=document.createElement("label");d.className="product-list-filters-personalized-label",d.setAttribute("for","personalized-switch"),d.textContent="Personalized Bottles",l.appendChild(d);const u=document.createElement("div");u.classList.add("toggle-switch");const f=!!(null==i?void 0:i.personalized);f&&u.classList.add("active");const g=document.createElement("div");g.classList.add("toggle-slider"),u.id="personalized-switch",u.setAttribute("tabindex","0"),u.setAttribute("aria-label","Toggle Personalized Bottles"),u.setAttribute("role","switch"),u.setAttribute("aria-checked",f?"true":"false"),u.appendChild(g);const h=n=>{u.classList.toggle("active",n),u.setAttribute("aria-checked",n?"true":"false")},o=()=>{const n=u.classList.contains("active"),i=!n;h(i),null==s||s(i)};if(u.addEventListener("click",()=>{r||o()}),u.addEventListener("keydown",n=>{r||"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),o())}),l.appendChild(u),r){const n=document.createElement("div");n.className="product-list-filters-warning",n.textContent="(Not Available With Same-Day Delivery)",l.appendChild(n)}return a.push(l),a}function createPreOrderFilter(n){const{currentFilters:i,isPreOrderDisabled:r,onPreOrderChange:s}=n,a=[],l=document.createElement("div");l.className="product-list-filters-pre-order";const d=document.createElement("label");d.className="product-list-filters-pre-order-label",d.setAttribute("for","pre-order-switch"),d.textContent="Pre-Order",l.appendChild(d);const u=document.createElement("div");u.classList.add("toggle-switch");const f=!!(null==i?void 0:i.preOrder);f&&u.classList.add("active"),r&&u.classList.add("disabled");const g=document.createElement("div");g.classList.add("toggle-slider"),u.id="pre-order-switch",u.setAttribute("tabindex",r?"-1":"0"),u.setAttribute("aria-label","Toggle Pre-Order"),u.setAttribute("role","switch"),u.setAttribute("aria-checked",f?"true":"false"),u.setAttribute("aria-disabled",r?"true":"false"),u.appendChild(g);const h=n=>{u.classList.toggle("active",n),u.setAttribute("aria-checked",n?"true":"false")},o=()=>{const n=u.classList.contains("active"),i=!n;h(i),null==s||s(i)};if(u.addEventListener("click",()=>{r||o()}),u.addEventListener("keydown",n=>{r||"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),o())}),l.appendChild(u),r){const n=document.createElement("div");n.className="product-list-filters-warning",n.textContent="(Not Available With Same-Day Delivery)",l.appendChild(n)}return a.push(l),a}class ProductListFiltersComponent extends BaseComponent{constructor(){super(...arguments),this.priceCollapsed=![],this.deliveryCollapsed=![],this.checkboxFilterStates=new Map,this.DEFAULT_MIN="0",this.DEFAULT_MAX="1000"}get hostClasses(){const n=["product-list-filters-container"];return this.params.isDrawerMode&&n.push("drawer-mode"),n}isSameDayDeliveryDisabled(){var n,i;return!(!(null===(n=this.params.currentFilters)||void 0===n?void 0:n.personalized)&&!(null===(i=this.params.currentFilters)||void 0===i?void 0:i.preOrder))}isPersonalizationDisabled(){var n;return"onDemand"===(null===(n=this.params.currentFilters)||void 0===n?void 0:n.deliveryOptions)}isPreOrderDisabled(){var n;return"onDemand"===(null===(n=this.params.currentFilters)||void 0===n?void 0:n.deliveryOptions)}createPersonalizedFilterWrapper(){return createPersonalizedFilter({currentFilters:this.params.currentFilters,isPersonalizationDisabled:this.isPersonalizationDisabled(),onPersonalizedChange:this.params.onPersonalizedChange})}createPreOrderFilterWrapper(){return createPreOrderFilter({currentFilters:this.params.currentFilters,isPreOrderDisabled:this.isPreOrderDisabled(),onPreOrderChange:this.params.onPreOrderChange})}createDeliveryOptionsFilterWrapper(){const n=createDeliveryOptionsFilter({currentFilters:this.params.currentFilters,deliveryCollapsed:this.deliveryCollapsed,isSameDayDeliveryDisabled:this.isSameDayDeliveryDisabled(),onDeliveryOptionsChange:this.params.onDeliveryOptionsChange,onToggleCollapse:()=>this.toggleDeliveryCollapse()});return this.deliveryChevronContainer=n.chevronContainer,this.deliveryOptionsList=n.deliveryOptionsList,n.elements}toggleDeliveryCollapse(){this.deliveryCollapsed=!this.deliveryCollapsed,this.deliveryOptionsList&&this.deliveryOptionsList.classList.toggle("collapsed"),this.deliveryChevronContainer&&(this.deliveryChevronContainer.innerHTML=this.deliveryCollapsed?ChevronDownIcon({width:20,height:20,color:"#374151"}):ChevronUpIcon({width:20,height:20,color:"#374151"}))}createPriceFilterWrapper(){const n=createPriceFilter({priceConfig:this.params.priceConfig,currentFilters:this.params.currentFilters,priceCollapsed:this.priceCollapsed,onPriceChange:this.params.onPriceChange,onToggleCollapse:()=>this.togglePriceCollapse(),DEFAULT_MIN:this.DEFAULT_MIN,DEFAULT_MAX:this.DEFAULT_MAX});return this.priceChevronContainer=n.chevronContainer,this.priceSliderContainer=n.sliderContainer,n.elements}togglePriceCollapse(){this.priceCollapsed=!this.priceCollapsed,this.priceSliderContainer&&this.priceSliderContainer.classList.toggle("collapsed"),this.priceChevronContainer&&(this.priceChevronContainer.innerHTML=this.priceCollapsed?ChevronDownIcon({}):ChevronUpIcon({}))}createCheckboxFilter(n){var i;const r=[];if(!this.checkboxFilterStates.has(n.bucket)){const r=null===(i=this.params.currentFilters)||void 0===i?void 0:i[n.bucket],s=Array.isArray(r)?new Set(r):new Set;this.checkboxFilterStates.set(n.bucket,{isExpanded:s.size>0,selectedValues:s,searchInput:null,checkboxList:null,filteredItems:[...n.values],contentElement:null,iconElement:null,hasUserInteraction:s.size>0})}const s=this.checkboxFilterStates.get(n.bucket),a=document.createElement("div");a.className="product-list-checkbox-filter",a.setAttribute("data-filter-bucket",n.bucket);const l=document.createElement("div");l.className="checkbox-filter-container";const d=createCheckboxFilterHeader({filter:n,state:s,onToggle:n=>this.toggleCheckboxFilter(n)});l.appendChild(d);const u=document.createElement("div");u.className="checkbox-filter-content "+(s.isExpanded?"expanded":"collapsed"),s.contentElement=u;const f=createCheckboxFilterSearchContainer({state:s,onSearch:i=>{handleCheckboxFilterSearch({filter:n,state:s,searchTerm:i,renderCheckboxItems:()=>this.renderCheckboxItemsWrapper(n,s)})}});return u.appendChild(f),s.checkboxList=document.createElement("div"),s.checkboxList.className="checkbox-filter-list",this.renderCheckboxItemsWrapper(n,s),u.appendChild(s.checkboxList),l.appendChild(u),a.appendChild(l),r.push(a),r}renderCheckboxItemsWrapper(n,i){renderCheckboxItems({filter:n,state:i,onCheckboxChange:(r,s)=>this.handleCheckboxChange(n.bucket,i,r,s)})}handleCheckboxChange(n,i,r,s){s?i.selectedValues.add(r):i.selectedValues.delete(r),i.hasUserInteraction=!![],i.isExpanded||(i.isExpanded=!![],updateFilterExpandState(i)),this.params.onCheckboxFilterChange&&this.params.onCheckboxFilterChange(n,Array.from(i.selectedValues))}toggleCheckboxFilter(n){const i=this.checkboxFilterStates.get(n);i&&(i.isExpanded=!i.isExpanded,i.hasUserInteraction=!![],updateFilterExpandState(i))}template(){var n;const i=[],r=document.createElement("div");r.className="product-list-filters-header",this.params.isDrawerMode&&r.classList.add("drawer-mode");const s=document.createElement("h3");if(s.className="product-list-filters-title",s.textContent="Filters",r.appendChild(s),this.params.isDrawerMode){const n=document.createElement("button");n.className="product-list-filters-close-btn",n.innerHTML=CloseIcon({}),n.addEventListener("click",()=>{this.commands.ui.closeDrawer()}),r.appendChild(n)}return i.push(r),this.params.enablePersonalized&&i.push(...this.createPersonalizedFilterWrapper()),this.params.enablePreOrder&&i.push(...this.createPreOrderFilterWrapper()),this.params.enableDeliveryOptions&&i.push(...this.createDeliveryOptionsFilterWrapper()),this.params.priceConfig&&i.push(...this.createPriceFilterWrapper()),null===(n=this.params.sanitizedFilters)||void 0===n||n.forEach(n=>{i.push(...this.createCheckboxFilter(n))}),this.params.isDrawerMode&&i.push(createApplyFiltersButton(()=>{var n,i;null===(i=(n=this.params).onApplyFilters)||void 0===i?void 0:i.call(n),this.commands.ui.closeDrawer()})),i}}const FilterIcon=({width:n=16,height:i=16,className:r="",color:s=null})=>{const a=s?"--icon-color: "+s:"";return'\n <svg xmlns="http://www.w3.org/2000/svg" width="'+n+'" height="'+i+'" viewBox="0 0 24 24" class="filter-icon '+r+'" style="'+a+'" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">\n <path d="M20 7h-9"></path>\n <path d="M14 17H5"></path>\n <circle cx="17" cy="17" r="3"></circle>\n <circle cx="7" cy="7" r="3"></circle>\n </svg>\n '};var Lt;(function(n){n.IDLE="idle",n.LOADING_INITIAL="loading_initial",n.LOADING_MORE="loading_more",n.ERROR="error"})(Lt||(Lt={}));class ProductListComponent extends BaseComponent{get hostClasses(){const n=["product-list"];return this.params.filters.length>0&&n.push("has-filters"),n}constructor(){super({watchOnlyStorePaths:["address"]}),this.products=[],this.retailers=[],this.pagination={currentPage:0,totalPages:0,hasMorePages:!![]},this.sanitizedFilters=[],this.searchFilter={searchTerm:""},this.currentFilters={personalized:![],preOrder:![],deliveryOptions:"all",price:{min:"0",max:"1000"}},this.cardsContainer=null,this.filtersContainer=null,this.searchContainer=null,this.sentinelElement=null,this.personalizedSwitch=null,this.preOrderSwitch=null,this.deliveryRadios=[],this.deliveryRadioLabels=new Map,this.loadingState=Lt.IDLE,this.scrollObserver=null,this.initializationPromise=null,this.filterDebounceTimer=null,this.FILTER_DEBOUNCE_MS=500,this.filterButton=null}async connected(){if(this.initializationPromise)return this.initializationPromise;this.initializationPromise=this.initializeComponent(),await this.initializationPromise}disconnectedCallback(){super.disconnectedCallback(),this.doCleanup()}async initializeComponent(){try{this.setLoadingState(Lt.LOADING_INITIAL),await this.loadInitialProducts(),this.cardsContainer&&(this.renderProducts(),this.setupInfiniteScroll()),this.setLoadingState(Lt.IDLE)}catch(ut){this.logger.error("Error initializing product list:",ut),this.setLoadingState(Lt.ERROR),this.showErrorState("Failed to load products")}}template(){const n=[],i=document.createElement("div");i.className="product-list-search__control-container",i.appendChild(this.createSearchContainer()),n.push(i),this.params.filters.length>0&&(this.filterButton=this.createFilterButton(),n.push(this.filterButton));const r=document.createElement("div");return r.className="product-list-controls",this.params.filters.length>0&&r.appendChild(this.createFiltersContainer()),this.cardsContainer=this.createCardsContainer(),r.appendChild(this.cardsContainer),n.push(r),this.renderCurrentState(),n}setLoadingState(n){this.loadingState=n,this.cardsContainer&&this.renderCurrentState()}renderCurrentState(){if(this.cardsContainer)switch(this.loadingState){case Lt.LOADING_INITIAL:this.renderLoadingState();break;case Lt.ERROR:break;case Lt.IDLE:case Lt.LOADING_MORE:this.updateSentinel()}}sanitizeFilterValues(n){return n.map(n=>({...n,formattedValue:n.value}))}processResponseFilters(n){var i;return(null===(i=null==n?void 0:n.navigation)||void 0===i?void 0:i.filters)?n.navigation.filters.filter(n=>n.bucket!==f.AVAILABILITY).filter(n=>n.bucket!==f.PRICE).filter(n=>n.bucket!==f.ENGRAVING).filter(n=>n.bucket!==f.PRESALE).filter(n=>n.bucket!==f.TAGS).map(n=>{var i,r;if(n.bucket===f.CATEGORIES){const s=new Set;return{...n,values:null!==(r=null===(i=n.values)||void 0===i?void 0:i.map(n=>{const i=n.value.split(">").map(n=>n.trim()),r=i.pop()||"";let a=r;return s.has(r)&&(a=i.slice(-1).concat(r).join(" > ")),s.add(a),{...n,formattedValue:a}}).slice(1))&&void 0!==r?r:[]}}return{...n,values:this.sanitizeFilterValues(n.values)}}).filter(n=>{var i;return(null===(i=n.values)||void 0===i?void 0:i.length)>0}):[]}async loadInitialProducts(){var n;try{const i=this.buildApiParams(0),r=await this.commands.productList.getProductList(i);this.sanitizedFilters=this.processResponseFilters(r),this.products=r.products||[],this.retailers=r.retailers||[],this.updatePagination(r.navigation),this.syncFiltersFromResponse((null===(n=r.navigation)||void 0===n?void 0:n.filters)||[]),this.updateFiltersComponent()}catch(i){throw this.products=[],this.retailers=[],this.pagination.hasMorePages=![],i}}updateFiltersComponent(){if(!this.filtersContainer||0===this.params.filters.length)return;const n=this.filtersContainer.parentElement;if(!n)return;const i=this.filtersContainer;this.filtersContainer=this.createFiltersContainer(),n.replaceChild(this.filtersContainer,i)}async loadMoreProducts(){if(this.loadingState!==Lt.LOADING_MORE&&this.pagination.hasMorePages)try{this.setLoadingState(Lt.LOADING_MORE);const n=this.pagination.currentPage+1,i=this.buildApiParams(n),r=await this.commands.productList.getProductList(i);this.sanitizedFilters=this.processResponseFilters(r),r.products&&r.products.length>0?(this.products.push(...r.products),this.mergeRetailers(r.retailers||[]),this.updatePagination(r.navigation),this.appendNewProducts(r.products)):(this.pagination.hasMorePages=![],this.updatePagination(r.navigation)),this.setLoadingState(Lt.IDLE)}catch(n){this.logger.error("Error loading more products:",n),this.setLoadingState(Lt.ERROR),this.showSentinelError("Error loading products")}}mergeRetailers(n){const i=new Map(this.retailers.map(n=>[n.id,n]));for(const r of n)i.has(r.id)||(this.retailers.push(r),i.set(r.id,r))}updatePagination(n){var i,r,s,a;n&&(this.pagination={currentPage:null!==(i=n.currentPage)&&void 0!==i?i:0,totalPages:null!==(r=n.totalPages)&&void 0!==r?r:0,hasMorePages:(null!==(s=n.currentPage)&&void 0!==s?s:0)<(null!==(a=n.totalPages)&&void 0!==a?a:1)-1})}buildApiParams(n){const i={page:n,perPage:this.params.rows*this.params.columns,filters:this.buildFiltersFromState()};return this.searchFilter.searchTerm&&this.searchFilter.searchTerm.trim().length>0&&(i.search=this.searchFilter.searchTerm.trim()),i}buildFiltersFromState(){const n=[{key:"availability",values:"IN_STOCK"}];if(this.currentFilters.personalized&&n.push({key:"engraving",values:"YES"}),this.currentFilters.preOrder&&n.push({key:"presale",values:"YES"}),"all"!==this.currentFilters.deliveryOptions&&n.push({key:"fulfillment",values:[this.currentFilters.deliveryOptions]}),this.currentFilters.price){const i={};"0"!==this.currentFilters.price.min&&(i.min=this.currentFilters.price.min),"1000"!==this.currentFilters.price.max&&(i.max=this.currentFilters.price.max),Object.keys(i).length>0&&n.push({key:"price",values:i})}const i=Object.keys(this.currentFilters).filter(n=>!["personalized","preOrder","deliveryOptions","price"].includes(n));for(const r of i){const i=this.currentFilters[r];Array.isArray(i)&&i.length>0&&n.push({key:r,values:i})}return n}syncFiltersFromResponse(n){if(n)for(const i of n)switch(i.key){case"engraving":this.currentFilters.personalized="YES"===i.values;break;case"presale":this.currentFilters.preOrder="YES"===i.values;break;case"fulfillment":Array.isArray(i.values)&&(i.values.includes("onDemand")?this.currentFilters.deliveryOptions="onDemand":i.values.includes("shipping")?this.currentFilters.deliveryOptions="shipping":this.currentFilters.deliveryOptions="all")}}async onFilterChange(){try{this.updateFiltersUI(),this.resetPagination(),this.products=[],this.retailers=[],this.cleanupScrollObserver(),this.clearCardsContainer(),this.setLoadingState(Lt.LOADING_INITIAL),await this.loadInitialProducts(),this.renderProducts(),this.setupInfiniteScroll(),this.setLoadingState(Lt.IDLE)}catch(ut){this.logger.error("Error handling filter change:",ut),this.setLoadingState(Lt.ERROR),this.showErrorState("Error updating filters")}}resetPagination(){this.pagination={currentPage:0,totalPages:0,hasMorePages:!![]}}updateFiltersUI(){this.filtersContainer&&(this.updatePersonalizedSwitch(),this.updatePreOrderSwitch(),this.updateDeliveryOptions())}updatePersonalizedSwitch(){this.personalizedSwitch&&(this.personalizedSwitch.checked=this.currentFilters.personalized,this.personalizedSwitch.disabled=this.isPersonalizationDisabled())}updatePreOrderSwitch(){this.preOrderSwitch&&(this.preOrderSwitch.checked=this.currentFilters.preOrder,this.preOrderSwitch.disabled=this.isPreOrderDisabled())}updateDeliveryOptions(){0!==this.deliveryRadios.length&&this.deliveryRadios.forEach(n=>{const i="onDemand"===n.value&&this.isSameDayDeliveryDisabled();n.disabled=i,i&&"onDemand"===n.value||(n.checked=n.value===this.currentFilters.deliveryOptions),this.updateRadioLabel(n,i)})}updateRadioLabel(n,i){const r=this.deliveryRadioLabels.get(n.id);r&&(r.className="product-list-filters-delivery-radio-label "+(i?"disabled":""))}isPersonalizationDisabled(){return"onDemand"===this.currentFilters.deliveryOptions}isPreOrderDisabled(){return"onDemand"===this.currentFilters.deliveryOptions}isSameDayDeliveryDisabled(){return this.currentFilters.personalized||this.currentFilters.preOrder}createCardsContainer(){const n=document.createElement("div");n.className="product-list-cards__container";const i=100/this.params.columns;return n.style.setProperty("--card-width",i+"%"),n.style.setProperty("--columns",""+this.params.columns),n}renderLoadingState(){if(!this.cardsContainer)return;this.clearCardsContainer();const n=ComponentFactoryService.createElement({type:C.PRODUCT_LIST_CARD_LOADING,cardVariant:this.params.cardVariant,rows:this.params.rows,columns:this.params.columns,fillCard:this.params.fillCard,filters:this.params.filters,productUrl:this.params.productUrl});this.cardsContainer.appendChild(n)}renderProducts(){if(this.cardsContainer){if(this.clearCardsContainer(),0===this.products.length){const n=this.createInfoElement("No products found");return this.cardsContainer.appendChild(n),void 0}for(const n of this.products){const i=this.createProductCard(n);i&&this.cardsContainer.appendChild(i)}}}appendNewProducts(n){if(this.cardsContainer&&0!==n.length){this.sentinelElement&&this.sentinelElement.parentNode===this.cardsContainer&&this.sentinelElement.remove();for(const i of n){const n=this.createProductCard(i);n&&this.cardsContainer.appendChild(n)}this.sentinelElement?(this.cardsContainer.appendChild(this.sentinelElement),this.updateSentinel(),this.scrollObserver&&this.pagination.hasMorePages&&this.scrollObserver.observe(this.sentinelElement)):this.pagination.hasMorePages&&this.setupInfiniteScroll()}}createProductCard(n){var i;try{const r=null===(i=n.sizes)||void 0===i?void 0:i[0];if(!r)return this.logger.warn("Product "+n.id+" has no sizes"),null;const s=new Map(this.retailers.flatMap(n=>n.fulfillments.map(n=>[n.id,n]))),a=new Set(r.variants.flatMap(n=>n.fulfillments)),l=Array.from(a).map(n=>s.get(n)).filter(n=>Boolean(n));return ComponentFactoryService.createElement({type:C.PRODUCT_LIST_CARD,variant:this.params.cardVariant,fillCard:this.params.fillCard,product:n,fulfillments:l,productUrl:this.params.productUrl})}catch(r){return this.logger.error("Error creating product card for product "+n.id+":",r),null}}filterSanitizedFilters(){if(!this.params.filters||0===this.params.filters.length)return[];const n={[f.BRANDS]:_.BRANDS,[f.CATEGORIES]:_.CATEGORIES,[f.FLAVOR]:_.FLAVOR,[f.REGION]:_.REGION,[f.VARIETY]:_.VARIETY,[f.VINTAGE]:_.VINTAGE,[f.COUNTRY]:_.COUNTRY,[f.APPELLATION]:_.APPELLATION,[f.MATERIALS]:_.MATERIALS,[f.SIZES]:_.SIZES};return this.sanitizedFilters.filter(i=>{const r=n[i.bucket];return r&&this.params.filters.includes(r)})}buildFiltersParams(n=![]){const I=async()=>{this.filterDebounceTimer&&(clearTimeout(this.filterDebounceTimer),this.filterDebounceTimer=null),await this.onFilterChange()};return{enablePersonalized:this.params.filters.includes(_.PERSONALIZATION),enablePreOrder:this.params.filters.includes(_.PRE_ORDER),enableDeliveryOptions:this.params.filters.includes(_.DELIVERY_OPTIONS),currentFilters:this.currentFilters,sanitizedFilters:this.filterSanitizedFilters(),priceConfig:this.params.filters.includes(_.PRICE)?{min:"0",max:"1000"}:void 0,onPersonalizedChange:async i=>{this.currentFilters.personalized=i,n||await this.onFilterChange()},onPreOrderChange:async i=>{this.currentFilters.preOrder=i,n||await this.onFilterChange()},onDeliveryOptionsChange:async i=>{this.currentFilters.deliveryOptions=i,"onDemand"===i&&(this.currentFilters.personalized=![],this.currentFilters.preOrder=![]),n||await this.onFilterChange()},onPriceChange:async(i,r)=>{this.currentFilters.price||(this.currentFilters.price={}),"0"!==i?this.currentFilters.price.min=i:delete this.currentFilters.price.min,"1000"!==r?this.currentFilters.price.max=r:delete this.currentFilters.price.max,n||(this.filterDebounceTimer&&clearTimeout(this.filterDebounceTimer),this.filterDebounceTimer=setTimeout(async()=>{await this.onFilterChange()},this.FILTER_DEBOUNCE_MS))},onCheckboxFilterChange:async(i,r)=>{r.length>0?this.currentFilters[i]=r:delete this.currentFilters[i],n||await this.onFilterChange()},isDrawerMode:n,onApplyFilters:async()=>{await I()}}}createSearchContainer(){return this.searchContainer=ComponentFactoryService.createElement({type:C.PRODUCT_LIST_SEARCH,searchTerm:this.searchFilter.searchTerm,handleInputChange:async n=>{this.searchFilter.searchTerm=n,this.filterDebounceTimer&&clearTimeout(this.filterDebounceTimer),this.filterDebounceTimer=setTimeout(async()=>{await this.onFilterChange()},this.FILTER_DEBOUNCE_MS)},clearSearch:async()=>{this.searchFilter.searchTerm="",this.filterDebounceTimer&&(clearTimeout(this.filterDebounceTimer),this.filterDebounceTimer=null),await this.onFilterChange()}}),this.searchContainer}createFiltersContainer(n={}){const{isDrawerMode:i=![]}=n;return this.filtersContainer=ComponentFactoryService.createElement({type:C.PRODUCT_LIST_FILTERS,...this.buildFiltersParams(i)}),this.storeFilterElementReferences(),this.filtersContainer}storeFilterElementReferences(){if(!this.filtersContainer)return;this.personalizedSwitch=this.filtersContainer.querySelector("#personalized-switch"),this.preOrderSwitch=this.filtersContainer.querySelector("#pre-order-switch");const n=this.filtersContainer.querySelectorAll('input[name="delivery-options"]');this.deliveryRadios=Array.from(n),this.deliveryRadioLabels.clear(),this.deliveryRadios.forEach(n=>{var i;const r=null===(i=this.filtersContainer)||void 0===i?void 0:i.querySelector('label[for="'+n.id+'"]');r&&this.deliveryRadioLabels.set(n.id,r)})}openFiltersDrawer(){this.commands.ui.openDrawer(C.PRODUCT_LIST_FILTERS,this.buildFiltersParams(!![]))}createFilterButton(){const n=document.createElement("div");n.className="product-list-filter-container";const i=document.createElement("div");i.className="product-list-filter-icon",i.innerHTML=FilterIcon({}),i.addEventListener("click",()=>{this.openFiltersDrawer()});const r=document.createElement("span");return r.className="product-list-filter-text",r.textContent="Filter",n.appendChild(i),n.appendChild(r),n}setupInfiniteScroll(){this.cardsContainer&&this.pagination.hasMorePages&&(this.cleanupScrollObserver(),this.sentinelElement=this.createScrollSentinel(),this.cardsContainer.appendChild(this.sentinelElement),this.scrollObserver=new IntersectionObserver(n=>{const i=n[0];i.isIntersecting&&this.loadingState===Lt.IDLE&&this.pagination.hasMorePages&&void this.loadMoreProducts()},{root:null,rootMargin:"100px",threshold:.1}),this.scrollObserver.observe(this.sentinelElement))}createScrollSentinel(){const n=document.createElement("div");return n.className="product-list-scroll-sentinel",this.updateSentinelContent(n),n}updateSentinel(){this.sentinelElement&&this.updateSentinelContent(this.sentinelElement)}updateSentinelContent(n){let i;n.innerHTML="",i=this.loadingState===Lt.LOADING_MORE?this.createLoadingElement("Loading more products..."):this.pagination.hasMorePages?this.createInfoElement("Scroll for more products"):this.createInfoElement("No more products",!![]),n.appendChild(i)}showSentinelError(n){if(!this.sentinelElement)return;this.sentinelElement.innerHTML="";const i=this.createErrorElement(n);this.sentinelElement.appendChild(i)}createLoadingElement(n){const i=document.createElement("div");i.className="product-list-sentinel-container";const r=document.createElement("div");r.className="product-list-sentinel-spinner";const s=document.createElement("div");return s.className="product-list-sentinel-text",s.textContent=n,i.appendChild(r),i.appendChild(s),i}createErrorElement(n){const i=document.createElement("div");i.className="product-list-sentinel-error-container";const r=document.createElement("div");r.className="product-list-sentinel-error-icon",r.innerHTML="⚠";const s=document.createElement("div");return s.className="product-list-sentinel-error-text",s.textContent=n,i.appendChild(r),i.appendChild(s),i}createInfoElement(n,i=![]){const r=document.createElement("div");if(r.className="product-list-sentinel-info-container",!i&&n.includes("Scroll")){const n=document.createElement("div");n.className="product-list-sentinel-icon",n.innerHTML="↓",r.appendChild(n)}else if(i){const n=document.createElement("div");n.className="product-list-sentinel-divider",r.appendChild(n)}const s=document.createElement("div");return s.className=i?"product-list-sentinel-info-text no-more":"product-list-sentinel-info-text",s.textContent=n,r.appendChild(s),r}showErrorState(n){if(!this.cardsContainer)return;this.clearCardsContainer();const i=this.createErrorElement(n);this.cardsContainer.appendChild(i)}clearCardsContainer(){if(this.cardsContainer)for(this.sentinelElement&&this.sentinelElement.parentNode===this.cardsContainer&&(this.sentinelElement.remove(),this.sentinelElement=null);this.cardsContainer.firstChild;)this.cardsContainer.removeChild(this.cardsContainer.firstChild)}cleanupScrollObserver(){this.scrollObserver&&(this.scrollObserver.disconnect(),this.scrollObserver=null),this.sentinelElement&&(this.sentinelElement=null)}async onStoreWatch(n){const i=n.find(n=>"address"===n.path);if(i&&void 0!==i.value&&this.cardsContainer)try{this.resetPagination(),this.products=[],this.retailers=[],this.cleanupScrollObserver(),this.clearCardsContainer(),this.renderLoadingState(),await this.loadInitialProducts(),this.cardsContainer&&(this.renderProducts(),this.setupInfiniteScroll())}catch(r){this.logger.error("Error reloading products after address change:",r),this.setLoadingState(Lt.ERROR),this.cardsContainer&&this.showErrorState("Failed to reload products")}}doCleanup(){this.filterDebounceTimer&&(clearTimeout(this.filterDebounceTimer),this.filterDebounceTimer=null),this.cleanupScrollObserver(),this.products=[],this.retailers=[],this.cardsContainer=null,this.filtersContainer=null,this.searchContainer=null,this.filterButton=null,this.personalizedSwitch=null,this.preOrderSwitch=null,this.deliveryRadios=[],this.deliveryRadioLabels.clear(),this.initializationPromise=null}}class AlertComponent extends BaseComponent{constructor(){super(...arguments),this.hideTimeout=null,this.elements=[]}get hostClasses(){return["alert-wrapper","hidden"]}get hostAttributes(){return{role:"alert","aria-live":"polite"}}beforeSetupStoreWatchers(){this.reactiveOptions.watchStorePaths=[this.params.errorStorePath]}afterRender(){this.updateAlert()}onStoreWatch(n){n.length>0&&this.updateAlert()}getErrorMessages(){var n,i;const r=null!==(n=this.params.fromEvents)&&void 0!==n?n:![],s=null!==(i=this.params.showFirstEvent)&&void 0!==i?i:!![];if(r){const n=this.store.get(this.params.errorStorePath)||[],i=n.filter(n=>null==n?void 0:n.message).map(n=>({message:n.message,level:n.level||"error",type:n.type}));return s?i.slice(0,1):i}const a=this.store.get(this.params.errorStorePath);return a?[{message:a,level:"error"}]:[]}createErrorElement(n){const i=document.createElement("div");i.classList.add("alert-container","alert-"+n.level);const r=document.createElement("span");r.classList.add("alert-icon"),r.innerHTML=ErrorInfoIcon({className:n.level+"-icon"});const s=document.createElement("span");return s.classList.add("alert-text"),s.textContent=n.message,i.appendChild(r),i.appendChild(s),i}scheduleHide(){var n;this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=null);const i=null!==(n=this.params.autoHideDelay)&&void 0!==n?n:3e3;this.hideTimeout=setTimeout(()=>{this.hideAllErrors(),this.hideTimeout=null},i)}hideAllErrors(){var n;this.addHostClasses("hidden"),this.removeHostClasses("alert-success","alert-info","alert-warning","alert-error"),this.elements.forEach(n=>{n.parentNode&&n.parentNode.removeChild(n)}),this.elements=[];const i=null!==(n=this.params.fromEvents)&&void 0!==n?n:![];i?this.store.set(this.params.errorStorePath,[]):this.store.set(this.params.errorStorePath,null)}updateAlert(){const n=this.getErrorMessages();if(this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=null),this.elements.forEach(n=>{n.parentNode&&n.parentNode.removeChild(n)}),this.elements=[],0===n.length)return this.addHostClasses("hidden"),this.removeHostClasses("alert-success","alert-info","alert-warning","alert-error"),void 0;this.removeHostClasses("hidden"),this.elements=n.map(n=>this.createErrorElement(n)),this.elements.forEach(n=>{this.container.appendChild(n)}),this.scheduleHide()}template(){return[]}disconnectedCallback(){this.hideTimeout&&(clearTimeout(this.hideTimeout),this.hideTimeout=null),super.disconnectedCallback()}}class ButtonsOpenCartComponent extends BaseComponent{get hostClasses(){return["lce-ui-button",...this.params.classes||[]]}template(){const n=this.getConfigs("global");this.addEventListener("click",()=>{this.commands.ui.openDrawer(C.CART)});const i=document.createElement("span");if(i.className="lce-cart-button-icon",i.innerHTML=BagIcon({color:n.theme.primaryColor}),this.params.showItemsCount){const n=document.createElement("span");return n.className="lce-cart-button-badge",n.style.visibility="hidden",[i,n]}return[i]}afterRender(){this.params.showItemsCount&&this.setupCartBadge()}setupCartBadge(){const n=this.container.querySelector(".lce-cart-button-badge");if(!n)return;const i=this.getStoreValue("cart.totals.quantity")||0;n.textContent=i.toString(),n.style.visibility=i>0?"visible":"hidden",this.store.watch("cart.totals",()=>{const i=this.getStoreValue("cart.totals.quantity")||0;n.textContent=i.toString(),n.style.visibility=i>0?"visible":"hidden"})}}class DrawerComponent extends BaseComponent{constructor(){super({watchStorePaths:["ui.drawer"]}),this.isOpen=![],this.wrapperElement=null,this.drawerElement=null,this.backdropElement=null,this.contentContainer=null,this.currentContentType=null,this.isTransitioning=![],this.boundHandleKeydown=this.handleKeydown.bind(this)}disconnected(){this.backdropElement&&this.backdropElement.removeEventListener("click",this.handleBackdropClick.bind(this)),document.removeEventListener("keydown",this.boundHandleKeydown)}onStoreChanged(n){var i;const r=n.find(n=>"ui.drawer"===n.path);if(!r)return![];const s=r.value,a=s.isOpen,l=null===(i=s.contentConfig)||void 0===i?void 0:i.type,d=l!==this.currentContentType;return a&&!this.isOpen?(this.currentContentType=l,this.openWithContent(s),![]):a&&this.isOpen&&!d?![]:a&&this.isOpen&&d?(this.currentContentType=l,this.openWithContent(s),![]):!a&&this.isOpen?(this.close(),this.currentContentType=null,![]):![]}openWithContent({contentConfig:n}){try{if(!n)return this.logger.warn("Drawer opening attempted without content configuration"),void 0;const{type:i,data:r}=n||{};let s;s=this.isElementsEnabled()?ComponentFactoryService.createElement({type:i,...r}):this.clientConfig.isProduction()?productionComponentError({title:"Element Unavailable",message:"We're sorry, this element is currently unavailable.",componentType:i}):componentError({message:"Elements is not enabled.",componentType:i}),this.isOpen&&this.contentContainer&&this.contentContainer.firstElementChild?this.animateContentSwap(s,i):(this.cleanupCurrentContent(),this.contentContainer&&this.contentContainer.appendChild(s),this.updateDrawerContentTypeClass(i),this.open()),this.addHostAttribute("data-target",i.toString().toLowerCase())}catch(i){this.logger.error("Drawer content loading failed",i),this.commands.ui.closeDrawer()}}animateContentSwap(n,i){if(!this.contentContainer||this.isTransitioning)return;this.isTransitioning=!![];const r=this.contentContainer.firstElementChild;r.classList.add("drawer-content-fade-out"),requestAnimationFrame(()=>{r.classList.add("fading")}),setTimeout(()=>{r.remove(),n.classList.add("drawer-content-fade-in"),this.contentContainer.appendChild(n),this.updateDrawerContentTypeClass(i),requestAnimationFrame(()=>{n.classList.add("visible"),setTimeout(()=>{n.classList.remove("drawer-content-fade-in","visible"),this.isTransitioning=![]},150)})},150)}open(){this.isOpen=!![],this.updateDrawerState()}close(){this.isOpen=![],this.updateDrawerState()}cleanupCurrentContent(){this.contentContainer&&(this.contentContainer.innerHTML="")}handleBackdropClick(){this.commands.ui.closeDrawer()}handleKeydown(n){this.isOpen&&"Escape"===n.key&&this.commands.ui.closeDrawer()}updateDrawerContentTypeClass(n){if(!this.drawerElement)return;const i=["drawer"];this.isOpen&&i.push("open"),i.push(n.toString().toLowerCase()),this.drawerElement.className=i.join(" ")}updateDrawerState(){this.wrapperElement&&this.drawerElement&&this.backdropElement&&(this.isOpen&&(this.wrapperElement.classList.add("open"),this.backdropElement.classList.add("visible"),document.body.style.overflow="hidden",this.currentContentType&&this.updateDrawerContentTypeClass(this.currentContentType)),this.isOpen||(this.wrapperElement.classList.remove("open"),this.backdropElement.classList.remove("visible"),document.body.style.overflow="",this.drawerElement.className="drawer"))}isElementsEnabled(){var n;try{const i=this.themeProvider.getConfigs("configurations");return null!==(n=null==i?void 0:i.isElementsEnabled)&&void 0!==n?n:![]}catch(i){return this.logger.error("Could not check elements enabled status, defaulting to not enabled",i),!![]}}template(){return this.wrapperElement=document.createElement("div"),this.wrapperElement.classList.add("drawer-wrapper"),this.backdropElement=document.createElement("div"),this.backdropElement.classList.add("drawer-backdrop"),this.backdropElement.addEventListener("click",this.handleBackdropClick.bind(this)),this.drawerElement=document.createElement("div"),this.drawerElement.classList.add("drawer"),this.contentContainer=document.createElement("div"),this.contentContainer.classList.add("drawer-content"),this.drawerElement.append(this.contentContainer),this.wrapperElement.append(this.backdropElement),this.wrapperElement.append(this.drawerElement),document.addEventListener("keydown",this.boundHandleKeydown),this.wrapperElement}}class EngravingFormComponent extends BaseComponent{constructor(){super(...arguments),this.engravingLines=[],this.fulfillmentId=null,this.partNumber=null}get hostClasses(){return["engraving-form"]}beforeConnected(){var n;if(this.engravingLines=this.params.lines,"product"===this.params.context){const i=this.store.get("products."+this.params.identifier);this.fulfillmentId=i.selectedFulfillmentId,this.partNumber=(null===(n=i.selectedFulfillment)||void 0===n?void 0:n.partNumber)||null}if("cart"===this.params.context){const n=this.store.get("cart.items."+this.params.identifier);this.fulfillmentId=n.fulfillmentId,this.partNumber=n.partNumber}}calculateTotalPrice(){var n,i;if("product"===this.params.context){const r=this.store.get("products."+this.params.identifier),s=r.sizes[r.selectedSizeId],a=s.shippingFulfillments[this.fulfillmentId],l=a.price,d=(null===(i=null===(n=null==s?void 0:s.attributes)||void 0===n?void 0:n.engraving)||void 0===i?void 0:i.fee)||0;return l+d}if("cart"===this.params.context){const n=this.store.get("cart.items."+this.params.identifier),i=n.unitPrice,r=n.attributes.engraving.fee||0;return i+r}return 0}productInformationSection(){const n=[];let i="",r="";if("product"===this.params.context){const s=this.store.get("products."+this.params.identifier);s.mainImage?n.push(s.mainImage):n.push(...s.images||[]),i=s.name,r=s.sizes[s.selectedSizeId].size}if("cart"===this.params.context){const s=this.store.get("cart.items."+this.params.identifier);s.mainImage&&n.push(s.mainImage),i=s.name,r=s.size}const s=document.createElement("div");if(s.className="product-info-section",n.length>0){const r=document.createElement("div");r.className="product-image-container";const a=document.createElement("img");a.src=n[0],a.alt=i,a.loading="lazy",a.className="product-image",r.appendChild(a),s.appendChild(r)}const a=document.createElement("div");a.className="product-details-container";const l=document.createElement("div");l.className="product-header";const d=document.createElement("h4");d.className="product-title",d.textContent=i,this.productPriceSpan=document.createElement("span"),this.productPriceSpan.className="product-price",this.productPriceSpan.textContent=formatCentToDollarText(this.calculateTotalPrice()),l.appendChild(d),l.appendChild(this.productPriceSpan),a.appendChild(l);const u=document.createElement("p");u.className="product-size-text",u.textContent=r,a.appendChild(u);const f=document.createElement("p");return f.className="engraving-fees-disclaimer",f.textContent="Personalization fees included in total, varies by retailer.",a.appendChild(f),s.appendChild(a),s}addToCartButtonText(n){if("product"!==this.params.context)return"Save";const i=this.getConfigs("product"),r=i.layout.addToCartButtonText;return i.layout.addToCartButtonShowTotalPrice?r+" - "+formatCentToDollarText(n):r}retailersSection(){var n,i,r,s,a,l,d;const u=this.store.get("products."+this.params.identifier),f=u.sizes[u.selectedSizeId],g=Object.values(f.shippingFulfillments).filter(n=>n.isVariantEngravable&&n.canEngrave),v=document.createElement("div");v.className="fulfillment-section";const b=document.createElement("p");if(b.className="shipping-from-text",b.innerHTML="Shipping from: <b>"+(null===(n=u.selectedFulfillment)||void 0===n?void 0:n.retailerName)+"</b>",v.appendChild(b),1===g.length)return v;const x=document.createElement("div");x.className="fulfillment-options-container",v.appendChild(x);const w=document.createElement("span");w.className="see-more-fulfillments",w.textContent="See More Delivery Options ("+g.length+")",w.setAttribute("role","button"),w.setAttribute("tabindex","0"),w.setAttribute("aria-label","See More Delivery Options ("+g.length+")"),w.setAttribute("aria-expanded","false");const S=()=>{const n=x.classList.contains("expanded");x.classList.toggle("expanded"),n?(w.textContent="See More Delivery Options ("+g.length+")",w.setAttribute("aria-label","See More Delivery Options ("+g.length+")"),w.setAttribute("aria-expanded","false")):(w.textContent="See Less Delivery Options",w.setAttribute("aria-label","See Less Delivery Options"),w.setAttribute("aria-expanded","true"))};w.addEventListener("click",S),w.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),S())}),v.appendChild(w);for(const C of g){const n=document.createElement("div");n.className="fulfillment-option",n.setAttribute("data-fulfillment-id",C.fulfillmentId),C.fulfillmentId===(null===(i=u.selectedFulfillment)||void 0===i?void 0:i.fulfillmentId)&&n.classList.add("selected"),n.setAttribute("role","button"),n.setAttribute("tabindex","0"),n.setAttribute("aria-label","Select delivery from "+C.retailerName+", "+formatCentToDollarText(C.price+((null===(s=null===(r=u.sizes[u.selectedSizeId].attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.fee)||0))+", "+C.expectation.engraving),n.setAttribute("aria-pressed",C.fulfillmentId===(null===(a=u.selectedFulfillment)||void 0===a?void 0:a.fulfillmentId)?"true":"false");const z=()=>{this.fulfillmentId=C.fulfillmentId,this.partNumber=C.partNumber;const i=this.calculateTotalPrice();this.addToCartButton.textContent=this.addToCartButtonText(i),this.productPriceSpan.textContent=formatCentToDollarText(i);const r=x.querySelector(".fulfillment-option.selected");r&&(r.classList.remove("selected"),r.setAttribute("aria-pressed","false")),n.classList.add("selected"),n.setAttribute("aria-pressed","true"),b.innerHTML="Shipping from: <b>"+C.retailerName+"</b>"};n.addEventListener("click",z),n.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),z())});const f=C.price+((null===(d=null===(l=u.sizes[u.selectedSizeId].attributes)||void 0===l?void 0:l.engraving)||void 0===d?void 0:d.fee)||0),g=document.createElement("div");g.className="option-row row-1",n.appendChild(g);const v=document.createElement("span");v.className="retailer-name",v.textContent=C.retailerName,g.appendChild(v);const w=document.createElement("span");w.className="fulfillment-price",w.textContent=formatCentToDollarText(f),g.appendChild(w),n.appendChild(g);const E=document.createElement("div");E.className="option-row row-2",n.appendChild(E);const T=document.createElement("span");T.className="estimated-time",T.textContent=""+C.expectation.engraving,E.appendChild(T),n.appendChild(E),x.appendChild(n)}return v}engravingLinesSection(){var n;const{lines:i,maxLines:r,location:s,maxCharsPerLine:a}=this.params,l=document.createElement("div");l.className="engraving-section";const d=document.createElement("p");if(d.className="engraving-title",d.textContent="Personalize Your Bottle",l.appendChild(d),s&&(null===(n=null==s?void 0:s.trim())||void 0===n?void 0:n.length)>0){const n=document.createElement("p");n.className="engraving-location-text",n.textContent="Your message will appear "+s.toLowerCase()+".",l.appendChild(n)}const u=Array.from({length:r},(n,r)=>{const s=r+1,l=document.createElement("div");l.className="engraving-input-wrapper",l.setAttribute("data-line-number",s.toString());const d=document.createElement("input");d.type="text",d.id="engraving-line-"+s,d.dataset.lineNumber=s.toString(),d.maxLength=a,d.value=i[r]||"",d.placeholder=s>1?"Line "+s+" (optional)":"Line "+s,d.className="engraving-input",d.autocomplete="off",d.setAttribute("aria-label",s>1?"Engraving line "+s+", optional, maximum "+a+" characters":"Engraving line "+s+", maximum "+a+" characters");const u=document.createElement("span");return u.className="engraving-char-count",u.textContent=d.value.length+"/"+a,u.setAttribute("aria-live","polite"),u.setAttribute("aria-atomic","true"),d.addEventListener("input",()=>{u.textContent=d.value.length+"/"+a,this.engravingLines[r]=d.value.trim().toUpperCase(),this.addToCartButton.disabled=this.engravingLines.length<=0}),l.appendChild(d),l.appendChild(u),l}),f=document.createElement("div");return f.className="engraving-inputs-container",f.append(...u),l.appendChild(f),l}actionButtonsSection(){const{identifier:n,context:i}=this.params,r=document.createElement("div");r.className="action-buttons-container";const s=document.createElement("button");s.type="button",s.className="cancel-action-button",s.textContent="Cancel",s.setAttribute("aria-label","Cancel personalization and close");const y=async()=>{"product"===i&&await this.commands.product.closeProductDrawer(n),"cart"===i&&this.commands.ui.openDrawer(C.CART)};s.addEventListener("click",y),s.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),y())}),r.appendChild(s),this.addToCartButton=document.createElement("button"),this.addToCartButton.type="button",this.addToCartButton.className="add-to-cart-button",this.addToCartButton.disabled=this.engravingLines.length<=0,this.addToCartButton.textContent=this.addToCartButtonText(this.calculateTotalPrice()),this.addToCartButton.setAttribute("aria-label","product"===i?"Add personalized item to cart":"Update personalization and return to cart");const p=async()=>{const r=this.engravingLines.map(n=>n.trim().toUpperCase()).filter(n=>n&&n.length>0);if("product"===i&&this.fulfillmentId&&this.partNumber){const i=this.store.get("products."+n);await this.commands.product.addToCart(n,{upc:i.sizes[i.selectedSizeId].upc,fulfillmentId:this.fulfillmentId,partNumber:this.partNumber,quantity:1,engravingLines:r,identifier:n}),await this.commands.product.closeProductDrawer(n)}"cart"===i&&(await this.commands.cart.updateItemEngraving(n,r),this.commands.ui.openDrawer(C.CART))};return this.addToCartButton.addEventListener("click",p),this.addToCartButton.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),p())}),r.appendChild(this.addToCartButton),r}template(){const n=[],i=this.productInformationSection();if(n.push(i),"product"===this.params.context){const i=this.retailersSection();n.push(i)}const r=this.engravingLinesSection();n.push(r);const s=this.actionButtonsSection();n.push(s);const a=document.createElement("p");return a.className="engraving-disclaimer",a.innerHTML="Personalized orders require up to 10 business days to be processed and then shipped. Tracking information will be provided once processed. <b>Personalized bottle orders cannot be cancelled.</b>",n.push(a),n}}class EngravingViewComponent extends BaseComponent{get hostClasses(){const n=this.getConfigs("global");return["engraving-view-container",n.layout.personalizationCardStyle,this.params.context]}engravingQuantityFee(){const n=this.params.identifier;if("cart"===this.params.context){const i=this.getStoreValue("cart.items."+n),r=(null==i?void 0:i.attributes.engraving.fee)||0,s=(null==i?void 0:i.quantity)||1;return{quantity:s,fee:r,total:r*s}}if("checkout"===this.params.context){const i=this.getStoreValue("checkout.items."+n),r=(null==i?void 0:i.attributes.engraving.fee)||0,s=(null==i?void 0:i.quantity)||1;return{quantity:s,fee:r,total:r*s}}return{quantity:0,fee:0,total:0}}engravingLines(){const n=this.params.identifier;if("cart"===this.params.context){const i=this.getStoreValue("cart.items."+n);return(null==i?void 0:i.attributes.engraving.lines)||[]}if("checkout"===this.params.context){const i=this.getStoreValue("checkout.items."+n);return(null==i?void 0:i.attributes.engraving.lines)||[]}return[]}handleEdit(){var n,i,r,s,a,l,d,u,f,g,v,b,x,w,E,T,A,P,_,N;const F=this.params.identifier,R={identifier:F,context:this.params.context,lines:[],maxLines:1,maxCharsPerLine:16,fee:0,location:""};if("cart"===this.params.context){const v=this.getStoreValue("cart.items."+F);R.lines=(null===(i=null===(n=null==v?void 0:v.attributes)||void 0===n?void 0:n.engraving)||void 0===i?void 0:i.lines)||[],R.maxLines=(null===(s=null===(r=null==v?void 0:v.attributes)||void 0===r?void 0:r.engraving)||void 0===s?void 0:s.maxLines)||1,R.maxCharsPerLine=(null===(l=null===(a=null==v?void 0:v.attributes)||void 0===a?void 0:a.engraving)||void 0===l?void 0:l.maxCharsPerLine)||16,R.fee=(null===(u=null===(d=null==v?void 0:v.attributes)||void 0===d?void 0:d.engraving)||void 0===u?void 0:u.fee)||0,R.location=(null===(g=null===(f=null==v?void 0:v.attributes)||void 0===f?void 0:f.engraving)||void 0===g?void 0:g.location)||""}if("checkout"===this.params.context){const n=this.getStoreValue("checkout.items."+F);R.lines=(null===(b=null===(v=null==n?void 0:n.attributes)||void 0===v?void 0:v.engraving)||void 0===b?void 0:b.lines)||[],R.maxLines=(null===(w=null===(x=null==n?void 0:n.attributes)||void 0===x?void 0:x.engraving)||void 0===w?void 0:w.maxLines)||1,R.maxCharsPerLine=(null===(T=null===(E=null==n?void 0:n.attributes)||void 0===E?void 0:E.engraving)||void 0===T?void 0:T.maxCharsPerLine)||16,R.fee=(null===(P=null===(A=null==n?void 0:n.attributes)||void 0===A?void 0:A.engraving)||void 0===P?void 0:P.fee)||0,R.location=(null===(N=null===(_=null==n?void 0:n.attributes)||void 0===_?void 0:_.engraving)||void 0===N?void 0:N.location)||""}this.commands.ui.openDrawer(C.ENGRAVING_FORM,R)}async handleRemove(){const n=this.params.identifier;"cart"===this.params.context&&await this.commands.cart.updateItemEngraving(n,[]),"checkout"===this.params.context&&await this.commands.checkout.removeItemEngraving(n)}template(){const n=this.engravingQuantityFee(),i=this.engravingLines();if(0===i.length)return"";const r=document.createElement("div");r.className="engraving-header";const s=document.createElement("h3");s.textContent="Personalization";const a=document.createElement("span");if(a.className="engraving-fee",1===n.quantity&&(a.textContent=formatCentToDollarText(n.total,![])),n.quantity>1){a.textContent=formatCentToDollarText(n.total,![]);const i=document.createElement("span");i.className="engraving-fee-each",i.textContent=" ("+formatCentToDollarText(n.fee,![])+" ea)",a.appendChild(i)}r.appendChild(s),r.appendChild(a);const l=document.createElement("div");l.className="engraving-body";const d=document.createElement("div");d.className="engraving-lines";for(const g of i){const n=document.createElement("span");n.className="engraving-line",n.textContent=g,d.appendChild(n)}const u=document.createElement("div");u.className="engraving-actions";const f=document.createElement("button");f.type="button",f.classList.add("remove-button"),f.textContent="Remove",f.setAttribute("aria-label","Remove engraving");const h=async()=>{await this.handleRemove()};if(f.addEventListener("click",h),f.addEventListener("keydown",async n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),await h())}),u.appendChild(f),"checkout"!==this.params.context){const n=document.createElement("button");n.type="button",n.classList.add("edit-button"),n.textContent="Edit",n.setAttribute("aria-label","Edit engraving"),n.addEventListener("click",this.handleEdit.bind(this)),n.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),this.handleEdit())}),u.appendChild(n)}return l.appendChild(d),l.appendChild(u),[r,l]}}class BirthdateInputComponent extends BaseComponent{constructor(){super(...arguments),this.validationTimeout=null}get hostClasses(){const n=this.getConfigs("global");return["custom-input","birthdate",n.layout.inputFieldStyle]}afterRender(){this.monthInput=this.container.querySelector('input[data-field="month"]'),this.dayInput=this.container.querySelector('input[data-field="day"]'),this.yearInput=this.container.querySelector('input[data-field="year"]'),this.errorContainer=this.container.querySelector("div.error-container"),this.setupEventListeners(),this.populateInitialValue()}populateInitialValue(){if(this.params.value){const n=this.params.value.split("-");3===n.length&&(this.yearInput.value=n[0],this.monthInput.value=n[1],this.dayInput.value=n[2])}}setupEventListeners(){this.monthInput.addEventListener("input",n=>{this.formatMonth(n),this.handleNavigation(n,this.dayInput),this.handleChange()}),this.dayInput.addEventListener("input",n=>{this.formatDay(n),this.handleNavigation(n,this.yearInput),this.handleChange()}),this.yearInput.addEventListener("input",n=>{this.formatYear(n),this.handleChange()}),this.monthInput.addEventListener("blur",()=>{this.padMonthOnBlur(),this.validateInput()}),this.dayInput.addEventListener("blur",()=>{this.padDayOnBlur(),this.validateInput()}),this.yearInput.addEventListener("blur",()=>{this.validateInput()});const n=[this.monthInput,this.dayInput,this.yearInput];for(const i of n)i.addEventListener("focus",()=>this.clearErrors());this.dayInput.addEventListener("keydown",n=>{"Backspace"===n.key&&""===this.dayInput.value&&0===this.dayInput.selectionStart&&(this.monthInput.focus(),this.monthInput.setSelectionRange(this.monthInput.value.length,this.monthInput.value.length))}),this.yearInput.addEventListener("keydown",n=>{"Backspace"===n.key&&""===this.yearInput.value&&0===this.yearInput.selectionStart&&(this.dayInput.focus(),this.dayInput.setSelectionRange(this.dayInput.value.length,this.dayInput.value.length))})}formatMonth(n){const i=n.target;let r=i.value.replace(/\D/g,"");if(r.length>2&&(r=r.substring(0,2)),1===r.length){const n=Number.parseInt(r,10);n>=2&&n<=9&&(r="0"+r)}else if(2===r.length){const n=Number.parseInt(r,10);n>12?r="12":n<1&&"00"!==r&&(r="01")}i.value=r}formatDay(n){const i=n.target;let r=i.value.replace(/\D/g,"");if(r.length>2&&(r=r.substring(0,2)),1===r.length){const n=Number.parseInt(r,10);n>=4&&n<=9&&(r="0"+r)}else if(2===r.length){const n=Number.parseInt(r,10);n>31?r="31":n<1&&"00"!==r&&(r="01")}i.value=r}formatYear(n){const i=n.target;let r=i.value.replace(/\D/g,"");r.length>4&&(r=r.substring(0,4)),i.value=r}padMonthOnBlur(){const n=this.monthInput.value;if(1===n.length){const i=Number.parseInt(n,10);if(i>=0&&i<=9&&(this.monthInput.value="0"+n,this.params.onChange)){const n=this.getFormattedValue();this.params.onChange(n)}}}padDayOnBlur(){const n=this.dayInput.value;if(1===n.length){const i=Number.parseInt(n,10);if(i>=0&&i<=9&&(this.dayInput.value="0"+n,this.params.onChange)){const n=this.getFormattedValue();this.params.onChange(n)}}}handleNavigation(n,i){const r=n.target,s=r===this.yearInput?4:2;r.value.length===s&&i&&i.focus()}handleChange(){if(this.clearErrors(),this.scheduleValidation(),this.params.onChange){const n=this.getFormattedValue();this.params.onChange(n)}}isFieldsComplete(){const n=this.monthInput.value,i=this.dayInput.value,r=this.yearInput.value;return 2===n.length&&2===i.length&&4===r.length}scheduleValidation(){if(null!==this.validationTimeout&&clearTimeout(this.validationTimeout),this.isFieldsComplete())return this.validateInput(),void 0;this.validationTimeout=setTimeout(()=>{this.validateInput(),this.validationTimeout=null},500)}getFormattedValue(){const n=this.monthInput.value.padStart(2,"0"),i=this.dayInput.value.padStart(2,"0"),r=this.yearInput.value;return n&&i&&r&&4===r.length?r+"-"+n+"-"+i:""}validateDate(n,i,r){if(!n||!i||!r||4!==r.length)return![];const s=Number.parseInt(n,10),a=Number.parseInt(i,10),l=Number.parseInt(r,10);if(s<1||s>12||a<1||a>31||l<1e3)return![];const d=new Date(l,s-1,a);return d.getFullYear()===l&&d.getMonth()===s-1&&d.getDate()===a}calculateAge(n){const i=new Date;let r=i.getFullYear()-n.getFullYear();const s=i.getMonth()-n.getMonth();return(s<0||0===s&&i.getDate()<n.getDate())&&r--,r}validateInput(){const n=this.monthInput.value,i=this.dayInput.value,r=this.yearInput.value,s=[],a=this.params.validation;if(!a)return this.showErrors([]),!![];const l=2===n.length&&2===i.length&&4===r.length,d=n||i||r;if(a.required&&!d)s.push("Please enter a complete date (MM/DD/YYYY)");else if(d&&!l)s.push("Please enter a complete date (MM/DD/YYYY)");else if(l)if(this.validateDate(n,i,r)){const l=Number.parseInt(n,10),d=Number.parseInt(i,10),u=Number.parseInt(r,10),f=new Date(u,l-1,d);if(void 0!==a.minYear&&u<a.minYear&&s.push("Year must be "+a.minYear+" or later"),void 0!==a.maxYear&&u>a.maxYear&&s.push("Year must be "+a.maxYear+" or earlier"),void 0!==a.minAge||void 0!==a.maxAge){const n=this.calculateAge(f);void 0!==a.minAge&&n<a.minAge&&s.push("Must be at least "+a.minAge+" years old"),void 0!==a.maxAge&&n>a.maxAge&&s.push("Must be no more than "+a.maxAge+" years old")}if(a.customValidator){const n=a.customValidator(this.getFormattedValue());n&&s.push(n)}}else s.push("Please enter a valid date");this.showErrors(s);const u=0===s.length;return this.params.onValidation&&this.params.onValidation(u,s),u}showErrors(n){this.errorContainer.innerHTML="";const i=[this.monthInput,this.dayInput,this.yearInput];if(n.length>0){this.errorContainer.classList.add("show");for(const n of i)n.classList.add("input-error");for(const i of n){const n=document.createElement("div");n.className="error-message",n.textContent=i,this.errorContainer.appendChild(n)}}else for(const r of i)r.classList.remove("input-error")}clearErrors(){const n=[this.monthInput,this.dayInput,this.yearInput],i=n.some(n=>n.classList.contains("input-error"));if(i){for(const i of n)i.classList.remove("input-error");this.errorContainer.innerHTML="",this.errorContainer.classList.remove("show")}}getValue(){return this.getFormattedValue()}setValue(n){if(n){const i=n.split("/");3===i.length&&(this.monthInput.value=i[0],this.dayInput.value=i[1],this.yearInput.value=i[2])}else this.monthInput.value="",this.dayInput.value="",this.yearInput.value=""}validate(){return this.validateInput()}focus(){this.monthInput.focus()}disable(){this.monthInput.disabled=!![],this.dayInput.disabled=!![],this.yearInput.disabled=!![]}enable(){this.monthInput.disabled=![],this.dayInput.disabled=![],this.yearInput.disabled=![]}clear(){this.setValue(""),this.clearErrors()}template(){var n;const i=[];if(this.params.label){const r=document.createElement("label");r.textContent=this.params.label,(null===(n=this.params.validation)||void 0===n?void 0:n.required)&&(r.textContent+="*"),r.setAttribute("for",this.params.name+"-month"),i.push(r)}const r=document.createElement("div");r.className="date-input-container";const s=document.createElement("input");s.type="text",s.placeholder="MM",s.name=this.params.name+"-month",s.id=this.params.name+"-month",s.maxLength=2,s.className="date-field month-field",s.setAttribute("data-field","month"),s.inputMode="numeric";const a=document.createElement("span");a.className="date-separator",a.textContent="/";const l=document.createElement("input");l.type="text",l.placeholder="DD",l.name=this.params.name+"-day",l.id=this.params.name+"-day",l.maxLength=2,l.className="date-field day-field",l.setAttribute("data-field","day"),l.inputMode="numeric";const d=document.createElement("span");d.className="date-separator",d.textContent="/";const u=document.createElement("input");u.type="text",u.placeholder="YYYY",u.name=this.params.name+"-year",u.id=this.params.name+"-year",u.maxLength=4,u.className="date-field year-field",u.setAttribute("data-field","year"),u.inputMode="numeric",this.params.disabled&&(s.disabled=!![],l.disabled=!![],u.disabled=!![]),this.params.className&&(r.className+=" "+this.params.className),r.appendChild(s),r.appendChild(a),r.appendChild(l),r.appendChild(d),r.appendChild(u);const f=document.createElement("div");return f.className="error-container",i.push(r),i.push(f),i}}class InputComponent extends BaseComponent{constructor(){super(...arguments),this.validationTimeout=null}get hostClasses(){const n=this.getConfigs("global");return["custom-input",n.layout.inputFieldStyle]}handlePhoneKeydown(n){if("Backspace"===n.key){const i=n.target,r=i.selectionStart||0,s=i.value;r>0&&/\D/.test(s[r-1])&&setTimeout(()=>{const n=Math.max(0,r-2);i.setSelectionRange(n,n)},0)}}formatPhoneNumber(n){const i=n.target;let r=i.value.replace(/\D/g,"");r.length>10&&(r=r.substring(0,10)),r.length>=6?r="("+r.substring(0,3)+") "+r.substring(3,6)+"-"+r.substring(6):r.length>=3&&(r="("+r.substring(0,3)+") "+r.substring(3)),i.value=r}formatDate(n){const i=n.target;let r=i.value.replace(/\D/g,"");r.length>8&&(r=r.substring(0,8)),r.length>=5?r=r.substring(0,2)+"/"+r.substring(2,4)+"/"+r.substring(4):r.length>=3&&(r=r.substring(0,2)+"/"+r.substring(2)),i.value=r}validateEmail(n){const i=/^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;return i.test(n)}validateTel(n){const i=/^\(\d{3}\) \d{3}-\d{4}$/;return i.test(n)}validateDate(n){const i=/^(0[1-9]|1[0-2])\/(0[1-9]|[12]\d|3[01])\/\d{4}$/;if(!i.test(n))return![];const[r,s,a]=n.split("/").map(Number),l=new Date(a,r-1,s);return l.getFullYear()===a&&l.getMonth()===r-1&&l.getDate()===s}isFieldComplete(){var n,i,r;const s=this.inputElement.value.trim();if(!s)return![];switch(this.params.inputType){case"tel":return this.validateTel(s);case"date":return this.validateDate(s);case"email":return s.includes("@")&&(null===(n=s.split("@")[1])||void 0===n?void 0:n.includes("."));case"number":return!Number.isNaN(Number.parseFloat(s));default:return(null===(i=this.params.validation)||void 0===i?void 0:i.max)&&s.length>=this.params.validation.max||(null===(r=this.params.validation)||void 0===r?void 0:r.min)&&s.length>=this.params.validation.min?!![]:s.length>=3}}validateInput(){const n=this.inputElement.value,i=[],r=this.params.validation;if(!r)return this.showErrors([]),!![];if(r.required&&!n.trim()&&i.push("This field is required"),!r.required&&!n.trim())return this.showErrors([]),!![];if(n.trim()){if("email"!==this.params.inputType||this.validateEmail(n)||i.push("Please enter a valid email address"),"tel"!==this.params.inputType||this.validateTel(n)||i.push("Please enter a valid phone number ((XXX) XXX-XXXX)"),"date"!==this.params.inputType||this.validateDate(n)||i.push("Please enter a valid date (MM/DD/YYYY)"),"number"===this.params.inputType){const s=Number.parseFloat(n);Number.isNaN(s)?n.trim()&&i.push("Please enter a valid number"):(void 0!==r.min&&s<r.min&&i.push("Value must be at least "+r.min),void 0!==r.max&&s>r.max&&i.push("Value must be no more than "+r.max))}if("text"!==this.params.inputType&&"email"!==this.params.inputType||(void 0!==r.min&&n.length<r.min&&i.push("Must be at least "+r.min+" characters"),void 0!==r.max&&n.length>r.max&&i.push("Must be no more than "+r.max+" characters")),r.pattern){const s=new RegExp(r.pattern);s.test(n)||i.push("Invalid format")}if(r.customValidator){const s=r.customValidator(n);s&&i.push(s)}}this.showErrors(i);const s=0===i.length;return this.params.onValidation&&this.params.onValidation(s,i),s}scheduleValidation(){if(null!==this.validationTimeout&&clearTimeout(this.validationTimeout),this.isFieldComplete())return this.validateInput(),void 0;this.validationTimeout=setTimeout(()=>{this.validateInput(),this.validationTimeout=null},500)}showErrors(n){if(this.errorContainer.innerHTML="",n.length>0){this.errorContainer.classList.add("show"),this.inputElement.classList.add("input-error");for(const i of n){const n=document.createElement("div");n.className="error-message",n.textContent=i,this.errorContainer.appendChild(n)}}else this.inputElement.classList.remove("input-error")}clearErrors(){this.inputElement.classList.contains("input-error")&&(this.inputElement.classList.remove("input-error"),this.errorContainer.innerHTML="",this.errorContainer.classList.remove("show"))}getValue(){return this.inputElement.value}setValue(n){this.inputElement.value=n,"tel"===this.params.inputType&&this.formatPhoneNumber({target:this.inputElement}),"date"===this.params.inputType&&this.formatDate({target:this.inputElement})}validate(){return this.validateInput()}focus(){this.inputElement.focus()}disable(){this.inputElement.disabled=!![]}enable(){this.inputElement.disabled=![]}template(){var n;const i=[];if(this.params.label){const r=document.createElement("label");r.textContent=this.params.label,(null===(n=this.params.validation)||void 0===n?void 0:n.required)&&(r.textContent+="*"),r.setAttribute("for",this.params.name),i.push(r)}return this.inputElement=document.createElement("input"),this.inputElement.type=this.params.inputType,this.inputElement.placeholder=this.params.placeholder||"",this.inputElement.name=this.params.name,this.inputElement.id=this.params.name,this.params.autocomplete&&(this.inputElement.autocomplete=this.params.autocomplete?"on":"off"),this.params.className&&(this.inputElement.className=this.params.className),this.params.hostClassName&&this.addHostClasses(this.params.hostClassName),this.params.disabled&&(this.inputElement.disabled=!![]),this.params.value&&(this.inputElement.value=this.params.value),this.params.validation&&(this.params.validation.required&&(this.inputElement.required=!![]),void 0!==this.params.validation.min&&(this.inputElement.min=this.params.validation.min.toString()),void 0!==this.params.validation.max&&(this.inputElement.max=this.params.validation.max.toString()),this.params.validation.pattern&&(this.inputElement.pattern=this.params.validation.pattern)),"tel"===this.params.inputType&&(this.inputElement.addEventListener("keydown",this.handlePhoneKeydown.bind(this)),this.inputElement.addEventListener("input",this.formatPhoneNumber.bind(this))),"date"===this.params.inputType&&this.inputElement.addEventListener("input",this.formatDate.bind(this)),this.inputElement.addEventListener("focusout",this.validateInput.bind(this)),this.inputElement.addEventListener("input",n=>{this.clearErrors(),this.scheduleValidation(),this.params.onChange&&this.params.onChange(n.target.value)}),this.errorContainer=document.createElement("div"),this.errorContainer.className="error-container",i.push(this.inputElement),i.push(this.errorContainer),i}}class LceElementComponent extends HTMLElement{constructor(){super(),this.N=![],this.q=null;const n=ClientConfigService.getInstance();this.j=this.attachShadow({mode:n.get("openShadowDom")?"open":"closed"})}initialize(n,i){if(this.N)return;if(!n||"string"!=typeof n)throw new SDKError("LceElementComponent: contentType must be a non-empty string");if(!(i&&i instanceof HTMLElement))throw new SDKError("LceElementComponent: contentElement must be a valid HTMLElement");if(this.setAttribute(n.toLowerCase(),""),!this.j)throw new SDKError("LceElementComponent: Shadow DOM container is not available");i&&"function"==typeof i.rerender&&(this.q=n=>{i.rerender(n||"LceElementRerender")}),this.j.appendChild(i),this.applyBasicStyles();const r=ThemeProviderService.getInstance(),s=r.getStylesheet(n);this.applyThemeStyles(s),this.N=!![],this.j=null}rerender(n){this.q&&this.q(n)}applyBasicStyles(){const n="\n :host {\n display: block;\n contain: layout style paint;\n isolation: isolate;\n width: 100%;\n height: auto;\n }\n\n :host([drawer]),\n :host([address]),\n :host([buttons-cart-open]) {\n contain: none;\n isolation: auto;\n }\n ";try{if(this.isCSSStyleSheetSupported()){const i=new CSSStyleSheet;i.replaceSync(n),this.j.adoptedStyleSheets=[i,...this.j.adoptedStyleSheets]}else this.createFallbackStylesheet(n)}catch(ut){this.createFallbackStylesheet(n)}}isCSSStyleSheetSupported(){try{if("undefined"==typeof CSSStyleSheet)return![];if("function"!=typeof CSSStyleSheet.prototype.replaceSync)return![];const n=new CSSStyleSheet;return n.replaceSync("/* test */"),!![]}catch(n){return![]}}applyThemeStyles(n){n.forEach(n=>{"string"==typeof n?this.createFallbackStylesheet(n):this.j.adoptedStyleSheets=[...this.j.adoptedStyleSheets,n]})}createFallbackStylesheet(n){const i=document.createElement("style");i.textContent=n,this.j&&this.j.appendChild(i)}}class PoweredByComponent extends BaseComponent{get hostClasses(){return["powered-by-container",this.params.context,this.getConfigs("global").layout.poweredByMode]}createPoweredBySection(){const n=document.createElement("div");n.className="pb-title-container";const i=document.createElement("span");i.className="pb-text",i.textContent="Powered by",n.appendChild(i);const r=document.createElement("span");r.className="pb-lc",r.textContent="LiquidCommerce",n.appendChild(r);const s=document.createElement("span");return s.className="pb-dot",s.textContent=".",n.appendChild(s),n}createDisclaimerSection(){const n=document.createElement("div");n.className="pb-disclaimer-container";const i=this.getDisclaimerConfig();return i.parts.forEach(i=>{"text"===i.type?n.appendChild(document.createTextNode(i.content)):"link"===i.type&&n.appendChild(this.createLink(i.href,i.text))}),n}getDisclaimerConfig(){return"checkout"===this.params.context?{parts:[{type:"text",content:"All orders are fulfilled by LiquidCommerce, which is owned and operated by ReserveBar Holdings Corp., an independent third party that facilitates transactions between customers and licensed retailers. By placing an order, you agree to "},{type:"link",href:"https://www.reservebar.com/privacy-policy.html",text:"LiquidCommerce's Privacy Policy"},{type:"text",content:" and "},{type:"link",href:"https://www.reservebar.com/terms-conditions",text:"Terms and Conditions of Sale"},{type:"text",content:"."}]}:{parts:[{type:"text",content:"LiquidCommerce is owned & operated by ReserveBar. See our "},{type:"link",href:"https://www.reservebar.com/privacy-policy.html",text:"Privacy Policy"},{type:"text",content:" and "},{type:"link",href:"https://www.reservebar.com/terms-conditions",text:"Terms & Conditions"},{type:"text",content:"."}]}}createLink(n,i){const r=document.createElement("a");return r.href=n,r.target="_blank",r.rel="noopener noreferrer",r.className="pb-link",r.textContent=i,r.setAttribute("role","link"),r.setAttribute("aria-label","Read "+i),r}template(){const n=this.createPoweredBySection(),i=this.createDisclaimerSection();return[n,i]}}class PromoCodeTickerComponent extends BaseComponent{constructor(){super(...arguments),this.applyButton=null,this.promoCodeApplied=![],this.currentActiveTicker=null}get hostClasses(){return["promo-ticker",this.params.context]}beforeSetupStoreWatchers(){this.reactiveOptions.watchOnlyStorePaths=["cart.promoCode","checkout.promoCode"]}onStoreWatch(n){const i=n.find(n=>"cart.promoCode"===n.path||"checkout.promoCode"===n.path);if(!i||!this.applyButton||!this.currentActiveTicker)return;const r=this.isPromoCodeApplied(this.currentActiveTicker.promoCode);r&&!this.promoCodeApplied?(this.applyButton.disabled=!![],this.applyButton.textContent="APPLIED",this.promoCodeApplied=!![]):!r&&this.promoCodeApplied&&(this.applyButton.disabled=![],this.applyButton.textContent="APPLY",this.promoCodeApplied=![])}isPromoCodeApplied(n){const i=this.store.get("cart.promoCode"),r=this.store.get("checkout.promoCode");return(null==i?void 0:i.code)===n||(null==r?void 0:r.code)===n}getActiveTickers(){var n;const i=this.store.get("address");return null===(n=this.params.tickers)||void 0===n?void 0:n.filter(n=>{var r;return isDateTimeInRange({startDate:n.activeFrom,endDate:n.activeUntil,addressState:null===(r=null==i?void 0:i.address)||void 0===r?void 0:r.state})})}selectCurrentTicker(n){return 0===n.length?null:n[0]}generateTextContent(n){const i=document.createElement("div");i.classList.add("promo-ticker__text-group");const r=n.text.map(n=>n.trim()).map(n=>n.substring(0,50)).filter(n=>""!==n.trim()).slice(0,5);for(const s of r){const r=s.trim();if(!r)continue;const a=document.createElement("span");a.classList.add("promo-ticker__text-item"),a.textContent=r,i.appendChild(a);const l=document.createElement("span");l.classList.add("promo-ticker__separator"),l.textContent=n.separator,i.appendChild(l)}return i}async handlePromoClick(){var n;(null===(n=this.currentActiveTicker)||void 0===n?void 0:n.promoCode)&&("cart"===this.params.context&&await this.commands.cart.applyPromoCode(this.currentActiveTicker.promoCode),"checkout"===this.params.context&&await this.commands.checkout.applyPromoCode(this.currentActiveTicker.promoCode))}template(){const n=this.getActiveTickers();if(this.currentActiveTicker=this.selectCurrentTicker(n),!this.currentActiveTicker)return[];this.promoCodeApplied=this.isPromoCodeApplied(this.currentActiveTicker.promoCode);const i=document.createElement("div");i.classList.add("promo-ticker__content");const r=document.createElement("div");r.classList.add("promo-ticker__track");for(let a=0;a<5;a++)r.appendChild(this.generateTextContent(this.currentActiveTicker));i.appendChild(r);const s=document.createElement("button");return s.type="button",s.classList.add("promo-ticker__cta"),s.textContent="APPLY",s.setAttribute("aria-label","Apply promo code"),this.promoCodeApplied&&(s.disabled=!![],s.textContent="APPLIED"),s.addEventListener("click",()=>this.handlePromoClick()),s.addEventListener("keydown",n=>{"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),this.handlePromoClick())}),this.applyButton=s,[i,s]}}const zt=LoggerFactory.get("ElementsClientHelper"),isObject=n=>null!==n&&"object"==typeof n&&!Array.isArray(n),getType=n=>null===n?"null":Array.isArray(n)?"array":typeof n;function deepMergeConfigs(n,i){if(!n||!i)return n;const r={...n},s=[];for(const a in i){const l=i[a],d=r[a];if(!(a in n)){s.push('Property "'+a+'" does not exist in target schema, skipping merge.');continue}const u=getType(l),f=getType(d);u===f?isObject(l)&&isObject(d)?r[a]=deepMergeConfigs(d,l):r[a]=l:s.push('Type mismatch for key "'+a+'": source is '+u+", target is "+f+". Skipping merge.")}return s.length>0&&zt.warn("Merging configurations with warnings:",s),r}const Mt=new Map([["global.layout.enablePersonalization",[C.PRODUCT,C.CART,C.CHECKOUT,C.ENGRAVING_FORM,C.ENGRAVING_VIEW,C.PRODUCT_INTERACTIONS,C.CART_ITEM,C.CHECKOUT_ITEM]],["global.layout.personalizationText",[C.PRODUCT,C.CART,C.CHECKOUT,C.ENGRAVING_FORM,C.ENGRAVING_VIEW,C.CART_ITEM]],["global.layout.personalizationCardStyle",[C.PRODUCT,C.CART,C.CHECKOUT,C.ENGRAVING_FORM,C.ENGRAVING_VIEW]],["global.layout.allowPromoCodes",[C.CART,C.CART_PROMO_CODE,C.CART_FOOTER,C.CHECKOUT_ORDER_SUMMARY,C.CHECKOUT_PC_GC]],["global.layout.inputFieldStyle",[C.CART,C.CHECKOUT,C.ADDRESS,C.INPUT,C.BIRTHDATE_INPUT,C.ADDRESS_INPUT,C.CHECKOUT_DELIVER_TO,C.CHECKOUT_BUYER,C.CHECKOUT_BILLING,C.CHECKOUT_PAYMENT,C.CART_PROMO_CODE]],["global.layout.showPoweredBy",[C.CART,C.CHECKOUT,C.CHECKOUT_COMPLETED,C.POWERED_BY,C.CART_FOOTER,C.CHECKOUT_ORDER_SUMMARY,C.CHECKOUT_PRESALE_EXPIRED]],["global.layout.poweredByMode",[C.POWERED_BY]],["product.layout.showImages",[C.PRODUCT,C.PRODUCT_IMAGE_CAROUSEL]],["product.layout.showTitle",[C.PRODUCT]],["product.layout.showDescription",[C.PRODUCT,C.PRODUCT_DESCRIPTION,C.PRODUCT_INTERACTIONS]],["product.layout.showQuantityCounter",[C.PRODUCT,C.PRODUCT_ADD_TO_CART_SECTION]],["product.layout.showOffHours",[C.PRODUCT,C.PRODUCT_RETAILERS,C.PRODUCT_RETAILERS_CAROUSEL,C.PRODUCT_RETAILERS_POPUP,C.PRODUCT_RETAILERS_POPUP_LIST]],["product.layout.quantityCounterStyle",[C.PRODUCT,C.PRODUCT_ADD_TO_CART_SECTION]],["product.layout.fulfillmentDisplay",[C.PRODUCT,C.PRODUCT_IMAGE_CAROUSEL,C.PRODUCT_RETAILERS]],["product.layout.enableShippingFulfillment",[C.PRODUCT,C.PRODUCT_RETAILERS,C.PRODUCT_RETAILERS_CAROUSEL,C.PRODUCT_RETAILERS_POPUP,C.PRODUCT_RETAILERS_POPUP_LIST]],["product.layout.enableOnDemandFulfillment",[C.PRODUCT,C.PRODUCT_RETAILERS,C.PRODUCT_RETAILERS_CAROUSEL,C.PRODUCT_RETAILERS_POPUP,C.PRODUCT_RETAILERS_POPUP_LIST]],["product.layout.addToCartButtonText",[C.PRODUCT,C.PRODUCT_ADD_TO_CART_SECTION,C.ENGRAVING_FORM]],["product.layout.addToCartButtonShowTotalPrice",[C.PRODUCT,C.PRODUCT_ADD_TO_CART_SECTION,C.ENGRAVING_FORM]],["product.layout.buyNowButtonText",[C.PRODUCT,C.PRODUCT_OPTIONS]],["product.layout.preSaleButtonText",[C.PRODUCT,C.PRODUCT_ADD_TO_CART_SECTION]],["cart.layout.showQuantityCounter",[C.CART,C.CART_ITEM_QUANTITY_PRICE]],["cart.layout.quantityCounterStyle",[C.CART,C.CART_ITEM_QUANTITY_PRICE]],["cart.layout.drawerHeaderText",[C.CART,C.CART_HEADER]],["cart.layout.goToCheckoutButtonText",[C.CART,C.CART_FOOTER]],["checkout.layout.emailOptIn",[C.CHECKOUT,C.CHECKOUT_ORDER_SUMMARY]],["checkout.layout.smsOptIn",[C.CHECKOUT,C.CHECKOUT_ORDER_SUMMARY]],["checkout.layout.allowGiftCards",[C.CHECKOUT,C.CHECKOUT_GIFT_CARDS,C.CHECKOUT_ORDER_SUMMARY,C.CHECKOUT_PC_GC]],["checkout.layout.legalMessage",[C.CHECKOUT,C.CHECKOUT_ORDER_SUMMARY,C.CHECKOUT_COMPLETED]],["checkout.layout.exitUrl",[C.CHECKOUT,C.CHECKOUT_COMPLETED]],["checkout.layout.thankYouButtonText",[C.CHECKOUT,C.CHECKOUT_COMPLETED]],["checkout.layout.drawerHeaderText",[C.CHECKOUT,C.CHECKOUT_HEADER]],["checkout.layout.placeOrderButtonText",[C.CHECKOUT,C.CHECKOUT_PLACE_ORDER_BUTTON]],["checkout.layout.checkoutCompleted",[C.CHECKOUT_COMPLETED]]]);function getComponentTypesForLayoutFields(n,i){const r=new Set;for(const s of Object.keys(i)){const i=Mt.get(n+"."+s);if(i)for(const n of i)r.add(n)}return Array.from(r)}class ElementsBaseClient{constructor(n){this.clientPrepared=![],this.componentFactoryInitialized=![],this.cartDrawerCreated=![],this.injectedComponents=new Map,this.clientConfig=ClientConfigService.getInstance(),this.store=StoreService.getInstance(),this.commands=CommandService.getInstance(),this.apiClient=ApiClientService.getInstance(),this.themeProvider=ThemeProviderService.getInstance(),this.fingerPrintService=FingerPrintService.getInstance(),this.googleTagManager=GoogleTagManagerService.getInstance(),this.clientAction=ClientActionService.getInstance(),this.telemetry=TelemetryService.getInstance(),this.debugPanel=DebugPanelService.getInstance(),this.logger=LoggerFactory.get("Client"),this.authClient=AuthClientService.getInstance({apiKey:n.apiKey,env:n.env,baseUrl:n.baseUrl})}async prepare(){try{if(this.clientPrepared)return;await this.prepareEssentialServices(),this.deferHeavyInitialization(),this.clientPrepared=!![],this.clientConfig.set("clientPrepared",!![])}catch(n){throw this.logger.error("Failed to prepare client",n),this.clientPrepared=![],this.clientConfig.set("clientPrepared",![]),n}}async prepareEssentialServices(){this.clientConfig.set("version",ut.version),this.clientConfig.isProduction()?LoggerFactory.setEnableLogging(![]):this.clientConfig.isDebuggingEnabled()&&(LoggerFactory.setEnableLogging(!![]),this.logger.info("🐞 Debugging mode is enabled"),this.clientConfig.isDebugPanelEnabled()&&(this.debugPanel.initialize(),this.logger.info("🔧 Debug panel initialized"))),this.telemetry.isEnabled()&&(LoggerFactory.setTelemetryService(this.telemetry),this.logger.info("📊 Telemetry initialized")),this.logger.info("🔐 Starting authentication...");const n=await this.authClient.authenticate();if(!n)throw this.clientPrepared=![],new SDKError("Authentication failed. Please try again.",!![]);this.logger.info("✅ Authentication completed"),this.logger.info("🌐 Setting up API client..."),await this.apiClient.setClient(this.authClient),this.logger.info("✅ API client setup completed"),this.logger.info("⚙️ Loading configurations...");let i=await this.apiClient.getAllConfigs();this.logger.info("✅ Configurations loaded"),this.clientConfig.set("partnerCode",i.configurations.partnerCode),this.clientConfig.set("partnerName",i.configurations.partnerName),this.logger.info("🔍 Setting up fingerprinting and store...");const r=await this.fingerPrintService.getId(i.configurations.partnerCode),s=this.fingerPrintService.isLocalStorageWebApiAvailable();this.clientConfig.set("userDeviceId",r),this.clientConfig.set("isLocalStorageAvailable",s);const a=s?null:await this.apiClient.getPersistedStore(r);if(await this.store.initialize({userDeviceId:r,isLocalStorageAvailable:s,persistedStore:a}),this.logger.info("✅ Store setup completed"),this.logger.info("🎨 Initializing theme provider..."),this.clientConfig.hasCustomTheme()){const n=this.clientConfig.get("customTheme"),r=i.global.layout.showPoweredBy;i=deepMergeConfigs(i,n),i.global.layout.showPoweredBy=r}await this.themeProvider.initialize(i),this.logger.info("✅ Theme provider initialized"),this.logger.info("📦 Registering essential components..."),this.registerEssentialComponents(),this.logger.info("✅ Essential components registered"),this.logger.info("🎯 Essential services preparation completed")}deferHeavyInitialization(){setTimeout(async()=>{try{await this.initializeHeavyServices()}catch(n){this.logger.error("Heavy initialization failed",n)}},0)}async initializeHeavyServices(){const n=this.themeProvider.getConfigs("configurations");await this.googleTagManager.initialize({partnerName:n.partnerName,partnerGtmId:n.googleTagManagerId,partnerEnableGaTracking:n.enablePartnerGaTracking,liquidCommerceEnableGaTracking:n.enableLiquidCommerceGaTracking,liquidCommerceGtmId:n.liquidCommerceGoogleTagManagerId}),this.isElementsEnabled()&&await this.commands.common.loadCart(),this.ensureCartDrawerExists(),this.ensureAllComponentsRegistered()}get actions(){return this.clientAction.actions}async processInjectElement(n){if(this.ensureAllComponentsRegistered(),!n||"object"!=typeof n)throw new SDKError("Invalid parameters provided. Expected an object, received: "+typeof n,!![]);const{type:i,containerId:r,...s}=n;if(!r||"string"!=typeof r)throw new SDKError("Container ID is required and must be a string. Received: "+("string"==typeof r?'"'+r+'"':r),!![]);if(!i)throw new SDKError("Component type is required (e.g., product, cart, checkout).",!![]);const a=r.replace("#",""),l=document.getElementById(a);if(!l)return console.warn("Container with ID '"+a+"' not found"),null;l.innerHTML="";const d={type:n.type,useShadowDom:!![],isIndependentComponent:!![],wrapInLceElement:!![],...s},u=ComponentFactoryService.createElement(d);return safeReplaceChildren(l,u),n.type===C.CHECKOUT&&await this.commands.checkout.loadCheckout(),this.createInjectedComponentWrapper(a,n.type,u)}async processInjectProduct(n){if(this.ensureAllComponentsRegistered(),0===n.length)throw new SDKError("At least one product is required. Received empty array.",!![]);n.length>20&&this.logger.warn("You can only inject up to 20 products at a time, limiting to 20 products");const i=n.slice(0,20),r=[],s=[];for(const a of i){if(!a||"object"!=typeof a){this.logger.warn("Invalid product parameter: must be an object");continue}if(!a.containerId||"string"!=typeof a.containerId){this.logger.warn("Container ID is required and must be a string for product with ID '"+a.identifier+"'");continue}const n=a.containerId.replace("#","").trim();if(!n){this.logger.warn("Container ID is required for product with ID '"+a.identifier+"'");continue}const i=document.getElementById(n);if(!i){this.logger.warn("Container with ID '"+n+"' not found for product '"+a.identifier+"'");continue}const s=r.every(i=>i.containerId!==n);if(!s){this.logger.warn("Duplicate container ID '"+n+"' found, skipping");continue}if(!a.identifier||"string"!=typeof a.identifier){this.logger.warn("Product identifier is required and must be a string for container ID '"+n+"'");continue}const l=r.every(n=>n.identifier!==a.identifier);l?r.push({containerId:n,identifier:a.identifier}):this.logger.warn("Duplicate product identifier '"+a.identifier+"' found, skipping")}for(const a of r){const n=ComponentFactoryService.createElement({type:C.PRODUCT,useShadowDom:!![],productId:a.identifier,isIndependentComponent:!![],wrapInLceElement:!![]}),i=document.getElementById(a.containerId);i?(i.innerHTML="",i.appendChild(n),s.push(this.createInjectedComponentWrapper(a.containerId,C.PRODUCT,n)),await this.commands.product.createProductInstance(a.identifier,!![])):this.logger.warn("Product ("+a.identifier+") container with ID '"+a.containerId+"' not found")}return await this.commands.product.loadMultipleProducts(r.map(n=>n.identifier)),s}async injectProductList(n){if(!this.isElementsEnabled())return this.injectDisabledElementsError(n.containerId,C.CHECKOUT),void 0;if(!n)throw new SDKError("Product list requires a container ID parameter.",!![]);if(!n.containerId||"string"!=typeof n.containerId)throw new SDKError("Product list container ID is required and must be a string. Received: "+("string"==typeof n.containerId?'"'+n.containerId+'"':n.containerId),!![]);if(n.rows&&("number"!=typeof n.rows||n.rows<1||n.rows>10))throw new SDKError("Rows must be a number between 1 and 10. Received: "+n.rows,!![]);if(n.columns&&("number"!=typeof n.columns||n.columns<1||n.columns>4))throw new SDKError("Columns must be a number between 1 and 4. Received: "+n.columns,!![]);if(n.cardVariant&&!Object.values(P).includes(n.cardVariant))throw new SDKError('Invalid card variant "'+n.cardVariant+'". Valid options: '+Object.values(P).join(", "),!![]);if(n.filters&&!Array.isArray(n.filters))throw new SDKError("Filters must be an array. Received: "+typeof n.filters,!![]);if(n.filters&&n.filters.length>0){const i=Object.values(_);for(const r of n.filters)if(!i.includes(r))throw new SDKError('Invalid filter "'+r+'". Valid options: '+i.join(", "),!![])}if(n.productUrl&&"string"==typeof n.productUrl&&!n.productUrl.includes("{upc}")&&!n.productUrl.includes("{grouping}"))throw new SDKError('Product URL must include either {upc} or {grouping} placeholder. Received: "'+n.productUrl+'"',!![]);const i=document.getElementById(n.containerId.replace("#",""));if(!i)throw new SDKError('Cannot find element with ID "'+n.containerId+'". Make sure the element exists before adding the product list.',!![]);const r=ComponentFactoryService.createElement({type:C.PRODUCT_LIST,wrapInLceElement:!![],cardVariant:n.cardVariant||P.STANDARD,fillCard:n.fillCard||![],rows:n.rows||4,columns:n.columns||4,filters:n.filters||[],productUrl:n.productUrl});safeReplaceChildren(i,r)}ensureCartDrawerExists(){if(!this.cartDrawerCreated)try{const n=ComponentFactoryService.createElement({type:C.DRAWER,useShadowDom:!![],isIndependentComponent:!![],wrapInLceElement:!![]});document.body.appendChild(n),this.cartDrawerCreated=!![]}catch(n){this.logger.warn("Failed to create cart drawer:",n)}}ensureAllComponentsRegistered(){this.componentFactoryInitialized||(this.registerComponents(),this.componentFactoryInitialized=!![])}createInjectedComponentWrapper(n,i,r){const s={getType:()=>i,getElement:()=>document.getElementById(n),rerender:()=>{try{r&&"function"==typeof r.rerender?r.rerender("InjectedComponentRerender"):this.logger.warn("Component in container '"+n+"' does not support rerender")}catch(i){this.logger.warn("Failed to rerender component in container '"+n+"'")}}};return this.injectedComponents.set(n,s),s}rerenderInjectedComponentsByType(n){for(const[i,r]of this.injectedComponents)r.getType()===n&&r.rerender()}isElementsEnabled(){var n;try{const i=this.themeProvider.getConfigs("configurations");return null!==(n=null==i?void 0:i.isElementsEnabled)&&void 0!==n?n:![]}catch(i){return this.logger.warn("Could not check elements enabled status, defaulting to not enabled",i),!![]}}injectDisabledElementsError(n,i){const r=document.getElementById(n.replace("#",""));if(!r)return this.logger.warn("Container with ID '"+n+"' not found for disabled elements error"),void 0;let s;s=this.clientConfig.isProduction()?productionComponentError({title:"Element Unavailable",message:"We're sorry, this element is currently unavailable.",componentType:i}):componentError({message:"Elements is not enabled.",componentType:i}),r.innerHTML="",safeReplaceChildren(r,s)}registerEssentialComponents(){ComponentFactoryService.registerComponent(C.LCE_ELEMENT,LceElementComponent),ComponentFactoryService.registerComponent(C.DRAWER,DrawerComponent),ComponentFactoryService.registerComponent(C.BUTTONS_CART_OPEN,ButtonsOpenCartComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LOADING,ProductLoadingComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST_CARD_LOADING,ProductListCardLoadingComponent),ComponentFactoryService.registerComponent(C.CART,AddressInputComponent),ComponentFactoryService.registerComponent(C.ADDRESS_INPUT,AddressInputComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST,ProductListComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST_CARD,ProductListCardComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST_FILTERS,ProductListFiltersComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST_SEARCH,ProductListSearchComponent)}registerComponents(){this.componentFactoryInitialized||this.registerAllComponents()}registerAllComponents(){ComponentFactoryService.registerComponent(C.DRAWER,DrawerComponent),ComponentFactoryService.registerComponent(C.INPUT,InputComponent),ComponentFactoryService.registerComponent(C.BIRTHDATE_INPUT,BirthdateInputComponent),ComponentFactoryService.registerComponent(C.ENGRAVING_FORM,EngravingFormComponent),ComponentFactoryService.registerComponent(C.ENGRAVING_VIEW,EngravingViewComponent),ComponentFactoryService.registerComponent(C.BUTTONS_CART_OPEN,ButtonsOpenCartComponent),ComponentFactoryService.registerComponent(C.POWERED_BY,PoweredByComponent),ComponentFactoryService.registerComponent(C.LCE_ELEMENT,LceElementComponent),ComponentFactoryService.registerComponent(C.PURCHASE_MIN_ALERT,PurchaseMinAlertComponent),ComponentFactoryService.registerComponent(C.ALERT,AlertComponent),ComponentFactoryService.registerComponent(C.PROMO_CODE_TICKER,PromoCodeTickerComponent),ComponentFactoryService.registerComponent(C.ADDRESS,AddressComponent),ComponentFactoryService.registerComponent(C.ADDRESS_INPUT,AddressInputComponent),ComponentFactoryService.registerComponent(C.ADDRESS_DISPLAY,AddressDisplayComponent),ComponentFactoryService.registerComponent(C.PRODUCT,ProductComponent),ComponentFactoryService.registerComponent(C.PRODUCT_IMAGE_CAROUSEL,ProductImageCarouselComponent),ComponentFactoryService.registerComponent(C.PRODUCT_OPTIONS,ProductOptionsComponent),ComponentFactoryService.registerComponent(C.PRODUCT_DESCRIPTION,ProductDescriptionComponent),ComponentFactoryService.registerComponent(C.PRODUCT_INTERACTIONS,ProductInteractionsComponent),ComponentFactoryService.registerComponent(C.PRODUCT_ADD_TO_CART_SECTION,ProductAddToCartSectionComponent),ComponentFactoryService.registerComponent(C.PRODUCT_RETAILERS,ProductRetailersComponent),ComponentFactoryService.registerComponent(C.PRODUCT_RETAILERS_CAROUSEL,ProductRetailersCarouselComponent),ComponentFactoryService.registerComponent(C.PRODUCT_RETAILERS_POPUP,ProductRetailersPopupComponent),ComponentFactoryService.registerComponent(C.PRODUCT_RETAILERS_POPUP_LIST,ProductRetailersPopupListComponent),ComponentFactoryService.registerComponent(C.PRODUCT_PRICE,ProductPriceComponent),ComponentFactoryService.registerComponent(C.PRODUCT_DRAWER,ProductDrawerComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LOADING,ProductLoadingComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST,ProductListComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST_CARD,ProductListCardComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST_FILTERS,ProductListFiltersComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST_CARD_LOADING,ProductListCardLoadingComponent),ComponentFactoryService.registerComponent(C.PRODUCT_LIST_SEARCH,ProductListSearchComponent),ComponentFactoryService.registerComponent(C.CART,CartComponent),ComponentFactoryService.registerComponent(C.CART_RETAILER,CartRetailerComponent),ComponentFactoryService.registerComponent(C.CART_ITEM,CartItemComponent),ComponentFactoryService.registerComponent(C.CART_FOOTER,CartFooterComponent),ComponentFactoryService.registerComponent(C.CART_ITEM_QUANTITY_PRICE,CartItemQuantityPriceComponent),ComponentFactoryService.registerComponent(C.CART_RETAILER_SUBTOTAL,CartRetailerSubtotalComponent),ComponentFactoryService.registerComponent(C.CART_PROMO_CODE,CartPromoCodeComponent),ComponentFactoryService.registerComponent(C.CART_HEADER,CartHeaderComponent),ComponentFactoryService.registerComponent(C.CART_BODY,CartBodyComponent),ComponentFactoryService.registerComponent(C.CART_FULFILLMENT,CartFulfillmentComponent),ComponentFactoryService.registerComponent(C.CHECKOUT,CheckoutComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_INFORMATION,CheckoutInformationComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_PAYMENT,CheckoutPaymentComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_PAYMENT_SUMMARY,CheckoutPaymentSummaryComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_STRIPE_HANDLER,CheckoutStripeHandlerComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_STRIPE_FORM,CheckoutStripeFormComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_BILLING,CheckoutBillingComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_ORDER_SUMMARY,CheckoutOrderSummaryComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_PROMO_CODE,CheckoutPromoCodeComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_GIFT_CARDS,CheckoutGiftCardsComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_AMOUNTS,CheckoutAmountsComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_ITEMS,CheckoutItemsComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_COMPLETED,CheckoutCompletedComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_DELIVER_TO,CheckoutDeliverToComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_DELIVER_TO_SUMMARY,CheckoutDeliverToSummaryComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_BUYER,CheckoutBuyer),ComponentFactoryService.registerComponent(C.CHECKOUT_BUYER_SUMMARY,CheckoutBuyerSummaryComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_TIPS,CheckoutTipsComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_PC_GC,CheckoutPcGcComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_ITEM,CheckoutItemComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_ITEM_QUANTITY,CheckoutItemQuantityComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_PLACE_ORDER_BUTTON,CheckoutPlaceOrderButtonComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_HEADER,CheckoutHeaderComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_PRESALE_COUNTDOWN,CheckoutPresaleCountdownComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_PRESALE_EXPIRED,CheckoutPresaleExpiredComponent),ComponentFactoryService.registerComponent(C.CHECKOUT_SEND_AS_GIFT,CheckoutSendAsGiftComponent)}}class ElementsClient extends ElementsBaseClient{constructor(){super(...arguments),this.ui={cartButton:(n,i)=>{if(!n||"string"!=typeof n)throw new SDKError("Cart button requires a valid container ID. Received: "+("string"==typeof n?'"'+n+'"':n),!![]);this.ensureCartDrawerExists();const r=document.getElementById(n.replace("#",""));if(!r)throw new SDKError('Cannot find element with ID "'+n+'". Make sure the element exists before adding the cart button.',!![]);const s=ComponentFactoryService.createElement({type:C.BUTTONS_CART_OPEN,useShadowDom:!![],isIndependentComponent:!![],wrapInLceElement:!![],showItemsCount:i});r.innerHTML="",safeReplaceChildren(r,s)},floatingCartButton:n=>{this.ensureCartDrawerExists();const i=ComponentFactoryService.createElement({type:C.BUTTONS_CART_OPEN,useShadowDom:!![],isIndependentComponent:!![],wrapInLceElement:!![],classes:["independent"],showItemsCount:n});document.body.appendChild(i)},cartSubtotal:n=>{if(!n||"string"!=typeof n)throw new SDKError("Cart subtotal display requires a valid element ID. Received: "+("string"==typeof n?'"'+n+'"':n),!![]);const i=document.getElementById(n.replace("#",""));if(!i)throw new SDKError('Cannot find element with ID "'+n+'". Make sure the element exists before displaying cart subtotal.',!![]);i.innerHTML="",i.classList.add("lce-cart-subtotal");const t=n=>{i.textContent=formatCentToDollarText(n)},r=this.store.get("cart.totals.subtotal")||0;t(r),this.store.watch("cart.totals",()=>{const n=this.store.get("cart.totals.subtotal")||0;t(n)})},cartItemsCount:(n,i)=>{if(!n||"string"!=typeof n)throw new SDKError("Cart items count display requires a valid element ID. Received: "+("string"==typeof n?'"'+n+'"':n),!![]);let r=!![];i&&"boolean"==typeof i.hideZero&&(r=i.hideZero);const s=document.getElementById(n.replace("#",""));if(!s)throw new SDKError('Cannot find element with ID "'+n+'". Make sure the element exists before displaying cart items count.',!![]);s.innerHTML="",s.classList.add("lce-cart-items-count");const y=n=>{s.textContent=n.toString(),0===n?(r&&(s.style.visibility="hidden"),s.classList.add("no-items")):(r&&(s.style.visibility="visible"),s.classList.remove("no-items"))},a=this.store.get("cart.totals.quantity")||0;y(a),this.store.watch("cart.totals",()=>{const n=this.store.get("cart.totals.quantity")||0;y(n)})}}}async injectProductElement(n){if(!Array.isArray(n))throw new SDKError("Product injection requires an array of product parameters. Received: "+typeof n,!![]);if(!this.isElementsEnabled()){for(const i of n)this.injectDisabledElementsError(i.containerId,C.PRODUCT);return[]}return await this.processInjectProduct(n)}async injectAddressElement(n,i){if(!n||"string"!=typeof n)throw new SDKError("Address element requires a valid container ID. Received: "+("string"==typeof n?'"'+n+'"':n),!![]);return this.isElementsEnabled()?await this.processInjectElement({type:C.ADDRESS,containerId:n,options:i}):(this.injectDisabledElementsError(n,C.ADDRESS),null)}async injectCartElement(n){if(!n||"string"!=typeof n)throw new SDKError("Cart element requires a valid container ID. Received: "+("string"==typeof n?'"'+n+'"':n),!![]);return this.isElementsEnabled()?await this.processInjectElement({type:C.CART,containerId:n}):(this.injectDisabledElementsError(n,C.CART),null)}async injectCheckoutElement(n){if(!n||"string"!=typeof n)throw new SDKError("Checkout element requires a valid container ID. Received: "+("string"==typeof n?'"'+n+'"':n),!![]);return this.isElementsEnabled()?await this.processInjectElement({type:C.CHECKOUT,containerId:n}):(this.injectDisabledElementsError(n,C.CHECKOUT),null)}getInjectedComponents(){return this.injectedComponents}}async function Elements(n,i){try{SingletonManager.setContext({isBuilder:![]});const r=ClientConfigService.getInstance();r.initialize(n,{env:i.env,isBuilder:![],debugMode:i.debugMode,customTheme:i.customTheme,promoTicker:i.promoTicker,proxy:i.proxy,development:i.development});const s=r.getConfigs();SingletonManager.setClientConstructor(ElementsClient);const a=await SingletonManager.getClient(s);if(!a.clientPrepared)throw new SDKError("Failed to initialize. Check console for authentication or configuration errors.",!![]);const l={injectProductElement:a.injectProductElement.bind(a),injectAddressElement:a.injectAddressElement.bind(a),injectCartElement:a.injectCartElement.bind(a),injectCheckoutElement:a.injectCheckoutElement.bind(a),injectProductList:a.injectProductList.bind(a),ui:a.ui,actions:a.actions,getInjectedComponents:a.getInjectedComponents.bind(a)};window.elements=l;const d=PubSubService.getInstance();return d.publishAction(x.CLIENT_READY,{isReady:!![],message:"Elements Client Is Ready",timestamp:Date.now(),version:r.get("version")}),l}catch(r){try{const n=LoggerFactory.get("ElementsClientInit");n.error("Elements Client Initialization failed",r)}catch(s){console.error("[LiquidCommerce Elements] Client initialization failed:",null==r?void 0:r.message)}try{const n=ClientConfigService.getInstance(),i=PubSubService.getInstance();i.publishAction(x.CLIENT_READY,{isReady:![],message:"Initialization failed: "+(null==r?void 0:r.message),timestamp:Date.now(),version:n.get("version")||"unknown"})}catch(a){console.warn("[LiquidCommerce Elements] Could not fire error event - services unavailable")}return null}}const Bt={CORE:{MAIN_SCRIPT:"data-liquid-commerce-elements",TOKEN:"data-token",ENV:"data-env",DEBUG_MODE:"data-debug-mode"},PROMO_TICKER:{CODE:"data-promo-code",TEXT:"data-promo-text",SEPARATOR:"data-promo-separator",ACTIVE_FROM:"data-promo-active-from",ACTIVE_UNTIL:"data-promo-active-until",CODE_PARAM:"data-promo-code-param"},PRODUCT:{PRODUCT:"data-product",CONTAINER:"data-container",PARAM:"data-product-param",FULFILLMENT_TYPE_PARAM:"data-product-fulfillment-type-param",LCE_PRODUCT:"data-lce-product"},PRODUCT_LIST:{LIST:"data-liquid-commerce-elements-products-list",SCRIPT:"data-liquid-commerce-elements-products",CARD:"data-card",CARD_FILL:"data-card-fill",ROWS:"data-rows",COLUMNS:"data-columns",FILTERS:"data-filters",PRODUCT_URL:"data-product-url"},CART:{BUTTON:"data-cart-button",BADGE_BUTTON:"data-cart-badge-button",MOBILE_BUTTON:"data-cart-mobile-button",MOBILE_BADGE_BUTTON:"data-cart-mobile-badge-button",BUTTON_HIDDEN:"data-cart-button-hidden",TOGGLE_BUTTON:"data-lce-cart-toggle-button",ITEMS_COUNT:"data-lce-cart-items-count"},DEVELOPMENT:"data-liquid-commerce-elements-development"};function startsWithLcePrefix(n){return null!==n&&"lce_"===n.substring(0,4)}function generateElementId({prefix:n,index:i}){const r=Math.random().toString(36).substring(2,7),s=void 0!==n?n:"",a=void 0!==i?i:"",l=s&&a?"-":"";return""+s+l+a+r}function pairsFromMainScript(n){const i=[];try{const s=n.getAttributeNames().filter(n=>n.substring(0,12)===Bt.PRODUCT.PRODUCT);for(const a of s)try{const r=a.match(/^data-product(-(.+))?$/),s=(null==r?void 0:r[2])?"-"+r[2]:"",l=""+Bt.PRODUCT.CONTAINER+s;if(n.hasAttribute(l)){const r=n.getAttribute(l),s=n.getAttribute(a);r&&s&&i.push({containerId:r,identifier:s})}}catch(r){console.error("[LiquidCommerce Elements Auto Initialization] Error processing product attribute:",r)}}catch(s){console.error("[LiquidCommerce Elements Auto Initialization] Error extracting products from main script:",s)}return i}function pairsFromProductsScript(){const n=[];try{const r=document.querySelectorAll("script["+Bt.PRODUCT_LIST.SCRIPT+"]");for(const s of r)try{const i=JSON.parse(s.textContent||"[]");if(!Array.isArray(i))continue;for(const r of i)r.containerId&&r.identifier&&n.push({containerId:r.containerId,identifier:r.identifier})}catch(i){console.error("[LiquidCommerce Elements Auto Initialization] Invalid JSON in data-liquid-commerce-elements-products script",i)}}catch(r){console.error("[LiquidCommerce Elements Auto Initialization] Error extracting products from products script:",r)}return n}function pairsFromAttributedElements(){const n=[];try{const r=document.querySelectorAll("div["+Bt.PRODUCT.LCE_PRODUCT+"]");let s=0;for(const a of r)try{const i=generateElementId({prefix:"lce-p",index:s});a.setAttribute("id",i);const r=a.getAttribute(Bt.PRODUCT.LCE_PRODUCT);i&&r&&n.push({containerId:i,identifier:r}),s+=1}catch(i){console.error("[LiquidCommerce Elements Auto Initialization] Error processing attributed element:",i)}}catch(r){console.error("[LiquidCommerce Elements Auto Initialization] Error extracting products from attributed elements:",r)}return n}async function addProductToCartViaQueryParam(n,i){try{const s=i.getAttribute(Bt.PRODUCT.PARAM),a=i.getAttribute(Bt.PRODUCT.FULFILLMENT_TYPE_PARAM);if(!s)return;if(!startsWithLcePrefix(s))return console.warn('[LiquidCommerce Elements Auto Initialization] Ignoring product query parameter "'+s+'" because it does not start with "lce_" prefix.'),void 0;const l=new URLSearchParams(window.location.search),d=l.get(s);if(!d)return;let u=E.SHIPPING;if(a)if(startsWithLcePrefix(a)){const n=l.get(a);n!==E.ON_DEMAND&&n!==E.SHIPPING||(u=n)}else console.warn('[LiquidCommerce Elements Auto Initialization] Ignoring product fulfillment type query parameter "'+a+'" because it does not start with "lce_" prefix.');try{await n.actions.cart.addProduct([{identifier:d,fulfillmentType:u,quantity:1}],!![])}catch(r){console.error("[LiquidCommerce Elements Auto Initialization] Failed to add product from query parameter to cart:",r)}}catch(s){console.error("[LiquidCommerce Elements Auto Initialization] Failed to process product query parameter:",s)}}async function addPromoCodeToCartViaQueryParam(n,i){try{const s=i.getAttribute(Bt.PROMO_TICKER.CODE_PARAM);if(!s)return;if(!startsWithLcePrefix(s))return console.warn('[LiquidCommerce Elements Auto Initialization] Ignoring promo code query parameter "'+s+'" because it does not start with "lce_" prefix.'),void 0;const a=new URLSearchParams(window.location.search),l=a.get(s);if(!l)return;try{await n.actions.cart.applyPromoCode(l)}catch(r){console.error("[LiquidCommerce Elements Auto Initialization] Failed to apply promo code from query parameter to cart:",r)}}catch(s){console.error("[LiquidCommerce Elements Auto Initialization] Failed to process promo code query parameter:",s)}}async function setupCartButtonWithPosition(n,i,r,s){var a,l,d;try{const u=r.includes("mobile"),f=u?"mobile":"desktop",g=!u,v=i.getAttribute(r),b=i.getAttribute(s);if(!i.hasAttribute(r)&&!i.hasAttribute(s))return;if(g){if(i.hasAttribute(r)&&!v)return n.ui.floatingCartButton(![]),void 0;if(i.hasAttribute(s)&&!b)return n.ui.floatingCartButton(!![]),void 0}const x=v||b,w=!!b;if(!x)return g&&(console.warn("[LiquidCommerce Elements Auto Initialization] No cart button position specified. Using floating button."),n.ui.floatingCartButton(w)),void 0;const C=["above","below","replace","inside"],E=x.match(/^(\w+):(.+)$/),T=E&&C.includes(E[1])?E[1]:"inside";let A=E?E[2]:x;/^[#.]/.test(A)||/\s/.test(A)||(A="#"+A);const P=document.querySelector(A);if(!P)return g&&(console.warn('[LiquidCommerce Elements Auto Initialization] Cart target "'+A+'" not found. Using floating button.'),n.ui.floatingCartButton(w)),void 0;const _=document.createElement("div");switch(_.classList.add("lce-cart-"+f+"-button-container"),_.id=generateElementId({prefix:"lce-cart-"+f+"-btn"}),T){case"above":null===(a=P.parentNode)||void 0===a?void 0:a.insertBefore(_,P);break;case"below":null===(l=P.parentNode)||void 0===l?void 0:l.insertBefore(_,P.nextSibling);break;case"replace":null===(d=P.parentNode)||void 0===d?void 0:d.replaceChild(_,P);break;default:P.appendChild(_)}n.ui.cartButton(_.id,w)}catch(u){console.error("[LiquidCommerce Elements Auto Initialization] Failed to setup cart button:",u)}}async function setupCartButtons(n,i){i.hasAttribute(Bt.CART.BUTTON_HIDDEN)||(await setupCartButtonWithPosition(n,i,Bt.CART.BUTTON,Bt.CART.BADGE_BUTTON),await setupCartButtonWithPosition(n,i,Bt.CART.MOBILE_BUTTON,Bt.CART.MOBILE_BADGE_BUTTON))}async function initializeProductsList(n){try{const i=document.querySelector("div["+Bt.PRODUCT_LIST.LIST+"]");if(!i)return;const r="lce-products-list-container";i.className="lce-products-list-container",i.id=r;const s=i.getAttribute(Bt.PRODUCT_LIST.CARD)||"standard",a=i.hasAttribute(Bt.PRODUCT_LIST.CARD_FILL),l=Number.parseInt(i.getAttribute(Bt.PRODUCT_LIST.ROWS)||"3",10)||3,d=Number.parseInt(i.getAttribute(Bt.PRODUCT_LIST.COLUMNS)||"4",10)||4,u=i.getAttribute(Bt.PRODUCT_LIST.FILTERS),f=i.getAttribute(Bt.PRODUCT_LIST.PRODUCT_URL)||void 0;let g=[];u&&(g=u.split(",").map(n=>n.trim()).filter(n=>n.length>0)),await n.injectProductList({containerId:r,rows:l,columns:d,cardVariant:s,fillCard:a,filters:g,productUrl:f})}catch(i){console.error("[LiquidCommerce Elements Auto Initialization] Failed to initialize products list:",i)}}function setupEventListeners(){try{window.addEventListener("lce:actions.client_ready",async n=>{const i=n.detail;if(!i.data.isReady)return;const r=window.elements,s=document.querySelectorAll("["+Bt.CART.TOGGLE_BUTTON+"]");if(s.length>0)for(const l of s)l.addEventListener("click",async n=>{n.stopPropagation(),n.preventDefault(),r.actions.cart.toggleCart()});const a=document.querySelectorAll("["+Bt.CART.ITEMS_COUNT+"]");if(a.length>0){let n=0;for(const i of a){const s=i.getAttribute(Bt.CART.ITEMS_COUNT),a=!(s&&"keep-zero"===s),l=Boolean(null==i?void 0:i.id);let d;l?d=i.id:(d=generateElementId({prefix:"lce-cart-items-count",index:n}),i.id=d),r.ui.cartItemsCount(d,{hideZero:a}),n+=1}}})}catch(ut){console.error("[LiquidCommerce Elements Auto Initialization] Failed to setup event listeners:",ut)}}function getDevelopmentConfigs(){const n=document.querySelector("script["+Bt.DEVELOPMENT+"]");if(n)try{return JSON.parse(n.textContent||"{}")}catch(i){return console.error("[LiquidCommerce Elements Auto Initialization] Invalid JSON in development config script",i),void 0}}async function ElementsAutoInitialize(){var n,i,r,s,a,l;try{const l=document.querySelector("script["+Bt.CORE.MAIN_SCRIPT+"]");if(!l)return;const d=l.getAttribute(Bt.CORE.TOKEN),u=l.getAttribute(Bt.CORE.ENV)||b.PRODUCTION,f=l.getAttribute(Bt.CORE.DEBUG_MODE);if(!d)throw new SDKError('Missing required data-token attribute on the script tag. Add data-token="your-api-key" to the Elements script tag.',!![]);const g=l.getAttribute(Bt.PROMO_TICKER.CODE),v=l.getAttribute(Bt.PROMO_TICKER.TEXT),x=null!==(n=l.getAttribute(Bt.PROMO_TICKER.SEPARATOR))&&void 0!==n?n:"•",w=null!==(i=l.getAttribute(Bt.PROMO_TICKER.ACTIVE_FROM))&&void 0!==i?i:void 0,C=null!==(r=l.getAttribute(Bt.PROMO_TICKER.ACTIVE_UNTIL))&&void 0!==r?r:void 0,E=pairsFromMainScript(l),A=pairsFromProductsScript(),P=pairsFromAttributedElements(),_=[...E,...A,...P],N=g&&v&&w&&C?{promoCode:g,text:v.split("|").map(n=>n.trim()).filter(n=>n.length>0),separator:x,activeFrom:null===(s=new Date(w))||void 0===s?void 0:s.toISOString(),activeUntil:null===(a=new Date(C))||void 0===a?void 0:a.toISOString()}:void 0;let F=T.NONE;f&&u!==b.PRODUCTION&&(F=f),setupEventListeners();const R=await Elements(d,{env:u,debugMode:F,promoTicker:N?[N]:void 0,development:getDevelopmentConfigs()});if(!R)throw new SDKError("Elements client returned null. Check console for authentication or API errors.",!![]);setupCartButtons(R,l),0!==_.length&&R.injectProductElement(_).catch(n=>{console.error("[LiquidCommerce Elements Auto Initialization] Failed to inject product elements:",n)}),initializeProductsList(R),addProductToCartViaQueryParam(R,l),addPromoCodeToCartViaQueryParam(R,l)}catch(d){console.error("[LiquidCommerce Elements Auto Initialization]",null!==(l=null==d?void 0:d.message)&&void 0!==l?l:String(d))}}function triggerElementsAutoInit(){try{"loading"===document.readyState?document.addEventListener("DOMContentLoaded",async()=>{setTimeout(async()=>{try{await ElementsAutoInitialize()}catch(ut){console.error("[LiquidCommerce Elements Auto Initialization] Failed to initialize:",ut)}},50)}):setTimeout(async()=>{try{await ElementsAutoInitialize()}catch(ut){console.error("[LiquidCommerce Elements Auto Initialization] Failed to initialize:",ut)}},50)}catch(ut){console.error("[LiquidCommerce Elements Auto Initialization] Failed to setup initialization:",ut)}}class ElementsBuilderClient extends ElementsBaseClient{async updateComponentGlobalConfigs(n){try{if(!n)throw new SDKError("Global configuration object is required.",!![]);if(this.themeProvider.updateComponentGlobalConfigs(n),n.layout&&Object.keys(n.layout).length>0){await this.commands.product.rerenderAllProducts(),this.commands.cart.rerenderCart(),this.commands.checkout.rerenderCheckout();for(const i of getComponentTypesForLayoutFields("global.layout",n.layout))this.rerenderInjectedComponentsByType(i)}this.logger.info("✅ Global theme configuration updated - changes applied to all components")}catch(i){throw this.logger.error("❌ Failed to update global theme configuration",i),new SDKError("Failed to update global configuration: "+i.message,!![])}}async updateProductComponent(n){try{if(!n)throw new SDKError("Product configuration object is required.",!![]);if(this.themeProvider.updateProductComponent(n),n.layout&&Object.keys(n.layout).length>0){await this.commands.product.rerenderAllProducts();for(const i of getComponentTypesForLayoutFields("product.layout",n.layout))this.rerenderInjectedComponentsByType(i)}this.logger.info("✅ Product component theme updated - changes applied to product elements")}catch(i){throw this.logger.error("❌ Failed to update product component theme",i),new SDKError("Failed to update product configuration: "+i.message,!![])}}updateCartComponent(n){try{if(!n)throw new SDKError("Cart configuration object is required.",!![]);if(this.themeProvider.updateCartComponent(n),n.layout&&Object.keys(n.layout).length>0){this.commands.cart.rerenderCart();for(const i of getComponentTypesForLayoutFields("cart.layout",n.layout))this.rerenderInjectedComponentsByType(i)}this.logger.info("✅ Cart component theme updated - changes applied to cart elements")}catch(i){throw this.logger.error("❌ Failed to update cart component theme",i),new SDKError("Failed to update cart configuration: "+i.message,!![])}}updateCheckoutComponent(n){try{if(!n)throw new SDKError("Checkout configuration object is required.",!![]);if(this.themeProvider.updateCheckoutComponent(n),n.layout&&Object.keys(n.layout).length>0){this.commands.checkout.rerenderCheckout();for(const i of getComponentTypesForLayoutFields("checkout.layout",n.layout))this.rerenderInjectedComponentsByType(i)}this.logger.info("✅ Checkout component theme updated - changes applied to checkout elements")}catch(i){throw this.logger.error("❌ Failed to update checkout component theme",i),new SDKError("Failed to update checkout configuration: "+i.message,!![])}}updateAddressComponent(n){try{if(!n)throw new SDKError("Address configuration object is required.",!![]);this.themeProvider.updateAddressComponent(n),this.logger.info("✅ Address component theme updated - changes applied to address elements")}catch(i){throw this.logger.error("❌ Failed to update address component theme",i),new SDKError("Failed to update address configuration: "+i.message,!![])}}async injectElement(n){if(!n)throw new SDKError("Element injection requires container ID and type parameters.",!![]);if(!n.containerId||"string"!=typeof n.containerId)throw new SDKError("Container ID is required and must be a string. Received: "+("string"==typeof n.containerId?'"'+n.containerId+'"':n.containerId),!![]);if(!n.type)throw new SDKError("Component type is required (e.g., product, cart, checkout).",!![]);return await this.processInjectElement(n)}async injectProductElement(n){if(!Array.isArray(n))throw new SDKError("Product injection requires an array of product parameters. Received: "+typeof n,!![]);return await this.processInjectProduct(n)}async injectAddressElement(n,i){if(!n||"string"!=typeof n)throw new SDKError("Address element requires a valid container ID. Received: "+("string"==typeof n?'"'+n+'"':n),!![]);return await this.processInjectElement({type:C.ADDRESS,containerId:n,options:i})}async injectCartElement(n){if(!n||"string"!=typeof n)throw new SDKError("Cart element requires a valid container ID. Received: "+("string"==typeof n?'"'+n+'"':n),!![]);return await this.processInjectElement({type:C.CART,containerId:n})}async injectCheckoutElement(n,i){if(!n||"string"!=typeof n)throw new SDKError("Checkout element requires a valid container ID. Received: "+("string"==typeof n?'"'+n+'"':n),!![]);const r=await this.processInjectElement({type:C.CHECKOUT,containerId:n});if(null==i?void 0:i.simulatePresale){const n=i.presaleExpiresInMinutes||15,r=new Date;r.setMinutes(r.getMinutes()+n),this.store.set("checkout.presale",{isLocked:!![],expiresAt:r.toISOString()}),this.logger.info("✅ Builder presale simulation activated - expires in "+n+" minutes")}return r}}async function ElementsBuilder(n,i){try{SingletonManager.setContext({isBuilder:!![]});const r=ClientConfigService.getInstance();r.initialize(n,{env:i.env,isBuilder:!![],debugMode:i.debugMode,customTheme:i.customTheme,promoTicker:i.promoTicker,proxy:void 0,development:void 0});const s=r.getConfigs();SingletonManager.setClientConstructor(ElementsBuilderClient);const a=await SingletonManager.getClient(s);if(!a.clientPrepared)throw new SDKError("Failed to initialize. Check console for authentication or configuration errors.",!![]);const l={updateComponentGlobalConfigs:a.updateComponentGlobalConfigs.bind(a),updateProductComponent:a.updateProductComponent.bind(a),updateAddressComponent:a.updateAddressComponent.bind(a),updateCartComponent:a.updateCartComponent.bind(a),updateCheckoutComponent:a.updateCheckoutComponent.bind(a),injectElement:a.injectElement.bind(a),injectProductElement:a.injectProductElement.bind(a),injectAddressElement:a.injectAddressElement.bind(a),injectCartElement:a.injectCartElement.bind(a),injectCheckoutElement:a.injectCheckoutElement.bind(a),injectProductList:a.injectProductList.bind(a),actions:a.actions};window.elementsBuilder=l;const d=PubSubService.getInstance();return d.publishAction(x.CLIENT_READY,{isReady:!![],message:"Elements Builder Client Is Ready",timestamp:Date.now(),version:r.get("version")}),l}catch(r){try{const n=LoggerFactory.get("ElementsBuilderClientInit");n.error("Elements Builder Client Initialization failed",r)}catch(s){console.error("[LiquidCommerce Elements] Builder Client initialization failed:",null==r?void 0:r.message)}try{const n=ClientConfigService.getInstance(),i=PubSubService.getInstance();i.publishAction(x.CLIENT_READY,{isReady:![],message:"Builder initialization failed: "+(null==r?void 0:r.message),timestamp:Date.now(),version:n.get("version")||"unknown"})}catch(a){console.warn("[LiquidCommerce Elements] Could not fire error event - services unavailable")}return null}}if(void 0===window.customElements)console.error("[LiquidCommerce Elements] SDK requires support for Web Components. Please include a Web Components polyfill for older browsers.");else if(void 0===HTMLElement.prototype.attachShadow)console.error("[LiquidCommerce Elements] SDK requires support for Shadow DOM. Please include a Shadow DOM polyfill for older browsers.");else try{const n=window.onerror;window.onerror=(i,r,s,a,l)=>isSDKError(l,r)?(console.error("[LiquidCommerce Elements] Unhandled SDK error:",{message:i,source:r,lineno:s,colno:a,error:l}),!![]):n?n(i,r,s,a,l):![];const i=window.onunhandledrejection;window.onunhandledrejection=n=>{if(n.reason&&isSDKError(n.reason))return console.error("[LiquidCommerce Elements] Unhandled SDK promise rejection:",n.reason),n.preventDefault(),void 0;i&&i.call(window,n)};try{initializeDOMPolyfills()}catch(Wt){console.error("[LiquidCommerce Elements] DOM polyfills initialization failed:",Wt)}try{triggerElementsAutoInit()}catch(Ht){console.error("[LiquidCommerce Elements] Auto-initialization failed:",Ht)}}catch(qt){console.error("[LiquidCommerce Elements] SDK initialization failed:",qt)}initializeDOMPolyfills(),window.Elements=Elements,window.ElementsBuilder=ElementsBuilder,exports.Elements=Elements,exports.ElementsBuilder=ElementsBuilder,Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"})});
|