heyiam 0.2.28 → 0.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (177) hide show
  1. package/README.md +45 -0
  2. package/dist/config.js +10 -1
  3. package/dist/db.js +1 -2
  4. package/dist/export.js +40 -25
  5. package/dist/format-utils.js +5 -0
  6. package/dist/index.js +168 -0
  7. package/dist/mount.js +300 -102
  8. package/dist/parsers/claude.js +2 -28
  9. package/dist/parsers/codex.js +2 -26
  10. package/dist/parsers/cursor.js +2 -26
  11. package/dist/parsers/duration.js +35 -0
  12. package/dist/parsers/gemini.js +2 -20
  13. package/dist/parsers/types.js +0 -1
  14. package/dist/public/assets/index-BZ65TU_Y.js +40 -0
  15. package/dist/public/assets/index-CqCaW2cb.css +1 -0
  16. package/dist/public/index.html +2 -2
  17. package/dist/redact.js +4 -104
  18. package/dist/render/build-render-data.js +9 -2
  19. package/dist/render/index.js +32 -5
  20. package/dist/render/liquid.js +147 -7
  21. package/dist/render/mock-data.js +303 -0
  22. package/dist/render/templates/aurora/portfolio.liquid +204 -0
  23. package/dist/render/templates/aurora/project.liquid +260 -0
  24. package/dist/render/templates/aurora/session.liquid +223 -0
  25. package/dist/render/templates/aurora/styles.css +1178 -0
  26. package/dist/render/templates/bauhaus/portfolio.liquid +179 -0
  27. package/dist/render/templates/bauhaus/project.liquid +300 -0
  28. package/dist/render/templates/bauhaus/session.liquid +333 -0
  29. package/dist/render/templates/bauhaus/styles.css +1641 -0
  30. package/dist/render/templates/blueprint/portfolio.liquid +167 -0
  31. package/dist/render/templates/blueprint/project.liquid +286 -0
  32. package/dist/render/templates/blueprint/session.liquid +248 -0
  33. package/dist/render/templates/blueprint/styles.css +1285 -0
  34. package/dist/render/templates/canvas/portfolio.liquid +215 -0
  35. package/dist/render/templates/canvas/project.liquid +235 -0
  36. package/dist/render/templates/canvas/session.liquid +223 -0
  37. package/dist/render/templates/canvas/styles.css +1436 -0
  38. package/dist/render/templates/carbon/portfolio.liquid +170 -0
  39. package/dist/render/templates/carbon/project.liquid +249 -0
  40. package/dist/render/templates/carbon/session.liquid +190 -0
  41. package/dist/render/templates/carbon/styles.css +1091 -0
  42. package/dist/render/templates/chalk/portfolio.liquid +199 -0
  43. package/dist/render/templates/chalk/project.liquid +245 -0
  44. package/dist/render/templates/chalk/session.liquid +215 -0
  45. package/dist/render/templates/chalk/styles.css +1157 -0
  46. package/dist/render/templates/circuit/portfolio.liquid +162 -0
  47. package/dist/render/templates/circuit/project.liquid +247 -0
  48. package/dist/render/templates/circuit/session.liquid +205 -0
  49. package/dist/render/templates/circuit/styles.css +1403 -0
  50. package/dist/render/templates/cosmos/portfolio.liquid +232 -0
  51. package/dist/render/templates/cosmos/project.liquid +327 -0
  52. package/dist/render/templates/cosmos/session.liquid +239 -0
  53. package/dist/render/templates/cosmos/styles.css +1151 -0
  54. package/dist/render/templates/daylight/portfolio.liquid +217 -0
  55. package/dist/render/templates/daylight/project.liquid +229 -0
  56. package/dist/render/templates/daylight/session.liquid +219 -0
  57. package/dist/render/templates/daylight/styles.css +1311 -0
  58. package/dist/render/templates/editorial/portfolio.liquid +126 -0
  59. package/dist/render/templates/editorial/project.liquid +202 -0
  60. package/dist/render/templates/editorial/session.liquid +171 -0
  61. package/dist/render/templates/editorial/styles.css +822 -0
  62. package/dist/render/templates/ember/portfolio.liquid +318 -0
  63. package/dist/render/templates/ember/project.liquid +232 -0
  64. package/dist/render/templates/ember/session.liquid +202 -0
  65. package/dist/render/templates/ember/styles.css +1283 -0
  66. package/dist/render/templates/glacier/portfolio.liquid +271 -0
  67. package/dist/render/templates/glacier/project.liquid +288 -0
  68. package/dist/render/templates/glacier/session.liquid +217 -0
  69. package/dist/render/templates/glacier/styles.css +1200 -0
  70. package/dist/render/templates/grid/portfolio.liquid +265 -0
  71. package/dist/render/templates/grid/project.liquid +306 -0
  72. package/dist/render/templates/grid/session.liquid +260 -0
  73. package/dist/render/templates/grid/styles.css +1441 -0
  74. package/dist/render/templates/kinetic/portfolio.liquid +170 -0
  75. package/dist/render/templates/kinetic/project.liquid +242 -0
  76. package/dist/render/templates/kinetic/session.liquid +228 -0
  77. package/dist/render/templates/kinetic/styles.css +944 -0
  78. package/dist/render/templates/meridian/portfolio.liquid +255 -0
  79. package/dist/render/templates/meridian/project.liquid +376 -0
  80. package/dist/render/templates/meridian/session.liquid +298 -0
  81. package/dist/render/templates/meridian/styles.css +1369 -0
  82. package/dist/render/templates/minimal/portfolio.liquid +71 -0
  83. package/dist/render/templates/minimal/project.liquid +154 -0
  84. package/dist/render/templates/minimal/session.liquid +140 -0
  85. package/dist/render/templates/minimal/styles.css +525 -0
  86. package/dist/render/templates/mono/portfolio.liquid +291 -0
  87. package/dist/render/templates/mono/project.liquid +275 -0
  88. package/dist/render/templates/mono/session.liquid +276 -0
  89. package/dist/render/templates/mono/styles.css +1016 -0
  90. package/dist/render/templates/neon/portfolio.liquid +217 -0
  91. package/dist/render/templates/neon/project.liquid +225 -0
  92. package/dist/render/templates/neon/session.liquid +195 -0
  93. package/dist/render/templates/neon/styles.css +1265 -0
  94. package/dist/render/templates/noir/portfolio.liquid +137 -0
  95. package/dist/render/templates/noir/project.liquid +220 -0
  96. package/dist/render/templates/noir/session.liquid +241 -0
  97. package/dist/render/templates/noir/styles.css +1223 -0
  98. package/dist/render/templates/obsidian/portfolio.liquid +257 -0
  99. package/dist/render/templates/obsidian/project.liquid +280 -0
  100. package/dist/render/templates/obsidian/session.liquid +241 -0
  101. package/dist/render/templates/obsidian/styles.css +1401 -0
  102. package/dist/render/templates/paper/portfolio.liquid +267 -0
  103. package/dist/render/templates/paper/project.liquid +235 -0
  104. package/dist/render/templates/paper/session.liquid +271 -0
  105. package/dist/render/templates/paper/styles.css +1509 -0
  106. package/dist/render/templates/parallax/portfolio.liquid +305 -0
  107. package/dist/render/templates/parallax/project.liquid +275 -0
  108. package/dist/render/templates/parallax/session.liquid +295 -0
  109. package/dist/render/templates/parallax/styles.css +1874 -0
  110. package/dist/render/templates/parchment/portfolio.liquid +290 -0
  111. package/dist/render/templates/parchment/project.liquid +289 -0
  112. package/dist/render/templates/parchment/session.liquid +346 -0
  113. package/dist/render/templates/parchment/styles.css +1397 -0
  114. package/dist/render/templates/partials/_beats.liquid +16 -0
  115. package/dist/render/templates/partials/_breadcrumb.liquid +9 -0
  116. package/dist/render/templates/partials/_footer.liquid +7 -0
  117. package/dist/render/templates/partials/_growth-chart.liquid +7 -0
  118. package/dist/render/templates/partials/_key-decisions.liquid +20 -0
  119. package/dist/render/templates/partials/_links.liquid +16 -0
  120. package/dist/render/templates/partials/_narrative.liquid +8 -0
  121. package/dist/render/templates/partials/_phases.liquid +20 -0
  122. package/dist/render/templates/partials/_portfolio-header.liquid +20 -0
  123. package/dist/render/templates/partials/_portfolio-projects.liquid +16 -0
  124. package/dist/render/templates/partials/_portfolio-stats.liquid +19 -0
  125. package/dist/render/templates/partials/_qa.liquid +13 -0
  126. package/dist/render/templates/partials/_screenshot.liquid +15 -0
  127. package/dist/render/templates/partials/_session-cards.liquid +30 -0
  128. package/dist/render/templates/partials/_session-header.liquid +39 -0
  129. package/dist/render/templates/partials/_session-sidebar.liquid +30 -0
  130. package/dist/render/templates/partials/_skills.liquid +12 -0
  131. package/dist/render/templates/partials/_source-breakdown.liquid +22 -0
  132. package/dist/render/templates/partials/_stats.liquid +38 -0
  133. package/dist/render/templates/partials/_work-timeline.liquid +7 -0
  134. package/dist/render/templates/project.liquid +7 -4
  135. package/dist/render/templates/radar/portfolio.liquid +233 -0
  136. package/dist/render/templates/radar/project.liquid +278 -0
  137. package/dist/render/templates/radar/session.liquid +300 -0
  138. package/dist/render/templates/radar/styles.css +1049 -0
  139. package/dist/render/templates/showcase/portfolio.liquid +231 -0
  140. package/dist/render/templates/showcase/project.liquid +237 -0
  141. package/dist/render/templates/showcase/session.liquid +210 -0
  142. package/dist/render/templates/showcase/styles.css +1279 -0
  143. package/dist/render/templates/signal/portfolio.liquid +227 -0
  144. package/dist/render/templates/signal/project.liquid +278 -0
  145. package/dist/render/templates/signal/session.liquid +282 -0
  146. package/dist/render/templates/signal/styles.css +1395 -0
  147. package/dist/render/templates/strata/portfolio.liquid +192 -0
  148. package/dist/render/templates/strata/project.liquid +282 -0
  149. package/dist/render/templates/strata/session.liquid +261 -0
  150. package/dist/render/templates/strata/styles.css +1350 -0
  151. package/dist/render/templates/styles.css +1190 -0
  152. package/dist/render/templates/terminal/portfolio.liquid +118 -0
  153. package/dist/render/templates/terminal/project.liquid +161 -0
  154. package/dist/render/templates/terminal/session.liquid +145 -0
  155. package/dist/render/templates/terminal/styles.css +492 -0
  156. package/dist/render/templates/verdant/portfolio.liquid +333 -0
  157. package/dist/render/templates/verdant/project.liquid +309 -0
  158. package/dist/render/templates/verdant/session.liquid +237 -0
  159. package/dist/render/templates/verdant/styles.css +1257 -0
  160. package/dist/render/templates/zen/portfolio.liquid +136 -0
  161. package/dist/render/templates/zen/project.liquid +187 -0
  162. package/dist/render/templates/zen/session.liquid +203 -0
  163. package/dist/render/templates/zen/styles.css +1207 -0
  164. package/dist/render/templates.js +90 -0
  165. package/dist/routes/context.js +15 -10
  166. package/dist/routes/enhance.js +17 -40
  167. package/dist/routes/export.js +14 -4
  168. package/dist/routes/preview.js +480 -108
  169. package/dist/routes/projects.js +11 -19
  170. package/dist/routes/publish.js +15 -17
  171. package/dist/routes/settings.js +94 -1
  172. package/dist/routes/sse.js +9 -0
  173. package/dist/server.js +8 -2
  174. package/dist/settings.js +17 -9
  175. package/package.json +2 -4
  176. package/dist/public/assets/index-B_d6DlEI.js +0 -21
  177. package/dist/public/assets/index-Dalqz2mC.css +0 -1
@@ -0,0 +1,492 @@
1
+ /* ── Terminal template styles ──
2
+ * Green-on-black terminal aesthetic.
3
+ * Monospace font, ASCII elements, command-line feel.
4
+ * Accent: #4ade80 (green-400)
5
+ */
6
+
7
+ /* ── Base ── */
8
+ .terminal {
9
+ --term-bg: #0a0f0a;
10
+ --term-surface: #0d1a0d;
11
+ --term-border: rgba(74, 222, 128, 0.2);
12
+ --term-green: #4ade80;
13
+ --term-green-dim: rgba(74, 222, 128, 0.6);
14
+ --term-green-faint: rgba(74, 222, 128, 0.1);
15
+ --term-text: #d1fae5;
16
+ --term-dim: rgba(74, 222, 128, 0.45);
17
+ --term-red: #f87171;
18
+ --term-font: 'JetBrains Mono', 'IBM Plex Mono', 'Fira Code', monospace;
19
+
20
+ font-family: var(--term-font);
21
+ background: var(--term-bg);
22
+ color: var(--term-text);
23
+ padding: 2rem 2.5rem;
24
+ max-width: 860px;
25
+ margin: 0 auto;
26
+ font-size: 0.875rem;
27
+ line-height: 1.6;
28
+ }
29
+
30
+ .terminal a {
31
+ color: var(--term-green);
32
+ text-decoration: none;
33
+ }
34
+ .terminal a:hover {
35
+ text-decoration: underline;
36
+ }
37
+
38
+ /* ── Prompt breadcrumb ── */
39
+ .term-prompt {
40
+ margin-bottom: 1.5rem;
41
+ font-size: 0.8125rem;
42
+ }
43
+ .term-prompt__char {
44
+ color: var(--term-green);
45
+ font-weight: 700;
46
+ }
47
+ .term-prompt__path {
48
+ color: var(--term-green-dim);
49
+ }
50
+ .term-prompt__path a {
51
+ color: var(--term-green-dim);
52
+ }
53
+ .term-prompt__path a:hover {
54
+ color: var(--term-green);
55
+ }
56
+
57
+ /* ── Header (portfolio) ── */
58
+ .term-header {
59
+ display: flex;
60
+ gap: 1.5rem;
61
+ align-items: flex-start;
62
+ margin-bottom: 1.5rem;
63
+ }
64
+
65
+ /* ── Photo with ASCII art border ── */
66
+ .term-photo {
67
+ flex-shrink: 0;
68
+ }
69
+ .term-photo__border {
70
+ border: 2px solid var(--term-green);
71
+ padding: 3px;
72
+ position: relative;
73
+ }
74
+ .term-photo__border::before {
75
+ content: '+ - - - - - - +';
76
+ position: absolute;
77
+ top: -1.2em;
78
+ left: -2px;
79
+ font-size: 0.625rem;
80
+ color: var(--term-dim);
81
+ letter-spacing: 0.05em;
82
+ }
83
+ .term-photo__border::after {
84
+ content: '+ - - - - - - +';
85
+ position: absolute;
86
+ bottom: -1.2em;
87
+ left: -2px;
88
+ font-size: 0.625rem;
89
+ color: var(--term-dim);
90
+ letter-spacing: 0.05em;
91
+ }
92
+ .term-photo__img {
93
+ display: block;
94
+ width: 80px;
95
+ height: 80px;
96
+ object-fit: cover;
97
+ filter: grayscale(0.3) contrast(1.1);
98
+ }
99
+
100
+ .term-identity {
101
+ flex: 1;
102
+ min-width: 0;
103
+ }
104
+
105
+ /* ── Heading ── */
106
+ .term-heading {
107
+ font-family: var(--term-font);
108
+ font-size: 1.25rem;
109
+ font-weight: 700;
110
+ color: var(--term-green);
111
+ margin: 0 0 0.25rem;
112
+ letter-spacing: -0.01em;
113
+ }
114
+
115
+ /* ── Status ── */
116
+ .term-status {
117
+ font-size: 0.75rem;
118
+ color: var(--term-dim);
119
+ margin-bottom: 0.5rem;
120
+ }
121
+
122
+ /* ── Blockquote ── */
123
+ .term-blockquote {
124
+ border-left: 2px solid var(--term-border);
125
+ padding-left: 1rem;
126
+ margin: 0.5rem 0;
127
+ color: var(--term-text);
128
+ font-style: normal;
129
+ }
130
+
131
+ /* ── Section ── */
132
+ .term-section {
133
+ margin: 1.5rem 0;
134
+ }
135
+
136
+ /* ── Comment heading ── */
137
+ .term-comment {
138
+ color: var(--term-dim);
139
+ font-size: 0.8125rem;
140
+ margin-bottom: 0.5rem;
141
+ font-weight: 400;
142
+ }
143
+
144
+ /* ── Table ── */
145
+ .term-table {
146
+ border-collapse: collapse;
147
+ width: 100%;
148
+ font-family: var(--term-font);
149
+ font-size: 0.8125rem;
150
+ }
151
+ .term-table tr {
152
+ border-bottom: 1px solid var(--term-green-faint);
153
+ }
154
+ .term-table tr:last-child {
155
+ border-bottom: none;
156
+ }
157
+ .term-table__key {
158
+ color: var(--term-green-dim);
159
+ padding: 0.25rem 1rem 0.25rem 0;
160
+ white-space: nowrap;
161
+ vertical-align: top;
162
+ }
163
+ .term-table__eq {
164
+ color: var(--term-dim);
165
+ padding: 0.25rem 0.5rem;
166
+ vertical-align: top;
167
+ }
168
+ .term-table__val {
169
+ color: var(--term-text);
170
+ padding: 0.25rem 0;
171
+ vertical-align: top;
172
+ }
173
+ .term-table__header {
174
+ color: var(--term-dim);
175
+ font-size: 0.6875rem;
176
+ text-transform: uppercase;
177
+ letter-spacing: 0.08em;
178
+ padding: 0.25rem 1rem 0.25rem 0;
179
+ border-bottom: 1px solid var(--term-border);
180
+ font-weight: 400;
181
+ }
182
+
183
+ /* ── Accent + dim helpers ── */
184
+ .term-accent {
185
+ color: var(--term-green);
186
+ font-weight: 700;
187
+ }
188
+ .term-dim {
189
+ color: var(--term-dim);
190
+ }
191
+ .term-sep {
192
+ color: var(--term-dim);
193
+ margin: 0 0.25rem;
194
+ }
195
+
196
+ /* ── Project entries (portfolio) ── */
197
+ .term-project-entry {
198
+ display: block;
199
+ padding: 0.75rem 0.75rem;
200
+ margin: 0.25rem 0;
201
+ border: 1px solid transparent;
202
+ border-radius: 2px;
203
+ text-decoration: none;
204
+ color: inherit;
205
+ transition: border-color 0.15s, background 0.15s;
206
+ }
207
+ .term-project-entry:hover {
208
+ border-color: var(--term-border);
209
+ background: var(--term-green-faint);
210
+ text-decoration: none;
211
+ }
212
+ .term-project-entry__row {
213
+ display: flex;
214
+ align-items: baseline;
215
+ gap: 0.5rem;
216
+ }
217
+ .term-project-entry__idx {
218
+ color: var(--term-green);
219
+ font-weight: 700;
220
+ flex-shrink: 0;
221
+ }
222
+ .term-project-entry__title {
223
+ color: var(--term-text);
224
+ font-weight: 600;
225
+ }
226
+ .term-project-entry__meta {
227
+ font-size: 0.75rem;
228
+ color: var(--term-dim);
229
+ margin-top: 0.125rem;
230
+ padding-left: 2rem;
231
+ }
232
+ .term-project-entry__skills {
233
+ display: flex;
234
+ flex-wrap: wrap;
235
+ gap: 0.375rem;
236
+ margin-top: 0.25rem;
237
+ padding-left: 2rem;
238
+ }
239
+
240
+ /* ── Session entries ── */
241
+ .term-session-entry {
242
+ margin: 0.375rem 0;
243
+ padding: 0.5rem 0.75rem;
244
+ }
245
+ .term-session-link {
246
+ display: block;
247
+ text-decoration: none;
248
+ color: inherit;
249
+ padding: 0.5rem 0.75rem;
250
+ margin: 0.25rem -0.75rem;
251
+ border: 1px solid transparent;
252
+ border-radius: 2px;
253
+ transition: border-color 0.15s, background 0.15s;
254
+ }
255
+ .term-session-link:hover {
256
+ border-color: var(--term-border);
257
+ background: var(--term-green-faint);
258
+ text-decoration: none;
259
+ }
260
+ .term-session-entry__row {
261
+ display: flex;
262
+ align-items: baseline;
263
+ gap: 0.5rem;
264
+ }
265
+ .term-session-entry__idx {
266
+ color: var(--term-green);
267
+ font-weight: 700;
268
+ flex-shrink: 0;
269
+ }
270
+ .term-session-entry__title {
271
+ color: var(--term-text);
272
+ font-weight: 600;
273
+ }
274
+ .term-session-entry__meta {
275
+ font-size: 0.75rem;
276
+ color: var(--term-dim);
277
+ margin-top: 0.125rem;
278
+ padding-left: 2rem;
279
+ }
280
+
281
+ /* ── Skill tags ── */
282
+ .term-skill-tag {
283
+ display: inline-block;
284
+ font-size: 0.6875rem;
285
+ padding: 0.125rem 0.5rem;
286
+ border: 1px solid var(--term-border);
287
+ border-radius: 2px;
288
+ color: var(--term-green-dim);
289
+ background: var(--term-green-faint);
290
+ }
291
+
292
+ .term-inline-skills {
293
+ display: flex;
294
+ flex-wrap: wrap;
295
+ gap: 0.375rem;
296
+ }
297
+
298
+ /* ── Command style ── */
299
+ .term-cmd {
300
+ margin: 0.25rem 0;
301
+ font-size: 0.8125rem;
302
+ }
303
+ .term-cmd__prefix {
304
+ color: var(--term-green);
305
+ font-weight: 700;
306
+ }
307
+ .term-cmd__text {
308
+ color: var(--term-green-dim);
309
+ }
310
+
311
+ /* ── Screenshot chrome ── */
312
+ .term-screenshot {
313
+ border: 1px solid var(--term-border);
314
+ border-radius: 2px;
315
+ overflow: hidden;
316
+ }
317
+ .term-screenshot__chrome {
318
+ display: flex;
319
+ align-items: center;
320
+ gap: 0.75rem;
321
+ padding: 0.375rem 0.75rem;
322
+ background: var(--term-surface);
323
+ border-bottom: 1px solid var(--term-border);
324
+ font-size: 0.6875rem;
325
+ }
326
+ .term-screenshot__dots {
327
+ color: var(--term-dim);
328
+ font-size: 0.5rem;
329
+ letter-spacing: 0.2em;
330
+ }
331
+ .term-screenshot__url {
332
+ color: var(--term-dim);
333
+ }
334
+ .term-screenshot__img {
335
+ display: block;
336
+ width: 100%;
337
+ filter: brightness(0.95) saturate(0.9);
338
+ }
339
+
340
+ /* ── Git log style (phases) ── */
341
+ .term-git-log {
342
+ font-size: 0.8125rem;
343
+ }
344
+ .term-git-log__entry {
345
+ display: flex;
346
+ align-items: baseline;
347
+ gap: 0.5rem;
348
+ padding: 0.25rem 0;
349
+ }
350
+ .term-git-log__graph {
351
+ color: var(--term-green);
352
+ flex-shrink: 0;
353
+ }
354
+ .term-git-log__hash {
355
+ color: var(--term-green);
356
+ font-weight: 700;
357
+ flex-shrink: 0;
358
+ }
359
+ .term-git-log__msg {
360
+ color: var(--term-text);
361
+ font-weight: 600;
362
+ }
363
+ .term-git-log__desc {
364
+ color: var(--term-dim);
365
+ }
366
+
367
+ /* ── Beats ── */
368
+ .term-beat {
369
+ margin: 0.75rem 0;
370
+ padding-left: 1rem;
371
+ border-left: 2px solid var(--term-green-faint);
372
+ }
373
+ .term-beat__header {
374
+ display: flex;
375
+ align-items: baseline;
376
+ gap: 0.375rem;
377
+ }
378
+ .term-beat__num {
379
+ color: var(--term-green);
380
+ font-weight: 700;
381
+ font-size: 0.75rem;
382
+ }
383
+ .term-beat__prefix {
384
+ color: var(--term-green);
385
+ font-weight: 700;
386
+ }
387
+ .term-beat__title {
388
+ color: var(--term-text);
389
+ }
390
+ .term-beat__body {
391
+ color: var(--term-dim);
392
+ margin: 0.125rem 0 0;
393
+ font-size: 0.8125rem;
394
+ }
395
+
396
+ /* ── List items ── */
397
+ .term-list-item {
398
+ color: var(--term-text);
399
+ padding: 0.125rem 0;
400
+ font-size: 0.8125rem;
401
+ }
402
+
403
+ /* ── Context ── */
404
+ .term-context {
405
+ color: var(--term-dim);
406
+ margin: 0.25rem 0;
407
+ font-size: 0.8125rem;
408
+ }
409
+
410
+ /* ── File entries ── */
411
+ .term-file-entry {
412
+ display: flex;
413
+ justify-content: space-between;
414
+ align-items: baseline;
415
+ padding: 0.1875rem 0;
416
+ font-size: 0.8125rem;
417
+ gap: 1rem;
418
+ }
419
+ .term-file-path {
420
+ color: var(--term-text);
421
+ overflow: hidden;
422
+ text-overflow: ellipsis;
423
+ white-space: nowrap;
424
+ min-width: 0;
425
+ }
426
+ .term-file-diff {
427
+ flex-shrink: 0;
428
+ font-size: 0.75rem;
429
+ }
430
+ .term-adds {
431
+ color: var(--term-green);
432
+ }
433
+ .term-dels {
434
+ color: var(--term-red);
435
+ }
436
+
437
+ /* ── Q&A as stdin/stdout ── */
438
+ .term-qa {
439
+ margin: 0.75rem 0;
440
+ font-size: 0.8125rem;
441
+ }
442
+ .term-qa__prefix {
443
+ color: var(--term-green);
444
+ font-weight: 700;
445
+ margin-right: 0.25rem;
446
+ }
447
+ .term-qa__question {
448
+ color: var(--term-text);
449
+ margin-bottom: 0.25rem;
450
+ }
451
+ .term-qa__answer {
452
+ color: var(--term-dim);
453
+ padding-left: 1rem;
454
+ }
455
+
456
+ /* ── Footer ── */
457
+ .term-footer {
458
+ margin-top: 3rem;
459
+ padding-top: 1rem;
460
+ border-top: 1px solid var(--term-green-faint);
461
+ font-size: 0.6875rem;
462
+ color: var(--term-dim);
463
+ }
464
+ .term-footer a {
465
+ color: var(--term-dim);
466
+ }
467
+ .term-footer a:hover {
468
+ color: var(--term-green);
469
+ }
470
+
471
+ /* ── Responsive ── */
472
+ @media (max-width: 640px) {
473
+ .terminal {
474
+ padding: 1.25rem 1rem;
475
+ font-size: 0.8125rem;
476
+ }
477
+ .term-header {
478
+ flex-direction: column;
479
+ gap: 1rem;
480
+ }
481
+ .term-photo__img {
482
+ width: 64px;
483
+ height: 64px;
484
+ }
485
+ .term-file-entry {
486
+ flex-direction: column;
487
+ gap: 0;
488
+ }
489
+ .term-git-log__entry {
490
+ flex-wrap: wrap;
491
+ }
492
+ }