@metrifox/angular-sdk 1.0.2 → 2.0.0

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.
Files changed (48) hide show
  1. package/README.md +310 -320
  2. package/dist/LICENSE +21 -0
  3. package/dist/README.md +477 -0
  4. package/dist/fesm2022/index.mjs +9653 -0
  5. package/{lib → dist/lib}/metrifox.module.d.ts +2 -2
  6. package/{lib → dist/lib}/metrifox.service.d.ts +22 -14
  7. package/{lib → dist/lib}/types/enum.d.ts +12 -2
  8. package/{lib → dist/lib}/types/interface.d.ts +390 -103
  9. package/dist/lib/utils/theme.d.ts +27 -0
  10. package/dist/modules/customer-portal/components/billing-history.component.d.ts +14 -0
  11. package/dist/modules/customer-portal/components/credit/credit-balance-section.component.d.ts +76 -0
  12. package/dist/modules/customer-portal/components/customer-portal.component.d.ts +64 -0
  13. package/dist/modules/customer-portal/components/entitlements/entitlement-summary.component.d.ts +15 -0
  14. package/dist/modules/customer-portal/components/entitlements/entitlement-usage.component.d.ts +35 -0
  15. package/dist/modules/customer-portal/components/entitlements/entitlements-section.component.d.ts +14 -0
  16. package/dist/modules/customer-portal/components/invoice-preview.component.d.ts +26 -0
  17. package/dist/modules/customer-portal/components/payment.component.d.ts +12 -0
  18. package/dist/modules/customer-portal/components/plan/plans-section.component.d.ts +70 -0
  19. package/dist/modules/customer-portal/components/subscription/subscription-actions.component.d.ts +22 -0
  20. package/dist/modules/customer-portal/components/subscription/subscription-details.component.d.ts +12 -0
  21. package/dist/modules/customer-portal/components/subscription/subscription-items.component.d.ts +27 -0
  22. package/dist/modules/customer-portal/components/subscription/subscription-section.component.d.ts +34 -0
  23. package/dist/modules/customer-portal/utils/defaults.d.ts +2 -0
  24. package/dist/modules/customer-portal/utils/helpers.d.ts +20 -0
  25. package/dist/modules/customer-portal/utils/icon-helpers.d.ts +3 -0
  26. package/dist/modules/customer-portal/utils/icons.d.ts +18 -0
  27. package/dist/modules/metrifox-ui/index.d.ts +1 -0
  28. package/dist/modules/metrifox-ui/themed-popover.component.d.ts +19 -0
  29. package/dist/modules/pricing-table/components/localization-select.component.d.ts +22 -0
  30. package/{lib/components/pricing-table → dist/modules/pricing-table/components}/pricing-table.component.d.ts +28 -6
  31. package/dist/modules/pricing-table/utils/defaults.d.ts +2 -0
  32. package/dist/public-api.d.ts +22 -0
  33. package/dist/styles.css +3 -0
  34. package/dist-storybook/3rdpartylicenses.txt +304 -0
  35. package/dist-storybook/index.html +12 -0
  36. package/dist-storybook/main.js +1 -0
  37. package/dist-storybook/polyfills.js +1 -0
  38. package/dist-storybook/runtime.js +1 -0
  39. package/dist-storybook/styles.css +2 -0
  40. package/package.json +53 -13
  41. package/vitest.config.ts +10 -0
  42. package/vitest.setup.ts +5 -0
  43. package/fesm2022/index.mjs +0 -5898
  44. package/lib/components/customer-portal/customer-portal.component.d.ts +0 -193
  45. package/public-api.d.ts +0 -20
  46. package/styles.css +0 -3
  47. /package/{index.d.ts → dist/index.d.ts} +0 -0
  48. /package/{lib → dist/lib}/types/index.d.ts +0 -0
@@ -1,193 +0,0 @@
1
- import { EventEmitter, OnInit, OnDestroy } from '@angular/core';
2
- import { SafeHtml } from '@angular/platform-browser';
3
- import { CustomerDetails, Wallet, SectionConfig, CustomerDataLoadedEvent, ErrorEvent, BillingHistory, ProductPlans, Offering, Invoice, InvoiceLineItem } from '../../types';
4
- import * as i0 from "@angular/core";
5
- declare const ICONS: {
6
- money: string;
7
- cardReceive: string;
8
- settings: string;
9
- settingsAlt: string;
10
- closeCircle: string;
11
- walletEmpty: string;
12
- noteEmpty: string;
13
- receipt: string;
14
- radar: string;
15
- arrowDown: string;
16
- arrowDownRight: string;
17
- subtitle: string;
18
- subtitleLarge: string;
19
- check: string;
20
- };
21
- export declare class CustomerPortalComponent implements OnInit, OnDestroy {
22
- private destroy$;
23
- private isLoadingData;
24
- private lastLoadedCustomerKey;
25
- private expandedLineItems;
26
- private iconCache;
27
- customerKey: string;
28
- sectionsConfig?: SectionConfig[];
29
- dataLoaded: EventEmitter<CustomerDataLoadedEvent>;
30
- errorOccurred: EventEmitter<ErrorEvent>;
31
- private metrifoxService;
32
- private sanitizer;
33
- constructor();
34
- loading: import("@angular/core").WritableSignal<boolean>;
35
- error: import("@angular/core").WritableSignal<string>;
36
- customerDetails: import("@angular/core").WritableSignal<CustomerDetails>;
37
- wallets: import("@angular/core").WritableSignal<Wallet[]>;
38
- billingHistory: import("@angular/core").WritableSignal<BillingHistory[]>;
39
- productPlans: import("@angular/core").WritableSignal<ProductPlans>;
40
- entitlementSummary: import("@angular/core").WritableSignal<any[]>;
41
- entitlementUsage: import("@angular/core").WritableSignal<any[]>;
42
- creditAllocations: import("@angular/core").WritableSignal<any[]>;
43
- selectedTabIndex: import("@angular/core").WritableSignal<number>;
44
- explorePricesPlan: import("@angular/core").WritableSignal<Offering>;
45
- selectedPlanInterval: import("@angular/core").WritableSignal<string>;
46
- showInvoicePreview: import("@angular/core").WritableSignal<boolean>;
47
- selectedInvoice: import("@angular/core").WritableSignal<any>;
48
- invoiceDetails: import("@angular/core").WritableSignal<Invoice>;
49
- invoiceDetailsLoading: import("@angular/core").WritableSignal<boolean>;
50
- selectedWalletIndex: import("@angular/core").WritableSignal<number>;
51
- walletTab: import("@angular/core").WritableSignal<"active" | "expired" | "overage">;
52
- entitlementTab: import("@angular/core").WritableSignal<"usage" | "summary">;
53
- showWalletSettings: import("@angular/core").WritableSignal<boolean>;
54
- selectedWalletForSettings: string;
55
- lowBalanceEnabled: boolean;
56
- walletSettingThreshold: string;
57
- walletSettingBehaviour: 'notify' | 'auto_top_up';
58
- walletSettingTargetBalance: string;
59
- walletSettingMonthlyLimit: string;
60
- walletSettingsList: import("@angular/core").WritableSignal<any[]>;
61
- walletSettingsLoading: import("@angular/core").WritableSignal<boolean>;
62
- walletSettingsSaving: import("@angular/core").WritableSignal<boolean>;
63
- walletSettingsError: import("@angular/core").WritableSignal<string>;
64
- walletSettingEditId: import("@angular/core").WritableSignal<string>;
65
- expandedEntitlements: Set<string>;
66
- allocationsLoading: import("@angular/core").WritableSignal<boolean>;
67
- showCreditTransactions: import("@angular/core").WritableSignal<boolean>;
68
- selectedAllocation: import("@angular/core").WritableSignal<any>;
69
- creditTransactions: import("@angular/core").WritableSignal<any[]>;
70
- creditTransactionsLoading: import("@angular/core").WritableSignal<boolean>;
71
- Math: Math;
72
- subscriptions: import("@angular/core").Signal<import("../../types").Subscription[]>;
73
- tenantCheckoutUsername: import("@angular/core").Signal<string>;
74
- plans: import("@angular/core").Signal<Offering[]>;
75
- planIntervals: import("@angular/core").Signal<string[]>;
76
- currentPlanIndex: import("@angular/core").Signal<number>;
77
- cssVars: import("@angular/core").Signal<import("../../types").CssVarMap>;
78
- private sectionLabels;
79
- ngOnInit(): void;
80
- ngOnDestroy(): void;
81
- private loadCustomerDetails;
82
- private loadAdditionalData;
83
- private loadCreditAllocations;
84
- selectTab(index: number): void;
85
- isSectionHidden(key: string): boolean;
86
- getSectionLabel(key: string): string;
87
- getIcon(name: keyof typeof ICONS): SafeHtml;
88
- toggleLineItems(productKey: string): void;
89
- isLineItemsExpanded(productKey: string): boolean;
90
- openUpdateItems(subscription: {
91
- subscription: {
92
- id: string;
93
- offering_key: string;
94
- };
95
- }): void;
96
- formatDate(dateString: string | null | undefined): string;
97
- formatCurrency(amount: number | null | undefined, currency: string | null | undefined): string;
98
- formatStatus(status: string | null | undefined): string;
99
- formatSourceType(sourceType: string | null | undefined): string;
100
- openInvoicePreview(invoice: any): void;
101
- closeInvoicePreview(): void;
102
- openExplorePricesModal(plan: Offering): void;
103
- closeExplorePricesModal(): void;
104
- buildTenantAddress(addr: any): string;
105
- buildBilledToAddress(customer: any): string;
106
- formatInvoiceDate(d: string | null | undefined): string;
107
- /** Build range label from usage_tiers like React SDK: "0 and above" or "X to Y". */
108
- private getInvoiceLineItemRangeLabel;
109
- /** Normalize a single item from API (handles snake_case and camelCase, nested data, range from tiers, unit_price from tiers). */
110
- private normalizeInvoiceLineItem;
111
- getInvoiceLineItems(invoice: Invoice | null | undefined): Array<InvoiceLineItem & {
112
- itemType: string;
113
- }>;
114
- /** Build HTML string for invoice print (new window) so download/print has no Storybook URL or timestamp in header. */
115
- private buildInvoicePrintHtml;
116
- private escapeHtml;
117
- triggerInvoicePrint(): void;
118
- selectWallet(index: number): void;
119
- formatWalletBalance(wallet: Wallet): string;
120
- changeWalletTab(tab: 'active' | 'expired' | 'overage'): void;
121
- getActiveAllocationsCount(): number;
122
- formatAllocationDate(dateStr: string): string;
123
- formatAllocationSource(type: string): string;
124
- formatAllocationDateShort(dateStr: string): string;
125
- formatValidUntilDate(dateStr: string): string;
126
- formatPrice(value: number | undefined | null): string;
127
- getAllocationBalance(allocation: any): number;
128
- getAllocationProgressPercent(allocation: any): number;
129
- openWalletSettings(): void;
130
- private loadWalletSettings;
131
- private applyExistingWalletSetting;
132
- closeWalletSettings(): void;
133
- getWalletSettingsValidationErrors(): string[];
134
- saveWalletSettings(): void;
135
- onWalletSelectChange(event: Event): void;
136
- toggleLowBalance(): void;
137
- getSelectedWalletName(): string;
138
- handleTopup(walletId: string): void;
139
- openCreditTransactions(allocation: any): void;
140
- closeCreditTransactions(): void;
141
- changeEntitlementTab(tab: 'summary' | 'usage'): void;
142
- getMeteredEntitlements(): any[];
143
- capitalize(str: string): string;
144
- formatUsageModel(entitlement: any): string;
145
- formatIncludedAllowance(entitlement: any): string;
146
- formatUsageLimits(entitlement: any): string;
147
- getResetIntervalLabel(interval: string): string;
148
- formatNumber(num: number): string;
149
- toggleEntitlementExpand(id: string): void;
150
- isEntitlementExpanded(id: string): boolean;
151
- getEntitlementUsageBalance(usage: any): string;
152
- getEntitlementUsagePercent(usage: any): number;
153
- getEntitlementUsageText(usage: any): string;
154
- getProcessedPools(usage: any): any[];
155
- formatResetDate(dateStr: string): string;
156
- getStatusBgClass(status: string | null | undefined): string;
157
- getInvoiceStatusBgClass(status: string | null | undefined): string;
158
- getBillingAddress(): string;
159
- selectPlanInterval(interval: string): void;
160
- formatPlanInterval(interval: string): string;
161
- getPlanPriceOption(plan: any): any;
162
- getPlanPriceInteger(plan: Offering): string;
163
- getPlanPriceDecimal(plan: Offering): string;
164
- getCurrencySymbol(currency: string): string;
165
- hasFixedPrice(plan: any): boolean;
166
- getDynamicPrices(plan: any): any[];
167
- getDynamicPriceName(priceOption: any): string;
168
- formatDynamicPrice(priceOption: any): string;
169
- formatDynamicPriceFull(priceOption: any): string;
170
- /** Formatted amount only for a dynamic price (e.g. "$3.00") for modal display. */
171
- getDynamicPriceAmountDisplay(priceOption: any): string;
172
- getMainDynamicPriceInteger(plan: any): string;
173
- getMainDynamicPriceDecimal(plan: any): string;
174
- getMainDynamicPriceUnit(plan: any): string;
175
- formatPriceAmount(amount: number): string;
176
- /** Format price with exactly two decimal places for invoice (e.g. $3.00). */
177
- formatInvoicePrice(amount: number): string;
178
- /** Get currency symbol from invoice (handles snake_case/camelCase). */
179
- getInvoiceCurrencySymbol(invoice: Invoice | null | undefined): string;
180
- /** Get a summary number from invoice (tries snake_case and camelCase keys). */
181
- getInvoiceSummaryNumber(invoice: Invoice | null | undefined, ...keys: string[]): number;
182
- /** Safe parse to number for invoice display (handles string/number, NaN -> 0). */
183
- toNumber(value: string | number | null | undefined): number;
184
- getPluralizedUnit(plan: Offering): string;
185
- getPlanButtonText(plan: Offering, index: number): string;
186
- getVisibleEntitlements(plan: Offering): any[];
187
- formatEntitlement(entitlement: any): string;
188
- getListingUrl(subscription: any): string;
189
- handlePlanAction(plan: Offering): void;
190
- static ɵfac: i0.ɵɵFactoryDeclaration<CustomerPortalComponent, never>;
191
- static ɵcmp: i0.ɵɵComponentDeclaration<CustomerPortalComponent, "metrifox-customer-portal", never, { "customerKey": { "alias": "customerKey"; "required": true; }; "sectionsConfig": { "alias": "sectionsConfig"; "required": false; }; }, { "dataLoaded": "dataLoaded"; "errorOccurred": "errorOccurred"; }, never, never, true, never>;
192
- }
193
- export {};
package/public-api.d.ts DELETED
@@ -1,20 +0,0 @@
1
- /**
2
- * Metrifox Angular SDK
3
- *
4
- * Angular SDK for Metrifox - SaaS billing, customer portals, and pricing tables.
5
- *
6
- * @packageDocumentation
7
- */
8
- export { MetrifoxService, metrifoxInit, MetrifoxNotInitializedError } from './lib/metrifox.service';
9
- export { CustomerPortalComponent } from './lib/components/customer-portal/customer-portal.component';
10
- export { PricingTableComponent } from './lib/components/pricing-table/pricing-table.component';
11
- export { MetrifoxModule, provideMetrifox } from './lib/metrifox.module';
12
- export type { Theme, CustomerPortalTheme, PricingTableTheme, CardTheme, CardHeaderTheme, CardDescriptionTheme, CardPriceTheme, ButtonTheme, FeatureListTheme, TabsTheme, IntervalToggleTheme, CurrentSubscriptionCardTheme, FreeTrialTheme, CheckoutBarTheme, } from './lib/types';
13
- export type { MetrifoxConfig, SectionConfig, SectionKey, } from './lib/types';
14
- export type { CustomerPortalProps, CustomerDetails, Subscription, SubscriptionDetails, SubscriptionItem, UpcomingInvoice, PaymentMethod, BillingAddress, Currency, InvoiceStatus, } from './lib/types';
15
- export type { Entitlement, Feature, EntitlementUsage, EntitlementSummary, Pool, ProcessedPool, } from './lib/types';
16
- export type { Wallet, WalletAllocation, CreditAllocation, CreditTransaction, WalletSetting, CreditSystem, CreditOwner, } from './lib/types';
17
- export type { PricingTableProps, Product, Offering, ParentOffering, PriceOption, PriceOwner, Price, Tier, SinglePurchase, } from './lib/types';
18
- export type { Invoice, InvoiceLineItem, InvoiceSummary, Tenant, TenantAddress, BillingHistory, } from './lib/types';
19
- export type { CustomerDataLoadedEvent, PlanSelectedEvent, PurchaseSelectedEvent, ErrorEvent, CssVarMap, } from './lib/types';
20
- export { FeatureType, FeatureModel, FeatureStatus, SubscriptionStatus, InvoiceStatusType, InvoiceItemType, PriceTypes, TierType, ResetIntervals, EnforcementType, BillingInterval, BillingTimingTypes, AggregationMethods, OneOffType, PoolType, OfferingTypes, } from './lib/types/enum';
package/styles.css DELETED
@@ -1,3 +0,0 @@
1
- *,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }
2
-
3
- /*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.bottom-4{bottom:1rem}.left-1\/2{left:50%}.left-3{left:.75rem}.right-0{right:0}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-4{top:1rem}.z-50{z-index:50}.z-\[100\]{z-index:100}.col-span-2{grid-column:span 2/span 2}.-mx-4{margin-left:-1rem;margin-right:-1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1\.5{margin-top:.375rem;margin-bottom:.375rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.-mt-2\.5{margin-top:-.625rem}.mb-1{margin-bottom:.25rem}.mb-10{margin-bottom:2.5rem}.mb-2{margin-bottom:.5rem}.mb-2\.5{margin-bottom:.625rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-\[5px\]{margin-bottom:5px}.ml-1{margin-left:.25rem}.ml-4{margin-left:1rem}.ml-auto{margin-left:auto}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-2\.5{margin-top:.625rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-16{height:4rem}.h-4{height:1rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-\[500px\]{height:500px}.h-\[51px\]{height:51px}.h-full{height:100%}.max-h-\[80vh\]{max-height:80vh}.max-h-\[85vh\]{max-height:85vh}.min-h-0{min-height:0}.min-h-\[187px\]{min-height:187px}.min-h-\[200px\]{min-height:200px}.min-h-\[240px\]{min-height:240px}.min-h-\[3\.5rem\]{min-height:3.5rem}.min-h-\[75vh\]{min-height:75vh}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-16{width:4rem}.w-20{width:5rem}.w-24{width:6rem}.w-28{width:7rem}.w-32{width:8rem}.w-40{width:10rem}.w-6{width:1.5rem}.w-72{width:18rem}.w-9{width:2.25rem}.w-96{width:24rem}.w-\[100px\]{width:100px}.w-\[140px\]{width:140px}.w-\[281px\]{width:281px}.w-\[330px\]{width:330px}.w-\[50\%\]{width:50%}.w-full{width:100%}.w-max{width:-moz-max-content;width:max-content}.min-w-0{min-width:0}.min-w-\[20px\]{min-width:20px}.min-w-\[400px\]{min-width:400px}.min-w-\[40px\]{min-width:40px}.min-w-\[8rem\]{min-width:8rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-\[1089px\]{max-width:1089px}.max-w-\[120px\]{max-width:120px}.max-w-\[12rem\]{max-width:12rem}.max-w-\[130px\]{max-width:130px}.max-w-\[165px\]{max-width:165px}.max-w-\[60rem\]{max-width:60rem}.max-w-\[65\%\]{max-width:65%}.max-w-\[80px\]{max-width:80px}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.table-fixed{table-layout:fixed}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-y-1\/2{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y:-50%}.rotate-180{--tw-rotate:180deg}.rotate-180,.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.cursor-help{cursor:help}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-8{gap:2rem}.gap-\[10px\]{gap:10px}.gap-x-1{-moz-column-gap:.25rem;column-gap:.25rem}.gap-x-2{-moz-column-gap:.5rem;column-gap:.5rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-x-40{-moz-column-gap:10rem;column-gap:10rem}.gap-x-6{-moz-column-gap:1.5rem;column-gap:1.5rem}.gap-y-0{row-gap:0}.gap-y-1{row-gap:.25rem}.gap-y-3{row-gap:.75rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem*var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem*var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis}.truncate,.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-\[14px\]{border-radius:14px}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-l-lg{border-top-left-radius:.5rem;border-bottom-left-radius:.5rem}.rounded-r-lg{border-top-right-radius:.5rem;border-bottom-right-radius:.5rem}.rounded-t-2xl{border-top-left-radius:1rem;border-top-right-radius:1rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-t-4{border-top-width:4px}.border-\[var\(--cp-card-title-bg\)\]{border-color:var(--cp-card-title-bg)}.border-\[var\(--cp-filter-border\)\]{border-color:var(--cp-filter-border)}.border-\[var\(--cp-subscription-item-border\)\]{border-color:var(--cp-subscription-item-border)}.border-\[var\(--cp-tabs-active-bg\)\]{border-color:var(--cp-tabs-active-bg)}.border-\[var\(--cp-tabs-border\)\]{border-color:var(--cp-tabs-border)}.border-\[var\(--pt-card-header-bg\)\]{border-color:var(--pt-card-header-bg)}.border-\[var\(--pt-card-price-border\)\]{border-color:var(--pt-card-price-border)}.border-\[var\(--pt-tabs-border\)\]{border-color:var(--pt-tabs-border)}.border-\[var\(--pt-tabs-indicator\)\]{border-color:var(--pt-tabs-indicator)}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-gray-900{--tw-border-opacity:1;border-color:rgb(17 24 39/var(--tw-border-opacity,1))}.border-neutral-200{--tw-border-opacity:1;border-color:rgb(229 229 229/var(--tw-border-opacity,1))}.border-red-200{--tw-border-opacity:1;border-color:rgb(254 202 202/var(--tw-border-opacity,1))}.border-t-gray-600{--tw-border-opacity:1;border-top-color:rgb(75 85 99/var(--tw-border-opacity,1))}.bg-\[\#0F0F0F\]{--tw-bg-opacity:1;background-color:rgb(15 15 15/var(--tw-bg-opacity,1))}.bg-\[var\(--cp-button-bg\)\]{background-color:var(--cp-button-bg)}.bg-\[var\(--cp-card-content-bg\)\]{background-color:var(--cp-card-content-bg)}.bg-\[var\(--cp-card-title-bg\)\]{background-color:var(--cp-card-title-bg)}.bg-\[var\(--cp-filter-active-bg\)\]{background-color:var(--cp-filter-active-bg)}.bg-\[var\(--cp-filter-bg\)\]{background-color:var(--cp-filter-bg)}.bg-\[var\(--cp-filter-count-bg\)\]{background-color:var(--cp-filter-count-bg)}.bg-\[var\(--cp-section-bg\)\]{background-color:var(--cp-section-bg)}.bg-\[var\(--cp-section-content-bg\)\]{background-color:var(--cp-section-content-bg)}.bg-\[var\(--cp-section-icon-bg\)\]{background-color:var(--cp-section-icon-bg)}.bg-\[var\(--cp-subscription-item-bg\)\]{background-color:var(--cp-subscription-item-bg)}.bg-\[var\(--cp-tabs-active-bg\)\]{background-color:var(--cp-tabs-active-bg)}.bg-\[var\(--cp-tabs-bg\)\]{background-color:var(--cp-tabs-bg)}.bg-\[var\(--pt-button-bg\)\]{background-color:var(--pt-button-bg)}.bg-\[var\(--pt-button-secondary-bg\)\]{background-color:var(--pt-button-secondary-bg)}.bg-\[var\(--pt-card-bg\)\]{background-color:var(--pt-card-bg)}.bg-\[var\(--pt-card-header-bg\)\]{background-color:var(--pt-card-header-bg)}.bg-\[var\(--pt-card-price-bg\)\]{background-color:var(--pt-card-price-bg)}.bg-\[var\(--pt-current-sub-card-header-bg\)\]{background-color:var(--pt-current-sub-card-header-bg)}.bg-\[var\(--pt-free-trial-bg\)\]{background-color:var(--pt-free-trial-bg)}.bg-\[var\(--pt-interval-active-bg\)\]{background-color:var(--pt-interval-active-bg)}.bg-\[var\(--pt-interval-bg\)\]{background-color:var(--pt-interval-bg)}.bg-black\/50{background-color:rgba(0,0,0,.5)}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-gray-500{--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity,1))}.bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-neutral-100{--tw-bg-opacity:1;background-color:rgb(245 245 245/var(--tw-bg-opacity,1))}.bg-purple-500{--tw-bg-opacity:1;background-color:rgb(168 85 247/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-yellow-500{--tw-bg-opacity:1;background-color:rgb(234 179 8/var(--tw-bg-opacity,1))}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.from-\[\#DEF764\]{--tw-gradient-from:#def764 var(--tw-gradient-from-position);--tw-gradient-to:hsla(70,90%,68%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-\[var\(--pt-card-gradient\)\]{--tw-gradient-from:var(--pt-card-gradient) var(--tw-gradient-from-position);--tw-gradient-to:hsla(0,0%,100%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-\[var\(--pt-card-bg\)\]{--tw-gradient-to:var(--pt-card-bg) var(--tw-gradient-to-position)}.to-white{--tw-gradient-to:#fff var(--tw-gradient-to-position)}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-10{padding-bottom:2.5rem}.pb-2{padding-bottom:.5rem}.pb-4{padding-bottom:1rem}.pb-\[2px\]{padding-bottom:2px}.pb-\[72px\]{padding-bottom:72px}.pl-10{padding-left:2.5rem}.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pr-10{padding-right:2.5rem}.pr-12{padding-right:3rem}.pr-3{padding-right:.75rem}.pr-8{padding-right:2rem}.pr-\[5px\]{padding-right:5px}.pt-2{padding-top:.5rem}.pt-2\.5{padding-top:.625rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-\[21px\]{padding-top:21px}.pt-\[6px\]{padding-top:6px}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-sans{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[16px\]{font-size:16px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-light{font-weight:300}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.leading-\[120\%\]{line-height:120%}.text-\[var\(--cp-button-text\)\]{color:var(--cp-button-text)}.text-\[var\(--cp-card-detail-label\)\]{color:var(--cp-card-detail-label)}.text-\[var\(--cp-card-detail-value\)\]{color:var(--cp-card-detail-value)}.text-\[var\(--cp-card-title-text\)\]{color:var(--cp-card-title-text)}.text-\[var\(--cp-filter-active-text\)\]{color:var(--cp-filter-active-text)}.text-\[var\(--cp-filter-count-text\)\]{color:var(--cp-filter-count-text)}.text-\[var\(--cp-filter-text\)\]{color:var(--cp-filter-text)}.text-\[var\(--cp-link-color\)\]{color:var(--cp-link-color)}.text-\[var\(--cp-section-empty-text\)\]{color:var(--cp-section-empty-text)}.text-\[var\(--cp-section-icon-color\)\]{color:var(--cp-section-icon-color)}.text-\[var\(--cp-section-title-text\)\]{color:var(--cp-section-title-text)}.text-\[var\(--cp-subscription-item-text\)\]{color:var(--cp-subscription-item-text)}.text-\[var\(--cp-table-header-text\)\]{color:var(--cp-table-header-text)}.text-\[var\(--cp-table-text\)\]{color:var(--cp-table-text)}.text-\[var\(--cp-tabs-active-text\)\]{color:var(--cp-tabs-active-text)}.text-\[var\(--cp-tabs-inactive-text\)\]{color:var(--cp-tabs-inactive-text)}.text-\[var\(--pt-button-link\)\]{color:var(--pt-button-link)}.text-\[var\(--pt-button-secondary-text\)\]{color:var(--pt-button-secondary-text)}.text-\[var\(--pt-button-text\)\]{color:var(--pt-button-text)}.text-\[var\(--pt-card-description-text\)\]{color:var(--pt-card-description-text)}.text-\[var\(--pt-card-header-text\)\]{color:var(--pt-card-header-text)}.text-\[var\(--pt-card-price-amount\)\]{color:var(--pt-card-price-amount)}.text-\[var\(--pt-card-price-secondary-text\)\]{color:var(--pt-card-price-secondary-text)}.text-\[var\(--pt-current-sub-card-header-text\)\]{color:var(--pt-current-sub-card-header-text)}.text-\[var\(--pt-feature-icon\)\]{color:var(--pt-feature-icon)}.text-\[var\(--pt-feature-text\)\]{color:var(--pt-feature-text)}.text-\[var\(--pt-free-trial-text\)\]{color:var(--pt-free-trial-text)}.text-\[var\(--pt-interval-active-text\)\]{color:var(--pt-interval-active-text)}.text-\[var\(--pt-interval-inactive-text\)\]{color:var(--pt-interval-inactive-text)}.text-\[var\(--pt-tabs-active-text\)\]{color:var(--pt-tabs-active-text)}.text-\[var\(--pt-tabs-inactive-text\)\]{color:var(--pt-tabs-inactive-text)}.text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-green-500{--tw-text-opacity:1;color:rgb(34 197 94/var(--tw-text-opacity,1))}.text-neutral-500{--tw-text-opacity:1;color:rgb(115 115 115/var(--tw-text-opacity,1))}.text-neutral-900{--tw-text-opacity:1;color:rgb(23 23 23/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-70{opacity:.7}.shadow-2xl{--tw-shadow:0 25px 50px -12px rgba(0,0,0,.25);--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color)}.shadow-2xl,.shadow-lg{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-sm,.shadow-xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.outline-none{outline:2px solid transparent;outline-offset:2px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}:root{--mfx-grey-50:#fafafa;--mfx-grey-100:#f4f4f5;--mfx-grey-200:#e4e4e7;--mfx-grey-300:#d4d4d8;--mfx-grey-400:#a1a1aa;--mfx-grey-500:#71717a;--mfx-grey-600:#52525b;--mfx-grey-700:#3f3f46;--mfx-grey-800:#27272a;--mfx-grey-900:#18181b;--mfx-primary:#3d3d3d;--mfx-secondary:#def764;--mfx-blue:#006fee;--mfx-black:#0f0f0f;--mfx-success:#17c964;--mfx-white:#fff;--mfx-dark:#191919;--mfx-danger:#de1135;--mfx-warning:#f5a524;--mfx-green-100:#e9ffd4;--mfx-green-200:#e6f7ea;--mfx-green-500:#6fe200;--mfx-green-600:#0bb02f;--mfx-red-100:#ffe5e5;--mfx-red-500:#e60000;--mfx-red-600:#cf2140;--mfx-neutral-100:#f5f5f5;--mfx-neutral-200:#e5e5e5;--mfx-font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--mfx-border-radius:0.5rem;--mfx-border-radius-lg:0.75rem;--mfx-border-radius-xl:1rem;--mfx-border-radius-full:9999px;--mfx-transition:all 0.2s ease;--mfx-shadow-sm:0 1px 2px 0 rgba(0,0,0,.05);--mfx-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06);--mfx-shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06)}.metrifox-customer-portal,.metrifox-pricing-table{font-family:var(--mfx-font-family);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.mfx-flex{display:flex}.mfx-flex-col{flex-direction:column}.mfx-items-center{align-items:center}.mfx-justify-center{justify-content:center}.mfx-justify-between{justify-content:space-between}.mfx-gap-1{gap:.25rem}.mfx-gap-2{gap:.5rem}.mfx-gap-3{gap:.75rem}.mfx-gap-4{gap:1rem}.mfx-p-4{padding:1rem}.mfx-p-6{padding:1.5rem}.mfx-px-4{padding-left:1rem;padding-right:1rem}.mfx-py-2{padding-top:.5rem;padding-bottom:.5rem}.mfx-mb-2{margin-bottom:.5rem}.mfx-mb-4{margin-bottom:1rem}.mfx-mt-4{margin-top:1rem}.mfx-text-sm{font-size:.875rem}.mfx-text-xs{font-size:.75rem}.mfx-text-lg{font-size:1.125rem}.mfx-text-xl{font-size:1.25rem}.mfx-text-2xl{font-size:1.5rem}.mfx-font-medium{font-weight:500}.mfx-font-semibold{font-weight:600}.mfx-font-bold{font-weight:700}.mfx-text-center{text-align:center}.mfx-text-primary{color:var(--mfx-primary)}.mfx-text-muted{color:var(--mfx-grey-500)}.mfx-text-success{color:var(--mfx-green-600)}.mfx-text-danger{color:var(--mfx-danger)}.mfx-text-warning{color:var(--mfx-warning)}.mfx-bg-white{background-color:var(--mfx-white)}.mfx-bg-grey-50{background-color:var(--mfx-grey-50)}.mfx-bg-grey-100{background-color:var(--mfx-grey-100)}.mfx-bg-primary{background-color:var(--mfx-primary)}.mfx-border{border:1px solid var(--mfx-grey-200)}.mfx-rounded{border-radius:var(--mfx-border-radius)}.mfx-rounded-lg{border-radius:var(--mfx-border-radius-lg)}.mfx-rounded-xl{border-radius:var(--mfx-border-radius-xl)}.mfx-rounded-full{border-radius:var(--mfx-border-radius-full)}@keyframes mfx-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes mfx-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes mfx-fade-in{0%{opacity:0}to{opacity:1}}@keyframes mfx-slide-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mfx-skeleton{background:linear-gradient(90deg,var(--mfx-grey-200) 25%,var(--mfx-grey-100) 50%,var(--mfx-grey-200) 75%);background-size:200% 100%;animation:mfx-shimmer 1.5s infinite;border-radius:var(--mfx-border-radius)}.mfx-spinner{width:1.5rem;height:1.5rem;border:2px solid var(--mfx-grey-200);border-top-color:var(--mfx-primary);border-radius:50%;animation:mfx-spin .8s linear infinite}.mfx-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--mfx-border-radius);border:none;cursor:pointer;transition:var(--mfx-transition)}.mfx-btn:disabled{opacity:.5;cursor:not-allowed}.mfx-btn-primary{background-color:var(--mfx-primary);color:var(--mfx-white)}.mfx-btn-primary:hover:not(:disabled){opacity:.9}.mfx-btn-secondary{background-color:var(--mfx-grey-100);color:var(--mfx-black)}.mfx-btn-secondary:hover:not(:disabled){background-color:var(--mfx-grey-200)}.mfx-card{background-color:var(--mfx-white);border:1px solid var(--mfx-grey-200);border-radius:var(--mfx-border-radius-lg);overflow:hidden}.mfx-badge{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:.75rem;font-weight:500;border-radius:var(--mfx-border-radius-full)}.mfx-badge-success{background-color:var(--mfx-green-200);color:var(--mfx-green-600)}.mfx-badge-warning{background-color:#fef3c7;color:#d97706}.mfx-badge-danger{background-color:var(--mfx-red-100);color:var(--mfx-red-600)}.mfx-badge-info{background-color:#dbeafe;color:#2563eb}.mfx-badge-neutral{background-color:var(--mfx-grey-100);color:var(--mfx-grey-600)}@media (max-width:640px){.mfx-hide-sm{display:none}}@media (min-width:641px){.mfx-show-sm{display:none}}@media (max-width:768px){.mfx-hide-md{display:none}}@media (min-width:769px){.mfx-show-md{display:none}}.mfx-btn:focus-visible,.mfx-input:focus-visible,.mfx-tab:focus-visible{outline:2px solid var(--mfx-blue);outline-offset:2px}@media (prefers-reduced-motion:reduce){.mfx-skeleton,.mfx-spinner{animation:none}*{transition-duration:.01ms!important}}.mfx-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media print{.metrifox-customer-portal,.metrifox-pricing-table{color:#000;background:#fff}.mfx-btn,.mfx-tab{border:1px solid #000}.mfx-skeleton{background:#e5e5e5;animation:none}}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:left-\[2px\]:after{content:var(--tw-content);left:2px}.after\:top-\[2px\]:after{content:var(--tw-content);top:2px}.after\:h-4:after{content:var(--tw-content);height:1rem}.after\:w-4:after{content:var(--tw-content);width:1rem}.after\:rounded-full:after{content:var(--tw-content);border-radius:9999px}.after\:bg-white:after{content:var(--tw-content);--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.after\:transition-all:after{content:var(--tw-content);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.after\:content-\[\'\'\]:after{--tw-content:"";content:var(--tw-content)}.first\:border-t-0:first-child{border-top-width:0}.first\:pt-0:first-child{padding-top:0}.last\:border-0:last-child{border-width:0}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-gray-700:hover{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity,1))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.hover\:opacity-80:hover{opacity:.8}.hover\:opacity-90:hover{opacity:.9}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-gray-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(156 163 175/var(--tw-ring-opacity,1))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.peer:checked~.peer-checked\:bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.peer:checked~.peer-checked\:after\:translate-x-full:after{content:var(--tw-content);--tw-translate-x:100%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:focus~.peer-focus\:outline-none{outline:2px solid transparent;outline-offset:2px}@media not all and (min-width:768px){.max-md\:bottom-0{bottom:0}.max-md\:w-full{width:100%}.max-md\:rounded-none{border-radius:0}.max-md\:pb-4{padding-bottom:1rem}}@media (min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
File without changes
File without changes