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