heyiam 0.2.29 → 0.3.1

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 (186) hide show
  1. package/README.md +45 -0
  2. package/dist/auth.js +29 -3
  3. package/dist/config.js +10 -1
  4. package/dist/db.js +0 -1
  5. package/dist/export.js +124 -27
  6. package/dist/format-utils.js +5 -0
  7. package/dist/github.js +381 -0
  8. package/dist/index.js +168 -0
  9. package/dist/mount.js +300 -102
  10. package/dist/parsers/claude.js +2 -28
  11. package/dist/parsers/codex.js +2 -26
  12. package/dist/parsers/cursor.js +2 -26
  13. package/dist/parsers/duration.js +35 -0
  14. package/dist/parsers/gemini.js +2 -20
  15. package/dist/parsers/index.js +22 -3
  16. package/dist/parsers/types.js +0 -1
  17. package/dist/public/assets/index-Coilyhtr.css +1 -0
  18. package/dist/public/assets/index-D0noVMFu.js +44 -0
  19. package/dist/public/index.html +2 -2
  20. package/dist/redact.js +4 -104
  21. package/dist/render/build-render-data.js +9 -2
  22. package/dist/render/index.js +32 -5
  23. package/dist/render/liquid.js +147 -7
  24. package/dist/render/mock-data.js +303 -0
  25. package/dist/render/templates/aurora/portfolio.liquid +192 -0
  26. package/dist/render/templates/aurora/project.liquid +260 -0
  27. package/dist/render/templates/aurora/session.liquid +223 -0
  28. package/dist/render/templates/aurora/styles.css +1184 -0
  29. package/dist/render/templates/bauhaus/portfolio.liquid +169 -0
  30. package/dist/render/templates/bauhaus/project.liquid +300 -0
  31. package/dist/render/templates/bauhaus/session.liquid +333 -0
  32. package/dist/render/templates/bauhaus/styles.css +1645 -0
  33. package/dist/render/templates/blueprint/portfolio.liquid +153 -0
  34. package/dist/render/templates/blueprint/project.liquid +286 -0
  35. package/dist/render/templates/blueprint/session.liquid +248 -0
  36. package/dist/render/templates/blueprint/styles.css +1289 -0
  37. package/dist/render/templates/canvas/portfolio.liquid +203 -0
  38. package/dist/render/templates/canvas/project.liquid +235 -0
  39. package/dist/render/templates/canvas/session.liquid +223 -0
  40. package/dist/render/templates/canvas/styles.css +1440 -0
  41. package/dist/render/templates/carbon/portfolio.liquid +160 -0
  42. package/dist/render/templates/carbon/project.liquid +249 -0
  43. package/dist/render/templates/carbon/session.liquid +190 -0
  44. package/dist/render/templates/carbon/styles.css +1097 -0
  45. package/dist/render/templates/chalk/portfolio.liquid +189 -0
  46. package/dist/render/templates/chalk/project.liquid +245 -0
  47. package/dist/render/templates/chalk/session.liquid +215 -0
  48. package/dist/render/templates/chalk/styles.css +1161 -0
  49. package/dist/render/templates/circuit/portfolio.liquid +152 -0
  50. package/dist/render/templates/circuit/project.liquid +247 -0
  51. package/dist/render/templates/circuit/session.liquid +205 -0
  52. package/dist/render/templates/circuit/styles.css +1409 -0
  53. package/dist/render/templates/cosmos/portfolio.liquid +222 -0
  54. package/dist/render/templates/cosmos/project.liquid +327 -0
  55. package/dist/render/templates/cosmos/session.liquid +239 -0
  56. package/dist/render/templates/cosmos/styles.css +1157 -0
  57. package/dist/render/templates/daylight/portfolio.liquid +207 -0
  58. package/dist/render/templates/daylight/project.liquid +229 -0
  59. package/dist/render/templates/daylight/session.liquid +219 -0
  60. package/dist/render/templates/daylight/styles.css +1315 -0
  61. package/dist/render/templates/editorial/portfolio.liquid +110 -0
  62. package/dist/render/templates/editorial/project.liquid +202 -0
  63. package/dist/render/templates/editorial/session.liquid +171 -0
  64. package/dist/render/templates/editorial/styles.css +826 -0
  65. package/dist/render/templates/ember/portfolio.liquid +306 -0
  66. package/dist/render/templates/ember/project.liquid +232 -0
  67. package/dist/render/templates/ember/session.liquid +202 -0
  68. package/dist/render/templates/ember/styles.css +1289 -0
  69. package/dist/render/templates/glacier/portfolio.liquid +261 -0
  70. package/dist/render/templates/glacier/project.liquid +288 -0
  71. package/dist/render/templates/glacier/session.liquid +217 -0
  72. package/dist/render/templates/glacier/styles.css +1204 -0
  73. package/dist/render/templates/grid/portfolio.liquid +255 -0
  74. package/dist/render/templates/grid/project.liquid +306 -0
  75. package/dist/render/templates/grid/session.liquid +260 -0
  76. package/dist/render/templates/grid/styles.css +1445 -0
  77. package/dist/render/templates/kinetic/portfolio.liquid +158 -0
  78. package/dist/render/templates/kinetic/project.liquid +242 -0
  79. package/dist/render/templates/kinetic/session.liquid +228 -0
  80. package/dist/render/templates/kinetic/styles.css +948 -0
  81. package/dist/render/templates/meridian/portfolio.liquid +243 -0
  82. package/dist/render/templates/meridian/project.liquid +376 -0
  83. package/dist/render/templates/meridian/session.liquid +298 -0
  84. package/dist/render/templates/meridian/styles.css +1375 -0
  85. package/dist/render/templates/minimal/portfolio.liquid +71 -0
  86. package/dist/render/templates/minimal/project.liquid +154 -0
  87. package/dist/render/templates/minimal/session.liquid +140 -0
  88. package/dist/render/templates/minimal/styles.css +529 -0
  89. package/dist/render/templates/mono/portfolio.liquid +281 -0
  90. package/dist/render/templates/mono/project.liquid +275 -0
  91. package/dist/render/templates/mono/session.liquid +276 -0
  92. package/dist/render/templates/mono/styles.css +1022 -0
  93. package/dist/render/templates/neon/portfolio.liquid +207 -0
  94. package/dist/render/templates/neon/project.liquid +225 -0
  95. package/dist/render/templates/neon/session.liquid +195 -0
  96. package/dist/render/templates/neon/styles.css +1271 -0
  97. package/dist/render/templates/noir/portfolio.liquid +137 -0
  98. package/dist/render/templates/noir/project.liquid +220 -0
  99. package/dist/render/templates/noir/session.liquid +241 -0
  100. package/dist/render/templates/noir/styles.css +1229 -0
  101. package/dist/render/templates/obsidian/portfolio.liquid +247 -0
  102. package/dist/render/templates/obsidian/project.liquid +280 -0
  103. package/dist/render/templates/obsidian/session.liquid +241 -0
  104. package/dist/render/templates/obsidian/styles.css +1407 -0
  105. package/dist/render/templates/paper/portfolio.liquid +257 -0
  106. package/dist/render/templates/paper/project.liquid +235 -0
  107. package/dist/render/templates/paper/session.liquid +271 -0
  108. package/dist/render/templates/paper/styles.css +1513 -0
  109. package/dist/render/templates/parallax/portfolio.liquid +295 -0
  110. package/dist/render/templates/parallax/project.liquid +275 -0
  111. package/dist/render/templates/parallax/session.liquid +295 -0
  112. package/dist/render/templates/parallax/styles.css +1880 -0
  113. package/dist/render/templates/parchment/portfolio.liquid +280 -0
  114. package/dist/render/templates/parchment/project.liquid +289 -0
  115. package/dist/render/templates/parchment/session.liquid +346 -0
  116. package/dist/render/templates/parchment/styles.css +1401 -0
  117. package/dist/render/templates/partials/_beats.liquid +16 -0
  118. package/dist/render/templates/partials/_breadcrumb.liquid +9 -0
  119. package/dist/render/templates/partials/_footer.liquid +7 -0
  120. package/dist/render/templates/partials/_growth-chart.liquid +7 -0
  121. package/dist/render/templates/partials/_key-decisions.liquid +20 -0
  122. package/dist/render/templates/partials/_links.liquid +16 -0
  123. package/dist/render/templates/partials/_narrative.liquid +8 -0
  124. package/dist/render/templates/partials/_phases.liquid +20 -0
  125. package/dist/render/templates/partials/_portfolio-header.liquid +20 -0
  126. package/dist/render/templates/partials/_portfolio-projects.liquid +16 -0
  127. package/dist/render/templates/partials/_portfolio-stats.liquid +19 -0
  128. package/dist/render/templates/partials/_qa.liquid +13 -0
  129. package/dist/render/templates/partials/_screenshot.liquid +15 -0
  130. package/dist/render/templates/partials/_session-cards.liquid +30 -0
  131. package/dist/render/templates/partials/_session-header.liquid +39 -0
  132. package/dist/render/templates/partials/_session-sidebar.liquid +30 -0
  133. package/dist/render/templates/partials/_skills.liquid +12 -0
  134. package/dist/render/templates/partials/_source-breakdown.liquid +22 -0
  135. package/dist/render/templates/partials/_stats.liquid +38 -0
  136. package/dist/render/templates/partials/_work-timeline.liquid +7 -0
  137. package/dist/render/templates/project.liquid +7 -4
  138. package/dist/render/templates/radar/portfolio.liquid +223 -0
  139. package/dist/render/templates/radar/project.liquid +278 -0
  140. package/dist/render/templates/radar/session.liquid +300 -0
  141. package/dist/render/templates/radar/styles.css +1055 -0
  142. package/dist/render/templates/showcase/portfolio.liquid +221 -0
  143. package/dist/render/templates/showcase/project.liquid +237 -0
  144. package/dist/render/templates/showcase/session.liquid +210 -0
  145. package/dist/render/templates/showcase/styles.css +1284 -0
  146. package/dist/render/templates/signal/portfolio.liquid +217 -0
  147. package/dist/render/templates/signal/project.liquid +278 -0
  148. package/dist/render/templates/signal/session.liquid +282 -0
  149. package/dist/render/templates/signal/styles.css +1401 -0
  150. package/dist/render/templates/strata/portfolio.liquid +180 -0
  151. package/dist/render/templates/strata/project.liquid +282 -0
  152. package/dist/render/templates/strata/session.liquid +261 -0
  153. package/dist/render/templates/strata/styles.css +1354 -0
  154. package/dist/render/templates/styles.css +1190 -0
  155. package/dist/render/templates/terminal/portfolio.liquid +102 -0
  156. package/dist/render/templates/terminal/project.liquid +161 -0
  157. package/dist/render/templates/terminal/session.liquid +145 -0
  158. package/dist/render/templates/terminal/styles.css +497 -0
  159. package/dist/render/templates/verdant/portfolio.liquid +321 -0
  160. package/dist/render/templates/verdant/project.liquid +309 -0
  161. package/dist/render/templates/verdant/session.liquid +237 -0
  162. package/dist/render/templates/verdant/styles.css +1261 -0
  163. package/dist/render/templates/zen/portfolio.liquid +124 -0
  164. package/dist/render/templates/zen/project.liquid +187 -0
  165. package/dist/render/templates/zen/session.liquid +203 -0
  166. package/dist/render/templates/zen/styles.css +1211 -0
  167. package/dist/render/templates.js +90 -0
  168. package/dist/routes/auth.js +7 -3
  169. package/dist/routes/context.js +17 -10
  170. package/dist/routes/delete.js +195 -0
  171. package/dist/routes/enhance.js +57 -40
  172. package/dist/routes/export.js +14 -4
  173. package/dist/routes/github.js +254 -0
  174. package/dist/routes/index.js +2 -0
  175. package/dist/routes/portfolio-render-data.js +160 -0
  176. package/dist/routes/preview.js +555 -108
  177. package/dist/routes/projects.js +61 -24
  178. package/dist/routes/publish.js +320 -31
  179. package/dist/routes/settings.js +194 -1
  180. package/dist/routes/sse.js +9 -0
  181. package/dist/search.js +6 -0
  182. package/dist/server.js +11 -3
  183. package/dist/settings.js +112 -9
  184. package/package.json +3 -4
  185. package/dist/public/assets/index-CC9G8EF1.js +0 -21
  186. package/dist/public/assets/index-Dalqz2mC.css +0 -1
@@ -0,0 +1,1407 @@
1
+ /* ── Obsidian template styles ──
2
+ * Extracted from mockup HTML files.
3
+ * Dark theme with purple accent, Space Grotesk display font.
4
+ */
5
+
6
+ body { background: var(--obs-bg); color: var(--obs-text); }
7
+
8
+ /* ── Tokens ── */
9
+ .obsidian {
10
+ --bg: #09090b;
11
+ --surface: #18181b;
12
+ --card: #27272a;
13
+ --fg: #fafafa;
14
+ --fg-muted: #a1a1aa;
15
+ --fg-dim: #71717a;
16
+ --accent: #a855f7;
17
+ --accent-light: #c084fc;
18
+ --accent-dim: rgba(168, 85, 247, 0.15);
19
+ --accent-glow: rgba(168, 85, 247, 0.08);
20
+ --border: #3f3f46;
21
+ --border-hover: #a855f7;
22
+ --radius-sm: 6px;
23
+ --radius: 10px;
24
+ --font-display: 'Space Grotesk', sans-serif;
25
+ --font-body: 'Inter', sans-serif;
26
+ --font-mono: 'JetBrains Mono', monospace;
27
+ /* Agent role colors */
28
+ --color-frontend: #7c3aed;
29
+ --color-backend: #0891b2;
30
+ --color-qa: #059669;
31
+ --color-security: #475569;
32
+ --color-reviewer: #e11d48;
33
+ --color-ux: #d97706;
34
+
35
+ font-family: var(--font-body);
36
+ color: var(--fg);
37
+ background-color: var(--bg);
38
+ line-height: 1.6;
39
+ -webkit-font-smoothing: antialiased;
40
+ }
41
+ .obsidian a { color: inherit; text-decoration: none; }
42
+ .obsidian a:visited { color: inherit; }
43
+ .obsidian a:focus-visible {
44
+ outline: 2px solid var(--accent);
45
+ outline-offset: 2px;
46
+ border-radius: var(--radius-sm);
47
+ }
48
+
49
+ /* ── Skip link ── */
50
+ .obsidian .skip-link {
51
+ position: absolute;
52
+ inset-inline-start: -9999px;
53
+ top: 0;
54
+ background: var(--accent);
55
+ color: var(--bg);
56
+ padding: 8px 16px;
57
+ font-family: var(--font-mono);
58
+ font-size: 13px;
59
+ z-index: 100;
60
+ border-radius: var(--radius-sm);
61
+ }
62
+ .obsidian .skip-link:focus {
63
+ inset-inline-start: 8px;
64
+ top: 8px;
65
+ }
66
+
67
+ /* ── Layout ── */
68
+ .obsidian .container {
69
+ max-width: 960px;
70
+ margin-inline: auto;
71
+ padding-inline: 24px;
72
+ }
73
+
74
+ /* ── Breadcrumb ── */
75
+ .obsidian .breadcrumb {
76
+ padding: 20px 0 0;
77
+ font-family: var(--font-mono);
78
+ font-size: 13px;
79
+ color: var(--fg-dim);
80
+ }
81
+ .obsidian .breadcrumb a {
82
+ color: var(--fg-muted);
83
+ text-decoration: none;
84
+ }
85
+ .obsidian .breadcrumb a:hover { color: var(--accent-light); }
86
+ .obsidian .breadcrumb a:focus-visible {
87
+ outline: 2px solid var(--accent);
88
+ outline-offset: 2px;
89
+ border-radius: var(--radius-sm);
90
+ }
91
+ .obsidian .breadcrumb-sep { margin: 0 8px; color: var(--fg-dim); }
92
+
93
+ /* ── Hero (shared) ── */
94
+ .obsidian .hero h1 {
95
+ font-family: var(--font-display);
96
+ font-weight: 700;
97
+ line-height: 1.15;
98
+ margin-bottom: 12px;
99
+ color: var(--fg);
100
+ }
101
+
102
+ /* ── Hero (portfolio) ── */
103
+ .obsidian .hero--portfolio {
104
+ padding: 72px 0 56px;
105
+ }
106
+ .obsidian .hero--portfolio h1 {
107
+ font-size: clamp(32px, 5vw, 48px);
108
+ }
109
+ .obsidian .hero--portfolio h1 span {
110
+ background: linear-gradient(135deg, var(--accent), var(--accent-light));
111
+ -webkit-background-clip: text;
112
+ -webkit-text-fill-color: transparent;
113
+ background-clip: text;
114
+ }
115
+ .obsidian .hero-bio {
116
+ font-size: 16px;
117
+ color: var(--fg-muted);
118
+ max-width: 600px;
119
+ margin-bottom: 6px;
120
+ line-height: 1.7;
121
+ }
122
+ .obsidian .hero-location {
123
+ font-family: var(--font-mono);
124
+ font-size: 13px;
125
+ color: var(--fg-dim);
126
+ display: flex;
127
+ align-items: center;
128
+ gap: 6px;
129
+ }
130
+ .obsidian .hero-location svg {
131
+ width: 14px; height: 14px;
132
+ stroke: var(--accent);
133
+ fill: none;
134
+ stroke-width: 2;
135
+ }
136
+ .obsidian .hero-row {
137
+ display: flex;
138
+ align-items: flex-start;
139
+ gap: 1.5rem;
140
+ margin-bottom: 1.25rem;
141
+ }
142
+ .obsidian .hero-row-text { flex: 1; min-width: 0; }
143
+ .obsidian .hero-photo {
144
+ width: 140px; height: 170px;
145
+ border-radius: 10px;
146
+ object-fit: cover;
147
+ object-position: center 10%;
148
+ flex-shrink: 0;
149
+ border: 2px solid var(--border);
150
+ transition: box-shadow 0.3s;
151
+ }
152
+ .obsidian .hero-photo:hover {
153
+ box-shadow: 0 0 24px var(--accent-glow);
154
+ border-color: var(--border-hover);
155
+ }
156
+ .obsidian .hero-links {
157
+ display: flex;
158
+ flex-wrap: wrap;
159
+ gap: 1rem;
160
+ margin-block-start: 1.25rem;
161
+ list-style: none;
162
+ }
163
+ .obsidian .hero-links a {
164
+ display: inline-flex;
165
+ align-items: center;
166
+ gap: 0.375rem;
167
+ font-family: var(--font-mono);
168
+ font-size: 13px;
169
+ color: var(--fg-muted);
170
+ text-decoration: none;
171
+ transition: color 0.15s;
172
+ }
173
+ .obsidian .hero-links a:hover { color: var(--accent-light); }
174
+ .obsidian .hero-links svg { flex-shrink: 0; }
175
+
176
+ /* ── Hero (project) ── */
177
+ .obsidian .hero--project {
178
+ padding: 48px 0 40px;
179
+ }
180
+ .obsidian .hero--project h1 {
181
+ font-size: clamp(28px, 5vw, 42px);
182
+ }
183
+ .obsidian .hero--project .hero-links {
184
+ display: flex;
185
+ gap: 16px;
186
+ margin-bottom: 16px;
187
+ }
188
+ .obsidian .hero--project .hero-links a {
189
+ font-family: var(--font-mono);
190
+ font-size: 13px;
191
+ color: var(--accent-light);
192
+ text-decoration: none;
193
+ display: flex;
194
+ align-items: center;
195
+ gap: 6px;
196
+ }
197
+ .obsidian .hero--project .hero-links a:hover { text-decoration: underline; }
198
+ .obsidian .hero--project .hero-links a:focus-visible {
199
+ outline: 2px solid var(--accent);
200
+ outline-offset: 2px;
201
+ border-radius: var(--radius-sm);
202
+ }
203
+ .obsidian .hero--project .hero-links svg {
204
+ width: 14px; height: 14px;
205
+ stroke: var(--accent);
206
+ fill: none;
207
+ stroke-width: 2;
208
+ }
209
+
210
+ /* ── Hero (session) ── */
211
+ .obsidian .hero--session {
212
+ padding: 48px 0 40px;
213
+ }
214
+ .obsidian .hero--session h1 {
215
+ font-size: clamp(24px, 4vw, 36px);
216
+ line-height: 1.2;
217
+ margin-bottom: 16px;
218
+ }
219
+ .obsidian .hero-meta {
220
+ display: flex;
221
+ flex-wrap: wrap;
222
+ gap: 20px;
223
+ font-family: var(--font-mono);
224
+ font-size: 13px;
225
+ color: var(--fg-dim);
226
+ margin-bottom: 12px;
227
+ }
228
+ .obsidian .hero-meta-item {
229
+ display: flex;
230
+ align-items: center;
231
+ gap: 6px;
232
+ }
233
+ .obsidian .hero-meta-item svg {
234
+ width: 14px; height: 14px;
235
+ stroke: var(--accent);
236
+ fill: none;
237
+ stroke-width: 2;
238
+ }
239
+ .obsidian .source-badge {
240
+ display: inline-flex;
241
+ align-items: center;
242
+ gap: 6px;
243
+ font-family: var(--font-mono);
244
+ font-size: 12px;
245
+ padding: 4px 12px;
246
+ border-radius: var(--radius-sm);
247
+ background: var(--accent-dim);
248
+ color: var(--accent-light);
249
+ }
250
+
251
+ /* ── Screenshot ── */
252
+ .obsidian .screenshot {
253
+ background: var(--surface);
254
+ border: 1px solid var(--border);
255
+ border-radius: var(--radius);
256
+ overflow: hidden;
257
+ margin-bottom: 48px;
258
+ }
259
+ .obsidian .screenshot-chrome {
260
+ background: var(--card);
261
+ padding: 10px 16px;
262
+ display: flex;
263
+ align-items: center;
264
+ gap: 8px;
265
+ }
266
+ .obsidian .chrome-dot {
267
+ width: 10px; height: 10px;
268
+ border-radius: 50%;
269
+ background: var(--border);
270
+ }
271
+ .obsidian .chrome-dot:nth-child(1) { background: #f87171; }
272
+ .obsidian .chrome-dot:nth-child(2) { background: #fbbf24; }
273
+ .obsidian .chrome-dot:nth-child(3) { background: #34d399; }
274
+ .obsidian .chrome-bar {
275
+ flex: 1;
276
+ margin-inline-start: 8px;
277
+ height: 24px;
278
+ background: var(--surface);
279
+ border-radius: var(--radius-sm);
280
+ font-family: var(--font-mono);
281
+ font-size: 11px;
282
+ color: var(--fg-dim);
283
+ display: flex;
284
+ align-items: center;
285
+ padding-inline-start: 12px;
286
+ }
287
+ .obsidian .screenshot img {
288
+ width: 100%;
289
+ display: block;
290
+ }
291
+ .obsidian .screenshot-body {
292
+ height: 240px;
293
+ background: linear-gradient(135deg, var(--accent-dim) 0%, var(--surface) 50%, var(--accent-glow) 100%);
294
+ }
295
+
296
+ /* ── Stats grid ── */
297
+ .obsidian .stats-grid {
298
+ display: grid;
299
+ grid-template-columns: repeat(4, 1fr);
300
+ gap: 16px;
301
+ margin: 0 0 56px;
302
+ }
303
+ .obsidian .stats-grid--project {
304
+ grid-template-columns: repeat(6, 1fr);
305
+ gap: 12px;
306
+ margin-bottom: 48px;
307
+ }
308
+ .obsidian .stat-card {
309
+ background: var(--surface);
310
+ border: 1px solid var(--border);
311
+ border-radius: var(--radius);
312
+ padding: 24px 20px;
313
+ text-align: center;
314
+ transition: border-color 0.3s, box-shadow 0.3s;
315
+ }
316
+ .obsidian .stat-card:hover {
317
+ border-color: var(--border-hover);
318
+ box-shadow: 0 0 24px var(--accent-glow);
319
+ }
320
+ .obsidian .stat-value {
321
+ font-family: var(--font-display);
322
+ font-size: clamp(28px, 4vw, 40px);
323
+ font-weight: 700;
324
+ color: var(--accent);
325
+ line-height: 1.2;
326
+ margin-bottom: 4px;
327
+ }
328
+ .obsidian .stat-label {
329
+ font-family: var(--font-mono);
330
+ font-size: 11px;
331
+ text-transform: uppercase;
332
+ letter-spacing: 0.08em;
333
+ color: var(--fg-dim);
334
+ }
335
+ /* Project stat overrides */
336
+ .obsidian.heyiam-project .stat-card {
337
+ padding: 20px 12px;
338
+ }
339
+ .obsidian.heyiam-project .stat-value {
340
+ font-size: clamp(20px, 3vw, 28px);
341
+ }
342
+ .obsidian.heyiam-project .stat-label {
343
+ font-size: 10px;
344
+ }
345
+ .obsidian .stat-card--leverage {
346
+ grid-column: span 2;
347
+ }
348
+ .obsidian .leverage-row {
349
+ display: flex;
350
+ justify-content: space-evenly;
351
+ gap: 1rem;
352
+ margin-bottom: 0.75rem;
353
+ }
354
+ .obsidian .leverage-cell { text-align: center; }
355
+ .obsidian .leverage-cell__value {
356
+ font-family: var(--font-display);
357
+ font-size: clamp(20px, 3vw, 28px);
358
+ font-weight: 700;
359
+ color: var(--fg);
360
+ line-height: 1.2;
361
+ margin-bottom: 4px;
362
+ }
363
+ .obsidian .leverage-cell__value--accent { color: var(--accent); }
364
+ .obsidian .leverage-cell__label {
365
+ font-family: var(--font-mono);
366
+ font-size: 10px;
367
+ color: var(--fg-dim);
368
+ text-transform: uppercase;
369
+ letter-spacing: 0.06em;
370
+ }
371
+ .obsidian .leverage-rule {
372
+ height: 1px;
373
+ background: var(--border);
374
+ margin-top: 0.5rem;
375
+ }
376
+
377
+ /* ── Section heading ── */
378
+ .obsidian .section-heading {
379
+ font-family: var(--font-display);
380
+ font-size: 24px;
381
+ font-weight: 700;
382
+ margin-bottom: 32px;
383
+ display: flex;
384
+ align-items: center;
385
+ gap: 12px;
386
+ }
387
+ .obsidian .section-heading::before {
388
+ content: '';
389
+ width: 4px;
390
+ height: 24px;
391
+ background: linear-gradient(180deg, var(--accent), var(--accent-light));
392
+ border-radius: 2px;
393
+ flex-shrink: 0;
394
+ }
395
+ .obsidian.heyiam-project .section-heading,
396
+ .obsidian.heyiam-session .section-heading {
397
+ font-size: 22px;
398
+ margin-bottom: 24px;
399
+ gap: 12px;
400
+ }
401
+ .obsidian.heyiam-project .section-heading::before,
402
+ .obsidian.heyiam-session .section-heading::before {
403
+ height: 22px;
404
+ }
405
+ /* Session section-heading is smaller */
406
+ .obsidian.heyiam-session .section-heading {
407
+ font-size: 20px;
408
+ margin-bottom: 20px;
409
+ gap: 10px;
410
+ }
411
+ .obsidian.heyiam-session .section-heading::before {
412
+ width: 3px;
413
+ height: 20px;
414
+ }
415
+
416
+ /* ── Narrative ── */
417
+ .obsidian .narrative {
418
+ margin-bottom: 48px;
419
+ }
420
+ .obsidian .narrative p {
421
+ font-size: 15px;
422
+ color: var(--fg-muted);
423
+ line-height: 1.8;
424
+ margin-bottom: 16px;
425
+ }
426
+ .obsidian .narrative p:last-child { margin-bottom: 0; }
427
+
428
+ /* ── Dev take ── */
429
+ .obsidian .dev-take {
430
+ background: var(--surface);
431
+ border: 1px solid var(--border);
432
+ border-inline-start: 3px solid var(--accent);
433
+ border-radius: var(--radius);
434
+ padding: 20px 24px;
435
+ margin-bottom: 48px;
436
+ }
437
+ .obsidian .dev-take-label {
438
+ font-family: var(--font-mono);
439
+ font-size: 11px;
440
+ text-transform: uppercase;
441
+ letter-spacing: 0.08em;
442
+ color: var(--accent-light);
443
+ margin-bottom: 8px;
444
+ }
445
+ .obsidian .dev-take p {
446
+ font-size: 15px;
447
+ color: var(--fg-muted);
448
+ line-height: 1.7;
449
+ font-style: italic;
450
+ }
451
+
452
+ /* ── Two-column layout ── */
453
+ .obsidian .content-grid {
454
+ display: grid;
455
+ grid-template-columns: 1fr 300px;
456
+ gap: 32px;
457
+ margin-bottom: 48px;
458
+ }
459
+
460
+ /* ── Execution Path (Beats) ── */
461
+ .obsidian .beats {
462
+ margin-bottom: 48px;
463
+ }
464
+ .obsidian .beat-list {
465
+ list-style: none;
466
+ position: relative;
467
+ padding-inline-start: 28px;
468
+ }
469
+ .obsidian .beat-list::before {
470
+ content: '';
471
+ position: absolute;
472
+ inset-inline-start: 8px;
473
+ top: 4px; bottom: 4px;
474
+ width: 2px;
475
+ background: linear-gradient(180deg, var(--accent), var(--accent-light), var(--accent));
476
+ border-radius: 1px;
477
+ }
478
+ .obsidian .beat-item {
479
+ position: relative;
480
+ padding-bottom: 24px;
481
+ }
482
+ .obsidian .beat-item:last-child { padding-bottom: 0; }
483
+ .obsidian .beat-dot {
484
+ position: absolute;
485
+ inset-inline-start: -24px;
486
+ top: 4px;
487
+ width: 12px; height: 12px;
488
+ border-radius: 50%;
489
+ background: var(--accent);
490
+ border: 2px solid var(--bg);
491
+ box-shadow: 0 0 0 2px var(--accent);
492
+ }
493
+ .obsidian .beat-title {
494
+ font-family: var(--font-display);
495
+ font-size: 15px;
496
+ font-weight: 600;
497
+ margin-bottom: 4px;
498
+ }
499
+ .obsidian .beat-desc {
500
+ font-size: 14px;
501
+ color: var(--fg-muted);
502
+ line-height: 1.7;
503
+ }
504
+
505
+ /* ── Sidebar ── */
506
+ .obsidian .sidebar {
507
+ display: flex;
508
+ flex-direction: column;
509
+ gap: 24px;
510
+ }
511
+ .obsidian .sidebar-card {
512
+ background: var(--surface);
513
+ border: 1px solid var(--border);
514
+ border-radius: var(--radius);
515
+ padding: 24px;
516
+ }
517
+ .obsidian .sidebar-title {
518
+ font-family: var(--font-mono);
519
+ font-size: 11px;
520
+ text-transform: uppercase;
521
+ letter-spacing: 0.08em;
522
+ color: var(--fg-dim);
523
+ margin-bottom: 16px;
524
+ }
525
+
526
+ /* Tools table */
527
+ .obsidian .tools-table { width: 100%; font-size: 13px; }
528
+ .obsidian .tools-row {
529
+ display: flex;
530
+ justify-content: space-between;
531
+ padding: 8px 0;
532
+ border-bottom: 1px solid rgba(63, 63, 70, 0.5);
533
+ }
534
+ .obsidian .tools-row:last-child { border-bottom: none; }
535
+ .obsidian .tools-name {
536
+ font-family: var(--font-mono);
537
+ color: var(--fg-muted);
538
+ }
539
+ .obsidian .tools-count {
540
+ font-family: var(--font-mono);
541
+ color: var(--accent-light);
542
+ font-weight: 500;
543
+ }
544
+ .obsidian .tools-bar {
545
+ width: 60px; height: 4px;
546
+ background: var(--card);
547
+ border-radius: 2px;
548
+ overflow: hidden;
549
+ display: inline-flex;
550
+ vertical-align: middle;
551
+ margin-inline-start: 8px;
552
+ }
553
+ .obsidian .tools-bar-fill {
554
+ height: 100%;
555
+ background: var(--accent);
556
+ border-radius: 2px;
557
+ }
558
+
559
+ /* Files table */
560
+ .obsidian .files-table { width: 100%; font-size: 12px; }
561
+ .obsidian .files-row {
562
+ display: flex;
563
+ justify-content: space-between;
564
+ align-items: center;
565
+ padding: 8px 0;
566
+ border-bottom: 1px solid rgba(63, 63, 70, 0.5);
567
+ gap: 8px;
568
+ }
569
+ .obsidian .files-row:last-child { border-bottom: none; }
570
+ .obsidian .files-name {
571
+ font-family: var(--font-mono);
572
+ color: var(--fg-muted);
573
+ white-space: nowrap;
574
+ overflow: hidden;
575
+ text-overflow: ellipsis;
576
+ min-width: 0;
577
+ }
578
+ .obsidian .files-diff {
579
+ font-family: var(--font-mono);
580
+ white-space: nowrap;
581
+ flex-shrink: 0;
582
+ }
583
+ .obsidian .files-diff--add { color: #34d399; }
584
+ .obsidian .files-diff--del { color: #f87171; }
585
+
586
+ /* Sidebar skills */
587
+ .obsidian .sidebar-skills {
588
+ display: flex;
589
+ flex-wrap: wrap;
590
+ gap: 6px;
591
+ }
592
+ .obsidian .sidebar-skill-tag {
593
+ font-family: var(--font-mono);
594
+ font-size: 11px;
595
+ padding: 3px 8px;
596
+ border-radius: var(--radius-sm);
597
+ background: var(--accent-dim);
598
+ color: var(--accent-light);
599
+ white-space: nowrap;
600
+ }
601
+
602
+ /* ── Q&A ── */
603
+ .obsidian .qa-section { margin-bottom: 48px; }
604
+ .obsidian .qa-list {
605
+ display: flex;
606
+ flex-direction: column;
607
+ gap: 20px;
608
+ }
609
+ .obsidian .qa-item {
610
+ background: var(--surface);
611
+ border: 1px solid var(--border);
612
+ border-radius: var(--radius);
613
+ padding: 24px;
614
+ transition: border-color 0.3s;
615
+ }
616
+ .obsidian .qa-item:hover { border-color: var(--border-hover); }
617
+ .obsidian .qa-question {
618
+ font-family: var(--font-display);
619
+ font-size: 15px;
620
+ font-weight: 600;
621
+ margin-bottom: 12px;
622
+ display: flex;
623
+ gap: 8px;
624
+ }
625
+ .obsidian .qa-label {
626
+ font-family: var(--font-mono);
627
+ font-size: 11px;
628
+ font-weight: 600;
629
+ padding: 2px 6px;
630
+ border-radius: 3px;
631
+ flex-shrink: 0;
632
+ line-height: 1.4;
633
+ }
634
+ .obsidian .qa-label--q {
635
+ background: var(--accent-dim);
636
+ color: var(--accent-light);
637
+ }
638
+ .obsidian .qa-label--a {
639
+ background: rgba(52, 211, 153, 0.15);
640
+ color: #6ee7b7;
641
+ }
642
+ .obsidian .qa-answer {
643
+ font-size: 14px;
644
+ color: var(--fg-muted);
645
+ line-height: 1.7;
646
+ display: flex;
647
+ gap: 8px;
648
+ }
649
+
650
+ /* ── Agent Summary ── */
651
+ .obsidian .agents-section { margin-bottom: 48px; }
652
+ .obsidian .agent-list {
653
+ display: flex;
654
+ flex-direction: column;
655
+ gap: 12px;
656
+ }
657
+ .obsidian .agent-row {
658
+ background: var(--surface);
659
+ border: 1px solid var(--border);
660
+ border-radius: var(--radius);
661
+ padding: 16px 20px;
662
+ display: grid;
663
+ grid-template-columns: auto 1fr auto auto;
664
+ gap: 16px;
665
+ align-items: center;
666
+ transition: border-color 0.3s;
667
+ }
668
+ .obsidian .agent-row:hover { border-color: var(--border-hover); }
669
+ .obsidian .agent-dot {
670
+ width: 10px; height: 10px;
671
+ border-radius: 50%;
672
+ flex-shrink: 0;
673
+ }
674
+ .obsidian .agent-name {
675
+ font-family: var(--font-display);
676
+ font-size: 14px;
677
+ font-weight: 600;
678
+ }
679
+ .obsidian .agent-duration {
680
+ font-family: var(--font-mono);
681
+ font-size: 13px;
682
+ color: var(--fg-dim);
683
+ text-align: end;
684
+ }
685
+ .obsidian .agent-loc {
686
+ font-family: var(--font-mono);
687
+ font-size: 13px;
688
+ color: var(--accent-light);
689
+ text-align: end;
690
+ min-width: 60px;
691
+ }
692
+ .obsidian .agent-chart {
693
+ background: var(--surface);
694
+ border: 1px solid var(--border);
695
+ border-radius: var(--radius);
696
+ padding: 24px;
697
+ margin-bottom: 16px;
698
+ }
699
+ .obsidian .agent-chart-title {
700
+ font-family: var(--font-mono);
701
+ font-size: 11px;
702
+ text-transform: uppercase;
703
+ letter-spacing: 0.08em;
704
+ color: var(--fg-dim);
705
+ margin-bottom: 20px;
706
+ }
707
+ .obsidian .agent-bar-row {
708
+ display: flex;
709
+ align-items: center;
710
+ gap: 12px;
711
+ margin-bottom: 12px;
712
+ }
713
+ .obsidian .agent-bar-row:last-child { margin-bottom: 0; }
714
+ .obsidian .agent-bar-label {
715
+ font-family: var(--font-mono);
716
+ font-size: 12px;
717
+ color: var(--fg-muted);
718
+ width: 100px;
719
+ text-align: end;
720
+ flex-shrink: 0;
721
+ }
722
+ .obsidian .agent-bar-track {
723
+ flex: 1; height: 8px;
724
+ background: var(--card);
725
+ border-radius: 4px;
726
+ overflow: hidden;
727
+ }
728
+ .obsidian .agent-bar-fill {
729
+ height: 100%;
730
+ border-radius: 4px;
731
+ transition: width 0.6s ease;
732
+ }
733
+ .obsidian .agent-bar-value {
734
+ font-family: var(--font-mono);
735
+ font-size: 12px;
736
+ color: var(--fg-dim);
737
+ width: 40px;
738
+ flex-shrink: 0;
739
+ }
740
+
741
+ /* ── Project cards (portfolio) ── */
742
+ .obsidian .projects-list {
743
+ display: flex;
744
+ flex-direction: column;
745
+ gap: 24px;
746
+ padding-bottom: 80px;
747
+ }
748
+ .obsidian .project-card {
749
+ background: var(--surface);
750
+ border: 1px solid var(--border);
751
+ border-radius: var(--radius);
752
+ padding: 32px;
753
+ text-decoration: none;
754
+ color: inherit;
755
+ display: block;
756
+ position: relative;
757
+ overflow: hidden;
758
+ transition: border-color 0.3s, box-shadow 0.3s;
759
+ background-image: linear-gradient(135deg, transparent 0%, transparent 40%, var(--accent-glow) 50%, transparent 60%, transparent 100%);
760
+ background-size: 300% 300%;
761
+ background-position: 100% 100%;
762
+ }
763
+ .obsidian .project-card:hover {
764
+ border-color: var(--border-hover);
765
+ box-shadow: 0 4px 32px var(--accent-glow);
766
+ background-position: 0% 0%;
767
+ }
768
+ .obsidian .project-card:focus-visible {
769
+ outline: 2px solid var(--accent);
770
+ outline-offset: 2px;
771
+ }
772
+ .obsidian .project-header {
773
+ display: flex;
774
+ align-items: baseline;
775
+ justify-content: space-between;
776
+ margin-bottom: 12px;
777
+ flex-wrap: wrap;
778
+ gap: 8px;
779
+ }
780
+ .obsidian .project-name {
781
+ font-family: var(--font-display);
782
+ font-size: 22px;
783
+ font-weight: 700;
784
+ color: var(--fg);
785
+ }
786
+ .obsidian .project-meta {
787
+ font-family: var(--font-mono);
788
+ font-size: 12px;
789
+ color: var(--fg-dim);
790
+ display: flex;
791
+ gap: 16px;
792
+ }
793
+ .obsidian .project-meta span { white-space: nowrap; }
794
+ .obsidian .project-narrative {
795
+ font-size: 15px;
796
+ color: var(--fg-muted);
797
+ margin-bottom: 20px;
798
+ line-height: 1.7;
799
+ }
800
+ .obsidian .project-skills {
801
+ display: flex;
802
+ flex-wrap: wrap;
803
+ gap: 8px;
804
+ margin-bottom: 20px;
805
+ }
806
+ .obsidian .skill-tag {
807
+ font-family: var(--font-mono);
808
+ font-size: 12px;
809
+ padding: 4px 10px;
810
+ border-radius: var(--radius-sm);
811
+ background: var(--accent-dim);
812
+ color: var(--accent-light);
813
+ white-space: nowrap;
814
+ }
815
+ .obsidian .project-footer {
816
+ display: flex;
817
+ align-items: center;
818
+ justify-content: space-between;
819
+ flex-wrap: wrap;
820
+ gap: 12px;
821
+ }
822
+ .obsidian .project-arrow {
823
+ color: var(--accent);
824
+ font-size: 18px;
825
+ transition: transform 0.2s;
826
+ }
827
+ .obsidian .project-card:hover .project-arrow {
828
+ transform: translateX(4px);
829
+ }
830
+
831
+ /* ── Phases ── */
832
+ .obsidian .phases { margin-bottom: 48px; }
833
+ .obsidian .phase-list {
834
+ list-style: none;
835
+ position: relative;
836
+ padding-inline-start: 28px;
837
+ }
838
+ .obsidian .phase-list::before {
839
+ content: '';
840
+ position: absolute;
841
+ inset-inline-start: 8px;
842
+ top: 4px; bottom: 4px;
843
+ width: 3px;
844
+ background: linear-gradient(180deg, var(--accent), var(--accent-light), var(--accent));
845
+ border-radius: 2px;
846
+ }
847
+ .obsidian .phase-item {
848
+ position: relative;
849
+ padding-bottom: 28px;
850
+ }
851
+ .obsidian .phase-item:last-child { padding-bottom: 0; }
852
+ .obsidian .phase-dot {
853
+ position: absolute;
854
+ inset-inline-start: -24px;
855
+ top: 4px;
856
+ width: 14px; height: 14px;
857
+ border-radius: 50%;
858
+ background: var(--accent);
859
+ border: 3px solid var(--bg);
860
+ box-shadow: 0 0 0 2px var(--accent);
861
+ }
862
+ .obsidian .phase-title {
863
+ font-family: var(--font-display);
864
+ font-size: 16px;
865
+ font-weight: 600;
866
+ margin-bottom: 4px;
867
+ }
868
+ .obsidian .phase-dates {
869
+ font-family: var(--font-mono);
870
+ font-size: 12px;
871
+ color: var(--fg-dim);
872
+ margin-bottom: 4px;
873
+ }
874
+ .obsidian .phase-desc {
875
+ font-size: 14px;
876
+ color: var(--fg-muted);
877
+ }
878
+
879
+ /* ── Key Decisions ── */
880
+ .obsidian .decisions { margin-bottom: 48px; }
881
+ .obsidian .decision-list {
882
+ list-style: none;
883
+ display: flex;
884
+ flex-direction: column;
885
+ gap: 12px;
886
+ }
887
+ .obsidian .decision-item {
888
+ background: var(--surface);
889
+ border: 1px solid var(--border);
890
+ border-radius: var(--radius);
891
+ padding: 20px 24px;
892
+ display: flex;
893
+ gap: 16px;
894
+ align-items: flex-start;
895
+ transition: border-color 0.3s;
896
+ }
897
+ .obsidian .decision-item:hover { border-color: var(--border-hover); }
898
+ .obsidian .decision-num {
899
+ font-family: var(--font-display);
900
+ font-size: 24px;
901
+ font-weight: 700;
902
+ color: var(--accent);
903
+ line-height: 1;
904
+ flex-shrink: 0;
905
+ width: 32px;
906
+ }
907
+ .obsidian .decision-text {
908
+ font-size: 14px;
909
+ color: var(--fg-muted);
910
+ line-height: 1.6;
911
+ }
912
+
913
+ /* ── Skills section ── */
914
+ .obsidian .skills-section { margin-bottom: 48px; }
915
+ .obsidian .skills-grid {
916
+ display: flex;
917
+ flex-wrap: wrap;
918
+ gap: 10px;
919
+ }
920
+
921
+ /* ── Source breakdown ── */
922
+ .obsidian .source-section { margin-bottom: 48px; }
923
+ .obsidian .source-breakdown {
924
+ background: var(--surface);
925
+ border: 1px solid var(--border);
926
+ border-radius: var(--radius);
927
+ padding: 28px 32px;
928
+ }
929
+ .obsidian .source-header {
930
+ display: flex;
931
+ justify-content: space-between;
932
+ margin-bottom: 16px;
933
+ font-family: var(--font-mono);
934
+ font-size: 13px;
935
+ }
936
+ .obsidian .source-header span:first-child { color: var(--accent-light); }
937
+ .obsidian .source-header span:last-child { color: var(--fg-dim); }
938
+ .obsidian .source-track-lg {
939
+ width: 100%; height: 8px;
940
+ background: var(--card);
941
+ border-radius: 4px;
942
+ overflow: hidden;
943
+ display: flex;
944
+ }
945
+ .obsidian .source-fill-lg {
946
+ height: 100%;
947
+ background: linear-gradient(90deg, var(--accent), var(--accent-light));
948
+ border-radius: 4px;
949
+ }
950
+
951
+ /* ── Work timeline chart ── */
952
+ .obsidian .timeline-chart {
953
+ background: var(--surface);
954
+ border: 1px solid var(--border);
955
+ border-radius: var(--radius);
956
+ padding: 32px;
957
+ margin-bottom: 48px;
958
+ }
959
+ .obsidian .chart-title {
960
+ font-family: var(--font-mono);
961
+ font-size: 12px;
962
+ text-transform: uppercase;
963
+ letter-spacing: 0.08em;
964
+ color: var(--fg-dim);
965
+ margin-bottom: 24px;
966
+ }
967
+ .obsidian .chart-area {
968
+ position: relative;
969
+ height: 200px;
970
+ }
971
+ .obsidian .chart-svg {
972
+ width: 100%;
973
+ height: 100%;
974
+ }
975
+ .obsidian .chart-grid-line {
976
+ stroke: var(--border);
977
+ stroke-width: 0.5;
978
+ }
979
+ .obsidian .chart-line {
980
+ fill: none;
981
+ stroke: var(--accent);
982
+ stroke-width: 2;
983
+ stroke-linecap: round;
984
+ stroke-linejoin: round;
985
+ }
986
+ .obsidian .chart-area-fill {
987
+ fill: url(#purpleGradient);
988
+ }
989
+ .obsidian .chart-dot {
990
+ fill: var(--accent);
991
+ stroke: var(--bg);
992
+ stroke-width: 2;
993
+ }
994
+ .obsidian .chart-labels {
995
+ display: flex;
996
+ justify-content: space-between;
997
+ margin-top: 12px;
998
+ font-family: var(--font-mono);
999
+ font-size: 11px;
1000
+ color: var(--fg-dim);
1001
+ }
1002
+ .obsidian .source-detail {
1003
+ display: flex;
1004
+ justify-content: space-between;
1005
+ margin-top: 12px;
1006
+ font-family: var(--font-mono);
1007
+ font-size: 12px;
1008
+ color: var(--fg-dim);
1009
+ }
1010
+
1011
+ /* ── Session cards (project) ── */
1012
+ .obsidian .sessions-section { margin-bottom: 48px; }
1013
+ .obsidian .session-list {
1014
+ display: flex;
1015
+ flex-direction: column;
1016
+ gap: 12px;
1017
+ }
1018
+ .obsidian .session-card {
1019
+ background: var(--surface);
1020
+ border: 1px solid var(--border);
1021
+ border-radius: var(--radius);
1022
+ padding: 20px 24px;
1023
+ text-decoration: none;
1024
+ color: inherit;
1025
+ display: grid;
1026
+ grid-template-columns: auto 1fr auto;
1027
+ gap: 16px;
1028
+ align-items: center;
1029
+ transition: border-color 0.3s, box-shadow 0.3s;
1030
+ background-image: linear-gradient(135deg, transparent 0%, transparent 40%, var(--accent-glow) 50%, transparent 60%, transparent 100%);
1031
+ background-size: 300% 300%;
1032
+ background-position: 100% 100%;
1033
+ }
1034
+ .obsidian .session-card:hover {
1035
+ border-color: var(--border-hover);
1036
+ box-shadow: 0 2px 24px var(--accent-glow);
1037
+ background-position: 0% 0%;
1038
+ }
1039
+ .obsidian .session-card:focus-visible {
1040
+ outline: 2px solid var(--accent);
1041
+ outline-offset: 2px;
1042
+ }
1043
+ .obsidian .session-num {
1044
+ font-family: var(--font-display);
1045
+ font-size: 20px;
1046
+ font-weight: 700;
1047
+ color: var(--accent);
1048
+ width: 28px;
1049
+ text-align: center;
1050
+ }
1051
+ .obsidian .session-info { min-width: 0; }
1052
+ .obsidian .session-title {
1053
+ font-family: var(--font-display);
1054
+ font-size: 15px;
1055
+ font-weight: 600;
1056
+ margin-bottom: 4px;
1057
+ white-space: nowrap;
1058
+ overflow: hidden;
1059
+ text-overflow: ellipsis;
1060
+ }
1061
+ .obsidian .session-meta {
1062
+ font-family: var(--font-mono);
1063
+ font-size: 12px;
1064
+ color: var(--fg-dim);
1065
+ display: flex;
1066
+ gap: 12px;
1067
+ flex-wrap: wrap;
1068
+ }
1069
+ .obsidian .session-tag {
1070
+ font-family: var(--font-mono);
1071
+ font-size: 11px;
1072
+ padding: 3px 8px;
1073
+ border-radius: var(--radius-sm);
1074
+ background: var(--accent-dim);
1075
+ color: var(--accent-light);
1076
+ white-space: nowrap;
1077
+ }
1078
+
1079
+ /* ── Source bar (portfolio project cards) ── */
1080
+ .obsidian .source-bar {
1081
+ display: flex;
1082
+ align-items: center;
1083
+ gap: 8px;
1084
+ font-family: var(--font-mono);
1085
+ font-size: 12px;
1086
+ color: var(--fg-dim);
1087
+ }
1088
+ .obsidian .source-track {
1089
+ width: 120px;
1090
+ height: 4px;
1091
+ background: var(--card);
1092
+ border-radius: 2px;
1093
+ overflow: hidden;
1094
+ display: flex;
1095
+ }
1096
+ .obsidian .source-fill {
1097
+ height: 100%;
1098
+ background: var(--accent);
1099
+ border-radius: 2px;
1100
+ }
1101
+
1102
+ /* ── Project skill-tag override ── */
1103
+ .obsidian.heyiam-project .skills-grid .skill-tag {
1104
+ font-size: 13px;
1105
+ padding: 6px 14px;
1106
+ }
1107
+
1108
+ /* ── Skills overview (portfolio) ── */
1109
+ .obsidian .skills-overview {
1110
+ background: var(--surface);
1111
+ border: 1px solid var(--border);
1112
+ border-radius: var(--radius);
1113
+ padding: 32px;
1114
+ margin-bottom: 56px;
1115
+ }
1116
+ .obsidian .skills-chart {
1117
+ margin-bottom: 24px;
1118
+ }
1119
+ .obsidian .skills-chart-title {
1120
+ font-family: var(--font-mono);
1121
+ font-size: 12px;
1122
+ text-transform: uppercase;
1123
+ letter-spacing: 0.08em;
1124
+ color: var(--fg-dim);
1125
+ margin-bottom: 20px;
1126
+ }
1127
+ .obsidian .skills-bar-list {
1128
+ display: flex;
1129
+ flex-direction: column;
1130
+ gap: 12px;
1131
+ }
1132
+ .obsidian .skills-bar-row {
1133
+ display: flex;
1134
+ align-items: center;
1135
+ gap: 12px;
1136
+ }
1137
+ .obsidian .skills-bar-label {
1138
+ font-family: var(--font-mono);
1139
+ font-size: 13px;
1140
+ color: var(--fg-muted);
1141
+ width: 100px;
1142
+ text-align: end;
1143
+ flex-shrink: 0;
1144
+ }
1145
+ .obsidian .skills-bar-track {
1146
+ flex: 1;
1147
+ height: 6px;
1148
+ background: var(--card);
1149
+ border-radius: 3px;
1150
+ overflow: hidden;
1151
+ }
1152
+ .obsidian .skills-bar-fill {
1153
+ height: 100%;
1154
+ background: linear-gradient(90deg, var(--accent), var(--accent-light));
1155
+ border-radius: 3px;
1156
+ }
1157
+ .obsidian .skills-bar-value {
1158
+ font-family: var(--font-mono);
1159
+ font-size: 12px;
1160
+ color: var(--fg-dim);
1161
+ width: 80px;
1162
+ flex-shrink: 0;
1163
+ }
1164
+ .obsidian .skills-tags {
1165
+ display: flex;
1166
+ flex-wrap: wrap;
1167
+ gap: 8px;
1168
+ padding-top: 16px;
1169
+ border-top: 1px solid var(--border);
1170
+ }
1171
+
1172
+ /* ── Activity section (portfolio) ── */
1173
+ .obsidian .activity-section {
1174
+ padding-bottom: 64px;
1175
+ }
1176
+ .obsidian .activity-grid {
1177
+ display: grid;
1178
+ grid-template-columns: 1fr 1fr;
1179
+ gap: 20px;
1180
+ }
1181
+ .obsidian .activity-card {
1182
+ background: var(--surface);
1183
+ border: 1px solid var(--border);
1184
+ border-radius: var(--radius);
1185
+ padding: 28px;
1186
+ }
1187
+ .obsidian .activity-chart-title {
1188
+ font-family: var(--font-mono);
1189
+ font-size: 12px;
1190
+ text-transform: uppercase;
1191
+ letter-spacing: 0.08em;
1192
+ color: var(--fg-dim);
1193
+ margin-bottom: 20px;
1194
+ }
1195
+ .obsidian .source-ring {
1196
+ position: relative;
1197
+ width: 120px;
1198
+ height: 120px;
1199
+ margin: 0 auto 20px;
1200
+ }
1201
+ .obsidian .ring-svg {
1202
+ width: 100%;
1203
+ height: 100%;
1204
+ }
1205
+ .obsidian .ring-label {
1206
+ position: absolute;
1207
+ top: 50%;
1208
+ left: 50%;
1209
+ transform: translate(-50%, -50%);
1210
+ text-align: center;
1211
+ }
1212
+ .obsidian .ring-value {
1213
+ display: block;
1214
+ font-family: var(--font-display);
1215
+ font-size: 22px;
1216
+ font-weight: 700;
1217
+ color: var(--accent);
1218
+ }
1219
+ .obsidian .ring-sub {
1220
+ font-family: var(--font-mono);
1221
+ font-size: 11px;
1222
+ color: var(--fg-dim);
1223
+ }
1224
+ .obsidian .source-legend {
1225
+ display: flex;
1226
+ flex-direction: column;
1227
+ gap: 8px;
1228
+ }
1229
+ .obsidian .legend-item {
1230
+ display: flex;
1231
+ align-items: center;
1232
+ gap: 8px;
1233
+ font-family: var(--font-mono);
1234
+ font-size: 13px;
1235
+ }
1236
+ .obsidian .legend-dot {
1237
+ width: 8px;
1238
+ height: 8px;
1239
+ border-radius: 50%;
1240
+ flex-shrink: 0;
1241
+ }
1242
+ .obsidian .legend-label {
1243
+ color: var(--fg-muted);
1244
+ flex: 1;
1245
+ }
1246
+ .obsidian .legend-value {
1247
+ color: var(--fg-dim);
1248
+ }
1249
+ .obsidian .recent-list {
1250
+ display: flex;
1251
+ flex-direction: column;
1252
+ gap: 0;
1253
+ }
1254
+ .obsidian .recent-item {
1255
+ display: flex;
1256
+ align-items: center;
1257
+ gap: 10px;
1258
+ padding: 10px 0;
1259
+ border-bottom: 1px solid rgba(63, 63, 70, 0.5);
1260
+ }
1261
+ .obsidian .recent-item:last-child { border-bottom: none; }
1262
+ .obsidian .recent-dot {
1263
+ width: 6px;
1264
+ height: 6px;
1265
+ border-radius: 50%;
1266
+ background: var(--accent);
1267
+ flex-shrink: 0;
1268
+ }
1269
+ .obsidian .recent-title {
1270
+ font-size: 13px;
1271
+ color: var(--fg-muted);
1272
+ flex: 1;
1273
+ white-space: nowrap;
1274
+ overflow: hidden;
1275
+ text-overflow: ellipsis;
1276
+ }
1277
+ .obsidian .recent-date {
1278
+ font-family: var(--font-mono);
1279
+ font-size: 12px;
1280
+ color: var(--fg-dim);
1281
+ flex-shrink: 0;
1282
+ }
1283
+
1284
+ /* ── Clickable session/project cards ── */
1285
+ .obsidian a.session-card {
1286
+ text-decoration: none;
1287
+ color: inherit;
1288
+ }
1289
+ .obsidian a.project-card {
1290
+ text-decoration: none;
1291
+ color: inherit;
1292
+ }
1293
+
1294
+ /* ── Highlights list ── */
1295
+ .obsidian .highlights-list {
1296
+ list-style: none;
1297
+ display: flex;
1298
+ flex-direction: column;
1299
+ gap: 12px;
1300
+ margin-bottom: 48px;
1301
+ }
1302
+ .obsidian .highlights-list li {
1303
+ font-size: 14px;
1304
+ color: var(--fg-muted);
1305
+ line-height: 1.7;
1306
+ padding-inline-start: 16px;
1307
+ position: relative;
1308
+ }
1309
+ .obsidian .highlights-list li::before {
1310
+ content: '';
1311
+ position: absolute;
1312
+ inset-inline-start: 0;
1313
+ top: 9px;
1314
+ width: 6px;
1315
+ height: 6px;
1316
+ border-radius: 50%;
1317
+ background: var(--accent);
1318
+ }
1319
+
1320
+ /* ── Footer ── */
1321
+ .obsidian .site-footer {
1322
+ border-top: 1px solid var(--border);
1323
+ padding: 32px 0;
1324
+ text-align: center;
1325
+ font-family: var(--font-mono);
1326
+ font-size: 12px;
1327
+ color: var(--fg-dim);
1328
+ }
1329
+
1330
+ /* ── Fade-up ── */
1331
+ .obsidian .fade-up {
1332
+ opacity: 0;
1333
+ transform: translateY(20px);
1334
+ transition: opacity 0.5s ease, transform 0.5s ease;
1335
+ }
1336
+ .obsidian .fade-up.visible {
1337
+ opacity: 1;
1338
+ transform: translateY(0);
1339
+ }
1340
+ .obsidian .shimmer-transition {
1341
+ transition: background-position 0.6s ease;
1342
+ }
1343
+
1344
+ /* ── Reduced motion ── */
1345
+ @media (prefers-reduced-motion: reduce) {
1346
+ .obsidian .fade-up {
1347
+ opacity: 1;
1348
+ transform: none;
1349
+ transition: none;
1350
+ }
1351
+ .obsidian .project-card,
1352
+ .obsidian .session-card,
1353
+ .obsidian .stat-card,
1354
+ .obsidian .decision-item,
1355
+ .obsidian .qa-item,
1356
+ .obsidian .agent-row {
1357
+ transition: none;
1358
+ }
1359
+ .obsidian .project-card,
1360
+ .obsidian .session-card {
1361
+ background-position: 100% 100% !important;
1362
+ }
1363
+ .obsidian .project-card:hover,
1364
+ .obsidian .session-card:hover {
1365
+ background-position: 100% 100% !important;
1366
+ }
1367
+ .obsidian .shimmer-transition { transition: none; }
1368
+ .obsidian .project-arrow { transition: none; }
1369
+ .obsidian .agent-bar-fill { transition: none; }
1370
+ }
1371
+
1372
+ /* ── Responsive ── */
1373
+ @media (max-width: 768px) {
1374
+ .obsidian .stats-grid,
1375
+ .obsidian .stats-grid--project {
1376
+ grid-template-columns: repeat(2, 1fr);
1377
+ }
1378
+ .obsidian .content-grid {
1379
+ grid-template-columns: 1fr;
1380
+ }
1381
+ .obsidian .sidebar { order: -1; }
1382
+ .obsidian .hero-meta { gap: 12px; }
1383
+ .obsidian .hero-row { flex-direction: column; gap: 1rem; }
1384
+ .obsidian .hero-photo { width: 100px; height: 120px; }
1385
+ .obsidian .project-card { padding: 24px 20px; }
1386
+ .obsidian .project-header { flex-direction: column; gap: 4px; }
1387
+ .obsidian .session-card { grid-template-columns: auto 1fr; }
1388
+ .obsidian .session-tag { display: none; }
1389
+ .obsidian .agent-row { grid-template-columns: auto 1fr auto; }
1390
+ .obsidian .agent-loc { display: none; }
1391
+ .obsidian .agent-bar-label { width: 80px; font-size: 11px; }
1392
+ .obsidian .hero-links { font-size: 12px; }
1393
+ .obsidian .timeline-chart { padding: 20px; }
1394
+ .obsidian .phase-list { padding-inline-start: 24px; }
1395
+ .obsidian .activity-grid { grid-template-columns: 1fr; }
1396
+ .obsidian .skills-bar-label { width: 80px; font-size: 12px; }
1397
+ }
1398
+
1399
+ @media (max-width: 480px) {
1400
+ .obsidian.heyiam-project .stats-grid {
1401
+ grid-template-columns: repeat(2, 1fr);
1402
+ }
1403
+ }
1404
+
1405
+
1406
+ /* Live-edit empty field hiding */
1407
+ [data-portfolio-empty="true"] { display: none; }