@tapizlabs/ui 0.1.1 → 0.1.2
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 -8
- package/dist/files/ibm-plex-mono-latin-400-italic.woff +0 -0
- package/dist/files/ibm-plex-mono-latin-400-italic.woff2 +0 -0
- package/dist/files/ibm-plex-mono-latin-400-normal.woff +0 -0
- package/dist/files/ibm-plex-mono-latin-400-normal.woff2 +0 -0
- package/dist/files/ibm-plex-mono-latin-500-normal.woff +0 -0
- package/dist/files/ibm-plex-mono-latin-500-normal.woff2 +0 -0
- package/dist/files/ibm-plex-mono-latin-600-normal.woff +0 -0
- package/dist/files/ibm-plex-mono-latin-600-normal.woff2 +0 -0
- package/dist/files/ibm-plex-mono-latin-ext-400-normal.woff +0 -0
- package/dist/files/ibm-plex-mono-latin-ext-400-normal.woff2 +0 -0
- package/dist/files/ibm-plex-mono-latin-ext-500-normal.woff +0 -0
- package/dist/files/ibm-plex-mono-latin-ext-500-normal.woff2 +0 -0
- package/dist/files/ibm-plex-mono-latin-ext-600-normal.woff +0 -0
- package/dist/files/ibm-plex-mono-latin-ext-600-normal.woff2 +0 -0
- package/dist/files/ibm-plex-sans-cyrillic-400-normal.woff +0 -0
- package/dist/files/ibm-plex-sans-cyrillic-400-normal.woff2 +0 -0
- package/dist/files/ibm-plex-sans-cyrillic-500-normal.woff +0 -0
- package/dist/files/ibm-plex-sans-cyrillic-500-normal.woff2 +0 -0
- package/dist/files/ibm-plex-sans-cyrillic-600-normal.woff +0 -0
- package/dist/files/ibm-plex-sans-cyrillic-600-normal.woff2 +0 -0
- package/dist/files/ibm-plex-sans-cyrillic-700-normal.woff +0 -0
- package/dist/files/ibm-plex-sans-cyrillic-700-normal.woff2 +0 -0
- package/dist/files/ibm-plex-sans-latin-400-italic.woff +0 -0
- package/dist/files/ibm-plex-sans-latin-400-italic.woff2 +0 -0
- package/dist/files/ibm-plex-sans-latin-400-normal.woff +0 -0
- package/dist/files/ibm-plex-sans-latin-400-normal.woff2 +0 -0
- package/dist/files/ibm-plex-sans-latin-500-normal.woff +0 -0
- package/dist/files/ibm-plex-sans-latin-500-normal.woff2 +0 -0
- package/dist/files/ibm-plex-sans-latin-600-normal.woff +0 -0
- package/dist/files/ibm-plex-sans-latin-600-normal.woff2 +0 -0
- package/dist/files/ibm-plex-sans-latin-700-normal.woff +0 -0
- package/dist/files/ibm-plex-sans-latin-700-normal.woff2 +0 -0
- package/dist/fonts.css +161 -0
- package/dist/fonts.js +1 -16
- package/dist/fonts.js.map +1 -1
- package/dist/theme.css +2 -774
- package/package.json +12 -8
package/README.md
CHANGED
|
@@ -50,7 +50,6 @@ Import the shared theme before your app-specific styles:
|
|
|
50
50
|
|
|
51
51
|
```css
|
|
52
52
|
@import "@tapizlabs/ui/theme.css";
|
|
53
|
-
@source "../node_modules/@tapizlabs/ui/dist/**/*.js";
|
|
54
53
|
```
|
|
55
54
|
|
|
56
55
|
Then consume components directly from the package:
|
|
@@ -77,13 +76,7 @@ export function ExamplePanel() {
|
|
|
77
76
|
|
|
78
77
|
## Tailwind Setup
|
|
79
78
|
|
|
80
|
-
`@tapizlabs/ui`
|
|
81
|
-
|
|
82
|
-
```css
|
|
83
|
-
@source "../node_modules/@tapizlabs/ui/dist/**/*.js";
|
|
84
|
-
```
|
|
85
|
-
|
|
86
|
-
Without that line, some shared component classes may be omitted from the final CSS build.
|
|
79
|
+
`@tapizlabs/ui/theme.css` is published as a compiled CSS bundle, so consumer apps only need to import it. No extra `@source` directive is required in application code.
|
|
87
80
|
|
|
88
81
|
## Included Components
|
|
89
82
|
|
|
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
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
package/dist/fonts.css
ADDED
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
/* IBM Plex Sans */
|
|
2
|
+
@font-face {
|
|
3
|
+
font-family: "IBM Plex Sans";
|
|
4
|
+
font-style: normal;
|
|
5
|
+
font-display: swap;
|
|
6
|
+
font-weight: 400;
|
|
7
|
+
src:
|
|
8
|
+
url("./files/ibm-plex-sans-latin-400-normal.woff2") format("woff2"),
|
|
9
|
+
url("./files/ibm-plex-sans-latin-400-normal.woff") format("woff");
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
@font-face {
|
|
13
|
+
font-family: "IBM Plex Sans";
|
|
14
|
+
font-style: italic;
|
|
15
|
+
font-display: swap;
|
|
16
|
+
font-weight: 400;
|
|
17
|
+
src:
|
|
18
|
+
url("./files/ibm-plex-sans-latin-400-italic.woff2") format("woff2"),
|
|
19
|
+
url("./files/ibm-plex-sans-latin-400-italic.woff") format("woff");
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
@font-face {
|
|
23
|
+
font-family: "IBM Plex Sans";
|
|
24
|
+
font-style: normal;
|
|
25
|
+
font-display: swap;
|
|
26
|
+
font-weight: 500;
|
|
27
|
+
src:
|
|
28
|
+
url("./files/ibm-plex-sans-latin-500-normal.woff2") format("woff2"),
|
|
29
|
+
url("./files/ibm-plex-sans-latin-500-normal.woff") format("woff");
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
@font-face {
|
|
33
|
+
font-family: "IBM Plex Sans";
|
|
34
|
+
font-style: normal;
|
|
35
|
+
font-display: swap;
|
|
36
|
+
font-weight: 600;
|
|
37
|
+
src:
|
|
38
|
+
url("./files/ibm-plex-sans-latin-600-normal.woff2") format("woff2"),
|
|
39
|
+
url("./files/ibm-plex-sans-latin-600-normal.woff") format("woff");
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
@font-face {
|
|
43
|
+
font-family: "IBM Plex Sans";
|
|
44
|
+
font-style: normal;
|
|
45
|
+
font-display: swap;
|
|
46
|
+
font-weight: 700;
|
|
47
|
+
src:
|
|
48
|
+
url("./files/ibm-plex-sans-latin-700-normal.woff2") format("woff2"),
|
|
49
|
+
url("./files/ibm-plex-sans-latin-700-normal.woff") format("woff");
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
@font-face {
|
|
53
|
+
font-family: "IBM Plex Sans";
|
|
54
|
+
font-style: normal;
|
|
55
|
+
font-display: swap;
|
|
56
|
+
font-weight: 400;
|
|
57
|
+
src:
|
|
58
|
+
url("./files/ibm-plex-sans-cyrillic-400-normal.woff2") format("woff2"),
|
|
59
|
+
url("./files/ibm-plex-sans-cyrillic-400-normal.woff") format("woff");
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
@font-face {
|
|
63
|
+
font-family: "IBM Plex Sans";
|
|
64
|
+
font-style: normal;
|
|
65
|
+
font-display: swap;
|
|
66
|
+
font-weight: 500;
|
|
67
|
+
src:
|
|
68
|
+
url("./files/ibm-plex-sans-cyrillic-500-normal.woff2") format("woff2"),
|
|
69
|
+
url("./files/ibm-plex-sans-cyrillic-500-normal.woff") format("woff");
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
@font-face {
|
|
73
|
+
font-family: "IBM Plex Sans";
|
|
74
|
+
font-style: normal;
|
|
75
|
+
font-display: swap;
|
|
76
|
+
font-weight: 600;
|
|
77
|
+
src:
|
|
78
|
+
url("./files/ibm-plex-sans-cyrillic-600-normal.woff2") format("woff2"),
|
|
79
|
+
url("./files/ibm-plex-sans-cyrillic-600-normal.woff") format("woff");
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
@font-face {
|
|
83
|
+
font-family: "IBM Plex Sans";
|
|
84
|
+
font-style: normal;
|
|
85
|
+
font-display: swap;
|
|
86
|
+
font-weight: 700;
|
|
87
|
+
src:
|
|
88
|
+
url("./files/ibm-plex-sans-cyrillic-700-normal.woff2") format("woff2"),
|
|
89
|
+
url("./files/ibm-plex-sans-cyrillic-700-normal.woff") format("woff");
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
/* IBM Plex Mono */
|
|
93
|
+
@font-face {
|
|
94
|
+
font-family: "IBM Plex Mono";
|
|
95
|
+
font-style: normal;
|
|
96
|
+
font-display: swap;
|
|
97
|
+
font-weight: 400;
|
|
98
|
+
src:
|
|
99
|
+
url("./files/ibm-plex-mono-latin-400-normal.woff2") format("woff2"),
|
|
100
|
+
url("./files/ibm-plex-mono-latin-400-normal.woff") format("woff");
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
@font-face {
|
|
104
|
+
font-family: "IBM Plex Mono";
|
|
105
|
+
font-style: italic;
|
|
106
|
+
font-display: swap;
|
|
107
|
+
font-weight: 400;
|
|
108
|
+
src:
|
|
109
|
+
url("./files/ibm-plex-mono-latin-400-italic.woff2") format("woff2"),
|
|
110
|
+
url("./files/ibm-plex-mono-latin-400-italic.woff") format("woff");
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
@font-face {
|
|
114
|
+
font-family: "IBM Plex Mono";
|
|
115
|
+
font-style: normal;
|
|
116
|
+
font-display: swap;
|
|
117
|
+
font-weight: 500;
|
|
118
|
+
src:
|
|
119
|
+
url("./files/ibm-plex-mono-latin-500-normal.woff2") format("woff2"),
|
|
120
|
+
url("./files/ibm-plex-mono-latin-500-normal.woff") format("woff");
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
@font-face {
|
|
124
|
+
font-family: "IBM Plex Mono";
|
|
125
|
+
font-style: normal;
|
|
126
|
+
font-display: swap;
|
|
127
|
+
font-weight: 600;
|
|
128
|
+
src:
|
|
129
|
+
url("./files/ibm-plex-mono-latin-600-normal.woff2") format("woff2"),
|
|
130
|
+
url("./files/ibm-plex-mono-latin-600-normal.woff") format("woff");
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
@font-face {
|
|
134
|
+
font-family: "IBM Plex Mono";
|
|
135
|
+
font-style: normal;
|
|
136
|
+
font-display: swap;
|
|
137
|
+
font-weight: 400;
|
|
138
|
+
src:
|
|
139
|
+
url("./files/ibm-plex-mono-latin-ext-400-normal.woff2") format("woff2"),
|
|
140
|
+
url("./files/ibm-plex-mono-latin-ext-400-normal.woff") format("woff");
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
@font-face {
|
|
144
|
+
font-family: "IBM Plex Mono";
|
|
145
|
+
font-style: normal;
|
|
146
|
+
font-display: swap;
|
|
147
|
+
font-weight: 500;
|
|
148
|
+
src:
|
|
149
|
+
url("./files/ibm-plex-mono-latin-ext-500-normal.woff2") format("woff2"),
|
|
150
|
+
url("./files/ibm-plex-mono-latin-ext-500-normal.woff") format("woff");
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
@font-face {
|
|
154
|
+
font-family: "IBM Plex Mono";
|
|
155
|
+
font-style: normal;
|
|
156
|
+
font-display: swap;
|
|
157
|
+
font-weight: 600;
|
|
158
|
+
src:
|
|
159
|
+
url("./files/ibm-plex-mono-latin-ext-600-normal.woff2") format("woff2"),
|
|
160
|
+
url("./files/ibm-plex-mono-latin-ext-600-normal.woff") format("woff");
|
|
161
|
+
}
|
package/dist/fonts.js
CHANGED
|
@@ -1,18 +1,3 @@
|
|
|
1
1
|
// src/fonts.ts
|
|
2
|
-
import "
|
|
3
|
-
import "@fontsource/ibm-plex-sans/latin-400-italic.css";
|
|
4
|
-
import "@fontsource/ibm-plex-sans/latin-500.css";
|
|
5
|
-
import "@fontsource/ibm-plex-sans/latin-600.css";
|
|
6
|
-
import "@fontsource/ibm-plex-sans/latin-700.css";
|
|
7
|
-
import "@fontsource/ibm-plex-sans/cyrillic-400.css";
|
|
8
|
-
import "@fontsource/ibm-plex-sans/cyrillic-500.css";
|
|
9
|
-
import "@fontsource/ibm-plex-sans/cyrillic-600.css";
|
|
10
|
-
import "@fontsource/ibm-plex-sans/cyrillic-700.css";
|
|
11
|
-
import "@fontsource/ibm-plex-mono/latin-400.css";
|
|
12
|
-
import "@fontsource/ibm-plex-mono/latin-400-italic.css";
|
|
13
|
-
import "@fontsource/ibm-plex-mono/latin-500.css";
|
|
14
|
-
import "@fontsource/ibm-plex-mono/latin-600.css";
|
|
15
|
-
import "@fontsource/ibm-plex-mono/latin-ext-400.css";
|
|
16
|
-
import "@fontsource/ibm-plex-mono/latin-ext-500.css";
|
|
17
|
-
import "@fontsource/ibm-plex-mono/latin-ext-600.css";
|
|
2
|
+
import "./fonts.css";
|
|
18
3
|
//# sourceMappingURL=fonts.js.map
|
package/dist/fonts.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/fonts.ts"],"sourcesContent":["import \"
|
|
1
|
+
{"version":3,"sources":["../src/fonts.ts"],"sourcesContent":["import \"./fonts.css\";\n"],"mappings":";AAAA,OAAO;","names":[]}
|
package/dist/theme.css
CHANGED
|
@@ -1,774 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
/* stylelint-disable */
|
|
4
|
-
@theme {
|
|
5
|
-
/* Grid Brutalism Electric Cyan + Signal Lime */
|
|
6
|
-
--color-ink-000: #050608;
|
|
7
|
-
--color-ink-100: #06080c;
|
|
8
|
-
--color-ink-200: #0c0f16;
|
|
9
|
-
--color-ink-300: #11151e;
|
|
10
|
-
--color-ink-400: #1d222d;
|
|
11
|
-
--color-ink-500: #262d3b;
|
|
12
|
-
--color-border: #1d2330;
|
|
13
|
-
--color-border-hi: #2a3346;
|
|
14
|
-
--color-txt-1: #f1f4f9;
|
|
15
|
-
--color-txt-2: #aab3c2;
|
|
16
|
-
--color-txt-3: #6b7686;
|
|
17
|
-
--color-txt-4: #7a8496;
|
|
18
|
-
|
|
19
|
-
/* Accent ramp electric cyan replaces Prussian Navy */
|
|
20
|
-
--color-primary-50: #e8fbff;
|
|
21
|
-
--color-primary-100: #c7f5ff;
|
|
22
|
-
--color-primary-200: #99eeff;
|
|
23
|
-
--color-primary-300: #5ee7ff;
|
|
24
|
-
--color-primary-400: #38d4f0;
|
|
25
|
-
--color-primary-500: #1eb5d4;
|
|
26
|
-
--color-primary-600: #1496b3;
|
|
27
|
-
--color-primary-700: #0e7088;
|
|
28
|
-
--color-primary-800: #0a4f60;
|
|
29
|
-
--color-primary-900: #062f3b;
|
|
30
|
-
--color-primary-950: #03161c;
|
|
31
|
-
|
|
32
|
-
/* Signal lime */
|
|
33
|
-
--color-signal-300: #e4ff66;
|
|
34
|
-
--color-signal-400: #d4ff3a;
|
|
35
|
-
--color-signal-500: #b8e620;
|
|
36
|
-
|
|
37
|
-
--color-warn: #ff7a4d;
|
|
38
|
-
--color-good: #4dd6a3;
|
|
39
|
-
|
|
40
|
-
/* Icon background for icon containers dark mode default */
|
|
41
|
-
--color-icon-bg: #03161c; /* = primary-950 */
|
|
42
|
-
/* btn-primary text color dark mode: black on bright cyan */
|
|
43
|
-
--btn-primary-color: #000;
|
|
44
|
-
|
|
45
|
-
--font-display: 'IBM Plex Sans', system-ui, sans-serif;
|
|
46
|
-
--font-body: 'IBM Plex Sans', system-ui, sans-serif;
|
|
47
|
-
--font-mono: 'IBM Plex Mono', ui-monospace, monospace;
|
|
48
|
-
|
|
49
|
-
/* Kill all rounding */
|
|
50
|
-
--radius-none: 0;
|
|
51
|
-
--radius-sm: 0;
|
|
52
|
-
--radius-md: 0;
|
|
53
|
-
--radius-lg: 0;
|
|
54
|
-
--radius-xl: 0;
|
|
55
|
-
--radius-2xl: 0;
|
|
56
|
-
--radius-full: 9999px;
|
|
57
|
-
|
|
58
|
-
/* Animations */
|
|
59
|
-
--animate-fade-in-up: fade-in-up 0.5s ease both;
|
|
60
|
-
--animate-fade-in-down: fade-in-down 0.4s ease both;
|
|
61
|
-
--animate-fade-in: fade-in 0.3s ease both;
|
|
62
|
-
--animate-fade-out: fade-out 0.25s ease both;
|
|
63
|
-
--animate-count-up: count-up 0.5s ease both;
|
|
64
|
-
--animate-slide-in-right: slide-in-right 0.35s ease both;
|
|
65
|
-
--animate-slide-in-left: slide-in-left 0.35s ease both;
|
|
66
|
-
--animate-scale-in: scale-in 0.3s cubic-bezier(0.34,1.56,0.64,1) both;
|
|
67
|
-
--animate-progress-fill: progress-fill 1s ease both;
|
|
68
|
-
--animate-pulse-soft: pulse-soft 2s ease-in-out infinite;
|
|
69
|
-
--animate-shake: shake 0.4s ease both;
|
|
70
|
-
--animate-bounce-in: bounce-in 0.5s cubic-bezier(0.34,1.56,0.64,1) both;
|
|
71
|
-
--animate-flip-in: flip-in 0.4s ease both;
|
|
72
|
-
--animate-blur-in: blur-in 0.35s ease both;
|
|
73
|
-
--animate-slide-up-fade: slide-up-fade 0.3s ease both;
|
|
74
|
-
|
|
75
|
-
@keyframes fade-in-up { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
|
|
76
|
-
@keyframes fade-in-down { from { opacity:0; transform:translateY(-12px); } to { opacity:1; transform:translateY(0); } }
|
|
77
|
-
@keyframes fade-in { from { opacity:0; } to { opacity:1; } }
|
|
78
|
-
@keyframes fade-out { from { opacity:1; } to { opacity:0; } }
|
|
79
|
-
@keyframes count-up { from { opacity:0; transform:scale(0.85); } to { opacity:1; transform:scale(1); } }
|
|
80
|
-
@keyframes slide-in-right { from { opacity:0; transform:translateX(20px); } to { opacity:1; transform:translateX(0); } }
|
|
81
|
-
@keyframes slide-in-left { from { opacity:0; transform:translateX(-20px); } to { opacity:1; transform:translateX(0); } }
|
|
82
|
-
@keyframes scale-in { from { opacity:0; transform:scale(0.88); } to { opacity:1; transform:scale(1); } }
|
|
83
|
-
@keyframes progress-fill { from { width: 0%; } }
|
|
84
|
-
@keyframes pulse-soft { 0%,100% { opacity:1; } 50% { opacity:0.6; } }
|
|
85
|
-
@keyframes shake {
|
|
86
|
-
0%,100% { transform:translateX(0); } 20% { transform:translateX(-6px); }
|
|
87
|
-
40% { transform:translateX(6px); } 60% { transform:translateX(-4px); }
|
|
88
|
-
80% { transform:translateX(4px); }
|
|
89
|
-
}
|
|
90
|
-
@keyframes bounce-in { from { opacity:0; transform:scale(0.7); } to { opacity:1; transform:scale(1); } }
|
|
91
|
-
@keyframes flip-in { from { opacity:0; transform:rotateX(-30deg) translateY(8px); } to { opacity:1; transform:rotateX(0deg) translateY(0); } }
|
|
92
|
-
@keyframes blur-in { from { opacity:0; filter:blur(6px); transform:scale(0.97); } to { opacity:1; filter:blur(0px); transform:scale(1); } }
|
|
93
|
-
@keyframes slide-up-fade { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
|
|
94
|
-
@keyframes accordion-open { from { grid-template-rows: 0fr; opacity: 0; } to { grid-template-rows: 1fr; opacity: 1; } }
|
|
95
|
-
@keyframes accordion-close { from { grid-template-rows: 1fr; opacity: 1; } to { grid-template-rows: 0fr; opacity: 0; } }
|
|
96
|
-
@keyframes tz-pulse { 0%,100% { opacity:1; } 50% { opacity:.35; } }
|
|
97
|
-
@keyframes tz-bar-grow { from { transform:scaleY(0); } to { transform:scaleY(1); } }
|
|
98
|
-
@keyframes skeleton-shimmer { 0% { background-position:-400px 0; } 100% { background-position:400px 0; } }
|
|
99
|
-
@keyframes slowSlideFade {
|
|
100
|
-
0% { transform:translateX(-120px); opacity:0; }
|
|
101
|
-
15% { transform:translateX(-80px); opacity:1; }
|
|
102
|
-
85% { transform:translateX(80px); opacity:1; }
|
|
103
|
-
100% { transform:translateX(120px); opacity:0; }
|
|
104
|
-
}
|
|
105
|
-
@keyframes thinPulse {
|
|
106
|
-
0%,100% { box-shadow:0 0 4px rgba(94,231,255,.15); background:rgba(94,231,255,.05); width:70px; height:2px; }
|
|
107
|
-
50% { box-shadow:0 0 14px rgba(94,231,255,.4); background:rgba(94,231,255,.15); width:90px; height:3px; }
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
.cmd-input::placeholder { color: var(--color-txt-4); opacity: 1; }
|
|
112
|
-
.cmd-input::selection { background: rgba(94,231,255,0.15); }
|
|
113
|
-
|
|
114
|
-
/*
|
|
115
|
-
LIGHT MODE OVERRIDES
|
|
116
|
-
*/
|
|
117
|
-
html:not(.dark) {
|
|
118
|
-
--color-ink-000: #ffffff;
|
|
119
|
-
--color-ink-100: #f5f6f8;
|
|
120
|
-
--color-ink-200: #ebedf1;
|
|
121
|
-
--color-ink-300: #dde0e8;
|
|
122
|
-
--color-ink-400: #cdd1db;
|
|
123
|
-
--color-ink-500: #b8bec9;
|
|
124
|
-
--color-border: #d8dce6;
|
|
125
|
-
--color-border-hi: #c4c9d6;
|
|
126
|
-
--color-txt-1: #0d1117;
|
|
127
|
-
--color-txt-2: #3a4255;
|
|
128
|
-
--color-txt-3: #6b7280;
|
|
129
|
-
--color-txt-4: #6b7280;
|
|
130
|
-
|
|
131
|
-
/* Shift primary accent slightly darker for light bg readability */
|
|
132
|
-
--color-primary-300: #0ea5c9;
|
|
133
|
-
--color-primary-400: #0891b2;
|
|
134
|
-
--color-primary-500: #0e7490;
|
|
135
|
-
|
|
136
|
-
/* Signal lime stays vivid but darkened for contrast */
|
|
137
|
-
--color-signal-300: #65a30d;
|
|
138
|
-
--color-signal-400: #4d7c0f;
|
|
139
|
-
--color-signal-500: #3f6212;
|
|
140
|
-
|
|
141
|
-
--color-warn: #dc4f1e;
|
|
142
|
-
--color-good: #059669;
|
|
143
|
-
|
|
144
|
-
/* Icon background light tint of primary for icon containers */
|
|
145
|
-
--color-icon-bg: color-mix(in srgb, var(--color-primary-300) 12%, var(--color-ink-200));
|
|
146
|
-
|
|
147
|
-
/* btn-primary text: black on dark (cyan bg), white on light (darker cyan bg) */
|
|
148
|
-
--btn-primary-color: #fff;
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
/*
|
|
152
|
-
BASE
|
|
153
|
-
*/
|
|
154
|
-
@layer base {
|
|
155
|
-
*, ::after, ::before, ::backdrop, ::file-selector-button {
|
|
156
|
-
border-color: var(--color-border, currentcolor);
|
|
157
|
-
border-radius: 0 !important;
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
html {
|
|
161
|
-
font-family: var(--font-body);
|
|
162
|
-
letter-spacing: 0;
|
|
163
|
-
-webkit-font-smoothing: antialiased;
|
|
164
|
-
background: var(--color-ink-100);
|
|
165
|
-
color: var(--color-txt-1);
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
body {
|
|
169
|
-
background: var(--color-ink-100);
|
|
170
|
-
color: var(--color-txt-1);
|
|
171
|
-
font-family: var(--font-body);
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
h1, h2, h3, h4 {
|
|
175
|
-
font-family: var(--font-display);
|
|
176
|
-
font-weight: 600;
|
|
177
|
-
letter-spacing: 0;
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
[class*="rounded"] { border-radius: 0 !important; }
|
|
181
|
-
|
|
182
|
-
html *:not([class*="animate-"]):not(.sliding-logo):not(.pulse-line) {
|
|
183
|
-
transition:
|
|
184
|
-
background-color 0.15s ease,
|
|
185
|
-
border-color 0.15s ease,
|
|
186
|
-
color 0.12s ease,
|
|
187
|
-
transform 0.15s ease;
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
/* Surface mapping */
|
|
191
|
-
.bg-white { background-color: var(--color-ink-200) !important; }
|
|
192
|
-
.bg-gray-50 { background-color: var(--color-ink-100) !important; }
|
|
193
|
-
.bg-gray-100 { background-color: var(--color-ink-300) !important; }
|
|
194
|
-
.bg-gray-200 { background-color: var(--color-ink-400) !important; }
|
|
195
|
-
|
|
196
|
-
.border-gray-100,
|
|
197
|
-
.border-gray-200,
|
|
198
|
-
.border-gray-300 { border-color: var(--color-border) !important; }
|
|
199
|
-
hr { border-color: var(--color-border) !important; }
|
|
200
|
-
|
|
201
|
-
.text-gray-900, .text-gray-800 { color: var(--color-txt-1) !important; }
|
|
202
|
-
.text-gray-700, .text-gray-600 { color: var(--color-txt-2) !important; }
|
|
203
|
-
.text-gray-500, .text-gray-400 { color: var(--color-txt-3) !important; }
|
|
204
|
-
.text-gray-300 { color: var(--color-txt-4) !important; }
|
|
205
|
-
|
|
206
|
-
.hover\:bg-gray-50:hover { background-color: var(--color-ink-300) !important; }
|
|
207
|
-
.hover\:bg-gray-100:hover { background-color: var(--color-ink-400) !important; }
|
|
208
|
-
.hover\:text-gray-900:hover,
|
|
209
|
-
.hover\:text-gray-800:hover { color: var(--color-txt-1) !important; }
|
|
210
|
-
.hover\:text-gray-600:hover { color: var(--color-txt-2) !important; }
|
|
211
|
-
|
|
212
|
-
/* Kill shadows */
|
|
213
|
-
.shadow-sm, .shadow-md, .shadow-xl, .shadow-2xl { box-shadow: none !important; }
|
|
214
|
-
|
|
215
|
-
/* Inputs */
|
|
216
|
-
input, textarea {
|
|
217
|
-
background-color: var(--color-ink-100) !important;
|
|
218
|
-
border-color: var(--color-border-hi) !important;
|
|
219
|
-
color: var(--color-txt-1) !important;
|
|
220
|
-
}
|
|
221
|
-
input::placeholder, textarea::placeholder { color: var(--color-txt-4) !important; }
|
|
222
|
-
input:focus, textarea:focus {
|
|
223
|
-
border-color: var(--color-primary-300) !important;
|
|
224
|
-
box-shadow: inset 3px 0 0 0 var(--color-signal-400), 0 0 0 1px var(--color-primary-300) !important;
|
|
225
|
-
outline: none !important;
|
|
226
|
-
}
|
|
227
|
-
.cmd-input:focus {
|
|
228
|
-
border-color: transparent !important;
|
|
229
|
-
box-shadow: none !important;
|
|
230
|
-
outline: none !important;
|
|
231
|
-
}
|
|
232
|
-
|
|
233
|
-
/* Tables */
|
|
234
|
-
table { color: var(--color-txt-2) !important; }
|
|
235
|
-
thead, thead tr { background-color: var(--color-ink-300) !important; }
|
|
236
|
-
thead th {
|
|
237
|
-
background-color: var(--color-ink-300) !important;
|
|
238
|
-
color: var(--color-txt-3) !important;
|
|
239
|
-
border-color: var(--color-border) !important;
|
|
240
|
-
font-family: var(--font-mono);
|
|
241
|
-
font-size: 10px;
|
|
242
|
-
letter-spacing: 0.18em;
|
|
243
|
-
text-transform: uppercase;
|
|
244
|
-
font-weight: 500;
|
|
245
|
-
}
|
|
246
|
-
tbody tr { background-color: var(--color-ink-200) !important; border-color: var(--color-border) !important; }
|
|
247
|
-
tbody tr:nth-child(even) { background-color: var(--color-ink-100) !important; }
|
|
248
|
-
tbody tr:hover { background-color: var(--color-ink-300) !important; }
|
|
249
|
-
tbody td, tbody th { color: var(--color-txt-2) !important; border-color: var(--color-border) !important; }
|
|
250
|
-
|
|
251
|
-
/* Cards */
|
|
252
|
-
.card, .stat-card {
|
|
253
|
-
background-color: var(--color-ink-200) !important;
|
|
254
|
-
border-color: var(--color-border) !important;
|
|
255
|
-
box-shadow: none !important;
|
|
256
|
-
}
|
|
257
|
-
header:not(.landing-nav) { background-color: var(--color-ink-200) !important; border-color: var(--color-border) !important; }
|
|
258
|
-
|
|
259
|
-
/* Primary cyan overrides */
|
|
260
|
-
.bg-primary-50 { background-color: color-mix(in srgb, var(--color-primary-300) 8%, var(--color-ink-300)) !important; }
|
|
261
|
-
.bg-primary-100 { background-color: color-mix(in srgb, var(--color-primary-300) 14%, var(--color-ink-300)) !important; }
|
|
262
|
-
.bg-primary-200 { background-color: color-mix(in srgb, var(--color-primary-300) 22%, var(--color-ink-300)) !important; }
|
|
263
|
-
.bg-primary-500 { background-color: var(--color-primary-300) !important; }
|
|
264
|
-
.bg-primary-600 { background-color: var(--color-primary-400) !important; }
|
|
265
|
-
.bg-primary-700 { background-color: var(--color-primary-300) !important; color: #fff !important; }
|
|
266
|
-
.bg-primary-800 { background-color: var(--color-primary-400) !important; }
|
|
267
|
-
.bg-primary-900 { background-color: var(--color-primary-600) !important; }
|
|
268
|
-
|
|
269
|
-
.text-primary-800, .text-primary-700 { color: var(--color-primary-300) !important; }
|
|
270
|
-
.text-primary-600, .text-primary-500 { color: var(--color-primary-400) !important; }
|
|
271
|
-
.text-primary-400 { color: var(--color-primary-500) !important; }
|
|
272
|
-
.text-primary-50 { color: #000 !important; }
|
|
273
|
-
|
|
274
|
-
.border-primary-100 { border-color: color-mix(in srgb, var(--color-primary-300) 35%, transparent) !important; }
|
|
275
|
-
.border-primary-200 { border-color: var(--color-border-hi) !important; }
|
|
276
|
-
.border-primary-300 { border-color: var(--color-primary-300) !important; }
|
|
277
|
-
.border-primary-500 { border-color: var(--color-primary-300) !important; }
|
|
278
|
-
.border-primary-600 { border-color: var(--color-primary-400) !important; }
|
|
279
|
-
|
|
280
|
-
.hover\:bg-primary-50:hover { background-color: var(--color-ink-300) !important; }
|
|
281
|
-
.hover\:bg-primary-100:hover { background-color: var(--color-ink-300) !important; }
|
|
282
|
-
.hover\:bg-primary-200:hover { background-color: var(--color-ink-400) !important; }
|
|
283
|
-
.hover\:bg-primary-800:hover { background-color: var(--color-primary-400) !important; }
|
|
284
|
-
.hover\:text-primary-700:hover { color: var(--color-primary-300) !important; }
|
|
285
|
-
.hover\:text-primary-600:hover { color: var(--color-primary-400) !important; }
|
|
286
|
-
.hover\:border-primary-300:hover { border-color: var(--color-primary-300) !important; }
|
|
287
|
-
|
|
288
|
-
.group:hover .group-hover\:text-primary-600 { color: var(--color-primary-300) !important; }
|
|
289
|
-
[class*="bg-primary-50"][class*="text-primary"] {
|
|
290
|
-
color: var(--color-primary-400) !important;
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
/* Emerald signal lime */
|
|
294
|
-
.bg-emerald-400, .bg-green-400 { background-color: var(--color-signal-400) !important; }
|
|
295
|
-
.text-emerald-600, .text-green-600 { color: var(--color-good) !important; }
|
|
296
|
-
.animate-pulse { animation: tz-pulse 1.8s ease-in-out infinite !important; }
|
|
297
|
-
|
|
298
|
-
/* Red/danger */
|
|
299
|
-
.text-red-600 { color: var(--color-warn) !important; }
|
|
300
|
-
.bg-red-50 { background-color: rgba(255,122,77,.08) !important; }
|
|
301
|
-
.border-red-100 { border-color: rgba(255,122,77,.2) !important; }
|
|
302
|
-
.text-red-700 { color: var(--color-warn) !important; }
|
|
303
|
-
.hover\:bg-red-50:hover { background-color: rgba(255,122,77,.12) !important; }
|
|
304
|
-
|
|
305
|
-
/* Role badge */
|
|
306
|
-
.bg-primary-500.text-primary-50 {
|
|
307
|
-
background-color: transparent !important;
|
|
308
|
-
border: 1px solid var(--color-primary-300) !important;
|
|
309
|
-
color: var(--color-primary-300) !important;
|
|
310
|
-
font-family: var(--font-mono);
|
|
311
|
-
font-size: 9px;
|
|
312
|
-
letter-spacing: 0.15em;
|
|
313
|
-
text-transform: uppercase;
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
/* Zinc / Slate / Stone */
|
|
317
|
-
.bg-zinc-50, .bg-slate-50, .bg-stone-50 { background-color: var(--color-ink-100) !important; }
|
|
318
|
-
.bg-zinc-100, .bg-slate-100, .bg-stone-100 { background-color: var(--color-ink-200) !important; }
|
|
319
|
-
.bg-zinc-200, .bg-slate-200 { background-color: var(--color-ink-300) !important; }
|
|
320
|
-
.border-zinc-100, .border-slate-100, .border-zinc-200, .border-slate-200 { border-color: var(--color-border) !important; }
|
|
321
|
-
.text-zinc-900,.text-slate-900,.text-zinc-700,.text-slate-700 { color: var(--color-txt-1) !important; }
|
|
322
|
-
.text-zinc-600,.text-slate-600,.text-zinc-500,.text-slate-500 { color: var(--color-txt-3) !important; }
|
|
323
|
-
|
|
324
|
-
/* Select */
|
|
325
|
-
select {
|
|
326
|
-
display: block;
|
|
327
|
-
background-color: var(--color-ink-100) !important;
|
|
328
|
-
border: 1px solid var(--color-border-hi) !important;
|
|
329
|
-
border-radius: 0 !important;
|
|
330
|
-
font-size: 0.875rem;
|
|
331
|
-
color: var(--color-txt-1) !important;
|
|
332
|
-
appearance: none;
|
|
333
|
-
-webkit-appearance: none;
|
|
334
|
-
padding-right: 2.25rem !important;
|
|
335
|
-
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%235ee7ff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E") !important;
|
|
336
|
-
background-repeat: no-repeat !important;
|
|
337
|
-
background-position: right 0.65rem center !important;
|
|
338
|
-
background-size: 1rem 1rem !important;
|
|
339
|
-
background-origin: padding-box !important;
|
|
340
|
-
}
|
|
341
|
-
select::-ms-expand { display: none; }
|
|
342
|
-
select option {
|
|
343
|
-
background: var(--color-ink-200);
|
|
344
|
-
color: var(--color-txt-1);
|
|
345
|
-
}
|
|
346
|
-
select:focus {
|
|
347
|
-
outline: none;
|
|
348
|
-
border-color: var(--color-primary-300) !important;
|
|
349
|
-
box-shadow: inset 3px 0 0 0 var(--color-signal-400) !important;
|
|
350
|
-
}
|
|
351
|
-
select:disabled { opacity: 0.4; cursor: not-allowed; }
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
/*
|
|
355
|
-
DARK MODE primary surface overrides
|
|
356
|
-
*/
|
|
357
|
-
html.dark .bg-primary-50 { background-color: var(--color-primary-950) !important; }
|
|
358
|
-
html.dark .bg-primary-100 { background-color: color-mix(in srgb, var(--color-primary-300) 5%, var(--color-ink-200)) !important; }
|
|
359
|
-
html.dark .bg-primary-200 { background-color: color-mix(in srgb, var(--color-primary-300) 10%, var(--color-ink-200)) !important; }
|
|
360
|
-
html.dark .border-primary-100 { border-color: color-mix(in srgb, var(--color-primary-300) 12%, transparent) !important; }
|
|
361
|
-
html.dark .text-primary-700,
|
|
362
|
-
html.dark .text-primary-800 { color: var(--color-primary-300) !important; }
|
|
363
|
-
|
|
364
|
-
/*
|
|
365
|
-
KICKER
|
|
366
|
-
*/
|
|
367
|
-
.kicker {
|
|
368
|
-
font-family: var(--font-mono);
|
|
369
|
-
font-size: 10px;
|
|
370
|
-
letter-spacing: 0.18em;
|
|
371
|
-
text-transform: uppercase;
|
|
372
|
-
font-weight: 500;
|
|
373
|
-
color: var(--color-txt-3);
|
|
374
|
-
}
|
|
375
|
-
|
|
376
|
-
.font-mono { font-family: var(--font-mono) !important; }
|
|
377
|
-
.font-display { font-family: var(--font-display) !important; }
|
|
378
|
-
|
|
379
|
-
/* Grid background */
|
|
380
|
-
.grid-bg {
|
|
381
|
-
background-image:
|
|
382
|
-
linear-gradient(var(--color-border) 1px, transparent 1px),
|
|
383
|
-
linear-gradient(90deg, var(--color-border) 1px, transparent 1px);
|
|
384
|
-
background-size: 24px 24px;
|
|
385
|
-
background-position: -1px -1px;
|
|
386
|
-
}
|
|
387
|
-
|
|
388
|
-
.tz-pulse { animation: tz-pulse 1.8s ease-in-out infinite; }
|
|
389
|
-
.tz-bar { transform-origin: bottom; animation: tz-bar-grow .6s cubic-bezier(.4,1.4,.4,1) both; }
|
|
390
|
-
|
|
391
|
-
/*
|
|
392
|
-
UTILITIES
|
|
393
|
-
*/
|
|
394
|
-
@utility btn-primary {
|
|
395
|
-
display: inline-flex;
|
|
396
|
-
align-items: center;
|
|
397
|
-
justify-content: center;
|
|
398
|
-
padding: 0.5rem 1rem;
|
|
399
|
-
background: var(--color-primary-300);
|
|
400
|
-
color: var(--btn-primary-color);
|
|
401
|
-
font-family: var(--font-display);
|
|
402
|
-
font-size: 0.875rem;
|
|
403
|
-
font-weight: 600;
|
|
404
|
-
border-radius: 0 !important;
|
|
405
|
-
box-shadow: 4px 4px 0 0 var(--color-signal-400);
|
|
406
|
-
cursor: pointer;
|
|
407
|
-
&:hover { transform: translate(-1px,-1px); box-shadow: 6px 6px 0 0 var(--color-signal-400); }
|
|
408
|
-
&:active { transform: translate(1px,1px); box-shadow: 2px 2px 0 0 var(--color-signal-400); }
|
|
409
|
-
&:disabled { opacity: 0.4; cursor: not-allowed; transform: none; box-shadow: none; }
|
|
410
|
-
}
|
|
411
|
-
|
|
412
|
-
@utility btn-secondary {
|
|
413
|
-
display: inline-flex;
|
|
414
|
-
align-items: center;
|
|
415
|
-
justify-content: center;
|
|
416
|
-
padding: 0.5rem 1rem;
|
|
417
|
-
background: transparent;
|
|
418
|
-
color: var(--color-txt-2);
|
|
419
|
-
font-family: var(--font-mono);
|
|
420
|
-
font-size: 0.875rem;
|
|
421
|
-
font-weight: 500;
|
|
422
|
-
border: 1px solid var(--color-border-hi);
|
|
423
|
-
border-radius: 0 !important;
|
|
424
|
-
cursor: pointer;
|
|
425
|
-
&:hover { color: var(--color-txt-1); border-color: var(--color-primary-300); }
|
|
426
|
-
&:active { background: var(--color-ink-300); }
|
|
427
|
-
&:disabled { opacity: 0.4; cursor: not-allowed; }
|
|
428
|
-
}
|
|
429
|
-
|
|
430
|
-
@utility btn-danger {
|
|
431
|
-
display: inline-flex;
|
|
432
|
-
align-items: center;
|
|
433
|
-
justify-content: center;
|
|
434
|
-
background: transparent;
|
|
435
|
-
color: var(--color-warn);
|
|
436
|
-
font-family: var(--font-mono);
|
|
437
|
-
border: 1px solid var(--color-warn);
|
|
438
|
-
border-radius: 0 !important;
|
|
439
|
-
cursor: pointer;
|
|
440
|
-
&:hover { background: rgba(255,122,77,.12); }
|
|
441
|
-
}
|
|
442
|
-
|
|
443
|
-
@utility input-field {
|
|
444
|
-
display: block;
|
|
445
|
-
width: 100%;
|
|
446
|
-
padding: 0.625rem 0.875rem;
|
|
447
|
-
background: var(--color-ink-100);
|
|
448
|
-
border: 1px solid var(--color-border-hi);
|
|
449
|
-
border-radius: 0 !important;
|
|
450
|
-
font-size: 0.875rem;
|
|
451
|
-
color: var(--color-txt-1);
|
|
452
|
-
outline: none;
|
|
453
|
-
&::placeholder { color: var(--color-txt-4); }
|
|
454
|
-
&:focus {
|
|
455
|
-
border-color: var(--color-primary-300);
|
|
456
|
-
box-shadow: inset 3px 0 0 0 var(--color-signal-400);
|
|
457
|
-
}
|
|
458
|
-
}
|
|
459
|
-
|
|
460
|
-
@utility skeleton {
|
|
461
|
-
border-radius: 0 !important;
|
|
462
|
-
background: linear-gradient(90deg, var(--color-ink-300) 25%, var(--color-ink-400) 50%, var(--color-ink-300) 75%);
|
|
463
|
-
background-size: 800px 100%;
|
|
464
|
-
animation: skeleton-shimmer 1.5s infinite linear;
|
|
465
|
-
}
|
|
466
|
-
|
|
467
|
-
@utility card {
|
|
468
|
-
background: var(--color-ink-200);
|
|
469
|
-
border: 1px solid var(--color-border);
|
|
470
|
-
border-radius: 0 !important;
|
|
471
|
-
box-shadow: none;
|
|
472
|
-
padding: 1.25rem;
|
|
473
|
-
}
|
|
474
|
-
|
|
475
|
-
@utility form-panel {
|
|
476
|
-
background: var(--color-ink-200);
|
|
477
|
-
border: 1px solid var(--color-border-hi);
|
|
478
|
-
border-top: 2px solid var(--color-primary-300);
|
|
479
|
-
border-radius: 0 !important;
|
|
480
|
-
box-shadow: none;
|
|
481
|
-
padding: 1.25rem;
|
|
482
|
-
}
|
|
483
|
-
|
|
484
|
-
@utility stat-card {
|
|
485
|
-
background: var(--color-ink-200);
|
|
486
|
-
border: 1px solid var(--color-border);
|
|
487
|
-
border-radius: 0 !important;
|
|
488
|
-
box-shadow: none;
|
|
489
|
-
padding: 1.25rem;
|
|
490
|
-
display: flex;
|
|
491
|
-
flex-direction: column;
|
|
492
|
-
gap: 0.25rem;
|
|
493
|
-
}
|
|
494
|
-
|
|
495
|
-
@utility label {
|
|
496
|
-
display: block;
|
|
497
|
-
font-size: 0.875rem;
|
|
498
|
-
font-weight: 500;
|
|
499
|
-
margin-bottom: 0.375rem;
|
|
500
|
-
color: var(--color-txt-2);
|
|
501
|
-
}
|
|
502
|
-
|
|
503
|
-
@utility hover-lift {
|
|
504
|
-
&:hover { transform: translate(-1px, -1px); }
|
|
505
|
-
}
|
|
506
|
-
@utility card-hover {
|
|
507
|
-
&:hover { transform: translate(-1px, -1px); border-color: var(--color-primary-300) !important; }
|
|
508
|
-
}
|
|
509
|
-
|
|
510
|
-
@utility animate-delay-50 { animation-delay: 50ms; }
|
|
511
|
-
@utility animate-delay-100 { animation-delay: 100ms; }
|
|
512
|
-
@utility animate-delay-150 { animation-delay: 150ms; }
|
|
513
|
-
@utility animate-delay-200 { animation-delay: 200ms; }
|
|
514
|
-
@utility animate-delay-250 { animation-delay: 250ms; }
|
|
515
|
-
@utility animate-delay-300 { animation-delay: 300ms; }
|
|
516
|
-
@utility animate-delay-350 { animation-delay: 350ms; }
|
|
517
|
-
@utility animate-delay-400 { animation-delay: 400ms; }
|
|
518
|
-
@utility animate-delay-500 { animation-delay: 500ms; }
|
|
519
|
-
@utility animate-delay-600 { animation-delay: 600ms; }
|
|
520
|
-
@utility animate-delay-700 { animation-delay: 700ms; }
|
|
521
|
-
|
|
522
|
-
/*
|
|
523
|
-
AUTH PANEL
|
|
524
|
-
*/
|
|
525
|
-
.auth-panel-bg {
|
|
526
|
-
background: var(--color-ink-200);
|
|
527
|
-
background-image:
|
|
528
|
-
linear-gradient(var(--color-border) 1px, transparent 1px),
|
|
529
|
-
linear-gradient(90deg, var(--color-border) 1px, transparent 1px);
|
|
530
|
-
background-size: 24px 24px;
|
|
531
|
-
}
|
|
532
|
-
.auth-panel-sweep { background: none !important; }
|
|
533
|
-
|
|
534
|
-
/*
|
|
535
|
-
MOBILE NAV
|
|
536
|
-
*/
|
|
537
|
-
.mobile-nav-bar {
|
|
538
|
-
background: rgba(12,15,22,0.35) !important;
|
|
539
|
-
border-top-color: var(--color-border) !important;
|
|
540
|
-
}
|
|
541
|
-
html:not(.dark) .mobile-nav-bar {
|
|
542
|
-
background: rgba(235,237,241,0.85) !important;
|
|
543
|
-
}
|
|
544
|
-
|
|
545
|
-
/*
|
|
546
|
-
LIGHT MODE PATCHES
|
|
547
|
-
*/
|
|
548
|
-
html:not(.dark) {
|
|
549
|
-
/* Select chevron in darker cyan for light backgrounds */
|
|
550
|
-
select {
|
|
551
|
-
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%230ea5c9' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E") !important;
|
|
552
|
-
}
|
|
553
|
-
|
|
554
|
-
/* Skeleton shimmer on light */
|
|
555
|
-
.skeleton, [class*="skeleton"] {
|
|
556
|
-
background: linear-gradient(90deg, var(--color-ink-300) 25%, var(--color-ink-400) 50%, var(--color-ink-300) 75%) !important;
|
|
557
|
-
}
|
|
558
|
-
|
|
559
|
-
/* Red tints */
|
|
560
|
-
.bg-red-50 { background-color: rgba(220,79,30,.07) !important; }
|
|
561
|
-
.border-red-100 { border-color: rgba(220,79,30,.2) !important; }
|
|
562
|
-
.hover\:bg-red-50:hover { background-color: rgba(220,79,30,.10) !important; }
|
|
563
|
-
|
|
564
|
-
/* btn-primary shadow in light uses same signal lime, keep */
|
|
565
|
-
.btn-secondary:active { background: var(--color-ink-300) !important; }
|
|
566
|
-
|
|
567
|
-
/* Role badge */
|
|
568
|
-
.bg-primary-500.text-primary-50 {
|
|
569
|
-
border-color: var(--color-primary-400) !important;
|
|
570
|
-
color: var(--color-primary-400) !important;
|
|
571
|
-
}
|
|
572
|
-
}
|
|
573
|
-
|
|
574
|
-
/* Logo on light theme keep bg dark so white squares stay visible */
|
|
575
|
-
html:not(.dark) .light-logo {
|
|
576
|
-
background-color: var(--color-primary-700) !important;
|
|
577
|
-
color: #fff !important;
|
|
578
|
-
}
|
|
579
|
-
|
|
580
|
-
/* Landing page respects global theme */
|
|
581
|
-
.landing-shell {
|
|
582
|
-
background: var(--color-ink-100);
|
|
583
|
-
color: var(--color-txt-1);
|
|
584
|
-
}
|
|
585
|
-
.landing-shell section,
|
|
586
|
-
.landing-shell footer {
|
|
587
|
-
background: var(--color-ink-100) !important;
|
|
588
|
-
}
|
|
589
|
-
.landing-shell [class*="border-white/"] {
|
|
590
|
-
border-color: var(--color-border) !important;
|
|
591
|
-
}
|
|
592
|
-
.landing-shell [class*="bg-white/"] {
|
|
593
|
-
background-color: var(--color-ink-300) !important;
|
|
594
|
-
}
|
|
595
|
-
.landing-shell [class*="shadow"] {
|
|
596
|
-
box-shadow: none !important;
|
|
597
|
-
}
|
|
598
|
-
.landing-shell [class*="tracking-tight"],
|
|
599
|
-
.landing-shell [class*="tracking-tighter"] {
|
|
600
|
-
letter-spacing: 0 !important;
|
|
601
|
-
}
|
|
602
|
-
.landing-shell .landing-accent {
|
|
603
|
-
color: var(--color-primary-300) !important;
|
|
604
|
-
}
|
|
605
|
-
/* Dashboard mockup illustration always dark regardless of theme */
|
|
606
|
-
.dashboard-mockup-wrapper {
|
|
607
|
-
--color-ink-000: #050608;
|
|
608
|
-
--color-ink-100: #06080c;
|
|
609
|
-
--color-border: #1d2330;
|
|
610
|
-
--color-txt-1: #f1f4f9;
|
|
611
|
-
--color-txt-3: #6b7686;
|
|
612
|
-
--color-primary-300: #5ee7ff;
|
|
613
|
-
}
|
|
614
|
-
|
|
615
|
-
/* Landing text/bg overrides in light mode for any remaining hardcoded white classes */
|
|
616
|
-
html:not(.dark) .landing-shell .text-white { color: var(--color-txt-1) !important; }
|
|
617
|
-
html:not(.dark) .landing-shell .text-white\/90,
|
|
618
|
-
html:not(.dark) .landing-shell .text-white\/80,
|
|
619
|
-
html:not(.dark) .landing-shell .text-white\/70,
|
|
620
|
-
html:not(.dark) .landing-shell .text-white\/65,
|
|
621
|
-
html:not(.dark) .landing-shell .text-white\/60 { color: var(--color-txt-2) !important; }
|
|
622
|
-
html:not(.dark) .landing-shell .text-white\/50,
|
|
623
|
-
html:not(.dark) .landing-shell .text-white\/45,
|
|
624
|
-
html:not(.dark) .landing-shell .text-white\/40,
|
|
625
|
-
html:not(.dark) .landing-shell .text-white\/35,
|
|
626
|
-
html:not(.dark) .landing-shell .text-white\/30,
|
|
627
|
-
html:not(.dark) .landing-shell .text-white\/25 { color: var(--color-txt-3) !important; }
|
|
628
|
-
html:not(.dark) .landing-shell .text-white\/20,
|
|
629
|
-
html:not(.dark) .landing-shell .text-white\/15,
|
|
630
|
-
html:not(.dark) .landing-shell .text-white\/10 { color: var(--color-txt-4) !important; }
|
|
631
|
-
html:not(.dark) .landing-shell .bg-black\/40,
|
|
632
|
-
html:not(.dark) .landing-shell .bg-black\/60 { background-color: rgba(235,237,241,0.9) !important; }
|
|
633
|
-
html:not(.dark) .landing-shell .border-white\/10,
|
|
634
|
-
html:not(.dark) .landing-shell .border-white\/15,
|
|
635
|
-
html:not(.dark) .landing-shell .border-white\/20 { border-color: var(--color-border) !important; }
|
|
636
|
-
/* Landing navbar white background in light mode */
|
|
637
|
-
html:not(.dark) .landing-nav {
|
|
638
|
-
--color-ink-100: #ffffff;
|
|
639
|
-
--color-ink-200: #ffffff;
|
|
640
|
-
}
|
|
641
|
-
|
|
642
|
-
/* Any remaining inline dark backgrounds via utility classes */
|
|
643
|
-
html:not(.dark) .landing-shell .bg-white\/3,
|
|
644
|
-
html:not(.dark) .landing-shell .bg-white\/4,
|
|
645
|
-
html:not(.dark) .landing-shell .bg-white\/5 { background-color: var(--color-ink-200) !important; }
|
|
646
|
-
|
|
647
|
-
/*
|
|
648
|
-
LOADING SCREEN
|
|
649
|
-
*/
|
|
650
|
-
.track {
|
|
651
|
-
position: relative; width: 280px; height: 60px;
|
|
652
|
-
display: flex; align-items: center; justify-content: center; overflow: visible;
|
|
653
|
-
}
|
|
654
|
-
.pulse-line {
|
|
655
|
-
position: absolute; width: 70px; height: 2px;
|
|
656
|
-
background: rgba(94,231,255,.05);
|
|
657
|
-
animation: thinPulse 3.5s ease-in-out infinite; z-index: 1;
|
|
658
|
-
}
|
|
659
|
-
.sliding-logo { position: relative; z-index: 2; animation: slowSlideFade 5s ease-in-out infinite; }
|
|
660
|
-
.sliding-logo > div { transition: all 0.3s ease; }
|
|
661
|
-
|
|
662
|
-
/*
|
|
663
|
-
MISC
|
|
664
|
-
*/
|
|
665
|
-
.fade-in { animation: fade-in 0.2s ease-out; }
|
|
666
|
-
|
|
667
|
-
::-webkit-scrollbar { width:0 !important; height:0 !important; background:transparent !important; }
|
|
668
|
-
::-webkit-scrollbar-button { display:none !important; }
|
|
669
|
-
::-webkit-scrollbar-track,
|
|
670
|
-
::-webkit-scrollbar-thumb,
|
|
671
|
-
::-webkit-scrollbar-corner { background:transparent !important; display:none !important; }
|
|
672
|
-
* { scrollbar-width:none !important; -ms-overflow-style:none !important; }
|
|
673
|
-
|
|
674
|
-
/*
|
|
675
|
-
TIPTAP EDITOR
|
|
676
|
-
*/
|
|
677
|
-
.tiptap-editor .ProseMirror,
|
|
678
|
-
.tiptap-readonly .ProseMirror {
|
|
679
|
-
outline: none;
|
|
680
|
-
color: var(--color-txt-1);
|
|
681
|
-
font-size: 0.875rem;
|
|
682
|
-
line-height: 1.7;
|
|
683
|
-
}
|
|
684
|
-
|
|
685
|
-
.tiptap-editor .ProseMirror p.is-editor-empty:first-child::before {
|
|
686
|
-
content: attr(data-placeholder);
|
|
687
|
-
color: var(--color-txt-4);
|
|
688
|
-
pointer-events: none;
|
|
689
|
-
float: left;
|
|
690
|
-
height: 0;
|
|
691
|
-
}
|
|
692
|
-
|
|
693
|
-
/* Headings */
|
|
694
|
-
.tiptap-editor .ProseMirror h1,
|
|
695
|
-
.tiptap-readonly .ProseMirror h1 { font-size: 1.4rem; font-weight: 700; margin: 1rem 0 0.5rem; color: var(--color-txt-1); font-family: var(--font-display); }
|
|
696
|
-
.tiptap-editor .ProseMirror h2,
|
|
697
|
-
.tiptap-readonly .ProseMirror h2 { font-size: 1.15rem; font-weight: 600; margin: 0.9rem 0 0.4rem; color: var(--color-txt-1); font-family: var(--font-display); }
|
|
698
|
-
.tiptap-editor .ProseMirror h3,
|
|
699
|
-
.tiptap-readonly .ProseMirror h3 { font-size: 1rem; font-weight: 600; margin: 0.75rem 0 0.35rem; color: var(--color-txt-2); font-family: var(--font-display); }
|
|
700
|
-
|
|
701
|
-
/* Paragraph */
|
|
702
|
-
.tiptap-editor .ProseMirror p,
|
|
703
|
-
.tiptap-readonly .ProseMirror p { margin: 0 0 0.5rem; }
|
|
704
|
-
|
|
705
|
-
/* Lists */
|
|
706
|
-
.tiptap-editor .ProseMirror ul,
|
|
707
|
-
.tiptap-readonly .ProseMirror ul { list-style: disc; padding-left: 1.4rem; margin: 0.4rem 0; }
|
|
708
|
-
.tiptap-editor .ProseMirror ol,
|
|
709
|
-
.tiptap-readonly .ProseMirror ol { list-style: decimal; padding-left: 1.4rem; margin: 0.4rem 0; }
|
|
710
|
-
.tiptap-editor .ProseMirror li,
|
|
711
|
-
.tiptap-readonly .ProseMirror li { margin: 0.15rem 0; }
|
|
712
|
-
|
|
713
|
-
/* Blockquote */
|
|
714
|
-
.tiptap-editor .ProseMirror blockquote,
|
|
715
|
-
.tiptap-readonly .ProseMirror blockquote {
|
|
716
|
-
border-left: 3px solid var(--color-primary-300);
|
|
717
|
-
margin: 0.6rem 0;
|
|
718
|
-
padding: 0.4rem 0 0.4rem 1rem;
|
|
719
|
-
color: var(--color-txt-3);
|
|
720
|
-
background: rgba(94,231,255,0.04);
|
|
721
|
-
}
|
|
722
|
-
|
|
723
|
-
/* Inline code */
|
|
724
|
-
.tiptap-editor .ProseMirror code,
|
|
725
|
-
.tiptap-readonly .ProseMirror code {
|
|
726
|
-
font-family: var(--font-mono);
|
|
727
|
-
font-size: 0.82em;
|
|
728
|
-
background: rgba(94,231,255,0.08);
|
|
729
|
-
border: 1px solid rgba(94,231,255,0.15);
|
|
730
|
-
color: var(--color-primary-300);
|
|
731
|
-
padding: 0.1em 0.4em;
|
|
732
|
-
}
|
|
733
|
-
|
|
734
|
-
/* Code block */
|
|
735
|
-
.tiptap-code-block,
|
|
736
|
-
.tiptap-editor .ProseMirror pre,
|
|
737
|
-
.tiptap-readonly .ProseMirror pre {
|
|
738
|
-
font-family: var(--font-mono);
|
|
739
|
-
font-size: 0.8rem;
|
|
740
|
-
background: var(--color-ink-300);
|
|
741
|
-
border: 1px solid var(--color-border-hi);
|
|
742
|
-
border-left: 3px solid var(--color-primary-300);
|
|
743
|
-
padding: 0.8rem 1rem;
|
|
744
|
-
margin: 0.6rem 0;
|
|
745
|
-
overflow-x: auto;
|
|
746
|
-
color: var(--color-txt-2);
|
|
747
|
-
}
|
|
748
|
-
.tiptap-editor .ProseMirror pre code,
|
|
749
|
-
.tiptap-readonly .ProseMirror pre code {
|
|
750
|
-
background: none;
|
|
751
|
-
border: none;
|
|
752
|
-
padding: 0;
|
|
753
|
-
color: inherit;
|
|
754
|
-
font-size: inherit;
|
|
755
|
-
}
|
|
756
|
-
|
|
757
|
-
/* Links */
|
|
758
|
-
.tiptap-link,
|
|
759
|
-
.tiptap-editor .ProseMirror a,
|
|
760
|
-
.tiptap-readonly .ProseMirror a {
|
|
761
|
-
color: var(--color-primary-300);
|
|
762
|
-
text-decoration: underline;
|
|
763
|
-
text-underline-offset: 2px;
|
|
764
|
-
}
|
|
765
|
-
|
|
766
|
-
/* Strong / em */
|
|
767
|
-
.tiptap-editor .ProseMirror strong,
|
|
768
|
-
.tiptap-readonly .ProseMirror strong { color: var(--color-txt-1); font-weight: 700; }
|
|
769
|
-
.tiptap-editor .ProseMirror em,
|
|
770
|
-
.tiptap-readonly .ProseMirror em { color: var(--color-txt-2); }
|
|
771
|
-
|
|
772
|
-
/* Faculty branding logo */
|
|
773
|
-
.faculty-logo { filter: none; }
|
|
774
|
-
html.dark .faculty-logo { filter: invert(1); }
|
|
1
|
+
/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
|
|
2
|
+
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:"IBM Plex Mono", ui-monospace, monospace;--color-black:#000;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--container-md:28rem;--container-lg:32rem;--container-2xl:42rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height:calc(1.5 / 1);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-widest:.1em;--leading-snug:1.375;--leading-relaxed:1.625;--radius-sm:0;--radius-lg:0;--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-ink-000:#050608;--color-ink-100:#06080c;--color-ink-200:#0c0f16;--color-ink-300:#11151e;--color-ink-400:#1d222d;--color-border:#1d2330;--color-border-hi:#2a3346;--color-txt-1:#f1f4f9;--color-txt-2:#aab3c2;--color-txt-3:#6b7686;--color-txt-4:#7a8496;--color-primary-100:#c7f5ff;--color-primary-300:#5ee7ff;--color-primary-400:#38d4f0;--color-primary-500:#1eb5d4;--color-primary-600:#1496b3;--color-primary-700:#0e7088;--color-primary-950:#03161c;--color-signal-400:#d4ff3a;--color-warn:#ff7a4d;--color-good:#4dd6a3;--btn-primary-color:#000;--font-display:"IBM Plex Sans", system-ui, sans-serif;--font-body:"IBM Plex Sans", system-ui, sans-serif;--radius-full:9999px;--animate-fade-in-up:fade-in-up .5s ease both;--animate-scale-in:scale-in .3s cubic-bezier(.34,1.56,.64,1) both}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*,:after,:before,::backdrop{border-color:var(--color-border,currentcolor);border-radius:0!important}::file-selector-button{border-color:var(--color-border,currentcolor);border-radius:0!important}html{font-family:var(--font-body);letter-spacing:0;-webkit-font-smoothing:antialiased;background:var(--color-ink-100);color:var(--color-txt-1)}body{background:var(--color-ink-100);color:var(--color-txt-1);font-family:var(--font-body)}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:0;font-weight:600}[class*=rounded]{border-radius:0!important}html :not([class*=animate-]):not(.sliding-logo):not(.pulse-line){transition:background-color .15s,border-color .15s,color .12s,transform .15s}.bg-white{background-color:var(--color-ink-200)!important}.bg-gray-50{background-color:var(--color-ink-100)!important}.bg-gray-100{background-color:var(--color-ink-300)!important}.bg-gray-200{background-color:var(--color-ink-400)!important}.border-gray-100,.border-gray-200,.border-gray-300,hr{border-color:var(--color-border)!important}.text-gray-900,.text-gray-800{color:var(--color-txt-1)!important}.text-gray-700,.text-gray-600{color:var(--color-txt-2)!important}.text-gray-500,.text-gray-400{color:var(--color-txt-3)!important}.text-gray-300{color:var(--color-txt-4)!important}.hover\:bg-gray-50:hover{background-color:var(--color-ink-300)!important}.hover\:bg-gray-100:hover{background-color:var(--color-ink-400)!important}.hover\:text-gray-900:hover,.hover\:text-gray-800:hover{color:var(--color-txt-1)!important}.hover\:text-gray-600:hover{color:var(--color-txt-2)!important}.shadow-sm,.shadow-md,.shadow-xl,.shadow-2xl{box-shadow:none!important}input,textarea{background-color:var(--color-ink-100)!important;border-color:var(--color-border-hi)!important;color:var(--color-txt-1)!important}input::placeholder,textarea::placeholder{color:var(--color-txt-4)!important}input:focus,textarea:focus{border-color:var(--color-primary-300)!important;box-shadow:inset 3px 0 0 0 var(--color-signal-400), 0 0 0 1px var(--color-primary-300)!important;outline:none!important}.cmd-input:focus{box-shadow:none!important;border-color:#0000!important;outline:none!important}table{color:var(--color-txt-2)!important}thead,thead tr{background-color:var(--color-ink-300)!important}thead th{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;font-size:10px;font-weight:500;background-color:var(--color-ink-300)!important;color:var(--color-txt-3)!important;border-color:var(--color-border)!important}tbody tr{background-color:var(--color-ink-200)!important;border-color:var(--color-border)!important}tbody tr:nth-child(2n){background-color:var(--color-ink-100)!important}tbody tr:hover{background-color:var(--color-ink-300)!important}tbody td,tbody th{color:var(--color-txt-2)!important;border-color:var(--color-border)!important}.card,.stat-card{background-color:var(--color-ink-200)!important;border-color:var(--color-border)!important;box-shadow:none!important}header:not(.landing-nav){background-color:var(--color-ink-200)!important;border-color:var(--color-border)!important}.bg-primary-50{background-color:#172630!important}@supports (color:color-mix(in lab, red, red)){.bg-primary-50{background-color:color-mix(in srgb, var(--color-primary-300) 8%, var(--color-ink-300))!important}}.bg-primary-100{background-color:#1c323e!important}@supports (color:color-mix(in lab, red, red)){.bg-primary-100{background-color:color-mix(in srgb, var(--color-primary-300) 14%, var(--color-ink-300))!important}}.bg-primary-200{background-color:#224350!important}@supports (color:color-mix(in lab, red, red)){.bg-primary-200{background-color:color-mix(in srgb, var(--color-primary-300) 22%, var(--color-ink-300))!important}}.bg-primary-500{background-color:var(--color-primary-300)!important}.bg-primary-600{background-color:var(--color-primary-400)!important}.bg-primary-700{background-color:var(--color-primary-300)!important;color:#fff!important}.bg-primary-800{background-color:var(--color-primary-400)!important}.bg-primary-900{background-color:var(--color-primary-600)!important}.text-primary-800,.text-primary-700{color:var(--color-primary-300)!important}.text-primary-600,.text-primary-500{color:var(--color-primary-400)!important}.text-primary-400{color:var(--color-primary-500)!important}.text-primary-50{color:#000!important}.border-primary-100{border-color:#5ee7ff59!important}@supports (color:color-mix(in lab, red, red)){.border-primary-100{border-color:color-mix(in srgb, var(--color-primary-300) 35%, transparent)!important}}.border-primary-200{border-color:var(--color-border-hi)!important}.border-primary-300,.border-primary-500{border-color:var(--color-primary-300)!important}.border-primary-600{border-color:var(--color-primary-400)!important}.hover\:bg-primary-50:hover,.hover\:bg-primary-100:hover{background-color:var(--color-ink-300)!important}.hover\:bg-primary-200:hover{background-color:var(--color-ink-400)!important}.hover\:bg-primary-800:hover{background-color:var(--color-primary-400)!important}.hover\:text-primary-700:hover{color:var(--color-primary-300)!important}.hover\:text-primary-600:hover{color:var(--color-primary-400)!important}.hover\:border-primary-300:hover{border-color:var(--color-primary-300)!important}.group:hover .group-hover\:text-primary-600{color:var(--color-primary-300)!important}[class*=bg-primary-50][class*=text-primary]{color:var(--color-primary-400)!important}.bg-emerald-400,.bg-green-400{background-color:var(--color-signal-400)!important}.text-emerald-600,.text-green-600{color:var(--color-good)!important}.animate-pulse{animation:1.8s ease-in-out infinite tz-pulse!important}.text-red-600{color:var(--color-warn)!important}.bg-red-50{background-color:#ff7a4d14!important}.border-red-100{border-color:#ff7a4d33!important}.text-red-700{color:var(--color-warn)!important}.hover\:bg-red-50:hover{background-color:#ff7a4d1f!important}.bg-primary-500.text-primary-50{font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;font-size:9px;border:1px solid var(--color-primary-300)!important;color:var(--color-primary-300)!important;background-color:#0000!important}.bg-zinc-50,.bg-slate-50,.bg-stone-50{background-color:var(--color-ink-100)!important}.bg-zinc-100,.bg-slate-100,.bg-stone-100{background-color:var(--color-ink-200)!important}.bg-zinc-200,.bg-slate-200{background-color:var(--color-ink-300)!important}.border-zinc-100,.border-slate-100,.border-zinc-200,.border-slate-200{border-color:var(--color-border)!important}.text-zinc-900,.text-slate-900,.text-zinc-700,.text-slate-700{color:var(--color-txt-1)!important}.text-zinc-600,.text-slate-600,.text-zinc-500,.text-slate-500{color:var(--color-txt-3)!important}select{appearance:none;font-size:.875rem;display:block;background-color:var(--color-ink-100)!important;border:1px solid var(--color-border-hi)!important;color:var(--color-txt-1)!important;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%235ee7ff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E")!important;background-position:right .65rem center!important;background-repeat:no-repeat!important;background-size:1rem 1rem!important;background-origin:padding-box!important;border-radius:0!important;padding-right:2.25rem!important}select::-ms-expand{display:none}select option{background:var(--color-ink-200);color:var(--color-txt-1)}select:focus{outline:none;border-color:var(--color-primary-300)!important;box-shadow:inset 3px 0 0 0 var(--color-signal-400)!important}select:disabled{opacity:.4;cursor:not-allowed}}@layer components;@layer utilities{.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.top-1\/2{top:50%}.top-1\/5{top:20%}.top-full{top:100%}.right-0{right:calc(var(--spacing) * 0)}.right-2{right:calc(var(--spacing) * 2)}.right-4{right:calc(var(--spacing) * 4)}.bottom-0{bottom:calc(var(--spacing) * 0)}.bottom-20{bottom:calc(var(--spacing) * 20)}.bottom-full{bottom:100%}.left-0{left:calc(var(--spacing) * 0)}.left-1\/2{left:50%}.left-3{left:calc(var(--spacing) * 3)}.left-4{left:calc(var(--spacing) * 4)}.z-10{z-index:10}.z-40{z-index:40}.z-50{z-index:50}.z-60{z-index:60}.z-300{z-index:300}.order-1{order:1}.order-2{order:2}.mt-0\.5{margin-top:calc(var(--spacing) * .5)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.label{color:var(--color-txt-2);margin-bottom:.375rem;font-size:.875rem;font-weight:500;display:block}.mb-0\.5{margin-bottom:calc(var(--spacing) * .5)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-1\.5{margin-bottom:calc(var(--spacing) * 1.5)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-5{margin-bottom:calc(var(--spacing) * 5)}.input-field{background:var(--color-ink-100);border:1px solid var(--color-border-hi);width:100%;color:var(--color-txt-1);outline:none;padding:.625rem .875rem;font-size:.875rem;display:block;border-radius:0!important}.input-field::placeholder{color:var(--color-txt-4)}.input-field:focus{border-color:var(--color-primary-300);box-shadow:inset 3px 0 0 0 var(--color-signal-400)}.btn-primary{background:var(--color-primary-300);color:var(--btn-primary-color);font-family:var(--font-display);box-shadow:4px 4px 0 0 var(--color-signal-400);cursor:pointer;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:600;display:inline-flex;border-radius:0!important}.btn-primary:hover{box-shadow:6px 6px 0 0 var(--color-signal-400);transform:translate(-1px,-1px)}.btn-primary:active{box-shadow:2px 2px 0 0 var(--color-signal-400);transform:translate(1px,1px)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{color:var(--color-txt-2);font-family:var(--font-mono);border:1px solid var(--color-border-hi);cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;display:inline-flex;border-radius:0!important}.btn-secondary:hover{color:var(--color-txt-1);border-color:var(--color-primary-300)}.btn-secondary:active{background:var(--color-ink-300)}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-danger{color:var(--color-warn);font-family:var(--font-mono);border:1px solid var(--color-warn);cursor:pointer;background:0 0;justify-content:center;align-items:center;display:inline-flex;border-radius:0!important}.btn-danger:hover{background:#ff7a4d1f}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-0{height:calc(var(--spacing) * 0)}.h-0\.5{height:calc(var(--spacing) * .5)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.h-2\.5{height:calc(var(--spacing) * 2.5)}.h-3{height:calc(var(--spacing) * 3)}.h-3\.5{height:calc(var(--spacing) * 3.5)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-7{height:calc(var(--spacing) * 7)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-16{height:calc(var(--spacing) * 16)}.h-48{height:calc(var(--spacing) * 48)}.h-60{height:calc(var(--spacing) * 60)}.w-0{width:calc(var(--spacing) * 0)}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-1\/2{width:50%}.w-2{width:calc(var(--spacing) * 2)}.w-2\.5{width:calc(var(--spacing) * 2.5)}.w-2\/5{width:40%}.w-3{width:calc(var(--spacing) * 3)}.w-3\.5{width:calc(var(--spacing) * 3.5)}.w-3\/4{width:75%}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-7{width:calc(var(--spacing) * 7)}.w-8{width:calc(var(--spacing) * 8)}.w-9{width:calc(var(--spacing) * 9)}.w-10{width:calc(var(--spacing) * 10)}.w-16{width:calc(var(--spacing) * 16)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-28{width:calc(var(--spacing) * 28)}.w-32{width:calc(var(--spacing) * 32)}.w-40{width:calc(var(--spacing) * 40)}.w-48{width:calc(var(--spacing) * 48)}.w-120{width:calc(var(--spacing) * 120)}.w-\[min\(20rem\,calc\(100vw-1\.5rem\)\)\]{width:min(20rem,100vw - 1.5rem)}.w-full{width:100%}.w-max{width:max-content}.max-w-2xl{max-width:var(--container-2xl)}.max-w-\[200px\]{max-width:200px}.max-w-\[calc\(100vw-1\.5rem\)\]{max-width:calc(100vw - 1.5rem)}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.flex-1{flex:1}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y:calc(calc(1 / 2 * 100%) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-0{--tw-translate-y:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-2{--tw-translate-y:calc(var(--spacing) * 2);translate:var(--tw-translate-x) var(--tw-translate-y)}.card-hover:hover{transform:translate(-1px,-1px);border-color:var(--color-primary-300)!important}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.skeleton{background:linear-gradient(90deg, var(--color-ink-300) 25%, var(--color-ink-400) 50%, var(--color-ink-300) 75%);background-size:800px 100%;animation:1.5s linear infinite skeleton-shimmer;border-radius:0!important}.animate-fade-in-up{animation:var(--animate-fade-in-up)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.card{background:var(--color-ink-200);border:1px solid var(--color-border);box-shadow:none;padding:1.25rem;border-radius:0!important}.rounded{border-radius:.25rem}.rounded-full{border-radius:var(--radius-full)}.rounded-lg{border-radius:var(--radius-lg)}.border{border-style:var(--tw-border-style);border-width:1px}.border-x-4{border-inline-style:var(--tw-border-style);border-inline-width:4px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-t-4{border-top-style:var(--tw-border-style);border-top-width:4px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-4{border-bottom-style:var(--tw-border-style);border-bottom-width:4px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-\[var\(--color-border-hi\)\]{border-color:var(--color-border-hi)}.border-\[var\(--color-good\)\]{border-color:var(--color-good)}.border-\[var\(--color-primary-300\)\]{border-color:var(--color-primary-300)}.border-\[var\(--color-warn\)\]{border-color:var(--color-warn)}.border-border{border-color:var(--color-border)}.border-border-hi{border-color:var(--color-border-hi)}.border-good{border-color:var(--color-good)}.border-primary-100{border-color:var(--color-primary-100)}.border-primary-300{border-color:var(--color-primary-300)}.border-signal-400{border-color:var(--color-signal-400)}.border-transparent{border-color:#0000}.border-txt-3{border-color:var(--color-txt-3)}.border-txt-4{border-color:var(--color-txt-4)}.border-warn{border-color:var(--color-warn)}.border-warn\/25{border-color:#ff7a4d40}@supports (color:color-mix(in lab, red, red)){.border-warn\/25{border-color:color-mix(in oklab, var(--color-warn) 25%, transparent)}}.border-warn\/30{border-color:#ff7a4d4d}@supports (color:color-mix(in lab, red, red)){.border-warn\/30{border-color:color-mix(in oklab, var(--color-warn) 30%, transparent)}}.border-x-transparent{border-inline-color:#0000}.bg-\[rgba\(94\,231\,255\,0\.06\)\]{background-color:#5ee7ff0f}.bg-\[rgba\(255\,180\,0\,0\.04\)\]{background-color:#ffb4000a}.bg-black\/10{background-color:#0000001a}@supports (color:color-mix(in lab, red, red)){.bg-black\/10{background-color:color-mix(in oklab, var(--color-black) 10%, transparent)}}.bg-ink-100{background-color:var(--color-ink-100)}.bg-ink-200{background-color:var(--color-ink-200)}.bg-ink-300{background-color:var(--color-ink-300)}.bg-ink-400{background-color:var(--color-ink-400)}.bg-primary-300{background-color:var(--color-primary-300)}.bg-primary-300\/10{background-color:#5ee7ff1a}@supports (color:color-mix(in lab, red, red)){.bg-primary-300\/10{background-color:color-mix(in oklab, var(--color-primary-300) 10%, transparent)}}.bg-primary-500\/10{background-color:#1eb5d41a}@supports (color:color-mix(in lab, red, red)){.bg-primary-500\/10{background-color:color-mix(in oklab, var(--color-primary-500) 10%, transparent)}}.bg-transparent{background-color:#0000}.bg-warn\/8{background-color:#ff7a4d14}@supports (color:color-mix(in lab, red, red)){.bg-warn\/8{background-color:color-mix(in oklab, var(--color-warn) 8%, transparent)}}.bg-\[linear-gradient\(var\(--color-border\)_1px\,transparent_1px\)\,linear-gradient\(90deg\,var\(--color-border\)_1px\,transparent_1px\)\]{background-image:linear-gradient(var(--color-border) 1px,transparent 1px),linear-gradient(90deg,var(--color-border) 1px,transparent 1px)}.bg-size-\[32px_32px\]{background-size:32px 32px}.p-0{padding:calc(var(--spacing) * 0)}.p-1{padding:calc(var(--spacing) * 1)}.p-4{padding:calc(var(--spacing) * 4)}.p-5{padding:calc(var(--spacing) * 5)}.p-6{padding:calc(var(--spacing) * 6)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-10{padding-block:calc(var(--spacing) * 10)}.pt-3{padding-top:calc(var(--spacing) * 3)}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pl-9{padding-left:calc(var(--spacing) * 9)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-mono)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[9px\]{font-size:9px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[22px\]{font-size:22px}.text-\[clamp\(72px\,16vw\,120px\)\]{font-size:clamp(72px,16vw,120px)}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.font-\(--font-display\){--tw-font-weight:var(--font-display);font-weight:var(--font-display)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[-0\.03em\]{--tw-tracking:-.03em;letter-spacing:-.03em}.tracking-\[-0\.04em\]{--tw-tracking:-.04em;letter-spacing:-.04em}.tracking-\[\.2em\]{--tw-tracking:.2em;letter-spacing:.2em}.tracking-\[\.08em\]{--tw-tracking:.08em;letter-spacing:.08em}.tracking-\[0\.15em\]{--tw-tracking:.15em;letter-spacing:.15em}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.whitespace-nowrap{white-space:nowrap}.text-\[var\(--color-good\)\]{color:var(--color-good)}.text-\[var\(--color-primary-300\)\]{color:var(--color-primary-300)}.text-\[var\(--color-txt-2\)\]{color:var(--color-txt-2)}.text-\[var\(--color-txt-3\)\]{color:var(--color-txt-3)}.text-\[var\(--color-warn\)\]{color:var(--color-warn)}.text-black{color:var(--color-black)}.text-border-hi{color:var(--color-border-hi)}.text-good{color:var(--color-good)}.text-primary-300{color:var(--color-primary-300)}.text-primary-300\!{color:var(--color-primary-300)!important}.text-primary-500{color:var(--color-primary-500)}.text-primary-700{color:var(--color-primary-700)}.text-signal-400{color:var(--color-signal-400)}.text-txt-1{color:var(--color-txt-1)}.text-txt-2{color:var(--color-txt-2)}.text-txt-3{color:var(--color-txt-3)}.text-txt-4{color:var(--color-txt-4)}.text-warn{color:var(--color-warn)}.uppercase{text-transform:uppercase}.opacity-0{opacity:0}.opacity-35{opacity:.35}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.opacity-100{opacity:1}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-\[0_0_0_1px_var\(--color-primary-300\)\]{--tw-shadow:0 0 0 1px var(--tw-shadow-color,var(--color-primary-300));box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring,.ring-1{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-primary-300{--tw-ring-color:var(--color-primary-300)}.backdrop-blur-\[3px\]{--tw-backdrop-blur:blur(3px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-none{transition-property:none}.duration-100{--tw-duration:.1s;transition-duration:.1s}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.select-none{-webkit-user-select:none;user-select:none}.\[background\:linear-gradient\(90deg\,transparent\,var\(--color-warn\)\,transparent\)\]{background:linear-gradient(90deg,transparent,var(--color-warn),transparent)}.\[border\:1px_solid_rgba\(255\,180\,0\,0\.2\)\]{border:1px solid #ffb40033}@media (hover:hover){.group-hover\:border-primary-400:is(:where(.group):hover *){border-color:var(--color-primary-400)}.group-hover\:text-txt-1:is(:where(.group):hover *){color:var(--color-txt-1)}.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}.hover\:border-\[var\(--color-primary-300\)\]:hover{border-color:var(--color-primary-300)}.hover\:border-\[var\(--color-txt-2\)\]:hover{border-color:var(--color-txt-2)}.hover\:border-border-hi:hover{border-color:var(--color-border-hi)}.hover\:bg-\[rgba\(77\,214\,163\,0\.08\)\]:hover{background-color:#4dd6a314}.hover\:bg-\[rgba\(94\,231\,255\,0\.08\)\]:hover{background-color:#5ee7ff14}.hover\:bg-\[rgba\(94\,231\,255\,0\.12\)\]:hover{background-color:#5ee7ff1f}.hover\:bg-\[rgba\(255\,122\,77\,0\.08\)\]:hover{background-color:#ff7a4d14}.hover\:bg-ink-300:hover{background-color:var(--color-ink-300)}.hover\:bg-ink-300\/30:hover{background-color:#11151e4d}@supports (color:color-mix(in lab, red, red)){.hover\:bg-ink-300\/30:hover{background-color:color-mix(in oklab, var(--color-ink-300) 30%, transparent)}}.hover\:text-\[var\(--color-primary-300\)\]:hover{color:var(--color-primary-300)}.hover\:text-\[var\(--color-primary-400\)\]:hover{color:var(--color-primary-400)}.hover\:text-\[var\(--color-txt-1\)\]:hover,.hover\:text-txt-1:hover{color:var(--color-txt-1)}.hover\:text-txt-2:hover{color:var(--color-txt-2)}}.focus\:border-warn:focus{border-color:var(--color-warn)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}@media (min-width:40rem){.sm\:top-5{top:calc(var(--spacing) * 5)}.sm\:right-5{right:calc(var(--spacing) * 5)}.sm\:bottom-auto{bottom:auto}.sm\:left-auto{left:auto}.sm\:order-1{order:1}.sm\:order-2{order:2}.sm\:inline{display:inline}.sm\:w-auto{width:auto}.sm\:max-w-xs{max-width:var(--container-xs)}.sm\:min-w-52{min-width:calc(var(--spacing) * 52)}.sm\:translate-x-4{--tw-translate-x:calc(var(--spacing) * 4);translate:var(--tw-translate-x) var(--tw-translate-y)}.sm\:translate-y-0{--tw-translate-y:calc(var(--spacing) * 0);translate:var(--tw-translate-x) var(--tw-translate-y)}.sm\:flex-row{flex-direction:row}.sm\:items-start{align-items:flex-start}.sm\:justify-between{justify-content:space-between}.sm\:justify-end{justify-content:flex-end}.sm\:text-\[13px\]{font-size:13px}}@media (min-width:48rem){.md\:hidden{display:none}.md\:table{display:table}}}.cmd-input::placeholder{color:var(--color-txt-4);opacity:1}.cmd-input::selection{background:#5ee7ff26}html:not(.dark){--color-ink-000:#fff;--color-ink-100:#f5f6f8;--color-ink-200:#ebedf1;--color-ink-300:#dde0e8;--color-ink-400:#cdd1db;--color-ink-500:#b8bec9;--color-border:#d8dce6;--color-border-hi:#c4c9d6;--color-txt-1:#0d1117;--color-txt-2:#3a4255;--color-txt-3:#6b7280;--color-txt-4:#6b7280;--color-primary-300:#0ea5c9;--color-primary-400:#0891b2;--color-primary-500:#0e7490;--color-signal-300:#65a30d;--color-signal-400:#4d7c0f;--color-signal-500:#3f6212;--color-warn:#dc4f1e;--color-good:#059669;--color-icon-bg:#162932}@supports (color:color-mix(in lab, red, red)){html:not(.dark){--color-icon-bg:color-mix(in srgb, var(--color-primary-300) 12%, var(--color-ink-200))}}html:not(.dark){--btn-primary-color:#fff}html.dark .bg-primary-50{background-color:var(--color-primary-950)!important}html.dark .bg-primary-100{background-color:#101a22!important}@supports (color:color-mix(in lab, red, red)){html.dark .bg-primary-100{background-color:color-mix(in srgb, var(--color-primary-300) 5%, var(--color-ink-200))!important}}html.dark .bg-primary-200{background-color:#14252d!important}@supports (color:color-mix(in lab, red, red)){html.dark .bg-primary-200{background-color:color-mix(in srgb, var(--color-primary-300) 10%, var(--color-ink-200))!important}}html.dark .border-primary-100{border-color:#5ee7ff1f!important}@supports (color:color-mix(in lab, red, red)){html.dark .border-primary-100{border-color:color-mix(in srgb, var(--color-primary-300) 12%, transparent)!important}}html.dark .text-primary-700,html.dark .text-primary-800{color:var(--color-primary-300)!important}.kicker{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--color-txt-3);font-size:10px;font-weight:500}.font-mono{font-family:var(--font-mono)!important}.font-display{font-family:var(--font-display)!important}.grid-bg{background-image:linear-gradient(var(--color-border) 1px, transparent 1px), linear-gradient(90deg, var(--color-border) 1px, transparent 1px);background-position:-1px -1px;background-size:24px 24px}.tz-pulse{animation:1.8s ease-in-out infinite tz-pulse}.tz-bar{transform-origin:bottom;animation:.6s cubic-bezier(.4,1.4,.4,1) both tz-bar-grow}.auth-panel-bg{background:var(--color-ink-200);background-image:linear-gradient(var(--color-border) 1px, transparent 1px), linear-gradient(90deg, var(--color-border) 1px, transparent 1px);background-size:24px 24px}.auth-panel-sweep{background:0 0!important}.mobile-nav-bar{border-top-color:var(--color-border)!important;background:#0c0f1659!important}html:not(.dark) .mobile-nav-bar{background:#ebedf1d9!important}html:not(.dark) select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%230ea5c9' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3E%3C/svg%3E")!important}html:not(.dark) .skeleton,html:not(.dark) [class*=skeleton]{background:linear-gradient(90deg, var(--color-ink-300) 25%, var(--color-ink-400) 50%, var(--color-ink-300) 75%)!important}html:not(.dark) .bg-red-50{background-color:#dc4f1e12!important}html:not(.dark) .border-red-100{border-color:#dc4f1e33!important}html:not(.dark) .hover\:bg-red-50:hover{background-color:#dc4f1e1a!important}html:not(.dark) .btn-secondary:active{background:var(--color-ink-300)!important}html:not(.dark) .bg-primary-500.text-primary-50{border-color:var(--color-primary-400)!important;color:var(--color-primary-400)!important}html:not(.dark) .light-logo{background-color:var(--color-primary-700)!important;color:#fff!important}.landing-shell{background:var(--color-ink-100);color:var(--color-txt-1)}.landing-shell section,.landing-shell footer{background:var(--color-ink-100)!important}.landing-shell [class*=border-white\/]{border-color:var(--color-border)!important}.landing-shell [class*=bg-white\/]{background-color:var(--color-ink-300)!important}.landing-shell [class*=shadow]{box-shadow:none!important}.landing-shell [class*=tracking-tight],.landing-shell [class*=tracking-tighter]{letter-spacing:0!important}.landing-shell .landing-accent{color:var(--color-primary-300)!important}.dashboard-mockup-wrapper{--color-ink-000:#050608;--color-ink-100:#06080c;--color-border:#1d2330;--color-txt-1:#f1f4f9;--color-txt-3:#6b7686;--color-primary-300:#5ee7ff}html:not(.dark) .landing-shell .text-white{color:var(--color-txt-1)!important}html:not(.dark) .landing-shell .text-white\/90,html:not(.dark) .landing-shell .text-white\/80,html:not(.dark) .landing-shell .text-white\/70,html:not(.dark) .landing-shell .text-white\/65,html:not(.dark) .landing-shell .text-white\/60{color:var(--color-txt-2)!important}html:not(.dark) .landing-shell .text-white\/50,html:not(.dark) .landing-shell .text-white\/45,html:not(.dark) .landing-shell .text-white\/40,html:not(.dark) .landing-shell .text-white\/35,html:not(.dark) .landing-shell .text-white\/30,html:not(.dark) .landing-shell .text-white\/25{color:var(--color-txt-3)!important}html:not(.dark) .landing-shell .text-white\/20,html:not(.dark) .landing-shell .text-white\/15,html:not(.dark) .landing-shell .text-white\/10{color:var(--color-txt-4)!important}html:not(.dark) .landing-shell .bg-black\/40,html:not(.dark) .landing-shell .bg-black\/60{background-color:#ebedf1e6!important}html:not(.dark) .landing-shell .border-white\/10,html:not(.dark) .landing-shell .border-white\/15,html:not(.dark) .landing-shell .border-white\/20{border-color:var(--color-border)!important}html:not(.dark) .landing-nav{--color-ink-100:#fff;--color-ink-200:#fff}html:not(.dark) .landing-shell .bg-white\/3,html:not(.dark) .landing-shell .bg-white\/4,html:not(.dark) .landing-shell .bg-white\/5{background-color:var(--color-ink-200)!important}.track{justify-content:center;align-items:center;width:280px;height:60px;display:flex;position:relative;overflow:visible}.pulse-line{z-index:1;background:#5ee7ff0d;width:70px;height:2px;animation:3.5s ease-in-out infinite thinPulse;position:absolute}.sliding-logo{z-index:2;animation:5s ease-in-out infinite slowSlideFade;position:relative}.sliding-logo>div{transition:all .3s}.fade-in{animation:.2s ease-out fade-in}::-webkit-scrollbar{background:0 0!important;width:0!important;height:0!important}::-webkit-scrollbar-button{display:none!important}::-webkit-scrollbar-track{background:0 0!important;display:none!important}::-webkit-scrollbar-thumb{background:0 0!important;display:none!important}::-webkit-scrollbar-corner{background:0 0!important;display:none!important}*{scrollbar-width:none!important;-ms-overflow-style:none!important}.tiptap-editor .ProseMirror,.tiptap-readonly .ProseMirror{color:var(--color-txt-1);outline:none;font-size:.875rem;line-height:1.7}.tiptap-editor .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--color-txt-4);pointer-events:none;float:left;height:0}.tiptap-editor .ProseMirror h1,.tiptap-readonly .ProseMirror h1{color:var(--color-txt-1);font-size:1.4rem;font-weight:700;font-family:var(--font-display);margin:1rem 0 .5rem}.tiptap-editor .ProseMirror h2,.tiptap-readonly .ProseMirror h2{color:var(--color-txt-1);font-size:1.15rem;font-weight:600;font-family:var(--font-display);margin:.9rem 0 .4rem}.tiptap-editor .ProseMirror h3,.tiptap-readonly .ProseMirror h3{color:var(--color-txt-2);font-size:1rem;font-weight:600;font-family:var(--font-display);margin:.75rem 0 .35rem}.tiptap-editor .ProseMirror p,.tiptap-readonly .ProseMirror p{margin:0 0 .5rem}.tiptap-editor .ProseMirror ul,.tiptap-readonly .ProseMirror ul{margin:.4rem 0;padding-left:1.4rem;list-style:outside}.tiptap-editor .ProseMirror ol,.tiptap-readonly .ProseMirror ol{margin:.4rem 0;padding-left:1.4rem;list-style:decimal}.tiptap-editor .ProseMirror li,.tiptap-readonly .ProseMirror li{margin:.15rem 0}.tiptap-editor .ProseMirror blockquote,.tiptap-readonly .ProseMirror blockquote{border-left:3px solid var(--color-primary-300);color:var(--color-txt-3);background:#5ee7ff0a;margin:.6rem 0;padding:.4rem 0 .4rem 1rem}.tiptap-editor .ProseMirror code,.tiptap-readonly .ProseMirror code{font-family:var(--font-mono);color:var(--color-primary-300);background:#5ee7ff14;border:1px solid #5ee7ff26;padding:.1em .4em;font-size:.82em}.tiptap-code-block,.tiptap-editor .ProseMirror pre,.tiptap-readonly .ProseMirror pre{font-family:var(--font-mono);background:var(--color-ink-300);border:1px solid var(--color-border-hi);border-left:3px solid var(--color-primary-300);color:var(--color-txt-2);margin:.6rem 0;padding:.8rem 1rem;font-size:.8rem;overflow-x:auto}.tiptap-editor .ProseMirror pre code,.tiptap-readonly .ProseMirror pre code{color:inherit;font-size:inherit;background:0 0;border:none;padding:0}.tiptap-link,.tiptap-editor .ProseMirror a,.tiptap-readonly .ProseMirror a{color:var(--color-primary-300);text-underline-offset:2px;text-decoration:underline}.tiptap-editor .ProseMirror strong,.tiptap-readonly .ProseMirror strong{color:var(--color-txt-1);font-weight:700}.tiptap-editor .ProseMirror em,.tiptap-readonly .ProseMirror em{color:var(--color-txt-2)}.faculty-logo{filter:none}html.dark .faculty-logo{filter:invert()}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes scale-in{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}@keyframes tz-pulse{0%,to{opacity:1}50%{opacity:.35}}@keyframes tz-bar-grow{0%{transform:scaleY(0)}to{transform:scaleY(1)}}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes slowSlideFade{0%{opacity:0;transform:translate(-120px)}15%{opacity:1;transform:translate(-80px)}85%{opacity:1;transform:translate(80px)}to{opacity:0;transform:translate(120px)}}@keyframes thinPulse{0%,to{background:#5ee7ff0d;width:70px;height:2px;box-shadow:0 0 4px #5ee7ff26}50%{background:#5ee7ff26;width:90px;height:3px;box-shadow:0 0 14px #5ee7ff66}}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tapizlabs/ui",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.2",
|
|
4
4
|
"description": "Centralized design system, theming foundation, and reusable React UI components for the Tapiz platform.",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"type": "module",
|
|
@@ -22,7 +22,8 @@
|
|
|
22
22
|
],
|
|
23
23
|
"sideEffects": [
|
|
24
24
|
"*.css",
|
|
25
|
-
"./dist/fonts.js"
|
|
25
|
+
"./dist/fonts.js",
|
|
26
|
+
"./dist/fonts.css"
|
|
26
27
|
],
|
|
27
28
|
"exports": {
|
|
28
29
|
".": {
|
|
@@ -33,7 +34,8 @@
|
|
|
33
34
|
"./fonts": {
|
|
34
35
|
"types": "./dist/fonts.d.ts",
|
|
35
36
|
"import": "./dist/fonts.js"
|
|
36
|
-
}
|
|
37
|
+
},
|
|
38
|
+
"./fonts.css": "./dist/fonts.css"
|
|
37
39
|
},
|
|
38
40
|
"files": [
|
|
39
41
|
"dist",
|
|
@@ -46,7 +48,9 @@
|
|
|
46
48
|
"access": "public"
|
|
47
49
|
},
|
|
48
50
|
"scripts": {
|
|
49
|
-
"build": "tsup &&
|
|
51
|
+
"build": "tsup && npm run build:css && npm run build:assets",
|
|
52
|
+
"build:assets": "powershell -ExecutionPolicy Bypass -File ./scripts/build-assets.ps1",
|
|
53
|
+
"build:css": "tailwindcss -i ./src/bundle.css -o ./dist/theme.css --minify",
|
|
50
54
|
"typecheck": "tsc --noEmit",
|
|
51
55
|
"prepublishOnly": "npm run typecheck && npm run build",
|
|
52
56
|
"pack:check": "npm pack --dry-run"
|
|
@@ -56,13 +60,13 @@
|
|
|
56
60
|
"react-dom": ">=19",
|
|
57
61
|
"tailwindcss": ">=4"
|
|
58
62
|
},
|
|
59
|
-
"dependencies": {
|
|
60
|
-
"@fontsource/ibm-plex-mono": "^5.2.7",
|
|
61
|
-
"@fontsource/ibm-plex-sans": "^5.2.8"
|
|
62
|
-
},
|
|
63
63
|
"devDependencies": {
|
|
64
|
+
"@tailwindcss/cli": "^4.1.13",
|
|
65
|
+
"@fontsource/ibm-plex-mono": "^5.2.7",
|
|
66
|
+
"@fontsource/ibm-plex-sans": "^5.2.8",
|
|
64
67
|
"@types/react": "^19.2.16",
|
|
65
68
|
"@types/react-dom": "^19.2.3",
|
|
69
|
+
"tailwindcss": "^4.1.13",
|
|
66
70
|
"tsup": "^8.5.1",
|
|
67
71
|
"typescript": "^5.9.3"
|
|
68
72
|
}
|