lecom-ui 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.
- package/README.md +1 -0
- package/dist/components/Button/Button.js +140 -0
- package/dist/index.d.ts +163 -0
- package/dist/index.js +3 -0
- package/dist/lib/utils.js +8 -0
- package/dist/plugin/extend.ts +51 -0
- package/dist/plugin/fontFaces.ts +172 -0
- package/dist/plugin/general.ts +12 -0
- package/dist/plugin/plugin.cjs +5 -0
- package/dist/plugin/pluginDev.cjs +5 -0
- package/dist/plugin/template.ts +31 -0
- package/dist/plugin/typographies.ts +106 -0
- package/dist/plugin/varsTheme.ts +57 -0
- package/dist/public/fonts/Ibm/bold-700-italic.woff2 +0 -0
- package/dist/public/fonts/Ibm/bold-700.woff2 +0 -0
- package/dist/public/fonts/Ibm/light-300-italic.woff2 +0 -0
- package/dist/public/fonts/Ibm/light-300.woff2 +0 -0
- package/dist/public/fonts/Ibm/medium-500-italic.woff2 +0 -0
- package/dist/public/fonts/Ibm/medium-500.woff2 +0 -0
- package/dist/public/fonts/Ibm/regular-400-italic.woff2 +0 -0
- package/dist/public/fonts/Ibm/regular-400.woff2 +0 -0
- package/dist/public/fonts/Ibm/thin-100-italic.woff2 +0 -0
- package/dist/public/fonts/Ibm/thin-100.woff2 +0 -0
- package/dist/public/fonts/Montserrat/italic.woff2 +0 -0
- package/dist/public/fonts/Montserrat/normal.woff2 +0 -0
- package/dist/public/fonts/Roboto/black-900-italic.woff2 +0 -0
- package/dist/public/fonts/Roboto/black-900.woff2 +0 -0
- package/dist/public/fonts/Roboto/bold-700-italic.woff2 +0 -0
- package/dist/public/fonts/Roboto/bold-700.woff2 +0 -0
- package/dist/public/fonts/Roboto/light-300-italic.woff2 +0 -0
- package/dist/public/fonts/Roboto/light-300.woff2 +0 -0
- package/dist/public/fonts/Roboto/medium-500-italic.woff2 +0 -0
- package/dist/public/fonts/Roboto/medium-500.woff2 +0 -0
- package/dist/public/fonts/Roboto/regular-400-italic.woff2 +0 -0
- package/dist/public/fonts/Roboto/regular-400.woff2 +0 -0
- package/dist/public/fonts/Roboto/thin-100-italic.woff2 +0 -0
- package/dist/public/fonts/Roboto/thin-100.woff2 +0 -0
- package/dist/public/img/logo-lecom-ui.png +0 -0
- package/dist/public/img/logo-lecom.png +0 -0
- package/dist/style.min.css +1 -0
- package/dist/tokens/colors.js +125 -0
- package/dist/tokens/fonts.js +7 -0
- package/package.json +87 -0
package/README.md
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
lecom-ui
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { cn } from '../../lib/utils.js';
|
|
3
|
+
import { cva } from 'class-variance-authority';
|
|
4
|
+
|
|
5
|
+
const buttonVariants = cva(
|
|
6
|
+
"flex items-center justify-center gap-2 rounded-full font-roboto font-medium shadow-sm outline-none transition-all duration-300",
|
|
7
|
+
{
|
|
8
|
+
variants: {
|
|
9
|
+
variant: {
|
|
10
|
+
filled: "",
|
|
11
|
+
outlined: "",
|
|
12
|
+
tonal: "",
|
|
13
|
+
ghost: ""
|
|
14
|
+
},
|
|
15
|
+
size: {
|
|
16
|
+
small: "h-8 px-3 py-2 text-sm leading-none [&>svg]:w-5 [&>svg]:h-5",
|
|
17
|
+
medium: "h-10 px-4 py-3 text-sm leading-none [&>svg]:w-5 [&>svg]:h-5",
|
|
18
|
+
large: "h-12 px-5 py-4 text-base leading-none [&>svg]:w-5 [&>svg]:h-5",
|
|
19
|
+
extraLarge: "h-14 px-6 py-5 text-base leading-none [&>svg]:w-6 [&>svg]:h-6"
|
|
20
|
+
},
|
|
21
|
+
color: {
|
|
22
|
+
blue: "",
|
|
23
|
+
grey: "",
|
|
24
|
+
destructive: ""
|
|
25
|
+
},
|
|
26
|
+
iconButton: {
|
|
27
|
+
false: "",
|
|
28
|
+
true: ""
|
|
29
|
+
}
|
|
30
|
+
},
|
|
31
|
+
compoundVariants: [
|
|
32
|
+
{
|
|
33
|
+
variant: "filled",
|
|
34
|
+
color: "blue",
|
|
35
|
+
class: "bg-blue-600 text-white hover:bg-blue-700 focus:ring-4 focus:ring-blue-200 active:bg-blue-800 disabled:bg-blue-100 disabled:text-blue-400 disabled:cursor-not-allowed"
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
variant: "outlined",
|
|
39
|
+
color: "blue",
|
|
40
|
+
class: "bg-white text-blue-600 border border-blue-600 hover:bg-blue-100 focus:ring-4 focus:ring-blue-200 active:bg-blue-300 disabled:bg-white disabled:border-blue-200 disabled:text-blue-200 disabled:cursor-not-allowed"
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
variant: "tonal",
|
|
44
|
+
color: "blue",
|
|
45
|
+
class: "bg-blue-50 text-blue-600 shadow-none hover:bg-blue-100 focus:ring-4 focus:ring-blue-200 active:bg-blue-300 disabled:bg-blue-50 disabled:text-blue-200 disabled:cursor-not-allowed"
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
variant: "ghost",
|
|
49
|
+
color: "blue",
|
|
50
|
+
class: "bg-transparent text-blue-600 shadow-none hover:bg-blue-100 active:bg-blue-300 disabled:bg-transparent disabled:text-blue-200 disabled:cursor-not-allowed"
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
variant: "filled",
|
|
54
|
+
color: "grey",
|
|
55
|
+
class: "bg-grey-600 text-white hover:bg-grey-800 focus:ring-4 focus:ring-grey-200 focus:ring-opacity-30 active:bg-grey-900 disabled:bg-grey-200 disabled:text-grey-800 disabled:cursor-not-allowed"
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
variant: "outlined",
|
|
59
|
+
color: "grey",
|
|
60
|
+
class: "bg-white text-grey-800 border border-grey-600 hover:bg-grey-50 focus:ring-4 focus:ring-grey-200 focus:ring-opacity-30 active:bg-grey-200 disabled:bg-white disabled:border-grey-300 disabled:text-grey-300 disabled:cursor-not-allowed"
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
variant: "tonal",
|
|
64
|
+
color: "grey",
|
|
65
|
+
class: "bg-grey-50 text-grey-800 shadow-none hover:bg-grey-200 focus:ring-4 focus:ring-grey-200 focus:ring-opacity-30 active:bg-grey-400 disabled:bg-grey-50 disabled:text-grey-300 disabled:cursor-not-allowed"
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
variant: "ghost",
|
|
69
|
+
color: "grey",
|
|
70
|
+
class: "bg-transparent text-grey-800 shadow-none hover:bg-grey-200 active:bg-grey-400 disabled:bg-transparent disabled:text-grey-300 disabled:cursor-not-allowed"
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
variant: "filled",
|
|
74
|
+
color: "destructive",
|
|
75
|
+
class: "bg-red-600 text-white hover:bg-red-700 focus:ring-4 focus:ring-red-200 active:bg-red-800 disabled:bg-red-100 disabled:cursor-not-allowed"
|
|
76
|
+
},
|
|
77
|
+
{
|
|
78
|
+
variant: "outlined",
|
|
79
|
+
color: "destructive",
|
|
80
|
+
class: "bg-white text-red-600 border border-red-600 hover:bg-red-100 focus:ring-4 focus:ring-red-200 active:bg-red-300 disabled:bg-white disabled:border-red-200 disabled:text-red-100 disabled:cursor-not-allowed"
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
variant: "tonal",
|
|
84
|
+
color: "destructive",
|
|
85
|
+
class: "bg-red-50 text-red-600 shadow-none hover:bg-red-100 focus:ring-4 focus:ring-red-200 active:bg-red-300 disabled:bg-red-50 disabled:text-red-200 disabled:cursor-not-allowed"
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
variant: "ghost",
|
|
89
|
+
color: "destructive",
|
|
90
|
+
class: "bg-transparent text-red-600 shadow-none hover:bg-red-100 active:bg-red-300 disabled:bg-transparent disabled:text-red-200 disabled:cursor-not-allowed"
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
iconButton: true,
|
|
94
|
+
size: "small",
|
|
95
|
+
class: "rounded-full w-8 h-8 p-0"
|
|
96
|
+
},
|
|
97
|
+
{
|
|
98
|
+
iconButton: true,
|
|
99
|
+
size: "medium",
|
|
100
|
+
class: "rounded-full w-10 h-10 p-0"
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
iconButton: true,
|
|
104
|
+
size: "large",
|
|
105
|
+
class: "rounded-full w-12 h-12 p-0"
|
|
106
|
+
},
|
|
107
|
+
{
|
|
108
|
+
iconButton: true,
|
|
109
|
+
size: "extraLarge",
|
|
110
|
+
class: "rounded-full w-14 h-14 p-0"
|
|
111
|
+
}
|
|
112
|
+
],
|
|
113
|
+
defaultVariants: {
|
|
114
|
+
variant: "filled",
|
|
115
|
+
size: "medium",
|
|
116
|
+
color: "blue",
|
|
117
|
+
iconButton: false
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
);
|
|
121
|
+
const Button = React.forwardRef(
|
|
122
|
+
({ className, variant, size, color, iconButton, children, ...props }, ref) => {
|
|
123
|
+
const Comp = "button";
|
|
124
|
+
return /* @__PURE__ */ React.createElement(
|
|
125
|
+
Comp,
|
|
126
|
+
{
|
|
127
|
+
className: cn(
|
|
128
|
+
buttonVariants({ variant, size, color, iconButton, className }),
|
|
129
|
+
""
|
|
130
|
+
),
|
|
131
|
+
ref,
|
|
132
|
+
...props
|
|
133
|
+
},
|
|
134
|
+
children
|
|
135
|
+
);
|
|
136
|
+
}
|
|
137
|
+
);
|
|
138
|
+
Button.displayName = "Button";
|
|
139
|
+
|
|
140
|
+
export { Button, buttonVariants };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import * as class_variance_authority_types from 'class-variance-authority/types';
|
|
2
|
+
import * as React from 'react';
|
|
3
|
+
import { VariantProps } from 'class-variance-authority';
|
|
4
|
+
|
|
5
|
+
type Transparent = 'transparent';
|
|
6
|
+
type Black = 'black';
|
|
7
|
+
type White = 'white';
|
|
8
|
+
type Blue = 'blue-50' | 'blue-100' | 'blue-200' | 'blue-300' | 'blue-400' | 'blue-500' | 'blue-600' | 'blue-700' | 'blue-800' | 'blue-900' | 'blue-950';
|
|
9
|
+
type Grey = 'grey-50' | 'grey-100' | 'grey-200' | 'grey-300' | 'grey-400' | 'grey-500' | 'grey-600' | 'grey-700' | 'grey-800' | 'grey-900' | 'grey-950';
|
|
10
|
+
type Red = 'red-50' | 'red-100' | 'red-200' | 'red-300' | 'red-400' | 'red-500' | 'red-600' | 'red-700' | 'red-800' | 'red-900' | 'red-950';
|
|
11
|
+
type Yellow = 'yellow-50' | 'yellow-100' | 'yellow-200' | 'yellow-300' | 'yellow-400' | 'yellow-500' | 'yellow-600' | 'yellow-700' | 'yellow-800' | 'yellow-900' | 'yellow-950';
|
|
12
|
+
type Orange = 'orange-50' | 'orange-100' | 'orange-200' | 'orange-300' | 'orange-400' | 'orange-500' | 'orange-600' | 'orange-700' | 'orange-800' | 'orange-900' | 'orange-950';
|
|
13
|
+
type Purple = 'purple-50' | 'purple-100' | 'purple-200' | 'purple-300' | 'purple-400' | 'purple-500' | 'purple-600' | 'purple-700' | 'purple-800' | 'purple-900' | 'purple-950';
|
|
14
|
+
type Green = 'green-50' | 'green-100' | 'green-200' | 'green-300' | 'green-400' | 'green-500' | 'green-600' | 'green-700' | 'green-800' | 'green-900' | 'green-950';
|
|
15
|
+
type Pink = 'pink-50' | 'pink-100' | 'pink-200' | 'pink-300' | 'pink-400' | 'pink-500' | 'pink-600' | 'pink-700' | 'pink-800' | 'pink-900' | 'pink-950';
|
|
16
|
+
type Turquoise = 'turquoise-50' | 'turquoise-100' | 'turquoise-200' | 'turquoise-300' | 'turquoise-400' | 'turquoise-500' | 'turquoise-600' | 'turquoise-700' | 'turquoise-800' | 'turquoise-900' | 'turquoise-950';
|
|
17
|
+
type ColorToken = Transparent | Black | White | Blue | Grey | Red | Yellow | Orange | Purple | Green | Pink | Turquoise;
|
|
18
|
+
type TextColor = `text-${ColorToken}`;
|
|
19
|
+
type BgColor = `bg-${ColorToken}`;
|
|
20
|
+
type FillColor = `fill-${ColorToken}`;
|
|
21
|
+
type Color = 'transparent' | 'black' | 'white' | 'blue' | 'grey' | 'red' | 'yellow' | 'orange' | 'purple' | 'green' | 'pink' | 'turquoise';
|
|
22
|
+
declare const colors: {
|
|
23
|
+
transparent: string;
|
|
24
|
+
current: string;
|
|
25
|
+
black: string;
|
|
26
|
+
white: string;
|
|
27
|
+
blue: {
|
|
28
|
+
50: string;
|
|
29
|
+
100: string;
|
|
30
|
+
200: string;
|
|
31
|
+
300: string;
|
|
32
|
+
400: string;
|
|
33
|
+
500: string;
|
|
34
|
+
600: string;
|
|
35
|
+
700: string;
|
|
36
|
+
800: string;
|
|
37
|
+
900: string;
|
|
38
|
+
950: string;
|
|
39
|
+
};
|
|
40
|
+
grey: {
|
|
41
|
+
50: string;
|
|
42
|
+
100: string;
|
|
43
|
+
200: string;
|
|
44
|
+
300: string;
|
|
45
|
+
400: string;
|
|
46
|
+
500: string;
|
|
47
|
+
600: string;
|
|
48
|
+
700: string;
|
|
49
|
+
800: string;
|
|
50
|
+
900: string;
|
|
51
|
+
950: string;
|
|
52
|
+
};
|
|
53
|
+
red: {
|
|
54
|
+
50: string;
|
|
55
|
+
100: string;
|
|
56
|
+
200: string;
|
|
57
|
+
300: string;
|
|
58
|
+
400: string;
|
|
59
|
+
500: string;
|
|
60
|
+
600: string;
|
|
61
|
+
700: string;
|
|
62
|
+
800: string;
|
|
63
|
+
900: string;
|
|
64
|
+
950: string;
|
|
65
|
+
};
|
|
66
|
+
yellow: {
|
|
67
|
+
50: string;
|
|
68
|
+
100: string;
|
|
69
|
+
200: string;
|
|
70
|
+
300: string;
|
|
71
|
+
400: string;
|
|
72
|
+
500: string;
|
|
73
|
+
600: string;
|
|
74
|
+
700: string;
|
|
75
|
+
800: string;
|
|
76
|
+
900: string;
|
|
77
|
+
950: string;
|
|
78
|
+
};
|
|
79
|
+
orange: {
|
|
80
|
+
50: string;
|
|
81
|
+
100: string;
|
|
82
|
+
200: string;
|
|
83
|
+
300: string;
|
|
84
|
+
400: string;
|
|
85
|
+
500: string;
|
|
86
|
+
600: string;
|
|
87
|
+
700: string;
|
|
88
|
+
800: string;
|
|
89
|
+
900: string;
|
|
90
|
+
950: string;
|
|
91
|
+
};
|
|
92
|
+
purple: {
|
|
93
|
+
50: string;
|
|
94
|
+
100: string;
|
|
95
|
+
200: string;
|
|
96
|
+
300: string;
|
|
97
|
+
400: string;
|
|
98
|
+
500: string;
|
|
99
|
+
600: string;
|
|
100
|
+
700: string;
|
|
101
|
+
800: string;
|
|
102
|
+
900: string;
|
|
103
|
+
950: string;
|
|
104
|
+
};
|
|
105
|
+
green: {
|
|
106
|
+
50: string;
|
|
107
|
+
100: string;
|
|
108
|
+
200: string;
|
|
109
|
+
300: string;
|
|
110
|
+
400: string;
|
|
111
|
+
500: string;
|
|
112
|
+
600: string;
|
|
113
|
+
700: string;
|
|
114
|
+
800: string;
|
|
115
|
+
900: string;
|
|
116
|
+
950: string;
|
|
117
|
+
};
|
|
118
|
+
pink: {
|
|
119
|
+
50: string;
|
|
120
|
+
100: string;
|
|
121
|
+
200: string;
|
|
122
|
+
300: string;
|
|
123
|
+
400: string;
|
|
124
|
+
500: string;
|
|
125
|
+
600: string;
|
|
126
|
+
700: string;
|
|
127
|
+
800: string;
|
|
128
|
+
900: string;
|
|
129
|
+
950: string;
|
|
130
|
+
};
|
|
131
|
+
turquoise: {
|
|
132
|
+
50: string;
|
|
133
|
+
100: string;
|
|
134
|
+
200: string;
|
|
135
|
+
300: string;
|
|
136
|
+
400: string;
|
|
137
|
+
500: string;
|
|
138
|
+
600: string;
|
|
139
|
+
700: string;
|
|
140
|
+
800: string;
|
|
141
|
+
900: string;
|
|
142
|
+
950: string;
|
|
143
|
+
};
|
|
144
|
+
};
|
|
145
|
+
|
|
146
|
+
type Fonts = 'roboto' | 'montserrat' | 'ibm';
|
|
147
|
+
declare const fonts: {
|
|
148
|
+
roboto: string[];
|
|
149
|
+
montserrat: string[];
|
|
150
|
+
ibm: string[];
|
|
151
|
+
};
|
|
152
|
+
|
|
153
|
+
declare const buttonVariants: (props?: ({
|
|
154
|
+
variant?: "filled" | "outlined" | "tonal" | "ghost" | null | undefined;
|
|
155
|
+
size?: "small" | "medium" | "large" | "extraLarge" | null | undefined;
|
|
156
|
+
color?: "blue" | "grey" | "destructive" | null | undefined;
|
|
157
|
+
iconButton?: boolean | null | undefined;
|
|
158
|
+
} & class_variance_authority_types.ClassProp) | undefined) => string;
|
|
159
|
+
interface ButtonProps extends Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'color'>, VariantProps<typeof buttonVariants> {
|
|
160
|
+
}
|
|
161
|
+
declare const Button: React.ForwardRefExoticComponent<ButtonProps & React.RefAttributes<HTMLButtonElement>>;
|
|
162
|
+
|
|
163
|
+
export { type BgColor, Button, type ButtonProps, type Color, type ColorToken, type FillColor, type Fonts, type TextColor, buttonVariants, colors, fonts };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
const extend = {
|
|
2
|
+
colors: {
|
|
3
|
+
background: 'hsl(var(--background))',
|
|
4
|
+
foreground: 'hsl(var(--foreground))',
|
|
5
|
+
card: {
|
|
6
|
+
DEFAULT: 'hsl(var(--card))',
|
|
7
|
+
foreground: 'hsl(var(--card-foreground))',
|
|
8
|
+
},
|
|
9
|
+
popover: {
|
|
10
|
+
DEFAULT: 'hsl(var(--popover))',
|
|
11
|
+
foreground: 'hsl(var(--popover-foreground))',
|
|
12
|
+
},
|
|
13
|
+
primary: {
|
|
14
|
+
DEFAULT: 'hsl(var(--primary))',
|
|
15
|
+
foreground: 'hsl(var(--primary-foreground))',
|
|
16
|
+
},
|
|
17
|
+
secondary: {
|
|
18
|
+
DEFAULT: 'hsl(var(--secondary))',
|
|
19
|
+
foreground: 'hsl(var(--secondary-foreground))',
|
|
20
|
+
},
|
|
21
|
+
muted: {
|
|
22
|
+
DEFAULT: 'hsl(var(--muted))',
|
|
23
|
+
foreground: 'hsl(var(--muted-foreground))',
|
|
24
|
+
},
|
|
25
|
+
accent: {
|
|
26
|
+
DEFAULT: 'hsl(var(--accent))',
|
|
27
|
+
foreground: 'hsl(var(--accent-foreground))',
|
|
28
|
+
},
|
|
29
|
+
destructive: {
|
|
30
|
+
DEFAULT: 'hsl(var(--destructive))',
|
|
31
|
+
foreground: 'hsl(var(--destructive-foreground))',
|
|
32
|
+
},
|
|
33
|
+
border: 'hsl(var(--border))',
|
|
34
|
+
input: 'hsl(var(--input))',
|
|
35
|
+
ring: 'hsl(var(--ring))',
|
|
36
|
+
chart: {
|
|
37
|
+
1: 'hsl(var(--chart-1))',
|
|
38
|
+
2: 'hsl(var(--chart-2))',
|
|
39
|
+
3: 'hsl(var(--chart-3))',
|
|
40
|
+
4: 'hsl(var(--chart-4))',
|
|
41
|
+
5: 'hsl(var(--chart-5))',
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
borderRadius: {
|
|
45
|
+
lg: 'var(--radius)',
|
|
46
|
+
md: 'calc(var(--radius) - 2px)',
|
|
47
|
+
sm: 'calc(var(--radius) - 4px)',
|
|
48
|
+
},
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
export { extend };
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
const fontFaces = (publicPath: string) => [
|
|
2
|
+
{
|
|
3
|
+
fontFamily: 'Roboto',
|
|
4
|
+
fontStyle: 'italic',
|
|
5
|
+
fontWeight: '100',
|
|
6
|
+
fontDisplay: 'swap',
|
|
7
|
+
src: `url('${publicPath}/fonts/Roboto/thin-100-italic.woff2')`,
|
|
8
|
+
},
|
|
9
|
+
{
|
|
10
|
+
fontFamily: 'Roboto',
|
|
11
|
+
fontStyle: 'italic',
|
|
12
|
+
fontWeight: '300',
|
|
13
|
+
fontDisplay: 'swap',
|
|
14
|
+
src: `url('${publicPath}/fonts/Roboto/light-300-italic.woff2')`,
|
|
15
|
+
},
|
|
16
|
+
{
|
|
17
|
+
fontFamily: 'Roboto',
|
|
18
|
+
fontStyle: 'italic',
|
|
19
|
+
fontWeight: '400',
|
|
20
|
+
fontDisplay: 'swap',
|
|
21
|
+
src: `url('${publicPath}/fonts/Roboto/regular-400-italic.woff2')`,
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
fontFamily: 'Roboto',
|
|
25
|
+
fontStyle: 'italic',
|
|
26
|
+
fontWeight: '500',
|
|
27
|
+
fontDisplay: 'swap',
|
|
28
|
+
src: `url('${publicPath}/fonts/Roboto/medium-500-italic.woff2')`,
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
fontFamily: 'Roboto',
|
|
32
|
+
fontStyle: 'italic',
|
|
33
|
+
fontWeight: '700',
|
|
34
|
+
fontDisplay: 'swap',
|
|
35
|
+
src: `url('${publicPath}/fonts/Roboto/bold-700-italic.woff2')`,
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
fontFamily: 'Roboto',
|
|
39
|
+
fontStyle: 'italic',
|
|
40
|
+
fontWeight: '900',
|
|
41
|
+
fontDisplay: 'swap',
|
|
42
|
+
src: `url('${publicPath}/fonts/Roboto/black-900-italic.woff2')`,
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
fontFamily: 'Roboto',
|
|
46
|
+
fontStyle: 'normal',
|
|
47
|
+
fontWeight: '100',
|
|
48
|
+
fontDisplay: 'swap',
|
|
49
|
+
src: `url('${publicPath}/fonts/Roboto/thin-100.woff2')`,
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
fontFamily: 'Roboto',
|
|
53
|
+
fontStyle: 'normal',
|
|
54
|
+
fontWeight: '300',
|
|
55
|
+
fontDisplay: 'swap',
|
|
56
|
+
src: `url('${publicPath}/fonts/Roboto/light-300.woff2')`,
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
fontFamily: 'Roboto',
|
|
60
|
+
fontStyle: 'normal',
|
|
61
|
+
fontWeight: '400',
|
|
62
|
+
fontDisplay: 'swap',
|
|
63
|
+
src: `url('${publicPath}/fonts/Roboto/regular-400.woff2')`,
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
fontFamily: 'Roboto',
|
|
67
|
+
fontStyle: 'normal',
|
|
68
|
+
fontWeight: '500',
|
|
69
|
+
fontDisplay: 'swap',
|
|
70
|
+
src: `url('${publicPath}/fonts/Roboto/medium-500.woff2')`,
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
fontFamily: 'Roboto',
|
|
74
|
+
fontStyle: 'normal',
|
|
75
|
+
fontWeight: '700',
|
|
76
|
+
fontDisplay: 'swap',
|
|
77
|
+
src: `url('${publicPath}/fonts/Roboto/bold-700.woff2')`,
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
fontFamily: 'Roboto',
|
|
81
|
+
fontStyle: 'normal',
|
|
82
|
+
fontWeight: '900',
|
|
83
|
+
fontDisplay: 'swap',
|
|
84
|
+
src: `url('${publicPath}/fonts/Roboto/black-900.woff2')`,
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
fontFamily: 'Montserrat',
|
|
88
|
+
fontStyle: 'italic',
|
|
89
|
+
fontWeight: '100 900',
|
|
90
|
+
fontDisplay: 'swap',
|
|
91
|
+
src: `url('${publicPath}/fonts/Montserrat/italic.woff2')`,
|
|
92
|
+
},
|
|
93
|
+
{
|
|
94
|
+
fontFamily: 'Montserrat',
|
|
95
|
+
fontStyle: 'normal',
|
|
96
|
+
fontWeight: '100 900',
|
|
97
|
+
fontDisplay: 'swap',
|
|
98
|
+
src: `url('${publicPath}/fonts/Montserrat/normal.woff2')`,
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
fontFamily: 'IBM Plex Mono',
|
|
102
|
+
fontStyle: 'italic',
|
|
103
|
+
fontWeight: '100',
|
|
104
|
+
fontDisplay: 'swap',
|
|
105
|
+
src: `url('${publicPath}/fonts/Ibm/thin-100-italic.woff2')`,
|
|
106
|
+
},
|
|
107
|
+
{
|
|
108
|
+
fontFamily: 'IBM Plex Mono',
|
|
109
|
+
fontStyle: 'italic',
|
|
110
|
+
fontWeight: '300',
|
|
111
|
+
fontDisplay: 'swap',
|
|
112
|
+
src: `url('${publicPath}/fonts/Ibm/light-300-italic.woff2')`,
|
|
113
|
+
},
|
|
114
|
+
{
|
|
115
|
+
fontFamily: 'IBM Plex Mono',
|
|
116
|
+
fontStyle: 'italic',
|
|
117
|
+
fontWeight: '400',
|
|
118
|
+
fontDisplay: 'swap',
|
|
119
|
+
src: `url('${publicPath}/fonts/Ibm/regular-400-italic.woff2')`,
|
|
120
|
+
},
|
|
121
|
+
{
|
|
122
|
+
fontFamily: 'IBM Plex Mono',
|
|
123
|
+
fontStyle: 'italic',
|
|
124
|
+
fontWeight: '500',
|
|
125
|
+
fontDisplay: 'swap',
|
|
126
|
+
src: `url('${publicPath}/fonts/Ibm/medium-500-italic.woff2')`,
|
|
127
|
+
},
|
|
128
|
+
{
|
|
129
|
+
fontFamily: 'IBM Plex Mono',
|
|
130
|
+
fontStyle: 'italic',
|
|
131
|
+
fontWeight: '700',
|
|
132
|
+
fontDisplay: 'swap',
|
|
133
|
+
src: `url('${publicPath}/fonts/Ibm/bold-700-italic.woff2')`,
|
|
134
|
+
},
|
|
135
|
+
{
|
|
136
|
+
fontFamily: 'IBM Plex Mono',
|
|
137
|
+
fontStyle: 'normal',
|
|
138
|
+
fontWeight: '100',
|
|
139
|
+
fontDisplay: 'swap',
|
|
140
|
+
src: `url('${publicPath}/fonts/Ibm/thin-100.woff2')`,
|
|
141
|
+
},
|
|
142
|
+
{
|
|
143
|
+
fontFamily: 'IBM Plex Mono',
|
|
144
|
+
fontStyle: 'normal',
|
|
145
|
+
fontWeight: '300',
|
|
146
|
+
fontDisplay: 'swap',
|
|
147
|
+
src: `url('${publicPath}/fonts/Ibm/light-300.woff2')`,
|
|
148
|
+
},
|
|
149
|
+
{
|
|
150
|
+
fontFamily: 'IBM Plex Mono',
|
|
151
|
+
fontStyle: 'normal',
|
|
152
|
+
fontWeight: '400',
|
|
153
|
+
fontDisplay: 'swap',
|
|
154
|
+
src: `url('${publicPath}/fonts/Ibm/regular-400.woff2')`,
|
|
155
|
+
},
|
|
156
|
+
{
|
|
157
|
+
fontFamily: 'IBM Plex Mono',
|
|
158
|
+
fontStyle: 'normal',
|
|
159
|
+
fontWeight: '500',
|
|
160
|
+
fontDisplay: 'swap',
|
|
161
|
+
src: `url('${publicPath}/fonts/Ibm/medium-500.woff2')`,
|
|
162
|
+
},
|
|
163
|
+
{
|
|
164
|
+
fontFamily: 'IBM Plex Mono',
|
|
165
|
+
fontStyle: 'normal',
|
|
166
|
+
fontWeight: '700',
|
|
167
|
+
fontDisplay: 'swap',
|
|
168
|
+
src: `url('${publicPath}/fonts/Ibm/bold-700.woff2')`,
|
|
169
|
+
},
|
|
170
|
+
];
|
|
171
|
+
|
|
172
|
+
export { fontFaces };
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import Plugin from 'tailwindcss/plugin';
|
|
2
|
+
|
|
3
|
+
import { colors } from '../tokens/colors';
|
|
4
|
+
import { fonts } from '../tokens/fonts';
|
|
5
|
+
|
|
6
|
+
import { extend } from './extend';
|
|
7
|
+
import { fontFaces } from './fontFaces';
|
|
8
|
+
import { general } from './general';
|
|
9
|
+
import { typographies } from './typographies';
|
|
10
|
+
import { varsTheme } from './varsTheme';
|
|
11
|
+
|
|
12
|
+
const buildPlugin = (publicPath: string) =>
|
|
13
|
+
Plugin(
|
|
14
|
+
({ addBase, addComponents }) => {
|
|
15
|
+
addBase(varsTheme);
|
|
16
|
+
fontFaces(publicPath).map((fontFace) =>
|
|
17
|
+
addBase({ '@font-face': fontFace })
|
|
18
|
+
);
|
|
19
|
+
addBase(general);
|
|
20
|
+
addComponents(typographies);
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
theme: {
|
|
24
|
+
fontFamily: fonts,
|
|
25
|
+
colors,
|
|
26
|
+
extend,
|
|
27
|
+
},
|
|
28
|
+
}
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
export { buildPlugin };
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
const typographies = {
|
|
2
|
+
'.heading-xxlarge-500': {
|
|
3
|
+
fontFamily: 'Montserrat, sans-serif',
|
|
4
|
+
fontSize: '3rem',
|
|
5
|
+
fontWeight: '500',
|
|
6
|
+
lineHeight: '3.25rem',
|
|
7
|
+
},
|
|
8
|
+
'.heading-xlarge-500': {
|
|
9
|
+
fontFamily: 'Montserrat, sans-serif',
|
|
10
|
+
fontSize: '2.5rem',
|
|
11
|
+
fontWeight: '500',
|
|
12
|
+
lineHeight: '2.75rem',
|
|
13
|
+
},
|
|
14
|
+
'.heading-large-500': {
|
|
15
|
+
fontFamily: 'Montserrat, sans-serif',
|
|
16
|
+
fontSize: '2rem',
|
|
17
|
+
fontWeight: '500',
|
|
18
|
+
lineHeight: '2.25rem',
|
|
19
|
+
},
|
|
20
|
+
'.heading-medium-500': {
|
|
21
|
+
fontFamily: 'Montserrat, sans-serif',
|
|
22
|
+
fontSize: '1.5rem',
|
|
23
|
+
fontWeight: '500',
|
|
24
|
+
lineHeight: '1.75rem',
|
|
25
|
+
},
|
|
26
|
+
'.heading-small-500': {
|
|
27
|
+
fontFamily: 'Montserrat, sans-serif',
|
|
28
|
+
fontSize: '1.25rem',
|
|
29
|
+
fontWeight: '500',
|
|
30
|
+
lineHeight: '1.5rem',
|
|
31
|
+
},
|
|
32
|
+
'.heading-xsmall-500': {
|
|
33
|
+
fontFamily: 'Montserrat, sans-serif',
|
|
34
|
+
fontSize: '1rem',
|
|
35
|
+
fontWeight: '500',
|
|
36
|
+
lineHeight: '1.25rem',
|
|
37
|
+
},
|
|
38
|
+
'.heading-xxsmall-500': {
|
|
39
|
+
fontFamily: 'Montserrat, sans-serif',
|
|
40
|
+
fontSize: '0.875rem',
|
|
41
|
+
lineHeight: '1.25rem',
|
|
42
|
+
fontWeight: '500',
|
|
43
|
+
},
|
|
44
|
+
'.body-large-700': {
|
|
45
|
+
fontFamily: 'Roboto, sans-serif',
|
|
46
|
+
fontSize: '1rem',
|
|
47
|
+
lineHeight: '1.5rem',
|
|
48
|
+
fontWeight: '700',
|
|
49
|
+
},
|
|
50
|
+
'.body-large-500': {
|
|
51
|
+
fontFamily: 'Roboto, sans-serif',
|
|
52
|
+
fontSize: '1rem',
|
|
53
|
+
lineHeight: '1.5rem',
|
|
54
|
+
fontWeight: '500',
|
|
55
|
+
},
|
|
56
|
+
'.body-large-400': {
|
|
57
|
+
fontFamily: 'Roboto, sans-serif',
|
|
58
|
+
fontSize: '1rem',
|
|
59
|
+
lineHeight: '1.5rem',
|
|
60
|
+
fontWeight: '400',
|
|
61
|
+
},
|
|
62
|
+
'.body-medium-700': {
|
|
63
|
+
fontFamily: 'Roboto, sans-serif',
|
|
64
|
+
fontSize: '0.875rem',
|
|
65
|
+
lineHeight: '1.25rem',
|
|
66
|
+
fontWeight: '700',
|
|
67
|
+
},
|
|
68
|
+
'.body-medium-500': {
|
|
69
|
+
fontFamily: 'Roboto, sans-serif',
|
|
70
|
+
fontSize: '0.875rem',
|
|
71
|
+
lineHeight: '1.25rem',
|
|
72
|
+
fontWeight: '500',
|
|
73
|
+
},
|
|
74
|
+
'.body-medium-400': {
|
|
75
|
+
fontFamily: 'Roboto, sans-serif',
|
|
76
|
+
fontSize: '0.875rem',
|
|
77
|
+
lineHeight: '1.25rem',
|
|
78
|
+
fontWeight: '400',
|
|
79
|
+
},
|
|
80
|
+
'.body-small-700': {
|
|
81
|
+
fontFamily: 'Roboto, sans-serif',
|
|
82
|
+
fontSize: '0.75rem',
|
|
83
|
+
lineHeight: '1rem',
|
|
84
|
+
fontWeight: '700',
|
|
85
|
+
},
|
|
86
|
+
'.body-small-500': {
|
|
87
|
+
fontFamily: 'Roboto, sans-serif',
|
|
88
|
+
fontSize: '0.75rem',
|
|
89
|
+
lineHeight: '1rem',
|
|
90
|
+
fontWeight: '500',
|
|
91
|
+
},
|
|
92
|
+
'.body-small-400': {
|
|
93
|
+
fontFamily: 'Roboto, sans-serif',
|
|
94
|
+
fontSize: '0.75rem',
|
|
95
|
+
lineHeight: '1rem',
|
|
96
|
+
fontWeight: '400',
|
|
97
|
+
},
|
|
98
|
+
'.code-medium-400': {
|
|
99
|
+
fontFamily: 'IBM Plex Mono, sans-serif',
|
|
100
|
+
fontSize: '0.875rem',
|
|
101
|
+
lineHeight: '1.25rem',
|
|
102
|
+
fontWeight: '400',
|
|
103
|
+
},
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
export { typographies };
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
const varsTheme = {
|
|
2
|
+
':root': {
|
|
3
|
+
'--background': '0 0% 100%',
|
|
4
|
+
'--foreground': '0 0% 14.9%',
|
|
5
|
+
'--card': '0 0% 100%',
|
|
6
|
+
'--card-foreground': '0 0% 3.9%',
|
|
7
|
+
'--popover': '0 0% 100%',
|
|
8
|
+
'--popover-foreground': '0 0% 14.9%',
|
|
9
|
+
'--primary': '0 0% 9%',
|
|
10
|
+
'--primary-foreground': '0 0% 98%',
|
|
11
|
+
'--secondary': '0 0% 96.1%',
|
|
12
|
+
'--secondary-foreground': '0 0% 9%',
|
|
13
|
+
'--muted': '0 0% 96.1%',
|
|
14
|
+
'--muted-foreground': '0 0% 45.1%',
|
|
15
|
+
'--accent': '0 0% 96.1%',
|
|
16
|
+
'--accent-foreground': '0 0% 9%',
|
|
17
|
+
'--destructive': '0 84.2% 60.2%',
|
|
18
|
+
'--destructive-foreground': '0 0% 98%',
|
|
19
|
+
'--border': '0 0% 89.8%',
|
|
20
|
+
'--input': '0 0% 89.8%',
|
|
21
|
+
'--ring': '0 0% 3.9%',
|
|
22
|
+
'--chart-1': '12 76% 61%',
|
|
23
|
+
'--chart-2': '173 58% 39%',
|
|
24
|
+
'--chart-3': '197 37% 24%',
|
|
25
|
+
'--chart-4': '43 74% 66%',
|
|
26
|
+
'--chart-5': '27 87% 67%',
|
|
27
|
+
'--radius': '0.5rem',
|
|
28
|
+
},
|
|
29
|
+
'.dark': {
|
|
30
|
+
'--background': '0 0% 3.9%',
|
|
31
|
+
'--foreground': '0 0% 98%',
|
|
32
|
+
'--card': '0 0% 3.9%',
|
|
33
|
+
'--card-foreground': '0 0% 98%',
|
|
34
|
+
'--popover': '0 0% 3.9%',
|
|
35
|
+
'--popover-foreground': '0 0% 98%',
|
|
36
|
+
'--primary': '0 0% 98%',
|
|
37
|
+
'--primary-foreground': '0 0% 9%',
|
|
38
|
+
'--secondary': '0 0% 14.9%',
|
|
39
|
+
'--secondary-foreground': '0 0% 98%',
|
|
40
|
+
'--muted': '0 0% 14.9%',
|
|
41
|
+
'--muted-foreground': '0 0% 63.9%',
|
|
42
|
+
'--accent': '0 0% 14.9%',
|
|
43
|
+
'--accent-foreground': '0 0% 98%',
|
|
44
|
+
'--destructive': '0 62.8% 30.6%',
|
|
45
|
+
'--destructive-foreground': '0 0% 98%',
|
|
46
|
+
'--border': '0 0% 14.9%',
|
|
47
|
+
'--input': '0 0% 14.9%',
|
|
48
|
+
'--ring': '0 0% 83.1%',
|
|
49
|
+
'--chart-1': '220 70% 50%',
|
|
50
|
+
'--chart-2': '160 60% 45%',
|
|
51
|
+
'--chart-3': '30 80% 55%',
|
|
52
|
+
'--chart-4': '280 65% 60%',
|
|
53
|
+
'--chart-5': '340 75% 55%',
|
|
54
|
+
},
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
export { varsTheme };
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -0,0 +1 @@
|
|
|
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(89,123,216,.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(89,123,216,.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: }/*! tailwindcss v3.4.16 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid}: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:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;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}:root{--background:0 0% 100%;--foreground:0 0% 14.9%;--card:0 0% 100%;--card-foreground:0 0% 3.9%;--popover:0 0% 100%;--popover-foreground:0 0% 14.9%;--primary:0 0% 9%;--primary-foreground:0 0% 98%;--secondary:0 0% 96.1%;--secondary-foreground:0 0% 9%;--muted:0 0% 96.1%;--muted-foreground:0 0% 45.1%;--accent:0 0% 96.1%;--accent-foreground:0 0% 9%;--destructive:0 84.2% 60.2%;--destructive-foreground:0 0% 98%;--border:0 0% 89.8%;--input:0 0% 89.8%;--ring:0 0% 3.9%;--chart-1:12 76% 61%;--chart-2:173 58% 39%;--chart-3:197 37% 24%;--chart-4:43 74% 66%;--chart-5:27 87% 67%;--radius:0.5rem}@font-face{font-family:Roboto;font-style:italic;font-weight:100;font-display:swap;src:url(../public/fonts/Roboto/thin-100-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:300;font-display:swap;src:url(../public/fonts/Roboto/light-300-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:400;font-display:swap;src:url(../public/fonts/Roboto/regular-400-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:500;font-display:swap;src:url(../public/fonts/Roboto/medium-500-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:700;font-display:swap;src:url(../public/fonts/Roboto/bold-700-italic.woff2)}@font-face{font-family:Roboto;font-style:italic;font-weight:900;font-display:swap;src:url(../public/fonts/Roboto/black-900-italic.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:100;font-display:swap;src:url(../public/fonts/Roboto/thin-100.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:300;font-display:swap;src:url(../public/fonts/Roboto/light-300.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:400;font-display:swap;src:url(../public/fonts/Roboto/regular-400.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:500;font-display:swap;src:url(../public/fonts/Roboto/medium-500.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:700;font-display:swap;src:url(../public/fonts/Roboto/bold-700.woff2)}@font-face{font-family:Roboto;font-style:normal;font-weight:900;font-display:swap;src:url(../public/fonts/Roboto/black-900.woff2)}@font-face{font-family:Montserrat;font-style:italic;font-weight:100 900;font-display:swap;src:url(../public/fonts/Montserrat/italic.woff2)}@font-face{font-family:Montserrat;font-style:normal;font-weight:100 900;font-display:swap;src:url(../public/fonts/Montserrat/normal.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:100;font-display:swap;src:url(../public/fonts/Ibm/thin-100-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:300;font-display:swap;src:url(../public/fonts/Ibm/light-300-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:400;font-display:swap;src:url(../public/fonts/Ibm/regular-400-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:500;font-display:swap;src:url(../public/fonts/Ibm/medium-500-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:italic;font-weight:700;font-display:swap;src:url(../public/fonts/Ibm/bold-700-italic.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:100;font-display:swap;src:url(../public/fonts/Ibm/thin-100.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:300;font-display:swap;src:url(../public/fonts/Ibm/light-300.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../public/fonts/Ibm/regular-400.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../public/fonts/Ibm/medium-500.woff2)}@font-face{font-family:IBM Plex Mono;font-style:normal;font-weight:700;font-display:swap;src:url(../public/fonts/Ibm/bold-700.woff2)}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));font-family:Roboto,sans-serif;color:hsl(var(--foreground))}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.heading-xxlarge-500{font-size:3rem;line-height:3.25rem}.heading-xlarge-500,.heading-xxlarge-500{font-family:Montserrat,sans-serif;font-weight:500}.heading-xlarge-500{font-size:2.5rem;line-height:2.75rem}.heading-large-500{font-size:2rem;line-height:2.25rem}.heading-large-500,.heading-medium-500{font-family:Montserrat,sans-serif;font-weight:500}.heading-medium-500{font-size:1.5rem;line-height:1.75rem}.heading-small-500{font-family:Montserrat,sans-serif;font-size:1.25rem;font-weight:500;line-height:1.5rem}.heading-xsmall-500{font-size:1rem}.heading-xsmall-500,.heading-xxsmall-500{font-family:Montserrat,sans-serif;font-weight:500;line-height:1.25rem}.heading-xxsmall-500{font-size:.875rem}.body-large-700{font-weight:700}.body-large-500,.body-large-700{font-family:Roboto,sans-serif;font-size:1rem;line-height:1.5rem}.body-large-500{font-weight:500}.body-large-400{font-family:Roboto,sans-serif;font-size:1rem;line-height:1.5rem;font-weight:400}.body-medium-700{font-weight:700}.body-medium-500,.body-medium-700{font-family:Roboto,sans-serif;font-size:.875rem;line-height:1.25rem}.body-medium-500{font-weight:500}.body-medium-400{font-family:Roboto,sans-serif;font-size:.875rem;line-height:1.25rem;font-weight:400}.body-small-700{font-weight:700}.body-small-500,.body-small-700{font-family:Roboto,sans-serif;font-size:.75rem;line-height:1rem}.body-small-500{font-weight:500}.body-small-400{font-family:Roboto,sans-serif;font-size:.75rem;line-height:1rem;font-weight:400}.code-medium-400{font-family:IBM Plex Mono,sans-serif;font-size:.875rem;line-height:1.25rem;font-weight:400}.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}.pointer-events-none{pointer-events:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.left-2{left:.5rem}.left-3{left:.75rem}.left-\[50\%\]{left:50%}.right-3{right:.75rem}.right-4{right:1rem}.top-4{top:1rem}.top-\[50\%\]{top:50%}.z-50{z-index:50}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.ml-auto{margin-left:auto}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.aspect-square{aspect-ratio:1/1}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-72{height:18rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[20px\]{height:20px}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-px{height:1px}.max-h-96{max-height:24rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-4{width:1rem}.w-40{width:10rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[100px\]{width:100px}.w-\[180px\]{width:180px}.w-\[200px\]{width:200px}.w-\[200x\]{width:200x}.w-\[250px\]{width:250px}.w-\[274px\]{width:274px}.w-\[800px\]{width:800px}.w-full{width:100%}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-80{max-width:20rem}.max-w-lg{max-width:32rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.translate-x-\[-50\%\]{--tw-translate-x:-50%}.translate-x-\[-50\%\],.translate-y-\[-50\%\]{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-\[-50\%\]{--tw-translate-y:-50%}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.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-1{gap:.25rem}.gap-12{gap:3rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.5rem*var(--tw-space-x-reverse));margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem*var(--tw-space-x-reverse));margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.375rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem*var(--tw-space-y-reverse))}.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))}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-3xl{border-radius:1.5rem}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-l-md{border-top-left-radius:calc(var(--radius) - 2px);border-bottom-left-radius:calc(var(--radius) - 2px)}.rounded-l-none{border-top-left-radius:0;border-bottom-left-radius:0}.rounded-r-md{border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.rounded-r-none{border-top-right-radius:0;border-bottom-right-radius:0}.border{border-width:1px}.border-2{border-width:2px}.border-l{border-left-width:1px}.border-l-0{border-left-width:0}.border-l-2{border-left-width:2px}.border-r-0{border-right-width:0}.border-t{border-top-width:1px}.border-none{border-style:none}.border-blue-600{--tw-border-opacity:1;border-color:rgb(60 89 201/var(--tw-border-opacity,1))}.border-grey-100{--tw-border-opacity:1;border-color:rgb(245 245 245/var(--tw-border-opacity,1))}.border-grey-400{--tw-border-opacity:1;border-color:rgb(201 201 201/var(--tw-border-opacity,1))}.border-grey-600{--tw-border-opacity:1;border-color:rgb(122 122 122/var(--tw-border-opacity,1))}.border-input{border-color:hsl(var(--input))}.border-red-600{--tw-border-opacity:1;border-color:rgb(236 22 22/var(--tw-border-opacity,1))}.border-white{--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-l-transparent{border-left-color:transparent}.border-t-transparent{border-top-color:transparent}.bg-background{background-color:hsl(var(--background))}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-black\/80{background-color:rgba(0,0,0,.8)}.bg-blue-100{--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.bg-blue-200{--tw-bg-opacity:1;background-color:rgb(201 215 244/var(--tw-bg-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(242 245 252/var(--tw-bg-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(60 89 201/var(--tw-bg-opacity,1))}.bg-blue-800{--tw-bg-opacity:1;background-color:rgb(53 65 152/var(--tw-bg-opacity,1))}.bg-border{background-color:hsl(var(--border))}.bg-green-100{--tw-bg-opacity:1;background-color:rgb(212 247 231/var(--tw-bg-opacity,1))}.bg-grey-100{--tw-bg-opacity:1;background-color:rgb(245 245 245/var(--tw-bg-opacity,1))}.bg-grey-200{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.bg-grey-400\/30{background-color:hsla(0,0%,79%,.3)}.bg-grey-50{--tw-bg-opacity:1;background-color:rgb(250 250 250/var(--tw-bg-opacity,1))}.bg-grey-600{--tw-bg-opacity:1;background-color:rgb(122 122 122/var(--tw-bg-opacity,1))}.bg-muted{background-color:hsl(var(--muted))}.bg-orange-100{--tw-bg-opacity:1;background-color:rgb(254 240 214/var(--tw-bg-opacity,1))}.bg-pink-100{--tw-bg-opacity:1;background-color:rgb(251 232 243/var(--tw-bg-opacity,1))}.bg-pink-500{--tw-bg-opacity:1;background-color:rgb(227 92 156/var(--tw-bg-opacity,1))}.bg-popover{background-color:hsl(var(--popover))}.bg-purple-100{--tw-bg-opacity:1;background-color:rgb(238 235 252/var(--tw-bg-opacity,1))}.bg-red-100{--tw-bg-opacity:1;background-color:rgb(255 224 224/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(255 241 241/var(--tw-bg-opacity,1))}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(236 22 22/var(--tw-bg-opacity,1))}.bg-transparent{background-color:transparent}.bg-turquoise-100{--tw-bg-opacity:1;background-color:rgb(211 247 250/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-yellow-100{--tw-bg-opacity:1;background-color:rgb(254 253 195/var(--tw-bg-opacity,1))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-purple-400{--tw-gradient-from:#aa94f1 var(--tw-gradient-from-position);--tw-gradient-to:rgba(170,148,241,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-yellow-400{--tw-gradient-from:#f9dc16 var(--tw-gradient-from-position);--tw-gradient-to:rgba(249,220,22,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-green-500{--tw-gradient-to:rgba(28,173,134,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1cad86 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-pink-500{--tw-gradient-to:rgba(227,92,156,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#e35c9c var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-blue-500{--tw-gradient-to:#597bd8 var(--tw-gradient-to-position)}.to-red-500{--tw-gradient-to:#ff4646 var(--tw-gradient-to-position)}.fill-blue-500{fill:#597bd8}.fill-current{fill:currentColor}.fill-grey-950{fill:#262626}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-\[1px\]{padding:1px}.p-\[2px\]{padding:2px}.px-2{padding-left:.5rem;padding-right:.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-0{padding-top:0;padding-bottom:0}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{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}.pl-10{padding-left:2.5rem}.pl-2{padding-left:.5rem}.pl-8{padding-left:2rem}.pr-10{padding-right:2.5rem}.pr-2{padding-right:.5rem}.pt-20{padding-top:5rem}.text-center{text-align:center}.font-roboto{font-family:Roboto,sans-serif}.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-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-blue-600{--tw-text-opacity:1;color:rgb(60 89 201/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:rgb(59 78 186/var(--tw-text-opacity,1))}.text-current{color:currentColor}.text-green-600{--tw-text-opacity:1;color:rgb(15 140 109/var(--tw-text-opacity,1))}.text-grey-600{--tw-text-opacity:1;color:rgb(122 122 122/var(--tw-text-opacity,1))}.text-grey-700{--tw-text-opacity:1;color:rgb(93 93 93/var(--tw-text-opacity,1))}.text-grey-800{--tw-text-opacity:1;color:rgb(74 74 74/var(--tw-text-opacity,1))}.text-grey-950{--tw-text-opacity:1;color:rgb(38 38 38/var(--tw-text-opacity,1))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-orange-600{--tw-text-opacity:1;color:rgb(229 105 16/var(--tw-text-opacity,1))}.text-pink-600{--tw-text-opacity:1;color:rgb(207 51 117/var(--tw-text-opacity,1))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-purple-600{--tw-text-opacity:1;color:rgb(130 80 223/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(236 22 22/var(--tw-text-opacity,1))}.text-turquoise-600{--tw-text-opacity:1;color:rgb(21 136 165/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-yellow-600{--tw-text-opacity:1;color:rgb(201 152 5/var(--tw-text-opacity,1))}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.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-lg,.shadow-md{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-none{--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000}.shadow-none,.shadow-sm{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.outline-none{outline:2px solid transparent;outline-offset:2px}.ring-offset-background{--tw-ring-offset-color:hsl(var(--background))}.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}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0) scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0) scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}.animate-in{animation-name:enter;animation-duration:.15s;--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial}.fade-in-0{--tw-enter-opacity:0}.zoom-in-95{--tw-enter-scale:.95}.duration-200{animation-duration:.2s}.duration-300{animation-duration:.3s}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:cursor-not-allowed:hover{cursor:not-allowed}.hover\:cursor-pointer:hover{cursor:pointer}.hover\:border-blue-600:hover{--tw-border-opacity:1;border-color:rgb(60 89 201/var(--tw-border-opacity,1))}.hover\:border-grey-200:hover{--tw-border-opacity:1;border-color:rgb(231 231 231/var(--tw-border-opacity,1))}.hover\:border-grey-500:hover{--tw-border-opacity:1;border-color:rgb(136 136 136/var(--tw-border-opacity,1))}.hover\:bg-blue-100:hover{--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.hover\:bg-blue-200:hover{--tw-bg-opacity:1;background-color:rgb(201 215 244/var(--tw-bg-opacity,1))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(59 78 186/var(--tw-bg-opacity,1))}.hover\:bg-green-200:hover{--tw-bg-opacity:1;background-color:rgb(172 238 212/var(--tw-bg-opacity,1))}.hover\:bg-grey-200:hover{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.hover\:bg-grey-200\/70:hover{background-color:hsla(0,0%,91%,.7)}.hover\:bg-grey-300:hover{--tw-bg-opacity:1;background-color:rgb(224 225 225/var(--tw-bg-opacity,1))}.hover\:bg-grey-50:hover{--tw-bg-opacity:1;background-color:rgb(250 250 250/var(--tw-bg-opacity,1))}.hover\:bg-grey-800:hover{--tw-bg-opacity:1;background-color:rgb(74 74 74/var(--tw-bg-opacity,1))}.hover\:bg-orange-200:hover{--tw-bg-opacity:1;background-color:rgb(252 221 172/var(--tw-bg-opacity,1))}.hover\:bg-pink-200:hover{--tw-bg-opacity:1;background-color:rgb(248 210 231/var(--tw-bg-opacity,1))}.hover\:bg-purple-200:hover{--tw-bg-opacity:1;background-color:rgb(222 217 251/var(--tw-bg-opacity,1))}.hover\:bg-red-100:hover{--tw-bg-opacity:1;background-color:rgb(255 224 224/var(--tw-bg-opacity,1))}.hover\:bg-red-200:hover{--tw-bg-opacity:1;background-color:rgb(255 197 197/var(--tw-bg-opacity,1))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(199 14 14/var(--tw-bg-opacity,1))}.hover\:bg-turquoise-200:hover{--tw-bg-opacity:1;background-color:rgb(172 238 245/var(--tw-bg-opacity,1))}.hover\:bg-yellow-200:hover{--tw-bg-opacity:1;background-color:rgb(254 248 138/var(--tw-bg-opacity,1))}.hover\:opacity-100:hover{opacity:1}.hover\:opacity-70:hover{opacity:.7}.focus\:border-blue-600:focus{--tw-border-opacity:1;border-color:rgb(60 89 201/var(--tw-border-opacity,1))}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:bg-background:focus{background-color:hsl(var(--background))}.focus\:bg-blue-100:focus{--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.focus\:bg-green-100:focus{--tw-bg-opacity:1;background-color:rgb(212 247 231/var(--tw-bg-opacity,1))}.focus\:bg-grey-200:focus{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.focus\:bg-orange-100:focus{--tw-bg-opacity:1;background-color:rgb(254 240 214/var(--tw-bg-opacity,1))}.focus\:bg-pink-100:focus{--tw-bg-opacity:1;background-color:rgb(251 232 243/var(--tw-bg-opacity,1))}.focus\:bg-purple-100:focus{--tw-bg-opacity:1;background-color:rgb(238 235 252/var(--tw-bg-opacity,1))}.focus\:bg-red-100:focus{--tw-bg-opacity:1;background-color:rgb(255 224 224/var(--tw-bg-opacity,1))}.focus\:bg-transparent:focus{background-color:transparent}.focus\:bg-turquoise-100:focus{--tw-bg-opacity:1;background-color:rgb(211 247 250/var(--tw-bg-opacity,1))}.focus\:bg-yellow-100:focus{--tw-bg-opacity:1;background-color:rgb(254 253 195/var(--tw-bg-opacity,1))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-0: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(var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-0:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.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)}.focus\:ring-4: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(4px + 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-blue-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(201 215 244/var(--tw-ring-opacity,1))}.focus\:ring-blue-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(242 245 252/var(--tw-ring-opacity,1))}.focus\:ring-blue-600:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(60 89 201/var(--tw-ring-opacity,1))}.focus\:ring-green-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(237 252 246/var(--tw-ring-opacity,1))}.focus\:ring-grey-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(231 231 231/var(--tw-ring-opacity,1))}.focus\:ring-grey-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(250 250 250/var(--tw-ring-opacity,1))}.focus\:ring-orange-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(255 248 237/var(--tw-ring-opacity,1))}.focus\:ring-pink-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(252 243 248/var(--tw-ring-opacity,1))}.focus\:ring-purple-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(246 244 254/var(--tw-ring-opacity,1))}.focus\:ring-red-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(255 197 197/var(--tw-ring-opacity,1))}.focus\:ring-red-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(255 241 241/var(--tw-ring-opacity,1))}.focus\:ring-ring:focus{--tw-ring-color:hsl(var(--ring))}.focus\:ring-turquoise-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(237 253 254/var(--tw-ring-opacity,1))}.focus\:ring-yellow-50:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(254 254 232/var(--tw-ring-opacity,1))}.focus\:ring-opacity-20:focus{--tw-ring-opacity:0.2}.focus\:ring-opacity-30:focus{--tw-ring-opacity:0.3}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:before\:absolute:focus-visible:before{content:var(--tw-content);position:absolute}.focus-visible\:before\:left-1\/2:focus-visible:before{content:var(--tw-content);left:50%}.focus-visible\:before\:top-1\/2:focus-visible:before{content:var(--tw-content);top:50%}.focus-visible\:before\:-z-10:focus-visible:before{content:var(--tw-content);z-index:-10}.focus-visible\:before\:h-10:focus-visible:before{content:var(--tw-content);height:2.5rem}.focus-visible\:before\:w-10:focus-visible:before{content:var(--tw-content);width:2.5rem}.focus-visible\:before\:-translate-x-1\/2:focus-visible:before{content:var(--tw-content);--tw-translate-x:-50%;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))}.focus-visible\:before\:-translate-y-1\/2:focus-visible:before{content:var(--tw-content);--tw-translate-y:-50%;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))}.focus-visible\:before\:transform:focus-visible:before{content:var(--tw-content);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))}.focus-visible\:before\:rounded-full:focus-visible:before{content:var(--tw-content);border-radius:9999px}.focus-visible\:before\:bg-blue-100:focus-visible:before{content:var(--tw-content);--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.active\:border-grey-700:active{--tw-border-opacity:1;border-color:rgb(93 93 93/var(--tw-border-opacity,1))}.active\:bg-blue-300:active{--tw-bg-opacity:1;background-color:rgb(164 190 236/var(--tw-bg-opacity,1))}.active\:bg-blue-800:active{--tw-bg-opacity:1;background-color:rgb(53 65 152/var(--tw-bg-opacity,1))}.active\:bg-green-300:active{--tw-bg-opacity:1;background-color:rgb(95 217 176/var(--tw-bg-opacity,1))}.active\:bg-grey-200:active{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.active\:bg-grey-400:active{--tw-bg-opacity:1;background-color:rgb(201 201 201/var(--tw-bg-opacity,1))}.active\:bg-grey-900:active{--tw-bg-opacity:1;background-color:rgb(61 61 61/var(--tw-bg-opacity,1))}.active\:bg-orange-300:active{--tw-bg-opacity:1;background-color:rgb(250 196 119/var(--tw-bg-opacity,1))}.active\:bg-pink-300:active{--tw-bg-opacity:1;background-color:rgb(244 173 211/var(--tw-bg-opacity,1))}.active\:bg-purple-300:active{--tw-bg-opacity:1;background-color:rgb(199 187 247/var(--tw-bg-opacity,1))}.active\:bg-red-300:active{--tw-bg-opacity:1;background-color:rgb(255 157 157/var(--tw-bg-opacity,1))}.active\:bg-red-800:active{--tw-bg-opacity:1;background-color:rgb(164 16 16/var(--tw-bg-opacity,1))}.active\:bg-turquoise-300:active{--tw-bg-opacity:1;background-color:rgb(107 221 237/var(--tw-bg-opacity,1))}.active\:bg-yellow-300:active{--tw-bg-opacity:1;background-color:rgb(252 237 72/var(--tw-bg-opacity,1))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:border-blue-200:disabled{--tw-border-opacity:1;border-color:rgb(201 215 244/var(--tw-border-opacity,1))}.disabled\:border-grey-200:disabled{--tw-border-opacity:1;border-color:rgb(231 231 231/var(--tw-border-opacity,1))}.disabled\:border-grey-300:disabled{--tw-border-opacity:1;border-color:rgb(224 225 225/var(--tw-border-opacity,1))}.disabled\:border-input:disabled{border-color:hsl(var(--input))}.disabled\:border-red-200:disabled{--tw-border-opacity:1;border-color:rgb(255 197 197/var(--tw-border-opacity,1))}.disabled\:bg-blue-100:disabled{--tw-bg-opacity:1;background-color:rgb(225 233 248/var(--tw-bg-opacity,1))}.disabled\:bg-blue-50:disabled{--tw-bg-opacity:1;background-color:rgb(242 245 252/var(--tw-bg-opacity,1))}.disabled\:bg-grey-200:disabled{--tw-bg-opacity:1;background-color:rgb(231 231 231/var(--tw-bg-opacity,1))}.disabled\:bg-grey-50:disabled{--tw-bg-opacity:1;background-color:rgb(250 250 250/var(--tw-bg-opacity,1))}.disabled\:bg-red-100:disabled{--tw-bg-opacity:1;background-color:rgb(255 224 224/var(--tw-bg-opacity,1))}.disabled\:bg-red-50:disabled{--tw-bg-opacity:1;background-color:rgb(255 241 241/var(--tw-bg-opacity,1))}.disabled\:bg-transparent:disabled{background-color:transparent}.disabled\:bg-white:disabled{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.disabled\:text-blue-200:disabled{--tw-text-opacity:1;color:rgb(201 215 244/var(--tw-text-opacity,1))}.disabled\:text-blue-400:disabled{--tw-text-opacity:1;color:rgb(121 157 225/var(--tw-text-opacity,1))}.disabled\:text-grey-300:disabled{--tw-text-opacity:1;color:rgb(224 225 225/var(--tw-text-opacity,1))}.disabled\:text-grey-800:disabled{--tw-text-opacity:1;color:rgb(74 74 74/var(--tw-text-opacity,1))}.disabled\:text-red-100:disabled{--tw-text-opacity:1;color:rgb(255 224 224/var(--tw-text-opacity,1))}.disabled\:text-red-200:disabled{--tw-text-opacity:1;color:rgb(255 197 197/var(--tw-text-opacity,1))}.disabled\:opacity-50:disabled{opacity:.5}.group:focus .group-focus\:ring-8{--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(8px + 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)}.group:focus .group-focus\:ring-blue-200{--tw-ring-opacity:1;--tw-ring-color:rgb(201 215 244/var(--tw-ring-opacity,1))}.group:focus .group-focus\:ring-opacity-50{--tw-ring-opacity:0.5}.group:active:enabled .group-active\:group-enabled\:h-5{height:1.25rem}.group:active:enabled .group-active\:group-enabled\:w-5{width:1.25rem}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-50{opacity:.5}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:0.25rem}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom],.data-\[side\=left\]\:-translate-x-1[data-side=left]{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))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:-0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right],.data-\[side\=top\]\:-translate-y-1[data-side=top]{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))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:-0.25rem}.data-\[state\=checked\]\:translate-x-6[data-state=checked]{--tw-translate-x:1.5rem}.data-\[state\=checked\]\:translate-x-6[data-state=checked],.data-\[state\=unchecked\]\:translate-x-1[data-state=unchecked]{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))}.data-\[state\=unchecked\]\:translate-x-1[data-state=unchecked]{--tw-translate-x:0.25rem}.data-\[state\=unchecked\]\:border-2[data-state=unchecked]{border-width:2px}.data-\[state\=checked\]\:border-blue-600[data-state=checked]{--tw-border-opacity:1;border-color:rgb(60 89 201/var(--tw-border-opacity,1))}.data-\[state\=unchecked\]\:border-grey-400[data-state=unchecked]{--tw-border-opacity:1;border-color:rgb(201 201 201/var(--tw-border-opacity,1))}.data-\[state\=checked\]\:bg-blue-600[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(60 89 201/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:bg-white[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--accent))}.data-\[state\=unchecked\]\:bg-grey-400[data-state=unchecked]{--tw-bg-opacity:1;background-color:rgb(201 201 201/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:text-blue-600[data-state=checked]{--tw-text-opacity:1;color:rgb(60 89 201/var(--tw-text-opacity,1))}.data-\[state\=checked\]\:text-white[data-state=checked]{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:hsl(var(--muted-foreground))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:animate-in[data-state=open]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:-0.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:0.5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:-0.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:0.5rem}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x:-50%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x:-50%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y:-48%}.data-\[state\=checked\]\:hover\:border-blue-700:hover[data-state=checked]{--tw-border-opacity:1;border-color:rgb(59 78 186/var(--tw-border-opacity,1))}.data-\[state\=unchecked\]\:hover\:border-grey-500:hover[data-state=unchecked]{--tw-border-opacity:1;border-color:rgb(136 136 136/var(--tw-border-opacity,1))}.data-\[state\=checked\]\:hover\:bg-blue-700:hover[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(59 78 186/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:hover\:text-blue-700:hover[data-state=checked]{--tw-text-opacity:1;color:rgb(59 78 186/var(--tw-text-opacity,1))}.data-\[state\=checked\]\:active\:border-blue-800:active[data-state=checked]{--tw-border-opacity:1;border-color:rgb(53 65 152/var(--tw-border-opacity,1))}.data-\[state\=unchecked\]\:active\:border-grey-700:active[data-state=unchecked]{--tw-border-opacity:1;border-color:rgb(93 93 93/var(--tw-border-opacity,1))}.data-\[state\=checked\]\:active\:bg-blue-800:active[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(53 65 152/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:active\:text-blue-800:active[data-state=checked]{--tw-text-opacity:1;color:rgb(53 65 152/var(--tw-text-opacity,1))}.data-\[state\=checked\]\:disabled\:border-blue-400:disabled[data-state=checked]{--tw-border-opacity:1;border-color:rgb(121 157 225/var(--tw-border-opacity,1))}.data-\[state\=unchecked\]\:disabled\:border-grey-300:disabled[data-state=unchecked]{--tw-border-opacity:1;border-color:rgb(224 225 225/var(--tw-border-opacity,1))}.data-\[state\=checked\]\:disabled\:bg-blue-200:disabled[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(201 215 244/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:disabled\:bg-blue-400:disabled[data-state=checked]{--tw-bg-opacity:1;background-color:rgb(121 157 225/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:disabled\:text-blue-400:disabled[data-state=checked]{--tw-text-opacity:1;color:rgb(121 157 225/var(--tw-text-opacity,1))}.group:hover .group-hover\:data-\[state\=unchecked\]\:bg-grey-500[data-state=unchecked]{--tw-bg-opacity:1;background-color:rgb(136 136 136/var(--tw-bg-opacity,1))}.group:active .group-active\:data-\[state\=unchecked\]\:bg-grey-700[data-state=unchecked]{--tw-bg-opacity:1;background-color:rgb(93 93 93/var(--tw-bg-opacity,1))}.group:active:enabled .group-active\:group-enabled\:data-\[state\=unchecked\]\:translate-x-\[-2px\][data-state=unchecked]{--tw-translate-x:-2px;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))}.group:disabled .group-disabled\:data-\[state\=unchecked\]\:bg-grey-300[data-state=unchecked]{--tw-bg-opacity:1;background-color:rgb(224 225 225/var(--tw-bg-opacity,1))}.group:disabled .group-disabled\:data-\[state\=unchecked\]\:bg-opacity-65[data-state=unchecked]{--tw-bg-opacity:0.65}@media (min-width:640px){.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.5rem*var(--tw-space-x-reverse));margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)))}.sm\:rounded-lg{border-radius:var(--radius)}.sm\:text-left{text-align:left}}.\[\&\>\.custom-icon\]\:fill-white>.custom-icon{fill:#fff}.\[\&\>\.lucide\]\:text-white>.lucide{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&\>svg\]\:\!h-5>svg{height:1.25rem!important}.\[\&\>svg\]\:\!h-6>svg{height:1.5rem!important}.\[\&\>svg\]\:\!h-8>svg{height:2rem!important}.\[\&\>svg\]\:h-5>svg{height:1.25rem}.\[\&\>svg\]\:h-6>svg{height:1.5rem}.\[\&\>svg\]\:\!w-5>svg{width:1.25rem!important}.\[\&\>svg\]\:\!w-6>svg{width:1.5rem!important}.\[\&\>svg\]\:\!w-8>svg{width:2rem!important}.\[\&\>svg\]\:w-5>svg{width:1.25rem}.\[\&\>svg\]\:w-6>svg{width:1.5rem}.\[\&_\.tooltip-arrow\]\:fill-black .tooltip-arrow{fill:#000}.\[\&_\.tooltip-arrow\]\:fill-white .tooltip-arrow{fill:#fff}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
const colors = {
|
|
2
|
+
transparent: "transparent",
|
|
3
|
+
current: "currentColor",
|
|
4
|
+
black: "#000000",
|
|
5
|
+
white: "#ffffff",
|
|
6
|
+
blue: {
|
|
7
|
+
50: "#f2f5fc",
|
|
8
|
+
100: "#e1e9f8",
|
|
9
|
+
200: "#c9d7f4",
|
|
10
|
+
300: "#a4beec",
|
|
11
|
+
400: "#799de1",
|
|
12
|
+
500: "#597bd8",
|
|
13
|
+
600: "#3c59c9",
|
|
14
|
+
700: "#3b4eba",
|
|
15
|
+
800: "#354198",
|
|
16
|
+
900: "#2f3a79",
|
|
17
|
+
950: "#21264a"
|
|
18
|
+
},
|
|
19
|
+
grey: {
|
|
20
|
+
50: "#FAFAFA",
|
|
21
|
+
100: "#F5F5F5",
|
|
22
|
+
200: "#E7E7E7",
|
|
23
|
+
300: "#E0E1E1",
|
|
24
|
+
400: "#C9C9C9",
|
|
25
|
+
500: "#888888",
|
|
26
|
+
600: "#7A7A7A",
|
|
27
|
+
700: "#5D5D5D",
|
|
28
|
+
800: "#4A4A4A",
|
|
29
|
+
900: "#3D3D3D",
|
|
30
|
+
950: "#262626"
|
|
31
|
+
},
|
|
32
|
+
red: {
|
|
33
|
+
50: "#fff1f1",
|
|
34
|
+
100: "#ffe0e0",
|
|
35
|
+
200: "#ffc5c5",
|
|
36
|
+
300: "#ff9d9d",
|
|
37
|
+
400: "#FF6565",
|
|
38
|
+
500: "#FF4646",
|
|
39
|
+
600: "#EC1616",
|
|
40
|
+
700: "#C70E0E",
|
|
41
|
+
800: "#A41010",
|
|
42
|
+
900: "#881414",
|
|
43
|
+
950: "#4A0505"
|
|
44
|
+
},
|
|
45
|
+
yellow: {
|
|
46
|
+
50: "#FEFEE8",
|
|
47
|
+
100: "#FEFDC3",
|
|
48
|
+
200: "#FEF88A",
|
|
49
|
+
300: "#FCED48",
|
|
50
|
+
400: "#F9DC16",
|
|
51
|
+
500: "#EFC709",
|
|
52
|
+
600: "#C99805",
|
|
53
|
+
700: "#A06D08",
|
|
54
|
+
800: "#85550E",
|
|
55
|
+
900: "#714612",
|
|
56
|
+
950: "#422406"
|
|
57
|
+
},
|
|
58
|
+
orange: {
|
|
59
|
+
50: "#FFF8ED",
|
|
60
|
+
100: "#FEF0D6",
|
|
61
|
+
200: "#FCDDAC",
|
|
62
|
+
300: "#FAC477",
|
|
63
|
+
400: "#F8A03F",
|
|
64
|
+
500: "#F5851A",
|
|
65
|
+
600: "#E56910",
|
|
66
|
+
700: "#BF4F0F",
|
|
67
|
+
800: "#983F14",
|
|
68
|
+
900: "#7A3614",
|
|
69
|
+
950: "#421908"
|
|
70
|
+
},
|
|
71
|
+
purple: {
|
|
72
|
+
50: "#F6F4FE",
|
|
73
|
+
100: "#EEEBFC",
|
|
74
|
+
200: "#DED9FB",
|
|
75
|
+
300: "#C7BBF7",
|
|
76
|
+
400: "#AA94F1",
|
|
77
|
+
500: "#8E69E9",
|
|
78
|
+
600: "#8250DF",
|
|
79
|
+
700: "#6D37CA",
|
|
80
|
+
800: "#5C2EA9",
|
|
81
|
+
900: "#4C278B",
|
|
82
|
+
950: "#2F175E"
|
|
83
|
+
},
|
|
84
|
+
green: {
|
|
85
|
+
50: "#EDFCF6",
|
|
86
|
+
100: "#D4F7E7",
|
|
87
|
+
200: "#ACEED4",
|
|
88
|
+
300: "#5FD9B0",
|
|
89
|
+
400: "#3FC89E",
|
|
90
|
+
500: "#1CAD86",
|
|
91
|
+
600: "#0F8C6D",
|
|
92
|
+
700: "#0C705A",
|
|
93
|
+
800: "#0C5948",
|
|
94
|
+
900: "#0B493D",
|
|
95
|
+
950: "#052922"
|
|
96
|
+
},
|
|
97
|
+
pink: {
|
|
98
|
+
50: "#FCF3F8",
|
|
99
|
+
100: "#FBE8F3",
|
|
100
|
+
200: "#F8D2E7",
|
|
101
|
+
300: "#F4ADD3",
|
|
102
|
+
400: "#EC7AB4",
|
|
103
|
+
500: "#E35C9C",
|
|
104
|
+
600: "#CF3375",
|
|
105
|
+
700: "#B3235C",
|
|
106
|
+
800: "#94204D",
|
|
107
|
+
900: "#7C1F42",
|
|
108
|
+
950: "#4B0C24"
|
|
109
|
+
},
|
|
110
|
+
turquoise: {
|
|
111
|
+
50: "#EDFDFE",
|
|
112
|
+
100: "#D3F7FA",
|
|
113
|
+
200: "#ACEEF5",
|
|
114
|
+
300: "#6BDDED",
|
|
115
|
+
400: "#32C7DE",
|
|
116
|
+
500: "#16AAC4",
|
|
117
|
+
600: "#1588A5",
|
|
118
|
+
700: "#186D86",
|
|
119
|
+
800: "#1C596E",
|
|
120
|
+
900: "#1C4B5D",
|
|
121
|
+
950: "#0D313F"
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
|
|
125
|
+
export { colors };
|
package/package.json
ADDED
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "lecom-ui",
|
|
3
|
+
"version": "2.0.0",
|
|
4
|
+
"license": "MIT",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"module": "dist/index.js",
|
|
7
|
+
"style": "dist/style.min.css",
|
|
8
|
+
"typings": "dist/index.d.ts",
|
|
9
|
+
"files": [
|
|
10
|
+
"dist"
|
|
11
|
+
],
|
|
12
|
+
"scripts": {
|
|
13
|
+
"dev": "next dev",
|
|
14
|
+
"build": "next build",
|
|
15
|
+
"start": "next start",
|
|
16
|
+
"lint": "next lint",
|
|
17
|
+
"storybook": "storybook dev -p 6006",
|
|
18
|
+
"build-storybook": "storybook build",
|
|
19
|
+
"build:tailwind": "npx tailwindcss -i ./src/globals.css -o ./dist/style.min.css --minify",
|
|
20
|
+
"build:rollup": "rollup -c && yarn build:tailwind",
|
|
21
|
+
"test": "jest",
|
|
22
|
+
"test:watch": "jest --watch",
|
|
23
|
+
"test:coverage": "jest --coverage"
|
|
24
|
+
},
|
|
25
|
+
"dependencies": {
|
|
26
|
+
"@radix-ui/react-checkbox": "^1.1.3",
|
|
27
|
+
"@radix-ui/react-dialog": "^1.1.4",
|
|
28
|
+
"@radix-ui/react-dropdown-menu": "^2.1.4",
|
|
29
|
+
"@radix-ui/react-popover": "^1.1.4",
|
|
30
|
+
"@radix-ui/react-radio-group": "^1.2.2",
|
|
31
|
+
"@radix-ui/react-scroll-area": "^1.2.2",
|
|
32
|
+
"@radix-ui/react-select": "^2.1.4",
|
|
33
|
+
"@radix-ui/react-slot": "^1.1.1",
|
|
34
|
+
"@radix-ui/react-switch": "^1.1.2",
|
|
35
|
+
"@radix-ui/react-tooltip": "^1.1.6",
|
|
36
|
+
"class-variance-authority": "^0.7.1",
|
|
37
|
+
"clsx": "^2.1.1",
|
|
38
|
+
"lucide-react": "^0.468.0",
|
|
39
|
+
"next": "15.1.0",
|
|
40
|
+
"react": "^19.0.0",
|
|
41
|
+
"react-dom": "^19.0.0",
|
|
42
|
+
"tailwind-merge": "^2.5.5",
|
|
43
|
+
"tailwindcss-animate": "^1.0.7"
|
|
44
|
+
},
|
|
45
|
+
"devDependencies": {
|
|
46
|
+
"@chromatic-com/storybook": "3.2.2",
|
|
47
|
+
"@eslint/eslintrc": "^3",
|
|
48
|
+
"@rollup/plugin-alias": "^5.1.1",
|
|
49
|
+
"@storybook/addon-essentials": "8.4.7",
|
|
50
|
+
"@storybook/addon-interactions": "8.4.7",
|
|
51
|
+
"@storybook/addon-onboarding": "8.4.7",
|
|
52
|
+
"@storybook/blocks": "8.4.7",
|
|
53
|
+
"@storybook/nextjs": "8.4.7",
|
|
54
|
+
"@storybook/react": "8.4.7",
|
|
55
|
+
"@storybook/test": "8.4.7",
|
|
56
|
+
"@testing-library/dom": "^10.4.0",
|
|
57
|
+
"@testing-library/jest-dom": "^6.6.3",
|
|
58
|
+
"@testing-library/react": "^16.1.0",
|
|
59
|
+
"@types/node": "^20",
|
|
60
|
+
"@types/react": "^19",
|
|
61
|
+
"@types/react-dom": "^19",
|
|
62
|
+
"eslint": "^9",
|
|
63
|
+
"eslint-config-next": "15.1.0",
|
|
64
|
+
"eslint-plugin-import-helpers": "^2.0.1",
|
|
65
|
+
"eslint-plugin-storybook": "^0.11.1",
|
|
66
|
+
"jest": "^29.7.0",
|
|
67
|
+
"jest-environment-jsdom": "^29.7.0",
|
|
68
|
+
"postcss": "^8",
|
|
69
|
+
"rollup": "^4.28.1",
|
|
70
|
+
"rollup-plugin-copy": "^3.5.0",
|
|
71
|
+
"rollup-plugin-dts": "^6.1.1",
|
|
72
|
+
"rollup-plugin-esbuild": "^6.1.1",
|
|
73
|
+
"storybook": "8.4.7",
|
|
74
|
+
"tailwindcss": "^3.4.1",
|
|
75
|
+
"ts-node": "^10.9.2",
|
|
76
|
+
"typescript": "^5"
|
|
77
|
+
},
|
|
78
|
+
"peerDependencies": {
|
|
79
|
+
"react": "^19.0.0",
|
|
80
|
+
"react-dom": "^19.0.0"
|
|
81
|
+
},
|
|
82
|
+
"eslintConfig": {
|
|
83
|
+
"extends": [
|
|
84
|
+
"plugin:storybook/recommended"
|
|
85
|
+
]
|
|
86
|
+
}
|
|
87
|
+
}
|