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,260 @@
1
+ <div class="heyiam-session grid" data-render-version="2" data-template="grid">
2
+
3
+ <div class="container">
4
+ <div class="breadcrumb" aria-label="Breadcrumb">
5
+ <a href="/{{ user.username }}">{{ user.username }}</a>
6
+ {% if projectSlug %}
7
+ <span class="breadcrumb-sep" aria-hidden="true">/</span>
8
+ <a href="/{{ user.username }}/{{ projectSlug }}">{{ projectSlug }}</a>
9
+ {% endif %}
10
+ <span class="breadcrumb-sep" aria-hidden="true">/</span>
11
+ <span aria-current="page">{{ session.title }}</span>
12
+ </div>
13
+
14
+ <div class="bento" aria-label="Session dashboard">
15
+
16
+ {%- comment -%} Cell 1: Title (3-wide) {%- endcomment -%}
17
+ <div class="bento-cell cell-title">
18
+ <h1>{{ session.title }}</h1>
19
+ <div class="session-subtitle">
20
+ {% if session.recordedAt %}
21
+ <span>{{ session.recordedAt | formatDate }}</span>
22
+ {% endif %}
23
+ {% if session.sourceTool %}
24
+ <span class="source-badge">
25
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M21 16V8a2 2 0 0 0-1-1.73l-7-4a2 2 0 0 0-2 0l-7 4A2 2 0 0 0 3 8v8a2 2 0 0 0 1 1.73l7 4a2 2 0 0 0 2 0l7-4A2 2 0 0 0 21 16z"/></svg>
26
+ {{ session.sourceTool }}
27
+ </span>
28
+ {% endif %}
29
+ </div>
30
+ </div>
31
+
32
+ {%- comment -%} Cell 2: Stat -- Duration {%- endcomment -%}
33
+ <section class="bento-cell cell-stat" aria-label="Duration">
34
+ <div class="stat-icon" aria-hidden="true">
35
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="12" cy="12" r="10"/><polyline points="12 6 12 12 16 14"/></svg>
36
+ </div>
37
+ <div>
38
+ <div class="stat-number">{{ session.durationMinutes | formatDuration }}</div>
39
+ <div class="stat-label">Duration</div>
40
+ </div>
41
+ </section>
42
+
43
+ {% if session.wallClockMinutes %}
44
+ <section class="bento-cell cell-stat" aria-label="Wall clock time">
45
+ <div class="stat-icon" aria-hidden="true">
46
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><rect x="2" y="3" width="20" height="14" rx="2" ry="2"/><line x1="8" y1="21" x2="16" y2="21"/><line x1="12" y1="17" x2="12" y2="21"/></svg>
47
+ </div>
48
+ <div>
49
+ <div class="stat-number">{{ session.wallClockMinutes | formatDuration }}</div>
50
+ <div class="stat-label">Wall Clock</div>
51
+ </div>
52
+ </section>
53
+ {% endif %}
54
+
55
+ {%- comment -%} Cell 3: Dev Take (4-wide) {%- endcomment -%}
56
+ {% if session.devTake %}
57
+ <div class="bento-cell cell-devtake">
58
+ <div class="devtake-label">Dev Take</div>
59
+ <blockquote>{{ session.devTake }}</blockquote>
60
+ </div>
61
+ {% endif %}
62
+
63
+ {%- comment -%} Cell 4: Stat -- Turns {%- endcomment -%}
64
+ <section class="bento-cell cell-stat" aria-label="Conversation turns">
65
+ <div class="stat-icon" aria-hidden="true">
66
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z"/></svg>
67
+ </div>
68
+ <div>
69
+ <div class="stat-number" data-target="{{ session.turns }}">0</div>
70
+ <div class="stat-label">Turns</div>
71
+ </div>
72
+ </section>
73
+
74
+ {%- comment -%} Cell 5: Stat -- LOC {%- endcomment -%}
75
+ <section class="bento-cell cell-stat" aria-label="Lines changed">
76
+ <div class="stat-icon" aria-hidden="true">
77
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><polyline points="16 18 22 12 16 6"/><polyline points="8 6 2 12 8 18"/></svg>
78
+ </div>
79
+ <div>
80
+ <div class="stat-number" data-target="{{ session.locChanged }}">0</div>
81
+ <div class="stat-label">Lines Changed</div>
82
+ </div>
83
+ </section>
84
+
85
+ {%- comment -%} Cell 6: Stat -- Files {%- endcomment -%}
86
+ <section class="bento-cell cell-stat" aria-label="Files changed">
87
+ <div class="stat-icon" aria-hidden="true">
88
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"/><polyline points="14 2 14 8 20 8"/></svg>
89
+ </div>
90
+ <div>
91
+ <div class="stat-number" data-target="{{ session.filesChanged }}">0</div>
92
+ <div class="stat-label">Files Changed</div>
93
+ </div>
94
+ </section>
95
+
96
+ {%- comment -%} Cell 7: Tools Used (2-wide) {%- endcomment -%}
97
+ {% if session.toolBreakdown.size > 0 %}
98
+ <section class="bento-cell cell-tools" aria-label="Tools used">
99
+ <h2 class="cell-heading">
100
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z"/></svg>
101
+ Tools Used
102
+ </h2>
103
+ <div class="tools-list">
104
+ {% assign maxToolCount = 0 %}
105
+ {% for t in session.toolBreakdown %}
106
+ {% if t.count > maxToolCount %}
107
+ {% assign maxToolCount = t.count %}
108
+ {% endif %}
109
+ {% endfor %}
110
+ {% for t in session.toolBreakdown %}
111
+ <div class="tool-row">
112
+ <span class="tool-name">{{ t.tool }}</span>
113
+ <div class="tool-bar-wrap">
114
+ <div class="tool-bar-track">
115
+ {% if maxToolCount > 0 %}
116
+ {% assign toolPct = t.count | times: 100 | divided_by: maxToolCount %}
117
+ <div class="tool-bar-fill" style="width: {{ toolPct }}%"></div>
118
+ {% endif %}
119
+ </div>
120
+ <span class="tool-count">{{ t.count }}</span>
121
+ </div>
122
+ </div>
123
+ {% endfor %}
124
+ </div>
125
+ </section>
126
+ {% endif %}
127
+
128
+ {%- comment -%} Cell 8: Files Changed (2-wide) {%- endcomment -%}
129
+ {% if session.topFiles.size > 0 %}
130
+ <section class="bento-cell cell-files" aria-label="Files changed">
131
+ <h2 class="cell-heading">
132
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"/><polyline points="14 2 14 8 20 8"/></svg>
133
+ Files Changed
134
+ </h2>
135
+ <div class="files-list">
136
+ {% for f in session.topFiles %}
137
+ <div class="file-row">
138
+ <span class="file-name">{{ f.path }}</span>
139
+ <span class="file-diff">+{{ f.additions }}{% if f.deletions > 0 %} -{{ f.deletions }}{% endif %}</span>
140
+ </div>
141
+ {% endfor %}
142
+ </div>
143
+ </section>
144
+ {% endif %}
145
+
146
+ {%- comment -%} Cell 9: Execution Path (3-wide) {%- endcomment -%}
147
+ {% if session.beats.size > 0 %}
148
+ <section class="bento-cell cell-beats" aria-label="Execution path">
149
+ <h2 class="cell-heading">
150
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><polyline points="22 12 18 12 15 21 9 3 6 12 2 12"/></svg>
151
+ Execution Path
152
+ </h2>
153
+ <ol class="beats-list" role="list">
154
+ {% for beat in session.beats %}
155
+ <li class="beat-item">
156
+ <div class="beat-indicator" aria-hidden="true">
157
+ <span class="beat-dot"></span>
158
+ {% unless forloop.last %}
159
+ <span class="beat-line"></span>
160
+ {% endunless %}
161
+ </div>
162
+ <div class="beat-content">
163
+ <div class="beat-title">{{ beat.title }}</div>
164
+ <div class="beat-desc">{{ beat.body }}</div>
165
+ </div>
166
+ </li>
167
+ {% endfor %}
168
+ </ol>
169
+ </section>
170
+ {% endif %}
171
+
172
+ {%- comment -%} Cell 10: Skills {%- endcomment -%}
173
+ {% if session.skills.size > 0 %}
174
+ <section class="bento-cell cell-skills" aria-label="Skills">
175
+ <h2 class="cell-heading">
176
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><polygon points="12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2"/></svg>
177
+ Skills
178
+ </h2>
179
+ <div class="skills-grid">
180
+ {% for skill in session.skills %}
181
+ <span class="skill-chip chip chip--violet">{{ skill }}</span>
182
+ {% endfor %}
183
+ </div>
184
+ </section>
185
+ {% endif %}
186
+
187
+ {%- comment -%} Cell 11: Narrative {%- endcomment -%}
188
+ {% if session.narrative %}
189
+ <section class="bento-cell cell-narrative" aria-label="Narrative">
190
+ <h2 class="cell-heading">
191
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M12 20h9"/><path d="M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4L16.5 3.5z"/></svg>
192
+ Narrative
193
+ </h2>
194
+ <p>{{ session.narrative }}</p>
195
+ </section>
196
+ {% endif %}
197
+
198
+ {%- comment -%} Cell 12: Highlights {%- endcomment -%}
199
+ {% if session.highlights.size > 0 %}
200
+ <section class="bento-cell cell-narrative" aria-label="Highlights">
201
+ <h2 class="cell-heading">Highlights</h2>
202
+ <ul class="highlights-list">
203
+ {% for h in session.highlights %}
204
+ <li>{{ h }}</li>
205
+ {% endfor %}
206
+ </ul>
207
+ </section>
208
+ {% endif %}
209
+
210
+ {%- comment -%} Cell 13: Q&A (4-wide) {%- endcomment -%}
211
+ {% if session.qaPairs.size > 0 %}
212
+ <section class="bento-cell cell-qa" aria-label="Questions and answers">
213
+ <h2 class="cell-heading">
214
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><circle cx="12" cy="12" r="10"/><path d="M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"/><line x1="12" y1="17" x2="12.01" y2="17"/></svg>
215
+ Q&amp;A
216
+ </h2>
217
+ <div class="qa-list">
218
+ {% for qa in session.qaPairs %}
219
+ <div class="qa-item qa-pair">
220
+ <div class="qa-question">
221
+ <span class="qa-q-badge" aria-hidden="true">Q</span>
222
+ <span>{{ qa.question }}</span>
223
+ </div>
224
+ <p class="qa-answer">{{ qa.answer }}</p>
225
+ </div>
226
+ {% endfor %}
227
+ </div>
228
+ </section>
229
+ {% endif %}
230
+
231
+ {%- comment -%} Cell 14: Agent Summary (4-wide) {%- endcomment -%}
232
+ {% if session.agentSummary %}
233
+ <section class="bento-cell cell-agents" aria-label="Agent summary">
234
+ <h2 class="cell-heading">
235
+ <svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true"><path d="M17 21v-2a4 4 0 0 0-4-4H5a4 4 0 0 0-4 4v2"/><circle cx="9" cy="7" r="4"/><path d="M23 21v-2a4 4 0 0 0-3-3.87"/><path d="M16 3.13a4 4 0 0 1 0 7.75"/></svg>
236
+ Agent Summary
237
+ <span style="font-family: var(--font-mono); font-size: 11px; color: var(--fg-faint); font-weight: 400; margin-inline-start: auto;">{{ session.agentSummary.agents.size }} sub-sessions</span>
238
+ </h2>
239
+ <div class="agents-grid">
240
+ {% assign agent_colors = '#7c3aed,#0891b2,#059669,#475569,#e11d48,#d97706' | split: ',' %}
241
+ {% for agent in session.agentSummary.agents %}
242
+ <div class="agent-card">
243
+ {% assign colorIdx = forloop.index0 | modulo: 6 %}
244
+ <span class="agent-color" style="background: {{ agent_colors[colorIdx] }};" aria-hidden="true"></span>
245
+ <div class="agent-info">
246
+ <div class="agent-role">{{ agent.role }}</div>
247
+ <div class="agent-meta">{{ agent.duration_minutes }}m &middot; {{ agent.loc_changed }} LOC</div>
248
+ </div>
249
+ </div>
250
+ {% endfor %}
251
+ </div>
252
+ </section>
253
+ {% endif %}
254
+
255
+ </div>
256
+ </div>
257
+
258
+ {%- comment -%} Stat counter animation {%- endcomment -%}
259
+
260
+ </div>