@tapizlabs/ui 0.1.1 → 0.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/README.md +29 -4
  2. package/dist/files/ibm-plex-mono-latin-400-italic.woff +0 -0
  3. package/dist/files/ibm-plex-mono-latin-400-italic.woff2 +0 -0
  4. package/dist/files/ibm-plex-mono-latin-400-normal.woff +0 -0
  5. package/dist/files/ibm-plex-mono-latin-400-normal.woff2 +0 -0
  6. package/dist/files/ibm-plex-mono-latin-500-normal.woff +0 -0
  7. package/dist/files/ibm-plex-mono-latin-500-normal.woff2 +0 -0
  8. package/dist/files/ibm-plex-mono-latin-600-normal.woff +0 -0
  9. package/dist/files/ibm-plex-mono-latin-600-normal.woff2 +0 -0
  10. package/dist/files/ibm-plex-mono-latin-ext-400-normal.woff +0 -0
  11. package/dist/files/ibm-plex-mono-latin-ext-400-normal.woff2 +0 -0
  12. package/dist/files/ibm-plex-mono-latin-ext-500-normal.woff +0 -0
  13. package/dist/files/ibm-plex-mono-latin-ext-500-normal.woff2 +0 -0
  14. package/dist/files/ibm-plex-mono-latin-ext-600-normal.woff +0 -0
  15. package/dist/files/ibm-plex-mono-latin-ext-600-normal.woff2 +0 -0
  16. package/dist/files/ibm-plex-sans-cyrillic-400-normal.woff +0 -0
  17. package/dist/files/ibm-plex-sans-cyrillic-400-normal.woff2 +0 -0
  18. package/dist/files/ibm-plex-sans-cyrillic-500-normal.woff +0 -0
  19. package/dist/files/ibm-plex-sans-cyrillic-500-normal.woff2 +0 -0
  20. package/dist/files/ibm-plex-sans-cyrillic-600-normal.woff +0 -0
  21. package/dist/files/ibm-plex-sans-cyrillic-600-normal.woff2 +0 -0
  22. package/dist/files/ibm-plex-sans-cyrillic-700-normal.woff +0 -0
  23. package/dist/files/ibm-plex-sans-cyrillic-700-normal.woff2 +0 -0
  24. package/dist/files/ibm-plex-sans-latin-400-italic.woff +0 -0
  25. package/dist/files/ibm-plex-sans-latin-400-italic.woff2 +0 -0
  26. package/dist/files/ibm-plex-sans-latin-400-normal.woff +0 -0
  27. package/dist/files/ibm-plex-sans-latin-400-normal.woff2 +0 -0
  28. package/dist/files/ibm-plex-sans-latin-500-normal.woff +0 -0
  29. package/dist/files/ibm-plex-sans-latin-500-normal.woff2 +0 -0
  30. package/dist/files/ibm-plex-sans-latin-600-normal.woff +0 -0
  31. package/dist/files/ibm-plex-sans-latin-600-normal.woff2 +0 -0
  32. package/dist/files/ibm-plex-sans-latin-700-normal.woff +0 -0
  33. package/dist/files/ibm-plex-sans-latin-700-normal.woff2 +0 -0
  34. package/dist/fonts.css +161 -0
  35. package/dist/fonts.js +1 -16
  36. package/dist/fonts.js.map +1 -1
  37. package/dist/theme.css +2 -774
  38. package/package.json +12 -8
package/README.md CHANGED
@@ -19,6 +19,14 @@ It is intended to keep multiple apps visually aligned while reducing duplicated
19
19
  npm install @tapizlabs/ui
20
20
  ```
21
21
 
22
+ This package expects Tailwind CSS v4 to already exist in the consuming app.
23
+
24
+ If your app does not use Tailwind yet, install it before using `@tapizlabs/ui`:
25
+
26
+ ```bash
27
+ npm install tailwindcss @tailwindcss/postcss
28
+ ```
29
+
22
30
  ## Requirements
23
31
 
24
32
  - `react >= 19`
@@ -27,6 +35,8 @@ npm install @tapizlabs/ui
27
35
 
28
36
  These are declared as peer dependencies and must be provided by the consuming app.
29
37
 
38
+ Important: `@tapizlabs/ui` is not Tailwind-free. Consumer applications must have Tailwind CSS v4 configured, otherwise shared styles and local utility classes will not build correctly.
39
+
30
40
  ## Package Exports
31
41
 
32
42
  This package exposes:
@@ -50,7 +60,6 @@ Import the shared theme before your app-specific styles:
50
60
 
51
61
  ```css
52
62
  @import "@tapizlabs/ui/theme.css";
53
- @source "../node_modules/@tapizlabs/ui/dist/**/*.js";
54
63
  ```
55
64
 
56
65
  Then consume components directly from the package:
@@ -77,13 +86,29 @@ export function ExamplePanel() {
77
86
 
78
87
  ## Tailwind Setup
79
88
 
80
- `@tapizlabs/ui` components contain Tailwind class strings inside the published JavaScript bundle. Consumer apps must include the package in Tailwind's source scan:
89
+ `@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.
90
+
91
+ You still must keep Tailwind enabled in the consuming app itself.
92
+
93
+ Minimum consumer setup:
94
+
95
+ ```js
96
+ // postcss.config.js
97
+ export default {
98
+ plugins: {
99
+ "@tailwindcss/postcss": {},
100
+ },
101
+ };
102
+ ```
81
103
 
82
104
  ```css
83
- @source "../node_modules/@tapizlabs/ui/dist/**/*.js";
105
+ /* app entry CSS */
106
+ @import "@tapizlabs/ui/theme.css";
107
+ @import "tailwindcss";
108
+ @source "./**/*.{ts,tsx}";
84
109
  ```
85
110
 
86
- Without that line, some shared component classes may be omitted from the final CSS build.
111
+ If Tailwind is missing from the consumer app, `@tapizlabs/ui` will not render correctly.
87
112
 
88
113
  ## Included Components
89
114
 
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 "@fontsource/ibm-plex-sans/latin-400.css";
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 \"@fontsource/ibm-plex-sans/latin-400.css\";\nimport \"@fontsource/ibm-plex-sans/latin-400-italic.css\";\nimport \"@fontsource/ibm-plex-sans/latin-500.css\";\nimport \"@fontsource/ibm-plex-sans/latin-600.css\";\nimport \"@fontsource/ibm-plex-sans/latin-700.css\";\nimport \"@fontsource/ibm-plex-sans/cyrillic-400.css\";\nimport \"@fontsource/ibm-plex-sans/cyrillic-500.css\";\nimport \"@fontsource/ibm-plex-sans/cyrillic-600.css\";\nimport \"@fontsource/ibm-plex-sans/cyrillic-700.css\";\nimport \"@fontsource/ibm-plex-mono/latin-400.css\";\nimport \"@fontsource/ibm-plex-mono/latin-400-italic.css\";\nimport \"@fontsource/ibm-plex-mono/latin-500.css\";\nimport \"@fontsource/ibm-plex-mono/latin-600.css\";\nimport \"@fontsource/ibm-plex-mono/latin-ext-400.css\";\nimport \"@fontsource/ibm-plex-mono/latin-ext-500.css\";\nimport \"@fontsource/ibm-plex-mono/latin-ext-600.css\";\n"],"mappings":";AAAA,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;AACP,OAAO;","names":[]}
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
- @import "tailwindcss";
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.1",
3
+ "version": "0.1.3",
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 && powershell -Command \"Copy-Item -Path src/theme.css -Destination dist/theme.css -Force\"",
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
  }