anentrypoint-design 0.0.121 → 0.0.124

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 (202) hide show
  1. package/README.md +253 -253
  2. package/app-shell.css +931 -594
  3. package/colors_and_type.css +226 -226
  4. package/community.css +817 -1222
  5. package/dist/247420.css +2202 -2084
  6. package/dist/247420.js +13 -13
  7. package/package.json +80 -80
  8. package/src/bootstrap.js +25 -25
  9. package/src/components/chat.js +199 -199
  10. package/src/components/community.js +190 -208
  11. package/src/components/content.js +269 -269
  12. package/src/components/editor-primitives.js +100 -0
  13. package/src/components/files-modals.js +107 -107
  14. package/src/components/files.js +118 -118
  15. package/src/components/freddie/helpers.js +50 -50
  16. package/src/components/freddie.js +33 -33
  17. package/src/components/shell.js +117 -117
  18. package/src/components/theme-toggle.js +70 -70
  19. package/src/components.js +59 -57
  20. package/src/debug.js +30 -30
  21. package/src/deck-stage.js +21 -21
  22. package/src/highlight.js +65 -32
  23. package/src/index.js +86 -86
  24. package/src/kits/os/about-app.js +52 -52
  25. package/src/kits/os/app-panes.css +152 -152
  26. package/src/kits/os/browser-app.js +58 -58
  27. package/src/kits/os/files-app.js +44 -44
  28. package/src/kits/os/freddie/helpers.js +59 -59
  29. package/src/kits/os/freddie/pages-chat.js +143 -143
  30. package/src/kits/os/freddie/pages-core.js +101 -101
  31. package/src/kits/os/freddie/pages-os.js +51 -51
  32. package/src/kits/os/freddie/pages-tools.js +183 -183
  33. package/src/kits/os/freddie/routes.js +24 -24
  34. package/src/kits/os/freddie-dashboard.css +51 -51
  35. package/src/kits/os/freddie-dashboard.js +101 -101
  36. package/src/kits/os/icons.js +17 -17
  37. package/src/kits/os/index.js +17 -17
  38. package/src/kits/os/launcher.css +61 -61
  39. package/src/kits/os/launcher.js +79 -79
  40. package/src/kits/os/monitor-app.js +34 -34
  41. package/src/kits/os/shell.js +214 -214
  42. package/src/kits/os/terminal-app.js +45 -45
  43. package/src/kits/os/theme.css +450 -450
  44. package/src/kits/os/validate.css +19 -19
  45. package/src/kits/os/validator-app.js +55 -55
  46. package/src/kits/os/wm.css +115 -115
  47. package/src/kits/os/wm.js +111 -111
  48. package/src/markdown.js +39 -39
  49. package/src/motion.js +35 -35
  50. package/src/page-html.js +196 -196
  51. package/src/styles.js +25 -25
  52. package/src/theme.js +99 -99
  53. package/src/web-components/ds-chat.js +116 -116
  54. package/dist/.nojekyll +0 -0
  55. package/dist/app-shell.css +0 -594
  56. package/dist/colors_and_type.css +0 -197
  57. package/dist/favicon.svg +0 -1
  58. package/dist/index.html +0 -308
  59. package/dist/preview/buttons.html +0 -28
  60. package/dist/preview/colors-core.html +0 -45
  61. package/dist/preview/colors-lore.html +0 -28
  62. package/dist/preview/colors-semantic.html +0 -34
  63. package/dist/preview/dateline.html +0 -19
  64. package/dist/preview/dropzone.html +0 -30
  65. package/dist/preview/file-grid.html +0 -19
  66. package/dist/preview/file-row.html +0 -20
  67. package/dist/preview/file-toolbar.html +0 -40
  68. package/dist/preview/file-viewer.html +0 -31
  69. package/dist/preview/header.html +0 -24
  70. package/dist/preview/icons-unicode.html +0 -26
  71. package/dist/preview/index-row.html +0 -25
  72. package/dist/preview/inputs.html +0 -22
  73. package/dist/preview/manifesto.html +0 -52
  74. package/dist/preview/motion-default.js +0 -106
  75. package/dist/preview/rules.html +0 -16
  76. package/dist/preview/spacing.html +0 -18
  77. package/dist/preview/stamps-lore.html +0 -20
  78. package/dist/preview/stamps.html +0 -14
  79. package/dist/preview/theme-ink.html +0 -15
  80. package/dist/preview/type-display.html +0 -16
  81. package/dist/preview/type-mono.html +0 -15
  82. package/dist/preview/type-prose.html +0 -11
  83. package/dist/preview/type-scale.html +0 -20
  84. package/dist/preview/wordmarks.html +0 -28
  85. package/dist/robots.txt +0 -8
  86. package/dist/site/content/globals/navigation.yaml +0 -5
  87. package/dist/site/content/globals/site.yaml +0 -16
  88. package/dist/site/content/pages/freddie.yaml +0 -88
  89. package/dist/site/content/pages/home.yaml +0 -190
  90. package/dist/site/theme.mjs +0 -368
  91. package/dist/sitemap.xml +0 -31
  92. package/dist/slides/deck-stage-overlay.js +0 -63
  93. package/dist/slides/deck-stage-state.js +0 -81
  94. package/dist/slides/deck-stage-style.js +0 -117
  95. package/dist/slides/deck-stage.js +0 -159
  96. package/dist/slides/index.html +0 -276
  97. package/dist/src/bootstrap.js +0 -25
  98. package/dist/src/components/chat.js +0 -199
  99. package/dist/src/components/community.js +0 -167
  100. package/dist/src/components/content.js +0 -213
  101. package/dist/src/components/files-modals.js +0 -107
  102. package/dist/src/components/files.js +0 -118
  103. package/dist/src/components/freddie/helpers.js +0 -50
  104. package/dist/src/components/freddie.js +0 -33
  105. package/dist/src/components/shell.js +0 -117
  106. package/dist/src/components/theme-toggle.js +0 -70
  107. package/dist/src/components.js +0 -52
  108. package/dist/src/debug.js +0 -30
  109. package/dist/src/deck-stage.js +0 -21
  110. package/dist/src/highlight.js +0 -32
  111. package/dist/src/index.js +0 -86
  112. package/dist/src/kits/os/about-app.js +0 -52
  113. package/dist/src/kits/os/app-panes.css +0 -152
  114. package/dist/src/kits/os/browser-app.js +0 -58
  115. package/dist/src/kits/os/files-app.js +0 -44
  116. package/dist/src/kits/os/freddie/helpers.js +0 -59
  117. package/dist/src/kits/os/freddie/pages-chat.js +0 -143
  118. package/dist/src/kits/os/freddie/pages-core.js +0 -101
  119. package/dist/src/kits/os/freddie/pages-os.js +0 -51
  120. package/dist/src/kits/os/freddie/pages-tools.js +0 -183
  121. package/dist/src/kits/os/freddie/routes.js +0 -24
  122. package/dist/src/kits/os/freddie-dashboard.css +0 -51
  123. package/dist/src/kits/os/freddie-dashboard.js +0 -101
  124. package/dist/src/kits/os/icons.js +0 -17
  125. package/dist/src/kits/os/index.js +0 -5
  126. package/dist/src/kits/os/launcher.css +0 -61
  127. package/dist/src/kits/os/launcher.js +0 -79
  128. package/dist/src/kits/os/monitor-app.js +0 -34
  129. package/dist/src/kits/os/shell.js +0 -214
  130. package/dist/src/kits/os/terminal-app.js +0 -45
  131. package/dist/src/kits/os/theme.css +0 -412
  132. package/dist/src/kits/os/validate.css +0 -19
  133. package/dist/src/kits/os/validator-app.js +0 -55
  134. package/dist/src/kits/os/wm.css +0 -115
  135. package/dist/src/kits/os/wm.js +0 -111
  136. package/dist/src/markdown.js +0 -39
  137. package/dist/src/motion.js +0 -35
  138. package/dist/src/page-html.js +0 -196
  139. package/dist/src/styles.js +0 -25
  140. package/dist/src/theme.js +0 -99
  141. package/dist/src/web-components/ds-chat.js +0 -45
  142. package/dist/ui_kits/aicat/README.md +0 -7
  143. package/dist/ui_kits/aicat/app.js +0 -156
  144. package/dist/ui_kits/aicat/index.html +0 -26
  145. package/dist/ui_kits/aicat/sample-square.png +0 -0
  146. package/dist/ui_kits/aicat/sample-svg.svg +0 -1
  147. package/dist/ui_kits/aicat/sample.pdf +0 -32
  148. package/dist/ui_kits/blog/README.md +0 -3
  149. package/dist/ui_kits/blog/index.html +0 -90
  150. package/dist/ui_kits/chat/README.md +0 -5
  151. package/dist/ui_kits/chat/app.js +0 -110
  152. package/dist/ui_kits/chat/index.html +0 -26
  153. package/dist/ui_kits/chat/sample-square.png +0 -0
  154. package/dist/ui_kits/chat/sample-svg.svg +0 -1
  155. package/dist/ui_kits/chat/sample.pdf +0 -32
  156. package/dist/ui_kits/community/app.js +0 -134
  157. package/dist/ui_kits/community/index.html +0 -24
  158. package/dist/ui_kits/dashboard/app.js +0 -92
  159. package/dist/ui_kits/dashboard/index.html +0 -26
  160. package/dist/ui_kits/docs/README.md +0 -3
  161. package/dist/ui_kits/docs/index.html +0 -123
  162. package/dist/ui_kits/error_404/app.js +0 -56
  163. package/dist/ui_kits/error_404/index.html +0 -26
  164. package/dist/ui_kits/file_browser/README.md +0 -48
  165. package/dist/ui_kits/file_browser/app.js +0 -231
  166. package/dist/ui_kits/file_browser/index.html +0 -33
  167. package/dist/ui_kits/gallery/app.js +0 -121
  168. package/dist/ui_kits/gallery/index.html +0 -26
  169. package/dist/ui_kits/homepage/README.md +0 -7
  170. package/dist/ui_kits/homepage/app.js +0 -167
  171. package/dist/ui_kits/homepage/index.html +0 -46
  172. package/dist/ui_kits/project_page/README.md +0 -3
  173. package/dist/ui_kits/project_page/app.js +0 -154
  174. package/dist/ui_kits/project_page/index.html +0 -45
  175. package/dist/ui_kits/search/app.js +0 -107
  176. package/dist/ui_kits/search/index.html +0 -26
  177. package/dist/ui_kits/settings/app.js +0 -133
  178. package/dist/ui_kits/settings/index.html +0 -26
  179. package/dist/ui_kits/signin/app.js +0 -115
  180. package/dist/ui_kits/signin/index.html +0 -26
  181. package/dist/ui_kits/slide_deck/app.js +0 -174
  182. package/dist/ui_kits/slide_deck/index.html +0 -26
  183. package/dist/ui_kits/system_primer/app.js +0 -152
  184. package/dist/ui_kits/system_primer/index.html +0 -26
  185. package/dist/ui_kits/terminal/app.js +0 -150
  186. package/dist/ui_kits/terminal/index.html +0 -26
  187. package/dist/vendor/webjsx/applyDiff.js +0 -182
  188. package/dist/vendor/webjsx/attributes.js +0 -154
  189. package/dist/vendor/webjsx/constants.js +0 -4
  190. package/dist/vendor/webjsx/createDOMElement.js +0 -52
  191. package/dist/vendor/webjsx/createElement.js +0 -75
  192. package/dist/vendor/webjsx/elementTags.js +0 -115
  193. package/dist/vendor/webjsx/factory.js +0 -6
  194. package/dist/vendor/webjsx/index.js +0 -6
  195. package/dist/vendor/webjsx/jsx-dev-runtime.js +0 -2
  196. package/dist/vendor/webjsx/jsx-runtime.js +0 -30
  197. package/dist/vendor/webjsx/jsx.js +0 -2
  198. package/dist/vendor/webjsx/package.json +0 -39
  199. package/dist/vendor/webjsx/renderSuspension.js +0 -25
  200. package/dist/vendor/webjsx/types.js +0 -5
  201. package/dist/vendor/webjsx/utils.js +0 -84
  202. package/src/components/overlays.js +0 -151
@@ -1,450 +1,450 @@
1
- @import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap');
2
-
3
- :root {
4
- --ff-ui: 'Space Grotesk', system-ui, sans-serif;
5
- --ff-display: 'Space Grotesk', system-ui, sans-serif;
6
- --ff-mono: 'JetBrains Mono', ui-monospace, monospace;
7
- --os-accent: var(--panel-accent, #3F8A4A);
8
- --os-accent-2: var(--panel-accent-2, #2B6B36);
9
- --os-accent-soft: var(--panel-select, #D8ECCB);
10
- --os-bg-0: var(--panel-0, #F5F0E4);
11
- --os-bg-1: var(--panel-1, #FBF6EB);
12
- --os-bg-2: var(--panel-2, #F0E9DA);
13
- --os-bg-3: var(--panel-3, #E3DAC7);
14
- --os-fg: var(--panel-text, #1F1B16);
15
- --os-fg-2: var(--panel-text-2, #5A5246);
16
- --os-fg-3: var(--panel-text-3, #857B6C);
17
- --os-red: var(--warn, #FF6B4A);
18
- --os-amber: var(--sun, #FFD86B);
19
- --os-green: var(--green, #3F8A4A);
20
- --os-radius: var(--r-2, 10px);
21
- --os-radius-sm: var(--r-1, 6px);
22
- --os-bar-h: 44px;
23
- --os-bar-h-mobile: 52px;
24
- --os-rail-w: 64px;
25
- --os-tap: 44px;
26
- --os-font: var(--ff-ui, 'Space Grotesk', system-ui, sans-serif);
27
- --os-display: var(--ff-display, 'Space Grotesk', system-ui, sans-serif);
28
- --os-mono: var(--ff-mono, 'JetBrains Mono', ui-monospace, monospace);
29
- }
30
-
31
- html, body {
32
- background: var(--os-bg-0);
33
- color: var(--os-fg);
34
- font-family: var(--os-font);
35
- -webkit-font-smoothing: antialiased;
36
- text-rendering: optimizeLegibility;
37
- }
38
-
39
- .os-menubar, .os-taskbar {
40
- background: color-mix(in oklab, var(--os-bg-2) 88%, transparent);
41
- backdrop-filter: blur(10px);
42
- -webkit-backdrop-filter: blur(10px);
43
- border: none;
44
- color: var(--os-fg);
45
- font: 13px var(--os-font);
46
- height: var(--os-bar-h);
47
- padding: 0 12px;
48
- gap: 6px;
49
- box-shadow: none;
50
- display: flex;
51
- align-items: center;
52
- flex-wrap: nowrap;
53
- min-width: 0;
54
- }
55
- .os-menubar > *, .os-taskbar > * { flex-shrink: 0; }
56
- .os-menubar .os-spacer { flex: 1 1 auto; min-width: 0; }
57
- .os-menubar .os-tray { margin-left: auto; }
58
-
59
- .os-brand {
60
- color: var(--os-fg);
61
- font-family: var(--os-display);
62
- font-weight: 700;
63
- letter-spacing: -0.01em;
64
- font-size: 15px;
65
- margin-right: 14px;
66
- display: inline-flex;
67
- align-items: center;
68
- gap: 8px;
69
- text-transform: lowercase;
70
- }
71
- .os-brand::before {
72
- content: '';
73
- display: inline-block;
74
- width: 8px; height: 8px;
75
- border-radius: 50%;
76
- background: var(--os-accent);
77
- }
78
-
79
- .os-btn {
80
- background: transparent;
81
- color: var(--os-fg-2);
82
- border: none;
83
- padding: 7px 14px;
84
- cursor: pointer;
85
- font: inherit;
86
- font-family: var(--os-font);
87
- font-size: 13px;
88
- border-radius: 999px;
89
- transition: background 80ms ease, color 80ms ease;
90
- display: inline-flex;
91
- align-items: center;
92
- gap: 6px;
93
- outline: none;
94
- text-transform: lowercase;
95
- }
96
- .os-btn:hover { background: var(--panel-hover, var(--os-bg-2)); color: var(--os-fg); }
97
- .os-btn.active, .os-btn[aria-pressed="true"] { background: var(--panel-select, var(--os-accent-soft)); color: var(--os-fg); }
98
- .os-btn:focus-visible { background: var(--panel-hover, var(--os-bg-2)); }
99
- .os-btn .ic { color: var(--os-accent); display: inline-flex; width: 16px; height: 16px; }
100
- .os-btn .ic svg { width: 16px; height: 16px; display: block; fill: none; stroke: currentColor; }
101
-
102
- .os-menu {
103
- position: absolute;
104
- background: var(--os-bg-1);
105
- border: none;
106
- border-radius: var(--r-3, 18px);
107
- padding: 8px;
108
- min-width: 220px;
109
- top: calc(var(--os-bar-h) + 4px);
110
- left: 8px;
111
- z-index: 9500;
112
- display: none;
113
- flex-direction: column;
114
- gap: 2px;
115
- pointer-events: auto;
116
- }
117
- .os-menu.open { display: flex; }
118
- .os-menu .os-btn {
119
- width: 100%;
120
- text-align: left;
121
- border-radius: var(--os-radius-sm);
122
- padding: 8px 10px;
123
- color: var(--os-fg);
124
- justify-content: flex-start;
125
- }
126
- .os-menu .os-btn:hover { background: var(--panel-hover, var(--os-bg-2)); color: var(--os-fg); }
127
-
128
- .os-clock {
129
- color: var(--os-fg-2);
130
- font-variant-numeric: tabular-nums;
131
- font-family: var(--os-mono);
132
- padding: 0 10px;
133
- font-size: 12px;
134
- }
135
-
136
- .os-task {
137
- border: none;
138
- background: var(--os-bg-1);
139
- color: var(--os-fg-2);
140
- border-radius: 999px;
141
- padding: 6px 14px;
142
- font-size: 12px;
143
- font-family: var(--os-font);
144
- transition: background 80ms ease, color 80ms ease, box-shadow 80ms ease;
145
- max-width: 200px;
146
- cursor: pointer;
147
- outline: none;
148
- white-space: nowrap;
149
- overflow: hidden;
150
- text-overflow: ellipsis;
151
- text-transform: lowercase;
152
- }
153
- .os-task:hover { background: var(--panel-hover, var(--os-bg-2)); color: var(--os-fg); }
154
- .os-task.focused {
155
- background: var(--panel-select, var(--os-accent-soft));
156
- color: var(--os-fg);
157
- font-weight: 600;
158
- box-shadow: inset 4px 0 0 var(--os-accent);
159
- }
160
-
161
- .wm-win {
162
- background: var(--os-bg-1) !important;
163
- border: none !important;
164
- border-radius: var(--r-3, 18px) !important;
165
- box-shadow: none !important;
166
- overflow: hidden;
167
- }
168
- .wm-win.wm-focused {
169
- border: none !important;
170
- box-shadow: inset 4px 0 0 var(--os-accent) !important;
171
- }
172
-
173
- .wm-bar {
174
- background: var(--os-bg-2) !important;
175
- border: none !important;
176
- padding: 8px 12px !important;
177
- gap: 10px !important;
178
- }
179
- .wm-title {
180
- font: 13px var(--os-font) !important;
181
- color: var(--os-fg-2) !important;
182
- letter-spacing: 0.005em;
183
- text-align: center;
184
- font-weight: 600;
185
- text-transform: lowercase;
186
- }
187
- .wm-btns { gap: 6px !important; order: -1; }
188
- .wm-btn {
189
- width: 22px !important;
190
- height: 22px !important;
191
- border-radius: var(--r-1, 6px) !important;
192
- border: none !important;
193
- background: var(--os-bg-3) !important;
194
- color: var(--os-fg-2) !important;
195
- padding: 0 !important;
196
- cursor: pointer;
197
- font: 600 12px var(--os-mono) !important;
198
- line-height: 1 !important;
199
- display: inline-flex !important;
200
- align-items: center;
201
- justify-content: center;
202
- transition: background 100ms ease, color 100ms ease;
203
- }
204
- .wm-btn:hover { background: var(--panel-hover, var(--os-bg-2)) !important; color: var(--os-fg) !important; }
205
-
206
- .wm-resize {
207
- background: transparent !important;
208
- width: 14px !important;
209
- height: 14px !important;
210
- color: var(--os-fg-3);
211
- opacity: 0.4;
212
- font: 10px var(--os-mono);
213
- display: flex;
214
- align-items: flex-end;
215
- justify-content: flex-end;
216
- line-height: 1;
217
- }
218
- .wm-resize::after { content: '\25E2'; }
219
- .wm-body { background: var(--os-bg-1) !important; }
220
-
221
- .os-side-rail {
222
- position: fixed;
223
- left: 0; top: 0; bottom: 0;
224
- width: var(--os-rail-w);
225
- background: var(--os-bg-2);
226
- border: none;
227
- display: none;
228
- flex-direction: column;
229
- align-items: center;
230
- padding: 12px 0;
231
- gap: 6px;
232
- z-index: 9100;
233
- pointer-events: auto;
234
- }
235
- .os-rail-btn {
236
- width: 48px; height: 48px;
237
- border-radius: var(--os-radius-sm);
238
- background: transparent;
239
- border: none;
240
- color: var(--os-fg);
241
- cursor: pointer;
242
- display: flex; align-items: center; justify-content: center;
243
- transition: background 100ms ease;
244
- padding: 0;
245
- outline: none;
246
- }
247
- .os-rail-btn:hover { background: var(--panel-hover, var(--os-bg-1)); }
248
- .os-rail-btn:active { background: var(--panel-select, var(--os-accent-soft)); }
249
- .os-rail-btn .ic { color: var(--os-accent); display: inline-flex; }
250
- .os-rail-btn .ic svg { width: 22px; height: 22px; fill: none; stroke: currentColor; }
251
-
252
- .os-drawer {
253
- position: fixed;
254
- inset: 0;
255
- background: var(--os-bg-0);
256
- z-index: 9700;
257
- pointer-events: auto;
258
- display: none;
259
- flex-direction: column;
260
- opacity: 0;
261
- transform: translateY(8px);
262
- transition: opacity 180ms ease, transform 180ms ease;
263
- padding-top: env(safe-area-inset-top, 0);
264
- padding-bottom: env(safe-area-inset-bottom, 0);
265
- }
266
- .os-drawer.open { display: flex; opacity: 1; transform: translateY(0); }
267
- .os-drawer-head {
268
- display: flex; align-items: center; justify-content: space-between;
269
- padding: 12px 16px;
270
- border: none;
271
- height: 56px;
272
- box-sizing: border-box;
273
- background: var(--os-bg-2);
274
- }
275
- .os-drawer-title { color: var(--os-fg); font-family: var(--os-display); font-size: 22px; font-weight: 700; letter-spacing: -0.01em; text-transform: lowercase; }
276
- .os-drawer-close {
277
- width: 44px; height: 44px;
278
- border: none; background: transparent;
279
- color: var(--os-fg-2);
280
- cursor: pointer;
281
- display: flex; align-items: center; justify-content: center;
282
- border-radius: var(--os-radius-sm);
283
- outline: none;
284
- }
285
- .os-drawer-close:hover { background: var(--panel-hover, var(--os-bg-2)); color: var(--os-fg); }
286
- .os-drawer-close .ic svg { width: 22px; height: 22px; fill: none; stroke: currentColor; }
287
- .os-drawer-grid {
288
- display: grid;
289
- grid-template-columns: repeat(3, 1fr);
290
- gap: 12px;
291
- padding: 16px;
292
- overflow-y: auto;
293
- flex: 1;
294
- align-content: start;
295
- }
296
- .os-drawer-tile {
297
- display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
298
- padding: 18px 8px;
299
- background: var(--os-bg-1);
300
- border: none;
301
- color: var(--os-fg);
302
- font: 13px var(--os-font);
303
- min-height: 100px;
304
- cursor: pointer;
305
- transition: background 80ms ease;
306
- outline: none;
307
- border-radius: var(--r-3, 18px);
308
- text-transform: lowercase;
309
- }
310
- .os-drawer-tile:hover { background: var(--panel-hover, var(--os-bg-2)); }
311
- .os-drawer-tile:active, .os-drawer-tile.active { background: var(--panel-select, var(--os-accent-soft)); }
312
- .os-drawer-tile .ic { color: var(--os-accent); display: inline-flex; }
313
- .os-drawer-tile .ic svg { width: 32px; height: 32px; fill: none; stroke: currentColor; }
314
- .os-drawer-tile .lbl { color: var(--os-fg); font-weight: 600; }
315
-
316
- .os-spacer { flex: 1 1 auto; }
317
- .os-tray { display: flex; align-items: center; gap: 6px; }
318
- .os-instances { display: flex; gap: 4px; margin-left: 8px; max-width: 280px; overflow-x: auto; overflow-y: hidden; scrollbar-width: thin; padding: 0 4px; }
319
- .os-instances::-webkit-scrollbar { height: 4px; }
320
- .os-instances .os-btn { flex: 0 0 auto; min-width: 36px; padding: 2px 8px; font-family: var(--os-mono); font-size: 11px; }
321
- .os-instances .os-btn.active { background: var(--panel-select, var(--os-accent-soft)); color: var(--os-fg); border-color: var(--panel-accent, var(--os-accent)); box-shadow: inset 0 0 0 1px var(--panel-accent, var(--os-accent)); }
322
- .os-menubar [data-role="home"] { display: none; }
323
- .os-root { position: fixed; inset: 0; display: flex; flex-direction: column; pointer-events: none; z-index: 8000; }
324
- .os-menubar, .os-taskbar { pointer-events: auto; flex: 0 0 auto; }
325
- .os-taskbar { margin-top: auto; }
326
- .wm-root { top: var(--os-bar-h) !important; bottom: var(--os-bar-h) !important; inset: var(--os-bar-h) 0 var(--os-bar-h) 0 !important; }
327
-
328
- .app-pane { padding: 16px 18px; font: 14px var(--os-font); color: var(--os-fg); line-height: 1.55; overflow: auto; height: 100%; box-sizing: border-box; background: var(--os-bg-1); }
329
- .app-pane h2 { margin: 0 0 10px 0; color: var(--os-fg); font-family: var(--os-display); font-size: 22px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.15; }
330
- .app-pane p { margin: 0 0 10px 0; color: var(--os-fg-2); }
331
- .app-pane ul { padding-left: 18px; margin: 6px 0 12px; color: var(--os-fg-2); }
332
- .app-pane li { padding: 2px 0; }
333
- .app-pane code { font: 12px var(--os-mono); background: var(--os-bg-2); padding: 1px 6px; border-radius: var(--r-1, 6px); color: var(--os-fg); }
334
- .app-pane a { color: var(--os-accent); text-decoration: none; }
335
- .app-pane a:hover { text-decoration: underline; text-underline-offset: 2px; }
336
- .app-pane .meta { color: var(--os-fg-3); font-size: 12px; }
337
- .app-pane.mono { font: 12.5px var(--os-mono); padding: 12px; background: var(--os-bg-1); }
338
- .app-pane.mono .row { padding: 5px 8px; cursor: pointer; border-radius: var(--r-1, 6px); }
339
- .app-pane.mono .row:hover { background: var(--panel-hover, var(--os-bg-2)); }
340
- .app-pane.mono .head { color: var(--os-accent); margin-bottom: 8px; padding-bottom: 6px; font-weight: 600; letter-spacing: 0.02em; }
341
- .app-pane.mono pre { background: var(--os-bg-2); padding: 10px 12px; margin: 8px 0 0 0; max-height: 220px; overflow: auto; white-space: pre-wrap; font: 11.5px var(--os-mono); border-radius: var(--r-1, 6px); color: var(--os-fg); border: none; }
342
- .app-shell-pane { margin: 0; padding: 8px; font: 12px var(--os-mono); color: var(--os-fg); background: var(--os-bg-0); height: 100%; overflow: auto; white-space: pre-wrap; box-sizing: border-box; }
343
- .app-canvas { width: 100%; height: 100%; background: var(--os-bg-0); display: block; cursor: default; }
344
- .app-canvas.x-display { background: #0b0d10; }
345
- .app-frame { width: 100%; height: 100%; border: 0; background: var(--os-bg-0); }
346
- .app-iframe { width: 100%; height: 100%; border: 0; display: block; }
347
- .app-iframe.web { background: #ffffff; }
348
- .app-text-cursor { animation: app-cursor-blink 0.5s step-end infinite; }
349
- @keyframes app-cursor-blink { 50% { opacity: 0; } }
350
- @media (max-width: 1023px) and (min-width: 768px) {
351
- .os-side-rail { display: flex; }
352
- .wm-root { left: var(--os-rail-w) !important; }
353
- .os-menubar { padding-left: calc(var(--os-rail-w) + 8px); }
354
- .os-taskbar { padding-left: calc(var(--os-rail-w) + 8px); }
355
- .os-menubar .os-instances { display: flex; }
356
- .os-menu { left: calc(var(--os-rail-w) + 8px); }
357
- }
358
-
359
- @media (max-width: 767px) {
360
- :root { --os-bar-h: var(--os-bar-h-mobile); }
361
- body { overscroll-behavior: none; }
362
- .os-menubar [data-role="home"] { display: inline-flex; min-width: var(--os-tap); min-height: var(--os-tap); padding: 0 12px; }
363
- .os-menubar [data-role="home"] .ic svg { width: 22px; height: 22px; }
364
- .os-menubar { font-size: 14px; padding: 0 8px; padding-top: env(safe-area-inset-top, 0); height: calc(var(--os-bar-h) + env(safe-area-inset-top, 0)); }
365
- .os-menubar [data-role="apps"] { display: none; }
366
- .os-menubar .os-brand { font-size: 13px; margin-right: 6px; }
367
- .os-menubar [data-role="add"] { display: none; }
368
- .os-menubar .os-instances { display: none; }
369
- .os-clock { display: none; }
370
- .os-taskbar {
371
- padding: 6px 8px calc(6px + env(safe-area-inset-bottom, 0));
372
- gap: 6px;
373
- overflow-x: auto;
374
- overflow-y: hidden;
375
- flex-wrap: nowrap;
376
- scroll-snap-type: x proximity;
377
- height: calc(var(--os-bar-h) + env(safe-area-inset-bottom, 0));
378
- align-items: center;
379
- }
380
- .os-taskbar::-webkit-scrollbar { display: none; }
381
- .os-task {
382
- flex: 0 0 auto;
383
- min-width: 120px;
384
- min-height: 44px;
385
- max-width: none;
386
- padding: 10px 14px;
387
- scroll-snap-align: start;
388
- font-size: 13px;
389
- }
390
- .os-task.focused { background: var(--panel-select, var(--os-accent-soft)); box-shadow: inset 4px 0 0 var(--os-accent); }
391
- .os-side-rail { display: none !important; }
392
- .os-menu { left: 8px; right: 8px; min-width: 0; top: calc(var(--os-bar-h) + env(safe-area-inset-top, 0) + 4px); }
393
- .wm-root {
394
- top: calc(var(--os-bar-h) + env(safe-area-inset-top, 0)) !important;
395
- bottom: calc(var(--os-bar-h) + env(safe-area-inset-bottom, 0)) !important;
396
- inset: calc(var(--os-bar-h) + env(safe-area-inset-top, 0)) 0 calc(var(--os-bar-h) + env(safe-area-inset-bottom, 0)) 0 !important;
397
- }
398
- .wm-win {
399
- position: absolute !important;
400
- left: 0 !important; top: 0 !important;
401
- width: 100% !important; height: 100% !important;
402
- border: none !important;
403
- border-radius: 0 !important;
404
- box-shadow: none !important;
405
- }
406
- .wm-bar {
407
- padding: 6px 10px !important;
408
- height: 36px !important;
409
- gap: 6px !important;
410
- cursor: default !important;
411
- touch-action: pan-y !important;
412
- pointer-events: none;
413
- }
414
- .wm-bar .wm-title { pointer-events: auto; font-size: 13px !important; }
415
- .wm-bar .wm-btns { pointer-events: auto; }
416
- .wm-btns .wm-btn:nth-child(1), .wm-btns .wm-btn:nth-child(2) { display: none !important; }
417
- .wm-btns .wm-btn:nth-child(3) { width: 44px !important; height: 44px !important; border-radius: var(--r-1, 6px) !important; background: var(--os-bg-3) !important; color: var(--os-fg) !important; }
418
- .wm-resize { display: none !important; }
419
- }
420
-
421
- /* ---- data-attr theme/density/accent rules (ported from anentrypoint-update colors_and_type.css) ---- */
422
- :root[data-theme="ink"] {
423
- --os-bg-0: #14131a;
424
- --os-bg-1: #1a1924;
425
- --os-bg-2: #20202a;
426
- --os-bg-3: #2a2a36;
427
- --os-fg: #efece4;
428
- --os-fg-2: #c8c5bc;
429
- --os-fg-3: #8c8a80;
430
- color-scheme: dark;
431
- }
432
- :root[data-theme="paper"] {
433
- --os-bg-0: #f6f5f1;
434
- --os-bg-1: #efece4;
435
- --os-bg-2: #e7e3d8;
436
- --os-bg-3: #d8d3c4;
437
- --os-fg: #14131a;
438
- --os-fg-2: #3a3833;
439
- --os-fg-3: #6a6660;
440
- color-scheme: light;
441
- }
442
- :root[data-density="compact"] { --os-bar-h: 28px; --os-tile-pad: 6px; --os-gap: 6px; }
443
- :root[data-density="comfortable"] { --os-bar-h: 36px; --os-tile-pad: 10px; --os-gap: 10px; }
444
- :root[data-density="spacious"] { --os-bar-h: 44px; --os-tile-pad: 14px; --os-gap: 14px; }
445
- :root[data-accent="green"] { --os-accent: #247420; --os-accent-tint: color-mix(in oklab, #247420 18%, transparent); }
446
- :root[data-accent="purple"] { --os-accent: #7c5cff; --os-accent-tint: color-mix(in oklab, #7c5cff 18%, transparent); }
447
- :root[data-accent="mascot"] { --os-accent: #ff6d3f; --os-accent-tint: color-mix(in oklab, #ff6d3f 18%, transparent); }
448
- :root[data-theme="ink"][data-accent="green"] { --os-accent: #3FA93A; }
449
- :root[data-theme="ink"][data-accent="purple"] { --os-accent: #a085ff; }
450
- :root[data-theme="ink"][data-accent="mascot"] { --os-accent: #ff8a64; }
1
+ @import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap');
2
+
3
+ :root {
4
+ --ff-ui: 'Space Grotesk', system-ui, sans-serif;
5
+ --ff-display: 'Space Grotesk', system-ui, sans-serif;
6
+ --ff-mono: 'JetBrains Mono', ui-monospace, monospace;
7
+ --os-accent: var(--panel-accent, #3F8A4A);
8
+ --os-accent-2: var(--panel-accent-2, #2B6B36);
9
+ --os-accent-soft: var(--panel-select, #D8ECCB);
10
+ --os-bg-0: var(--panel-0, #F5F0E4);
11
+ --os-bg-1: var(--panel-1, #FBF6EB);
12
+ --os-bg-2: var(--panel-2, #F0E9DA);
13
+ --os-bg-3: var(--panel-3, #E3DAC7);
14
+ --os-fg: var(--panel-text, #1F1B16);
15
+ --os-fg-2: var(--panel-text-2, #5A5246);
16
+ --os-fg-3: var(--panel-text-3, #857B6C);
17
+ --os-red: var(--warn, #FF6B4A);
18
+ --os-amber: var(--sun, #FFD86B);
19
+ --os-green: var(--green, #3F8A4A);
20
+ --os-radius: var(--r-2, 10px);
21
+ --os-radius-sm: var(--r-1, 6px);
22
+ --os-bar-h: 44px;
23
+ --os-bar-h-mobile: 52px;
24
+ --os-rail-w: 64px;
25
+ --os-tap: 44px;
26
+ --os-font: var(--ff-ui, 'Space Grotesk', system-ui, sans-serif);
27
+ --os-display: var(--ff-display, 'Space Grotesk', system-ui, sans-serif);
28
+ --os-mono: var(--ff-mono, 'JetBrains Mono', ui-monospace, monospace);
29
+ }
30
+
31
+ html, body {
32
+ background: var(--os-bg-0);
33
+ color: var(--os-fg);
34
+ font-family: var(--os-font);
35
+ -webkit-font-smoothing: antialiased;
36
+ text-rendering: optimizeLegibility;
37
+ }
38
+
39
+ .os-menubar, .os-taskbar {
40
+ background: color-mix(in oklab, var(--os-bg-2) 88%, transparent);
41
+ backdrop-filter: blur(10px);
42
+ -webkit-backdrop-filter: blur(10px);
43
+ border: none;
44
+ color: var(--os-fg);
45
+ font: 13px var(--os-font);
46
+ height: var(--os-bar-h);
47
+ padding: 0 12px;
48
+ gap: 6px;
49
+ box-shadow: none;
50
+ display: flex;
51
+ align-items: center;
52
+ flex-wrap: nowrap;
53
+ min-width: 0;
54
+ }
55
+ .os-menubar > *, .os-taskbar > * { flex-shrink: 0; }
56
+ .os-menubar .os-spacer { flex: 1 1 auto; min-width: 0; }
57
+ .os-menubar .os-tray { margin-left: auto; }
58
+
59
+ .os-brand {
60
+ color: var(--os-fg);
61
+ font-family: var(--os-display);
62
+ font-weight: 700;
63
+ letter-spacing: -0.01em;
64
+ font-size: 15px;
65
+ margin-right: 14px;
66
+ display: inline-flex;
67
+ align-items: center;
68
+ gap: 8px;
69
+ text-transform: lowercase;
70
+ }
71
+ .os-brand::before {
72
+ content: '';
73
+ display: inline-block;
74
+ width: 8px; height: 8px;
75
+ border-radius: 50%;
76
+ background: var(--os-accent);
77
+ }
78
+
79
+ .os-btn {
80
+ background: transparent;
81
+ color: var(--os-fg-2);
82
+ border: none;
83
+ padding: 7px 14px;
84
+ cursor: pointer;
85
+ font: inherit;
86
+ font-family: var(--os-font);
87
+ font-size: 13px;
88
+ border-radius: 999px;
89
+ transition: background 80ms ease, color 80ms ease;
90
+ display: inline-flex;
91
+ align-items: center;
92
+ gap: 6px;
93
+ outline: none;
94
+ text-transform: lowercase;
95
+ }
96
+ .os-btn:hover { background: var(--panel-hover, var(--os-bg-2)); color: var(--os-fg); }
97
+ .os-btn.active, .os-btn[aria-pressed="true"] { background: var(--panel-select, var(--os-accent-soft)); color: var(--os-fg); }
98
+ .os-btn:focus-visible { background: var(--panel-hover, var(--os-bg-2)); }
99
+ .os-btn .ic { color: var(--os-accent); display: inline-flex; width: 16px; height: 16px; }
100
+ .os-btn .ic svg { width: 16px; height: 16px; display: block; fill: none; stroke: currentColor; }
101
+
102
+ .os-menu {
103
+ position: absolute;
104
+ background: var(--os-bg-1);
105
+ border: none;
106
+ border-radius: var(--r-3, 18px);
107
+ padding: 8px;
108
+ min-width: 220px;
109
+ top: calc(var(--os-bar-h) + 4px);
110
+ left: 8px;
111
+ z-index: 9500;
112
+ display: none;
113
+ flex-direction: column;
114
+ gap: 2px;
115
+ pointer-events: auto;
116
+ }
117
+ .os-menu.open { display: flex; }
118
+ .os-menu .os-btn {
119
+ width: 100%;
120
+ text-align: left;
121
+ border-radius: var(--os-radius-sm);
122
+ padding: 8px 10px;
123
+ color: var(--os-fg);
124
+ justify-content: flex-start;
125
+ }
126
+ .os-menu .os-btn:hover { background: var(--panel-hover, var(--os-bg-2)); color: var(--os-fg); }
127
+
128
+ .os-clock {
129
+ color: var(--os-fg-2);
130
+ font-variant-numeric: tabular-nums;
131
+ font-family: var(--os-mono);
132
+ padding: 0 10px;
133
+ font-size: 12px;
134
+ }
135
+
136
+ .os-task {
137
+ border: none;
138
+ background: var(--os-bg-1);
139
+ color: var(--os-fg-2);
140
+ border-radius: 999px;
141
+ padding: 6px 14px;
142
+ font-size: 12px;
143
+ font-family: var(--os-font);
144
+ transition: background 80ms ease, color 80ms ease, box-shadow 80ms ease;
145
+ max-width: 200px;
146
+ cursor: pointer;
147
+ outline: none;
148
+ white-space: nowrap;
149
+ overflow: hidden;
150
+ text-overflow: ellipsis;
151
+ text-transform: lowercase;
152
+ }
153
+ .os-task:hover { background: var(--panel-hover, var(--os-bg-2)); color: var(--os-fg); }
154
+ .os-task.focused {
155
+ background: var(--panel-select, var(--os-accent-soft));
156
+ color: var(--os-fg);
157
+ font-weight: 600;
158
+ box-shadow: inset 4px 0 0 var(--os-accent);
159
+ }
160
+
161
+ .wm-win {
162
+ background: var(--os-bg-1) !important;
163
+ border: none !important;
164
+ border-radius: var(--r-3, 18px) !important;
165
+ box-shadow: none !important;
166
+ overflow: hidden;
167
+ }
168
+ .wm-win.wm-focused {
169
+ border: none !important;
170
+ box-shadow: inset 4px 0 0 var(--os-accent) !important;
171
+ }
172
+
173
+ .wm-bar {
174
+ background: var(--os-bg-2) !important;
175
+ border: none !important;
176
+ padding: 8px 12px !important;
177
+ gap: 10px !important;
178
+ }
179
+ .wm-title {
180
+ font: 13px var(--os-font) !important;
181
+ color: var(--os-fg-2) !important;
182
+ letter-spacing: 0.005em;
183
+ text-align: center;
184
+ font-weight: 600;
185
+ text-transform: lowercase;
186
+ }
187
+ .wm-btns { gap: 6px !important; order: -1; }
188
+ .wm-btn {
189
+ width: 22px !important;
190
+ height: 22px !important;
191
+ border-radius: var(--r-1, 6px) !important;
192
+ border: none !important;
193
+ background: var(--os-bg-3) !important;
194
+ color: var(--os-fg-2) !important;
195
+ padding: 0 !important;
196
+ cursor: pointer;
197
+ font: 600 12px var(--os-mono) !important;
198
+ line-height: 1 !important;
199
+ display: inline-flex !important;
200
+ align-items: center;
201
+ justify-content: center;
202
+ transition: background 100ms ease, color 100ms ease;
203
+ }
204
+ .wm-btn:hover { background: var(--panel-hover, var(--os-bg-2)) !important; color: var(--os-fg) !important; }
205
+
206
+ .wm-resize {
207
+ background: transparent !important;
208
+ width: 14px !important;
209
+ height: 14px !important;
210
+ color: var(--os-fg-3);
211
+ opacity: 0.4;
212
+ font: 10px var(--os-mono);
213
+ display: flex;
214
+ align-items: flex-end;
215
+ justify-content: flex-end;
216
+ line-height: 1;
217
+ }
218
+ .wm-resize::after { content: '\25E2'; }
219
+ .wm-body { background: var(--os-bg-1) !important; }
220
+
221
+ .os-side-rail {
222
+ position: fixed;
223
+ left: 0; top: 0; bottom: 0;
224
+ width: var(--os-rail-w);
225
+ background: var(--os-bg-2);
226
+ border: none;
227
+ display: none;
228
+ flex-direction: column;
229
+ align-items: center;
230
+ padding: 12px 0;
231
+ gap: 6px;
232
+ z-index: 9100;
233
+ pointer-events: auto;
234
+ }
235
+ .os-rail-btn {
236
+ width: 48px; height: 48px;
237
+ border-radius: var(--os-radius-sm);
238
+ background: transparent;
239
+ border: none;
240
+ color: var(--os-fg);
241
+ cursor: pointer;
242
+ display: flex; align-items: center; justify-content: center;
243
+ transition: background 100ms ease;
244
+ padding: 0;
245
+ outline: none;
246
+ }
247
+ .os-rail-btn:hover { background: var(--panel-hover, var(--os-bg-1)); }
248
+ .os-rail-btn:active { background: var(--panel-select, var(--os-accent-soft)); }
249
+ .os-rail-btn .ic { color: var(--os-accent); display: inline-flex; }
250
+ .os-rail-btn .ic svg { width: 22px; height: 22px; fill: none; stroke: currentColor; }
251
+
252
+ .os-drawer {
253
+ position: fixed;
254
+ inset: 0;
255
+ background: var(--os-bg-0);
256
+ z-index: 9700;
257
+ pointer-events: auto;
258
+ display: none;
259
+ flex-direction: column;
260
+ opacity: 0;
261
+ transform: translateY(8px);
262
+ transition: opacity 180ms ease, transform 180ms ease;
263
+ padding-top: env(safe-area-inset-top, 0);
264
+ padding-bottom: env(safe-area-inset-bottom, 0);
265
+ }
266
+ .os-drawer.open { display: flex; opacity: 1; transform: translateY(0); }
267
+ .os-drawer-head {
268
+ display: flex; align-items: center; justify-content: space-between;
269
+ padding: 12px 16px;
270
+ border: none;
271
+ height: 56px;
272
+ box-sizing: border-box;
273
+ background: var(--os-bg-2);
274
+ }
275
+ .os-drawer-title { color: var(--os-fg); font-family: var(--os-display); font-size: 22px; font-weight: 700; letter-spacing: -0.01em; text-transform: lowercase; }
276
+ .os-drawer-close {
277
+ width: 44px; height: 44px;
278
+ border: none; background: transparent;
279
+ color: var(--os-fg-2);
280
+ cursor: pointer;
281
+ display: flex; align-items: center; justify-content: center;
282
+ border-radius: var(--os-radius-sm);
283
+ outline: none;
284
+ }
285
+ .os-drawer-close:hover { background: var(--panel-hover, var(--os-bg-2)); color: var(--os-fg); }
286
+ .os-drawer-close .ic svg { width: 22px; height: 22px; fill: none; stroke: currentColor; }
287
+ .os-drawer-grid {
288
+ display: grid;
289
+ grid-template-columns: repeat(3, 1fr);
290
+ gap: 12px;
291
+ padding: 16px;
292
+ overflow-y: auto;
293
+ flex: 1;
294
+ align-content: start;
295
+ }
296
+ .os-drawer-tile {
297
+ display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 8px;
298
+ padding: 18px 8px;
299
+ background: var(--os-bg-1);
300
+ border: none;
301
+ color: var(--os-fg);
302
+ font: 13px var(--os-font);
303
+ min-height: 100px;
304
+ cursor: pointer;
305
+ transition: background 80ms ease;
306
+ outline: none;
307
+ border-radius: var(--r-3, 18px);
308
+ text-transform: lowercase;
309
+ }
310
+ .os-drawer-tile:hover { background: var(--panel-hover, var(--os-bg-2)); }
311
+ .os-drawer-tile:active, .os-drawer-tile.active { background: var(--panel-select, var(--os-accent-soft)); }
312
+ .os-drawer-tile .ic { color: var(--os-accent); display: inline-flex; }
313
+ .os-drawer-tile .ic svg { width: 32px; height: 32px; fill: none; stroke: currentColor; }
314
+ .os-drawer-tile .lbl { color: var(--os-fg); font-weight: 600; }
315
+
316
+ .os-spacer { flex: 1 1 auto; }
317
+ .os-tray { display: flex; align-items: center; gap: 6px; }
318
+ .os-instances { display: flex; gap: 4px; margin-left: 8px; max-width: 280px; overflow-x: auto; overflow-y: hidden; scrollbar-width: thin; padding: 0 4px; }
319
+ .os-instances::-webkit-scrollbar { height: 4px; }
320
+ .os-instances .os-btn { flex: 0 0 auto; min-width: 36px; padding: 2px 8px; font-family: var(--os-mono); font-size: 11px; }
321
+ .os-instances .os-btn.active { background: var(--panel-select, var(--os-accent-soft)); color: var(--os-fg); border-color: var(--panel-accent, var(--os-accent)); box-shadow: inset 0 0 0 1px var(--panel-accent, var(--os-accent)); }
322
+ .os-menubar [data-role="home"] { display: none; }
323
+ .os-root { position: fixed; inset: 0; display: flex; flex-direction: column; pointer-events: none; z-index: 8000; }
324
+ .os-menubar, .os-taskbar { pointer-events: auto; flex: 0 0 auto; }
325
+ .os-taskbar { margin-top: auto; }
326
+ .wm-root { top: var(--os-bar-h) !important; bottom: var(--os-bar-h) !important; inset: var(--os-bar-h) 0 var(--os-bar-h) 0 !important; }
327
+
328
+ .app-pane { padding: 16px 18px; font: 14px var(--os-font); color: var(--os-fg); line-height: 1.55; overflow: auto; height: 100%; box-sizing: border-box; background: var(--os-bg-1); }
329
+ .app-pane h2 { margin: 0 0 10px 0; color: var(--os-fg); font-family: var(--os-display); font-size: 22px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.15; }
330
+ .app-pane p { margin: 0 0 10px 0; color: var(--os-fg-2); }
331
+ .app-pane ul { padding-left: 18px; margin: 6px 0 12px; color: var(--os-fg-2); }
332
+ .app-pane li { padding: 2px 0; }
333
+ .app-pane code { font: 12px var(--os-mono); background: var(--os-bg-2); padding: 1px 6px; border-radius: var(--r-1, 6px); color: var(--os-fg); }
334
+ .app-pane a { color: var(--os-accent); text-decoration: none; }
335
+ .app-pane a:hover { text-decoration: underline; text-underline-offset: 2px; }
336
+ .app-pane .meta { color: var(--os-fg-3); font-size: 12px; }
337
+ .app-pane.mono { font: 12.5px var(--os-mono); padding: 12px; background: var(--os-bg-1); }
338
+ .app-pane.mono .row { padding: 5px 8px; cursor: pointer; border-radius: var(--r-1, 6px); }
339
+ .app-pane.mono .row:hover { background: var(--panel-hover, var(--os-bg-2)); }
340
+ .app-pane.mono .head { color: var(--os-accent); margin-bottom: 8px; padding-bottom: 6px; font-weight: 600; letter-spacing: 0.02em; }
341
+ .app-pane.mono pre { background: var(--os-bg-2); padding: 10px 12px; margin: 8px 0 0 0; max-height: 220px; overflow: auto; white-space: pre-wrap; font: 11.5px var(--os-mono); border-radius: var(--r-1, 6px); color: var(--os-fg); border: none; }
342
+ .app-shell-pane { margin: 0; padding: 8px; font: 12px var(--os-mono); color: var(--os-fg); background: var(--os-bg-0); height: 100%; overflow: auto; white-space: pre-wrap; box-sizing: border-box; }
343
+ .app-canvas { width: 100%; height: 100%; background: var(--os-bg-0); display: block; cursor: default; }
344
+ .app-canvas.x-display { background: #0b0d10; }
345
+ .app-frame { width: 100%; height: 100%; border: 0; background: var(--os-bg-0); }
346
+ .app-iframe { width: 100%; height: 100%; border: 0; display: block; }
347
+ .app-iframe.web { background: #ffffff; }
348
+ .app-text-cursor { animation: app-cursor-blink 0.5s step-end infinite; }
349
+ @keyframes app-cursor-blink { 50% { opacity: 0; } }
350
+ @media (max-width: 1023px) and (min-width: 768px) {
351
+ .os-side-rail { display: flex; }
352
+ .wm-root { left: var(--os-rail-w) !important; }
353
+ .os-menubar { padding-left: calc(var(--os-rail-w) + 8px); }
354
+ .os-taskbar { padding-left: calc(var(--os-rail-w) + 8px); }
355
+ .os-menubar .os-instances { display: flex; }
356
+ .os-menu { left: calc(var(--os-rail-w) + 8px); }
357
+ }
358
+
359
+ @media (max-width: 767px) {
360
+ :root { --os-bar-h: var(--os-bar-h-mobile); }
361
+ body { overscroll-behavior: none; }
362
+ .os-menubar [data-role="home"] { display: inline-flex; min-width: var(--os-tap); min-height: var(--os-tap); padding: 0 12px; }
363
+ .os-menubar [data-role="home"] .ic svg { width: 22px; height: 22px; }
364
+ .os-menubar { font-size: 14px; padding: 0 8px; padding-top: env(safe-area-inset-top, 0); height: calc(var(--os-bar-h) + env(safe-area-inset-top, 0)); }
365
+ .os-menubar [data-role="apps"] { display: none; }
366
+ .os-menubar .os-brand { font-size: 13px; margin-right: 6px; }
367
+ .os-menubar [data-role="add"] { display: none; }
368
+ .os-menubar .os-instances { display: none; }
369
+ .os-clock { display: none; }
370
+ .os-taskbar {
371
+ padding: 6px 8px calc(6px + env(safe-area-inset-bottom, 0));
372
+ gap: 6px;
373
+ overflow-x: auto;
374
+ overflow-y: hidden;
375
+ flex-wrap: nowrap;
376
+ scroll-snap-type: x proximity;
377
+ height: calc(var(--os-bar-h) + env(safe-area-inset-bottom, 0));
378
+ align-items: center;
379
+ }
380
+ .os-taskbar::-webkit-scrollbar { display: none; }
381
+ .os-task {
382
+ flex: 0 0 auto;
383
+ min-width: 120px;
384
+ min-height: 44px;
385
+ max-width: none;
386
+ padding: 10px 14px;
387
+ scroll-snap-align: start;
388
+ font-size: 13px;
389
+ }
390
+ .os-task.focused { background: var(--panel-select, var(--os-accent-soft)); box-shadow: inset 4px 0 0 var(--os-accent); }
391
+ .os-side-rail { display: none !important; }
392
+ .os-menu { left: 8px; right: 8px; min-width: 0; top: calc(var(--os-bar-h) + env(safe-area-inset-top, 0) + 4px); }
393
+ .wm-root {
394
+ top: calc(var(--os-bar-h) + env(safe-area-inset-top, 0)) !important;
395
+ bottom: calc(var(--os-bar-h) + env(safe-area-inset-bottom, 0)) !important;
396
+ inset: calc(var(--os-bar-h) + env(safe-area-inset-top, 0)) 0 calc(var(--os-bar-h) + env(safe-area-inset-bottom, 0)) 0 !important;
397
+ }
398
+ .wm-win {
399
+ position: absolute !important;
400
+ left: 0 !important; top: 0 !important;
401
+ width: 100% !important; height: 100% !important;
402
+ border: none !important;
403
+ border-radius: 0 !important;
404
+ box-shadow: none !important;
405
+ }
406
+ .wm-bar {
407
+ padding: 6px 10px !important;
408
+ height: 36px !important;
409
+ gap: 6px !important;
410
+ cursor: default !important;
411
+ touch-action: pan-y !important;
412
+ pointer-events: none;
413
+ }
414
+ .wm-bar .wm-title { pointer-events: auto; font-size: 13px !important; }
415
+ .wm-bar .wm-btns { pointer-events: auto; }
416
+ .wm-btns .wm-btn:nth-child(1), .wm-btns .wm-btn:nth-child(2) { display: none !important; }
417
+ .wm-btns .wm-btn:nth-child(3) { width: 44px !important; height: 44px !important; border-radius: var(--r-1, 6px) !important; background: var(--os-bg-3) !important; color: var(--os-fg) !important; }
418
+ .wm-resize { display: none !important; }
419
+ }
420
+
421
+ /* ---- data-attr theme/density/accent rules (ported from anentrypoint-update colors_and_type.css) ---- */
422
+ :root[data-theme="ink"] {
423
+ --os-bg-0: #14131a;
424
+ --os-bg-1: #1a1924;
425
+ --os-bg-2: #20202a;
426
+ --os-bg-3: #2a2a36;
427
+ --os-fg: #efece4;
428
+ --os-fg-2: #c8c5bc;
429
+ --os-fg-3: #8c8a80;
430
+ color-scheme: dark;
431
+ }
432
+ :root[data-theme="paper"] {
433
+ --os-bg-0: #f6f5f1;
434
+ --os-bg-1: #efece4;
435
+ --os-bg-2: #e7e3d8;
436
+ --os-bg-3: #d8d3c4;
437
+ --os-fg: #14131a;
438
+ --os-fg-2: #3a3833;
439
+ --os-fg-3: #6a6660;
440
+ color-scheme: light;
441
+ }
442
+ :root[data-density="compact"] { --os-bar-h: 28px; --os-tile-pad: 6px; --os-gap: 6px; }
443
+ :root[data-density="comfortable"] { --os-bar-h: 36px; --os-tile-pad: 10px; --os-gap: 10px; }
444
+ :root[data-density="spacious"] { --os-bar-h: 44px; --os-tile-pad: 14px; --os-gap: 14px; }
445
+ :root[data-accent="green"] { --os-accent: #247420; --os-accent-tint: color-mix(in oklab, #247420 18%, transparent); }
446
+ :root[data-accent="purple"] { --os-accent: #7c5cff; --os-accent-tint: color-mix(in oklab, #7c5cff 18%, transparent); }
447
+ :root[data-accent="mascot"] { --os-accent: #ff6d3f; --os-accent-tint: color-mix(in oklab, #ff6d3f 18%, transparent); }
448
+ :root[data-theme="ink"][data-accent="green"] { --os-accent: #3FA93A; }
449
+ :root[data-theme="ink"][data-accent="purple"] { --os-accent: #a085ff; }
450
+ :root[data-theme="ink"][data-accent="mascot"] { --os-accent: #ff8a64; }