@rolatech/angular-components 0.0.1

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 (62) hide show
  1. package/README.md +7 -0
  2. package/fesm2022/rolatech-angular-components.mjs +1845 -0
  3. package/fesm2022/rolatech-angular-components.mjs.map +1 -0
  4. package/index.d.ts +56 -0
  5. package/lib/accordion/accordion.component.d.ts +6 -0
  6. package/lib/angular-components.module.d.ts +7 -0
  7. package/lib/avatar/avatar.component.d.ts +12 -0
  8. package/lib/base.component.d.ts +14 -0
  9. package/lib/chip-bar/chip-bar.component.d.ts +30 -0
  10. package/lib/confirmation-dialog/confirmation-dialog.component.d.ts +13 -0
  11. package/lib/console-layout/console-layout.component.d.ts +5 -0
  12. package/lib/container/container.component.d.ts +7 -0
  13. package/lib/content/content.component.d.ts +5 -0
  14. package/lib/drawer/drawer-animations.d.ts +6 -0
  15. package/lib/drawer/drawer.component.d.ts +42 -0
  16. package/lib/editor/editor.component.d.ts +28 -0
  17. package/lib/empty/empty.component.d.ts +5 -0
  18. package/lib/filter/filter.component.d.ts +5 -0
  19. package/lib/folder/folder.component.d.ts +5 -0
  20. package/lib/footer/footer.component.d.ts +10 -0
  21. package/lib/icon/icon.component.d.ts +10 -0
  22. package/lib/icon-button/icon-button.component.d.ts +6 -0
  23. package/lib/image/image.component.d.ts +11 -0
  24. package/lib/image-placeholder/image-placeholder.component.d.ts +7 -0
  25. package/lib/image-preview-dialog/image-preview-dialog.component.d.ts +18 -0
  26. package/lib/input/input.component.d.ts +7 -0
  27. package/lib/layout/layout.component.d.ts +32 -0
  28. package/lib/list/list.component.d.ts +7 -0
  29. package/lib/material.module.d.ts +50 -0
  30. package/lib/media-list/media-list.component.d.ts +13 -0
  31. package/lib/media-list-item/media-list-item.component.d.ts +15 -0
  32. package/lib/media-preview/media-preview.component.d.ts +5 -0
  33. package/lib/media-preview-dialog/media-preview-dialog.component.d.ts +18 -0
  34. package/lib/media-upload/media-upload.component.d.ts +18 -0
  35. package/lib/media-upload-dialog/media-upload-dialog.component.d.ts +32 -0
  36. package/lib/menu-icon/menu-icon.component.d.ts +6 -0
  37. package/lib/menu-user/menu-user.component.d.ts +16 -0
  38. package/lib/mini-guide/mini-guide.component.d.ts +26 -0
  39. package/lib/not-found/not-found.component.d.ts +11 -0
  40. package/lib/page/page.component.d.ts +10 -0
  41. package/lib/paginator/paginator.component.d.ts +7 -0
  42. package/lib/panel/panel-animations.d.ts +6 -0
  43. package/lib/panel/panel-header.component.d.ts +5 -0
  44. package/lib/panel/panel.component.d.ts +17 -0
  45. package/lib/rich-item/rich-item.component.d.ts +13 -0
  46. package/lib/rich-view/rich-view.component.d.ts +18 -0
  47. package/lib/spinner/spinner.component.d.ts +16 -0
  48. package/lib/storage-bucket-create/storage-bucket-create.component.d.ts +10 -0
  49. package/lib/storage-file-upload/storage-file-upload.component.d.ts +17 -0
  50. package/lib/storage-folder-create/storage-folder-create.component.d.ts +11 -0
  51. package/lib/tab/tab.component.d.ts +10 -0
  52. package/lib/table/table.component.d.ts +18 -0
  53. package/lib/tabs/tabs.component.d.ts +19 -0
  54. package/lib/thumbnail/thumbnail.component.d.ts +20 -0
  55. package/lib/title/title.component.d.ts +9 -0
  56. package/lib/toolbar/toolbar.component.d.ts +13 -0
  57. package/lib/topbar/topbar.component.d.ts +22 -0
  58. package/lib/topbar-avatar-menu/topbar-avatar-menu.component.d.ts +10 -0
  59. package/lib/wechat-connect-dialog/wechat-connect-dialog.component.d.ts +19 -0
  60. package/package.json +50 -0
  61. package/provider.d.ts +17 -0
  62. package/themes/_default.scss +1 -0
@@ -0,0 +1,13 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class RichItemComponent {
3
+ hasClass: boolean;
4
+ list: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
5
+ thumbnail: import("@angular/core").InputSignal<string | undefined>;
6
+ avatar: import("@angular/core").InputSignal<string | undefined>;
7
+ title: import("@angular/core").InputSignal<string | undefined>;
8
+ subtitle: import("@angular/core").InputSignal<string | undefined>;
9
+ price: import("@angular/core").InputSignal<any>;
10
+ thumbnailRatio: import("@angular/core").InputSignal<string>;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<RichItemComponent, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<RichItemComponent, "rolatech-rich-item", never, { "list": { "alias": "list"; "required": false; "isSignal": true; }; "thumbnail": { "alias": "thumbnail"; "required": false; "isSignal": true; }; "avatar": { "alias": "avatar"; "required": false; "isSignal": true; }; "title": { "alias": "title"; "required": false; "isSignal": true; }; "subtitle": { "alias": "subtitle"; "required": false; "isSignal": true; }; "price": { "alias": "price"; "required": false; "isSignal": true; }; "thumbnailRatio": { "alias": "thumbnailRatio"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true, never>;
13
+ }
@@ -0,0 +1,18 @@
1
+ import { AfterViewInit, ElementRef, OnInit } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class RichViewComponent implements OnInit, AfterViewInit {
4
+ hasClass: boolean;
5
+ disableScrollbar: boolean;
6
+ platformId: Object;
7
+ el: ElementRef<any>;
8
+ items: import("@angular/core").Signal<readonly ElementRef<any>[]>;
9
+ list: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
10
+ wrap: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
11
+ private resizeObserver;
12
+ constructor();
13
+ ngOnInit(): void;
14
+ ngAfterViewInit(): void;
15
+ setCustomProperties(width: number): void;
16
+ static ɵfac: i0.ɵɵFactoryDeclaration<RichViewComponent, never>;
17
+ static ɵcmp: i0.ɵɵComponentDeclaration<RichViewComponent, "rolatech-rich-view", never, { "list": { "alias": "list"; "required": false; "isSignal": true; }; "wrap": { "alias": "wrap"; "required": false; "isSignal": true; }; }, {}, ["items"], ["*"], true, never>;
18
+ }
@@ -0,0 +1,16 @@
1
+ import { AfterViewInit, ChangeDetectorRef, ElementRef, OnDestroy } from '@angular/core';
2
+ import { LoadingService } from '@rolatech/angular-services';
3
+ import { Subscription } from 'rxjs';
4
+ import * as i0 from "@angular/core";
5
+ export declare class SpinnerComponent implements AfterViewInit, OnDestroy {
6
+ title: import("@angular/core").InputSignal<string | undefined>;
7
+ isLoading: boolean;
8
+ loadingSubscription: Subscription;
9
+ loadingService: LoadingService;
10
+ _elmRef: ElementRef<any>;
11
+ _changeDetectorRef: ChangeDetectorRef;
12
+ ngAfterViewInit(): void;
13
+ ngOnDestroy(): void;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<SpinnerComponent, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<SpinnerComponent, "rolatech-spinner", never, { "title": { "alias": "title"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
16
+ }
@@ -0,0 +1,10 @@
1
+ import { DoCheck, OnInit } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class StorageBucketCreateComponent implements OnInit, DoCheck {
4
+ name: import("@angular/core").InputSignal<string | undefined>;
5
+ output: import("@angular/core").OutputEmitterRef<any>;
6
+ ngOnInit(): void;
7
+ ngDoCheck(): void;
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<StorageBucketCreateComponent, never>;
9
+ static ɵcmp: i0.ɵɵComponentDeclaration<StorageBucketCreateComponent, "rolatech-storage-bucket-create", never, { "name": { "alias": "name"; "required": false; "isSignal": true; }; }, { "output": "output"; }, never, never, true, never>;
10
+ }
@@ -0,0 +1,17 @@
1
+ import { DoCheck, OnInit } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class StorageFileUploadComponent implements OnInit, DoCheck {
4
+ title: import("@angular/core").InputSignal<string | undefined>;
5
+ output: import("@angular/core").OutputEmitterRef<any>;
6
+ fileData: any;
7
+ progressInfos: any;
8
+ isFinished: boolean;
9
+ isUploaded: boolean;
10
+ file: any;
11
+ ngOnInit(): void;
12
+ ngDoCheck(): void;
13
+ selectFiles(event: any): void;
14
+ removeFile(): void;
15
+ static ɵfac: i0.ɵɵFactoryDeclaration<StorageFileUploadComponent, never>;
16
+ static ɵcmp: i0.ɵɵComponentDeclaration<StorageFileUploadComponent, "rolatech-storage-file-upload", never, { "title": { "alias": "title"; "required": false; "isSignal": true; }; }, { "output": "output"; }, never, never, true, never>;
17
+ }
@@ -0,0 +1,11 @@
1
+ import { DoCheck, OnInit } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class StorageFolderCreateComponent implements OnInit, DoCheck {
4
+ name: import("@angular/core").InputSignal<string | undefined>;
5
+ isPublic: import("@angular/core").InputSignal<boolean>;
6
+ output: import("@angular/core").OutputEmitterRef<any>;
7
+ ngOnInit(): void;
8
+ ngDoCheck(): void;
9
+ static ɵfac: i0.ɵɵFactoryDeclaration<StorageFolderCreateComponent, never>;
10
+ static ɵcmp: i0.ɵɵComponentDeclaration<StorageFolderCreateComponent, "rolatech-storage-folder-create", never, { "name": { "alias": "name"; "required": false; "isSignal": true; }; "isPublic": { "alias": "isPublic"; "required": false; "isSignal": true; }; }, { "output": "output"; }, never, never, true, never>;
11
+ }
@@ -0,0 +1,10 @@
1
+ import { ElementRef } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class TabComponent {
4
+ hasId: string;
5
+ hasClass: boolean;
6
+ label: import("@angular/core").InputSignal<unknown>;
7
+ item: import("@angular/core").Signal<ElementRef<any> | undefined>;
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<TabComponent, never>;
9
+ static ɵcmp: i0.ɵɵComponentDeclaration<TabComponent, "rolatech-tab", never, { "label": { "alias": "label"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
10
+ }
@@ -0,0 +1,18 @@
1
+ import { OnInit } from '@angular/core';
2
+ import { CdkTableDataSourceInput } from '@angular/cdk/table';
3
+ import * as i0 from "@angular/core";
4
+ export interface Column {
5
+ ref: string;
6
+ name: string;
7
+ }
8
+ export interface TableData<T> {
9
+ columns: Column[];
10
+ data: CdkTableDataSourceInput<T>;
11
+ }
12
+ export declare class TableComponent implements OnInit {
13
+ dataSource: import("@angular/core").InputSignal<TableData<any>>;
14
+ displayedColumns: string[];
15
+ ngOnInit(): void;
16
+ static ɵfac: i0.ɵɵFactoryDeclaration<TableComponent, never>;
17
+ static ɵcmp: i0.ɵɵComponentDeclaration<TableComponent, "rolatech-table", never, { "dataSource": { "alias": "dataSource"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
18
+ }
@@ -0,0 +1,19 @@
1
+ import { AfterContentInit, AfterViewInit, ElementRef, OnInit, Renderer2 } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class TabsComponent implements OnInit, AfterViewInit, AfterContentInit {
4
+ ngAfterContentInit(): void;
5
+ renderer: Renderer2;
6
+ tabs: import("@angular/core").Signal<readonly ElementRef<any>[]>;
7
+ selectionBar: import("@angular/core").Signal<ElementRef<any>>;
8
+ select: import("@angular/core").ModelSignal<number>;
9
+ loading: import("@angular/core").InputSignal<boolean>;
10
+ preSelect: number;
11
+ clientWidths: number[];
12
+ protected _isServer: boolean;
13
+ ngOnInit(): void;
14
+ ngAfterViewInit(): void;
15
+ init(): void;
16
+ getOffset(index: number): number;
17
+ static ɵfac: i0.ɵɵFactoryDeclaration<TabsComponent, never>;
18
+ static ɵcmp: i0.ɵɵComponentDeclaration<TabsComponent, "rolatech-tabs", never, { "select": { "alias": "select"; "required": false; "isSignal": true; }; "loading": { "alias": "loading"; "required": false; "isSignal": true; }; }, { "select": "selectChange"; }, ["tabs"], ["*"], true, never>;
19
+ }
@@ -0,0 +1,20 @@
1
+ import { ElementRef, Renderer2 } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export declare class ThumbnailComponent {
4
+ hasClass: boolean;
5
+ myColor: string;
6
+ el: ElementRef<any>;
7
+ src: import("@angular/core").InputSignal<string | undefined>;
8
+ size: import("@angular/core").InputSignal<string | undefined>;
9
+ mode: import("@angular/core").InputSignal<string>;
10
+ ratio: import("@angular/core").InputSignal<string>;
11
+ img: import("@angular/core").Signal<ElementRef<any>>;
12
+ width: import("@angular/core").InputSignal<number | undefined>;
13
+ height: import("@angular/core").InputSignal<number | undefined>;
14
+ renderer: Renderer2;
15
+ sizea: import("@angular/core").EffectRef;
16
+ full: import("@angular/core").EffectRef;
17
+ ratioSet: import("@angular/core").EffectRef;
18
+ static ɵfac: i0.ɵɵFactoryDeclaration<ThumbnailComponent, never>;
19
+ static ɵcmp: i0.ɵɵComponentDeclaration<ThumbnailComponent, "rolatech-thumbnail", never, { "src": { "alias": "src"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; "mode": { "alias": "mode"; "required": false; "isSignal": true; }; "ratio": { "alias": "ratio"; "required": false; "isSignal": true; }; "width": { "alias": "width"; "required": false; "isSignal": true; }; "height": { "alias": "height"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
20
+ }
@@ -0,0 +1,9 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class TitleComponent {
3
+ hasClass: boolean;
4
+ title: import("@angular/core").InputSignal<unknown>;
5
+ subtitle: import("@angular/core").InputSignal<unknown>;
6
+ large: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
7
+ static ɵfac: i0.ɵɵFactoryDeclaration<TitleComponent, never>;
8
+ static ɵcmp: i0.ɵɵComponentDeclaration<TitleComponent, "rolatech-title", never, { "title": { "alias": "title"; "required": false; "isSignal": true; }; "subtitle": { "alias": "subtitle"; "required": false; "isSignal": true; }; "large": { "alias": "large"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
9
+ }
@@ -0,0 +1,13 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class ToolbarComponent {
3
+ hasId: string;
4
+ hasClass: boolean;
5
+ title: import("@angular/core").InputSignal<unknown>;
6
+ subtitle: import("@angular/core").InputSignal<unknown>;
7
+ back: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
8
+ link: import("@angular/core").InputSignal<string>;
9
+ large: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
10
+ divider: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
11
+ static ɵfac: i0.ɵɵFactoryDeclaration<ToolbarComponent, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<ToolbarComponent, "rolatech-toolbar", never, { "title": { "alias": "title"; "required": false; "isSignal": true; }; "subtitle": { "alias": "subtitle"; "required": false; "isSignal": true; }; "back": { "alias": "back"; "required": false; "isSignal": true; }; "link": { "alias": "link"; "required": false; "isSignal": true; }; "large": { "alias": "large"; "required": false; "isSignal": true; }; "divider": { "alias": "divider"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true, never>;
13
+ }
@@ -0,0 +1,22 @@
1
+ import { ElementRef, OnInit, Renderer2 } from '@angular/core';
2
+ import { BreakpointObserver } from '@angular/cdk/layout';
3
+ import { DrawerComponent } from '../drawer/drawer.component';
4
+ import { MiniGuideComponent } from '../mini-guide/mini-guide.component';
5
+ import * as i0 from "@angular/core";
6
+ export declare class TopbarComponent implements OnInit {
7
+ hostId: string;
8
+ hasClass: boolean;
9
+ persistent: boolean | undefined;
10
+ el: ElementRef<any>;
11
+ renderer: Renderer2;
12
+ platformId: Object;
13
+ breakpointObserver: BreakpointObserver;
14
+ appLayout: import("../../provider").AppLayoutConfig;
15
+ link: import("@angular/core").InputSignal<string>;
16
+ appDrawer: DrawerComponent;
17
+ miniGuide: MiniGuideComponent;
18
+ ngOnInit(): void;
19
+ onToggle(): void;
20
+ static ɵfac: i0.ɵɵFactoryDeclaration<TopbarComponent, never>;
21
+ static ɵcmp: i0.ɵɵComponentDeclaration<TopbarComponent, "rolatech-topbar", never, { "link": { "alias": "link"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true, never>;
22
+ }
@@ -0,0 +1,10 @@
1
+ import { MatMenuPanel } from '@angular/material/menu';
2
+ import * as i0 from "@angular/core";
3
+ export declare class TopbarAvatarMenuComponent {
4
+ environment: any;
5
+ platformId: Object;
6
+ menu: import("@angular/core").InputSignal<MatMenuPanel<any>>;
7
+ avatar: import("@angular/core").InputSignal<string | undefined>;
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<TopbarAvatarMenuComponent, never>;
9
+ static ɵcmp: i0.ɵɵComponentDeclaration<TopbarAvatarMenuComponent, "rolatech-topbar-avatar-menu", never, { "menu": { "alias": "menu"; "required": true; "isSignal": true; }; "avatar": { "alias": "avatar"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
10
+ }
@@ -0,0 +1,19 @@
1
+ import { MatDialogRef } from '@angular/material/dialog';
2
+ import { SafeResourceUrl, DomSanitizer } from '@angular/platform-browser';
3
+ import * as i0 from "@angular/core";
4
+ export declare class WechatConnectDialogComponent {
5
+ dialogRef: MatDialogRef<any, any>;
6
+ environment: any;
7
+ appId: import("@angular/core").ModelSignal<unknown>;
8
+ redirectUri: import("@angular/core").ModelSignal<string>;
9
+ state: import("@angular/core").ModelSignal<unknown>;
10
+ urlSafe: SafeResourceUrl;
11
+ sanitizer: DomSanitizer;
12
+ baseUrl: string;
13
+ loaded: boolean;
14
+ constructor();
15
+ onNoClick(): void;
16
+ onLogin(event: any): void;
17
+ static ɵfac: i0.ɵɵFactoryDeclaration<WechatConnectDialogComponent, never>;
18
+ static ɵcmp: i0.ɵɵComponentDeclaration<WechatConnectDialogComponent, "rolatech-wechat-connect-dialog", never, { "appId": { "alias": "appId"; "required": false; "isSignal": true; }; "redirectUri": { "alias": "redirectUri"; "required": false; "isSignal": true; }; "state": { "alias": "state"; "required": false; "isSignal": true; }; }, { "appId": "appIdChange"; "redirectUri": "redirectUriChange"; "state": "stateChange"; }, never, never, true, never>;
19
+ }
package/package.json ADDED
@@ -0,0 +1,50 @@
1
+ {
2
+ "name": "@rolatech/angular-components",
3
+ "version": "0.0.1",
4
+ "private": false,
5
+ "description": "rolatech angular components",
6
+ "repository": {
7
+ "type": "git",
8
+ "url": "https://github.com/viablecell/rolatech-web.git"
9
+ },
10
+ "keywords": [
11
+ "rolatech",
12
+ "angular",
13
+ "component",
14
+ "development",
15
+ "store"
16
+ ],
17
+ "license": "MIT",
18
+ "peerDependencies": {
19
+ "@angular/core": "^19.0.0",
20
+ "@angular/common": "^19.0.0",
21
+ "@angular/router": "^19.0.0",
22
+ "@angular/material": "^19.0.0",
23
+ "@angular/animations": "^19.0.0",
24
+ "@angular/platform-browser": "^19.0.0",
25
+ "@angular/cdk": "^19.0.0",
26
+ "@angular/forms": "^19.0.0",
27
+ "quill": "^2.0.2",
28
+ "rxjs": "^7.8.1",
29
+ "lodash": "^4.17.21",
30
+ "@nx/angular": "^19.0.0 || ^20.0.0",
31
+ "@rolatech/angular-common": "file:../angular-common",
32
+ "@rolatech/angular-services": "file:../angular-services"
33
+ },
34
+ "dependencies": {
35
+ "tslib": "^2.3.0"
36
+ },
37
+ "exports": {
38
+ ".": {
39
+ "sass": "./themes/styles.scss",
40
+ "types": "./index.d.ts",
41
+ "default": "./fesm2022/rolatech-angular-components.mjs"
42
+ },
43
+ "./package.json": {
44
+ "default": "./package.json"
45
+ }
46
+ },
47
+ "module": "fesm2022/rolatech-angular-components.mjs",
48
+ "typings": "index.d.ts",
49
+ "sideEffects": false
50
+ }
package/provider.d.ts ADDED
@@ -0,0 +1,17 @@
1
+ import { EnvironmentProviders, InjectionToken } from '@angular/core';
2
+ export interface DrawerConfig {
3
+ persistent: boolean;
4
+ }
5
+ export interface AppTopbarConfig {
6
+ persistent: boolean;
7
+ }
8
+ export interface AppLayoutConfig {
9
+ title: string;
10
+ subtitle?: string;
11
+ persistent?: boolean | undefined;
12
+ topbar?: AppTopbarConfig;
13
+ drawer?: DrawerConfig;
14
+ guide?: boolean | undefined;
15
+ }
16
+ export declare const APP_LAYOUT: InjectionToken<AppLayoutConfig>;
17
+ export declare function provideAngularLayout(config?: AppLayoutConfig): EnvironmentProviders;
@@ -0,0 +1 @@
1
+ .pointer-events-none{pointer-events:none}.visible{visibility:visible}.invisible{visibility:hidden}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.left-0{left:0}.right-0{right:0}.top-0{top:0}.z-20{z-index:20}.z-30{z-index:30}.-m-1{margin:-.25rem}.m-3{margin:.75rem}.m-auto{margin:auto}.-mt-4{margin-top:-1rem}.mb-2{margin-bottom:.5rem}.ml-0{margin-left:0}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-\[40px\]{margin-left:40px}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-\[6px\]{margin-top:6px}.box-border{box-sizing:border-box}.line-clamp-1{-webkit-line-clamp:1}.line-clamp-1,.line-clamp-4{display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical}.line-clamp-4{-webkit-line-clamp:4}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.hidden{display:none}.aspect-video{aspect-ratio:16/9}.h-0{height:0}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-24{height:6rem}.h-4{height:1rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[190px\]{height:190px}.h-full{height:100%}.min-h-11{min-height:2.75rem}.min-h-\[320px\]{min-height:320px}.w-1\/2{width:50%}.w-10{width:2.5rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-20{width:5rem}.w-32{width:8rem}.w-4{width:1rem}.w-9{width:2.25rem}.w-\[190px\]{width:190px}.w-full{width:100%}.min-w-\[256px\]{min-width:256px}.min-w-\[320px\]{min-width:320px}.max-w-full{max-width:100%}.flex-1{flex:1 1 0%}.scale-90{--tw-scale-x:.9;--tw-scale-y:.9}.scale-90,.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))}.cursor-pointer{cursor:pointer}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-y-auto{overflow-y:auto}.overflow-y-hidden{overflow-y:hidden}.overflow-x-scroll{overflow-x:scroll}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-normal{white-space:normal}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-dashed{border-style:dashed}.border-\[--rt-border-color\]{border-color:var(--rt-border-color)}.bg-\[--rt-10-percent-layer\]{background-color:var(--rt-10-percent-layer)}.bg-\[--rt-base-background\]{background-color:var(--rt-base-background)}.bg-\[--rt-brand-color\]{background-color:var(--rt-brand-color)}.bg-\[--rt-raised-background\]{background-color:var(--rt-raised-background)}.bg-fixed{background-attachment:fixed}.fill-current{fill:currentColor}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-6{padding:1.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-12{padding-bottom:3rem;padding-top:3rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.pl-2{padding-left:.5rem}.pl-4{padding-left:1rem}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.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-medium{font-weight:500}.italic{font-style:italic}.leading-3{line-height:.75rem}.leading-none{line-height:1}.text-\[--rt-brand-color\]{color:var(--rt-brand-color)}.text-\[--rt-text-primary\]{color:var(--rt-text-primary)}.text-\[--rt-text-secondary\]{color:var(--rt-text-secondary)}.text-transparent{color:transparent}.underline{text-decoration-line:underline}.opacity-75{opacity:.75}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.outline-4{outline-width:4px}.outline-transparent{outline-color:transparent}.blur{--tw-blur:blur(8px)}.blur,.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{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.hover\:bg-\[--rt-10-percent-layer\]:hover{background-color:var(--rt-10-percent-layer)}.hover\:bg-\[--rt-base-background\]:hover{background-color:var(--rt-base-background)}.hover\:text-white:hover{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hover\:outline-\[--rt-raised-background\]:hover{outline-color:var(--rt-raised-background)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}@media (min-width:600px){.sm\:w-1\/3{width:33.333333%}}@media (min-width:768px){.md\:visible{visibility:visible}.md\:line-clamp-2{display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.md\:h-auto{height:auto}.md\:w-1\/4{width:25%}.md\:flex-row{flex-direction:row}.md\:gap-10{gap:2.5rem}.md\:px-16{padding-left:4rem;padding-right:4rem}.md\:text-lg{font-size:1.125rem}.md\:text-lg,.md\:text-xl{line-height:1.75rem}.md\:text-xl{font-size:1.25rem}}@media (min-width:1024px){.lg\:w-1\/6{width:16.666667%}}@media (min-width:1280px){.xl\:max-w-\[1024px\]{max-width:1024px}}@media (min-width:1536px){.\32xl\:max-w-\[1280px\]{max-width:1280px}}