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,1055 @@
1
+ /* ── Radar Template Styles ── */
2
+
3
+ :root {
4
+ --surface: #0f172a;
5
+ --surface-low: #131c31;
6
+ --surface-lowest: #1a2540;
7
+ --surface-high: #0b1120;
8
+ --on-surface: #e2e8f0;
9
+ --on-surface-variant: #64748b;
10
+ --accent: #22d3ee;
11
+ --accent-dim: rgba(34, 211, 238, 0.15);
12
+ --accent-faint: rgba(34, 211, 238, 0.06);
13
+ --outline: #1e293b;
14
+ --ghost: rgba(34, 211, 238, 0.08);
15
+ --grid-line: rgba(34, 211, 238, 0.04);
16
+ --green: #34d399;
17
+ --green-bg: rgba(52, 211, 153, 0.1);
18
+ --violet: #a78bfa;
19
+ --violet-bg: rgba(167, 139, 250, 0.1);
20
+ --font-display: 'Space Grotesk', sans-serif;
21
+ --font-body: 'Inter', sans-serif;
22
+ --font-mono: 'IBM Plex Mono', monospace;
23
+ --radius-sm: 2px;
24
+ --radius-md: 4px;
25
+ }
26
+ body { background: var(--surface); color: var(--on-surface); }
27
+
28
+
29
+ /* ── Dark Template Wrapper ── */
30
+ .radar {
31
+ font-family: var(--font-body);
32
+ color: var(--on-surface);
33
+ background-color: var(--surface);
34
+ background-image:
35
+ linear-gradient(var(--grid-line) 1px, transparent 1px),
36
+ linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
37
+ background-size: 40px 40px;
38
+ line-height: 1.7;
39
+ -webkit-font-smoothing: antialiased;
40
+ }
41
+
42
+ .radar a { color: var(--accent); text-decoration: none; }
43
+ .radar a:visited { color: var(--accent); }
44
+ .radar a:hover { text-decoration: underline; text-decoration-color: var(--accent-dim); }
45
+
46
+ /* ── Section Fade-In ── */
47
+ .radar-section {
48
+ margin-bottom: 2.5rem;
49
+ opacity: 0;
50
+ transform: translateY(16px);
51
+ transition: opacity 0.5s ease-out, transform 0.5s ease-out;
52
+ }
53
+ .radar-section.visible, .radar-section.is-visible {
54
+ opacity: 1;
55
+ transform: translateY(0);
56
+ }
57
+
58
+ @media (prefers-reduced-motion: reduce) {
59
+ .radar-section {
60
+ opacity: 1;
61
+ transform: none;
62
+ transition: none;
63
+ }
64
+ }
65
+
66
+ /* ── Section Labels ── */
67
+ .radar .radar-label {
68
+ font-family: var(--font-mono);
69
+ font-size: 9px;
70
+ font-weight: 500;
71
+ text-transform: uppercase;
72
+ letter-spacing: 0.1em;
73
+ color: var(--accent);
74
+ margin-bottom: 0.75rem;
75
+ display: flex;
76
+ align-items: center;
77
+ gap: 0.5rem;
78
+ }
79
+ .radar .radar-label::before {
80
+ content: '';
81
+ display: inline-block;
82
+ width: 6px;
83
+ height: 6px;
84
+ background: var(--accent);
85
+ border-radius: 1px;
86
+ }
87
+
88
+ /* ── Breadcrumb ── */
89
+ .radar .radar-breadcrumb {
90
+ font-family: var(--font-mono);
91
+ font-size: 0.75rem;
92
+ color: var(--on-surface-variant);
93
+ margin-bottom: 1.5rem;
94
+ display: flex;
95
+ align-items: center;
96
+ gap: 0.375rem;
97
+ flex-wrap: wrap;
98
+ }
99
+ .radar .radar-breadcrumb a { color: var(--accent); }
100
+ .radar .radar-breadcrumb a:visited { color: var(--accent); }
101
+ .radar .radar-breadcrumb__sep { color: var(--on-surface-variant); }
102
+
103
+ /* ── Title ── */
104
+ .radar .radar-title {
105
+ font-family: var(--font-display);
106
+ font-size: 2.25rem;
107
+ font-weight: 700;
108
+ color: var(--on-surface);
109
+ letter-spacing: -0.03em;
110
+ margin-bottom: 0.5rem;
111
+ }
112
+
113
+ /* ── Portfolio Header ── */
114
+ .radar .portfolio-header {
115
+ display: flex;
116
+ align-items: flex-start;
117
+ gap: 1.5rem;
118
+ margin-bottom: 2rem;
119
+ }
120
+
121
+ .radar .portfolio-photo {
122
+ width: 100px;
123
+ height: 130px;
124
+ border-radius: 4px;
125
+ object-fit: cover;
126
+ object-position: 55% 10%;
127
+ border: 2px solid var(--ghost);
128
+ flex-shrink: 0;
129
+ }
130
+
131
+ .radar .portfolio-info { flex: 1; min-width: 0; }
132
+
133
+ .radar .portfolio-name {
134
+ font-family: var(--font-display);
135
+ font-size: 1.5rem;
136
+ font-weight: 700;
137
+ color: var(--on-surface);
138
+ letter-spacing: -0.02em;
139
+ margin-bottom: 0.125rem;
140
+ }
141
+
142
+ .radar .portfolio-handle {
143
+ font-family: var(--font-mono);
144
+ font-size: 0.75rem;
145
+ color: var(--accent);
146
+ margin-bottom: 0.5rem;
147
+ }
148
+
149
+ .radar .portfolio-bio {
150
+ font-size: 0.875rem;
151
+ color: var(--on-surface-variant);
152
+ line-height: 1.6;
153
+ max-width: 50ch;
154
+ }
155
+
156
+ .radar .portfolio-location {
157
+ font-family: var(--font-mono);
158
+ font-size: 0.6875rem;
159
+ color: var(--on-surface-variant);
160
+ margin-top: 0.375rem;
161
+ display: flex;
162
+ align-items: center;
163
+ gap: 0.375rem;
164
+ }
165
+ .radar .portfolio-location svg {
166
+ width: 12px;
167
+ height: 12px;
168
+ fill: none;
169
+ stroke: var(--on-surface-variant);
170
+ stroke-width: 1.5;
171
+ }
172
+
173
+ /* ── Contact Links ── */
174
+ .radar .contact-row {
175
+ display: flex;
176
+ flex-wrap: wrap;
177
+ gap: 10px 18px;
178
+ margin-top: 0.75rem;
179
+ font-family: var(--font-mono);
180
+ font-size: 0.6875rem;
181
+ }
182
+ .radar .contact-row a,
183
+ .radar .contact-row span {
184
+ display: inline-flex;
185
+ align-items: center;
186
+ gap: 5px;
187
+ color: var(--on-surface-variant);
188
+ text-decoration: none;
189
+ transition: color 150ms ease;
190
+ }
191
+ .radar .contact-row a:hover {
192
+ color: var(--accent);
193
+ }
194
+ .radar .contact-row a:visited {
195
+ color: var(--on-surface-variant);
196
+ }
197
+ .radar .contact-row a:focus-visible {
198
+ outline: 2px solid var(--accent);
199
+ outline-offset: 2px;
200
+ border-radius: var(--radius-sm);
201
+ }
202
+ .radar .contact-row svg {
203
+ flex-shrink: 0;
204
+ }
205
+ .radar .resume-btn {
206
+ display: inline-flex;
207
+ align-items: center;
208
+ gap: 5px;
209
+ padding: 3px 10px;
210
+ border: 1px solid var(--ghost);
211
+ border-radius: var(--radius-sm);
212
+ font-family: var(--font-mono);
213
+ font-size: 0.6875rem;
214
+ color: var(--on-surface-variant);
215
+ text-decoration: none;
216
+ transition: border-color 150ms ease, color 150ms ease;
217
+ background: transparent;
218
+ }
219
+ .radar .resume-btn:hover {
220
+ border-color: var(--accent);
221
+ color: var(--accent);
222
+ }
223
+
224
+ /* ── Aggregate Stats (Portfolio) ── */
225
+ .radar .portfolio-stats {
226
+ display: flex;
227
+ gap: 0.75rem;
228
+ flex-wrap: wrap;
229
+ margin-bottom: 2.5rem;
230
+ }
231
+
232
+ .radar .portfolio-stat {
233
+ display: flex;
234
+ flex-direction: column;
235
+ align-items: center;
236
+ padding: 0.75rem 1.25rem;
237
+ background: var(--surface-lowest);
238
+ border: 1px solid var(--ghost);
239
+ border-radius: var(--radius-sm);
240
+ min-width: 100px;
241
+ }
242
+
243
+ .radar .portfolio-stat__value {
244
+ font-family: var(--font-display);
245
+ font-size: 1.25rem;
246
+ font-weight: 700;
247
+ color: var(--on-surface);
248
+ }
249
+
250
+ .radar .portfolio-stat__label {
251
+ font-family: var(--font-mono);
252
+ font-size: 9px;
253
+ text-transform: uppercase;
254
+ letter-spacing: 0.05em;
255
+ color: var(--on-surface-variant);
256
+ }
257
+ .radar .portfolio-stat--cyan {
258
+ border-color: rgba(34,211,238,0.4);
259
+ }
260
+ .radar .portfolio-stat--cyan .portfolio-stat__value {
261
+ color: var(--accent);
262
+ }
263
+
264
+ /* ── Project Cards (Portfolio) ── */
265
+ .radar .portfolio-projects {
266
+ display: grid;
267
+ grid-template-columns: repeat(3, 1fr);
268
+ gap: 0.75rem;
269
+ margin-bottom: 2.5rem;
270
+ }
271
+
272
+ .radar .portfolio-card {
273
+ background: var(--surface-lowest);
274
+ border: 1px solid var(--ghost);
275
+ border-radius: var(--radius-sm);
276
+ padding: 1rem;
277
+ transition: border-color 150ms ease;
278
+ cursor: pointer;
279
+ text-decoration: none;
280
+ color: inherit;
281
+ display: block;
282
+ }
283
+ .radar .portfolio-card:hover {
284
+ border-color: var(--accent-dim);
285
+ text-decoration: none;
286
+ }
287
+ .radar .portfolio-card:visited {
288
+ color: inherit;
289
+ }
290
+
291
+ .radar .portfolio-card__bar {
292
+ height: 2px;
293
+ border-radius: 1px;
294
+ margin-bottom: 0.75rem;
295
+ }
296
+ .radar .portfolio-card__bar--cyan { background: var(--accent); }
297
+ .radar .portfolio-card__bar--green { background: var(--green); }
298
+ .radar .portfolio-card__bar--violet { background: var(--violet); }
299
+
300
+ .radar .portfolio-card__title {
301
+ font-family: var(--font-display);
302
+ font-size: 0.875rem;
303
+ font-weight: 600;
304
+ color: var(--on-surface);
305
+ margin-bottom: 0.25rem;
306
+ }
307
+
308
+ .radar .portfolio-card__desc {
309
+ font-size: 0.75rem;
310
+ color: var(--on-surface-variant);
311
+ line-height: 1.5;
312
+ margin-bottom: 0.5rem;
313
+ display: -webkit-box;
314
+ -webkit-line-clamp: 2;
315
+ -webkit-box-orient: vertical;
316
+ overflow: hidden;
317
+ }
318
+
319
+ .radar .portfolio-card__meta {
320
+ font-family: var(--font-mono);
321
+ font-size: 0.6875rem;
322
+ color: var(--on-surface-variant);
323
+ margin-bottom: 0.5rem;
324
+ }
325
+
326
+ .radar .portfolio-card__skills {
327
+ display: flex;
328
+ flex-wrap: wrap;
329
+ gap: 0.25rem;
330
+ }
331
+
332
+ /* ── Skill Chips ── */
333
+ .radar .chip {
334
+ font-family: var(--font-mono);
335
+ font-size: 11px;
336
+ line-height: 1.2;
337
+ padding: 0.125rem 0.5rem;
338
+ border-radius: var(--radius-sm);
339
+ background: var(--accent-faint);
340
+ color: var(--accent);
341
+ border: 1px solid var(--ghost);
342
+ }
343
+
344
+ .radar .chip-list {
345
+ display: flex;
346
+ flex-wrap: wrap;
347
+ gap: 0.375rem;
348
+ }
349
+
350
+ /* ── Links (Project) ── */
351
+ .radar .radar-links {
352
+ display: flex;
353
+ align-items: center;
354
+ gap: 1.5rem;
355
+ margin-bottom: 2rem;
356
+ }
357
+ .radar .radar-link {
358
+ font-family: var(--font-mono);
359
+ font-size: 0.75rem;
360
+ color: var(--accent);
361
+ display: flex;
362
+ align-items: center;
363
+ gap: 0.375rem;
364
+ }
365
+ .radar .radar-link:visited { color: var(--accent); }
366
+ .radar .radar-link:hover {
367
+ text-decoration: underline;
368
+ text-decoration-color: var(--accent-dim);
369
+ }
370
+ .radar .radar-link svg {
371
+ width: 14px;
372
+ height: 14px;
373
+ fill: none;
374
+ stroke: var(--accent);
375
+ stroke-width: 1.5;
376
+ }
377
+
378
+ /* ── Screenshot (Project) ── */
379
+ .radar .browser-chrome {
380
+ border-radius: var(--radius-md);
381
+ border: 1px solid var(--ghost);
382
+ overflow: hidden;
383
+ background: var(--surface-low);
384
+ }
385
+ .radar .browser-chrome__bar {
386
+ display: flex;
387
+ align-items: center;
388
+ gap: 6px;
389
+ padding: 0.5rem 0.75rem;
390
+ background: var(--surface-high);
391
+ border-bottom: 1px solid var(--ghost);
392
+ }
393
+ .radar .browser-chrome__dot {
394
+ width: 10px;
395
+ height: 10px;
396
+ border-radius: 50%;
397
+ }
398
+ .radar .browser-chrome__dot--red { background: #ff5f57; }
399
+ .radar .browser-chrome__dot--yellow { background: #febc2e; }
400
+ .radar .browser-chrome__dot--green { background: #28c840; }
401
+ .radar .browser-chrome__viewport {
402
+ height: 24rem;
403
+ background: var(--surface-low);
404
+ display: flex;
405
+ align-items: center;
406
+ justify-content: center;
407
+ color: var(--on-surface-variant);
408
+ font-family: var(--font-mono);
409
+ font-size: 0.75rem;
410
+ }
411
+
412
+ /* ── Narrative ── */
413
+ .radar .radar-narrative {
414
+ border-left: 2px solid var(--accent);
415
+ padding-left: 1rem;
416
+ }
417
+ .radar .radar-narrative p {
418
+ font-size: 1rem;
419
+ color: var(--on-surface);
420
+ line-height: 1.7;
421
+ margin-bottom: 1rem;
422
+ }
423
+ .radar .radar-narrative p:last-child { margin-bottom: 0; }
424
+
425
+ /* ── Stats Grid (Project) ── */
426
+ .radar .stat-grid {
427
+ display: grid;
428
+ grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
429
+ gap: 0.75rem;
430
+ }
431
+ .radar .stat-card {
432
+ background: var(--surface-lowest);
433
+ border: 1px solid var(--ghost);
434
+ border-radius: var(--radius-sm);
435
+ padding: 1rem;
436
+ }
437
+ .radar .stat-card__label {
438
+ font-family: var(--font-mono);
439
+ font-size: 9px;
440
+ text-transform: uppercase;
441
+ letter-spacing: 0.05em;
442
+ color: var(--on-surface-variant);
443
+ margin-bottom: 0.25rem;
444
+ }
445
+ .radar .stat-card__value {
446
+ font-family: var(--font-display);
447
+ font-size: 1.5rem;
448
+ font-weight: 700;
449
+ color: var(--on-surface);
450
+ }
451
+ .radar .stat-card--cyan {
452
+ border-color: rgba(34,211,238,0.4);
453
+ }
454
+ .radar .stat-card--cyan .stat-card__value {
455
+ color: var(--accent);
456
+ }
457
+
458
+ /* ── Chart Cards ── */
459
+ .radar .chart-card {
460
+ background: var(--surface-lowest);
461
+ border: 1px solid var(--ghost);
462
+ border-radius: var(--radius-sm);
463
+ padding: 1rem;
464
+ }
465
+
466
+ /* ── Work Timeline Bars ── */
467
+ .radar .wt-bar {
468
+ transform-origin: left center;
469
+ transform: scaleX(0);
470
+ transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
471
+ }
472
+ .radar .wt-bar.is-animated { transform: scaleX(1); }
473
+ .radar .wt-agent-line {
474
+ stroke-dasharray: 100;
475
+ stroke-dashoffset: 100;
476
+ transition: stroke-dashoffset 0.8s ease-out;
477
+ }
478
+ .radar .wt-agent-line.is-animated { stroke-dashoffset: 0; }
479
+
480
+ @media (prefers-reduced-motion: reduce) {
481
+ .radar .wt-bar { transform: scaleX(1); transition: none; }
482
+ .radar .wt-agent-line { stroke-dashoffset: 0; transition: none; }
483
+ }
484
+
485
+ /* ── Growth Chart Lines ── */
486
+ .radar .growth-line {
487
+ stroke-dasharray: var(--line-length, 2000);
488
+ stroke-dashoffset: var(--line-length, 2000);
489
+ transition: stroke-dashoffset 1.2s ease-out;
490
+ }
491
+ .radar .growth-line.is-animated { stroke-dashoffset: 0; }
492
+ .radar .growth-area {
493
+ opacity: 0;
494
+ transition: opacity 0.8s ease-out 0.4s;
495
+ }
496
+ .radar .growth-area.is-animated { opacity: 1; }
497
+
498
+ @media (prefers-reduced-motion: reduce) {
499
+ .radar .growth-line { stroke-dashoffset: 0; transition: none; }
500
+ .radar .growth-area { opacity: 1; transition: none; }
501
+ }
502
+
503
+ /* ── Two Column ── */
504
+ .radar .two-col {
505
+ display: grid;
506
+ grid-template-columns: repeat(2, 1fr);
507
+ gap: 1.5rem;
508
+ }
509
+
510
+ /* ── Key Decisions ── */
511
+ .radar .decision-list { list-style: none; }
512
+ .radar .decision-item {
513
+ padding: 0.75rem 0;
514
+ border-bottom: 1px solid var(--ghost);
515
+ }
516
+ .radar .decision-item:last-child { border-bottom: none; }
517
+ .radar .decision-bullet {
518
+ display: flex;
519
+ align-items: flex-start;
520
+ gap: 0.625rem;
521
+ }
522
+ .radar .decision-bullet::before {
523
+ content: '';
524
+ display: block;
525
+ width: 6px;
526
+ height: 6px;
527
+ background: var(--accent);
528
+ border-radius: 1px;
529
+ margin-top: 0.375rem;
530
+ flex-shrink: 0;
531
+ }
532
+ .radar .decision-title {
533
+ font-family: var(--font-display);
534
+ font-size: 0.875rem;
535
+ font-weight: 600;
536
+ color: var(--on-surface);
537
+ margin-bottom: 0.25rem;
538
+ }
539
+ .radar .decision-desc {
540
+ font-size: 0.8125rem;
541
+ color: var(--on-surface-variant);
542
+ line-height: 1.6;
543
+ }
544
+
545
+ /* ── Source Table ── */
546
+ .radar .source-table { width: 100%; border-collapse: collapse; }
547
+ .radar .source-table th {
548
+ text-align: left;
549
+ padding: 0.5rem 0;
550
+ font-family: var(--font-mono);
551
+ font-size: 9px;
552
+ text-transform: uppercase;
553
+ letter-spacing: 0.05em;
554
+ color: var(--accent);
555
+ border-bottom: 1px solid var(--ghost);
556
+ font-weight: 400;
557
+ }
558
+ .radar .source-table td {
559
+ padding: 0.5rem 0;
560
+ border-bottom: 1px solid var(--ghost);
561
+ font-family: var(--font-mono);
562
+ font-size: 0.8125rem;
563
+ color: var(--on-surface);
564
+ }
565
+ .radar .source-table td:last-child {
566
+ text-align: right;
567
+ color: var(--on-surface-variant);
568
+ }
569
+
570
+ /* ── Phase Timeline ── */
571
+ .radar .phase-timeline {
572
+ position: relative;
573
+ padding-left: 1.25rem;
574
+ }
575
+ .radar .phase-timeline__line {
576
+ position: absolute;
577
+ left: 0.25rem;
578
+ top: 0.375rem;
579
+ bottom: 0.375rem;
580
+ width: 2px;
581
+ background: var(--ghost);
582
+ border-radius: 1px;
583
+ }
584
+ .radar .phase-timeline__item {
585
+ position: relative;
586
+ padding-bottom: 1.25rem;
587
+ }
588
+ .radar .phase-timeline__item:last-child { padding-bottom: 0; }
589
+ .radar .phase-timeline__dot {
590
+ position: absolute;
591
+ left: -1.25rem;
592
+ top: 0.25rem;
593
+ width: 8px;
594
+ height: 8px;
595
+ border-radius: 50%;
596
+ background: var(--accent);
597
+ box-shadow: 0 0 0 3px var(--accent-dim);
598
+ }
599
+ .radar .phase-timeline__title {
600
+ font-family: var(--font-display);
601
+ font-size: 0.875rem;
602
+ font-weight: 600;
603
+ color: var(--on-surface);
604
+ margin-bottom: 0.25rem;
605
+ }
606
+ .radar .phase-timeline__dates {
607
+ font-family: var(--font-mono);
608
+ font-size: 0.6875rem;
609
+ color: var(--on-surface-variant);
610
+ margin-bottom: 0.25rem;
611
+ }
612
+ .radar .phase-timeline__desc {
613
+ font-size: 0.8125rem;
614
+ color: var(--on-surface-variant);
615
+ line-height: 1.6;
616
+ }
617
+
618
+ /* ── Session Cards (Project) ── */
619
+ .radar .section-header {
620
+ display: flex;
621
+ align-items: center;
622
+ justify-content: space-between;
623
+ margin-bottom: 0.75rem;
624
+ }
625
+ .radar .section-header__meta {
626
+ font-family: var(--font-mono);
627
+ font-size: 9px;
628
+ text-transform: uppercase;
629
+ letter-spacing: 0.05em;
630
+ color: var(--on-surface-variant);
631
+ }
632
+ .radar .session-grid {
633
+ display: grid;
634
+ grid-template-columns: repeat(2, 1fr);
635
+ gap: 0.75rem;
636
+ }
637
+ .radar .session-card {
638
+ background: var(--surface-lowest);
639
+ border: 1px solid var(--ghost);
640
+ border-radius: var(--radius-sm);
641
+ padding: 1rem;
642
+ transition: border-color 150ms ease, transform 0.15s ease;
643
+ cursor: pointer;
644
+ text-decoration: none;
645
+ color: inherit;
646
+ display: block;
647
+ }
648
+ .radar .session-card:visited {
649
+ color: inherit;
650
+ }
651
+ .radar .session-card:hover {
652
+ border-color: var(--accent-dim);
653
+ text-decoration: none;
654
+ transform: translateY(-2px);
655
+ }
656
+ .radar .session-card__bar {
657
+ height: 2px;
658
+ border-radius: 1px;
659
+ margin-bottom: 0.75rem;
660
+ }
661
+ .radar .session-card__bar--cyan { background: var(--accent); }
662
+ .radar .session-card__bar--green { background: var(--green); }
663
+ .radar .session-card__bar--violet { background: var(--violet); }
664
+ .radar .session-card__title {
665
+ font-family: var(--font-display);
666
+ font-size: 0.8125rem;
667
+ font-weight: 600;
668
+ color: var(--on-surface);
669
+ margin-bottom: 0.25rem;
670
+ display: -webkit-box;
671
+ -webkit-line-clamp: 2;
672
+ -webkit-box-orient: vertical;
673
+ overflow: hidden;
674
+ }
675
+ .radar .session-card__meta {
676
+ color: var(--on-surface-variant);
677
+ font-size: 0.75rem;
678
+ margin-bottom: 0.5rem;
679
+ }
680
+ .radar .session-card__tag {
681
+ font-family: var(--font-mono);
682
+ font-size: 9px;
683
+ text-transform: uppercase;
684
+ letter-spacing: 0.05em;
685
+ color: var(--accent);
686
+ background: var(--accent-faint);
687
+ border: 1px solid var(--ghost);
688
+ border-radius: var(--radius-sm);
689
+ padding: 0.0625rem 0.375rem;
690
+ display: inline-block;
691
+ margin-top: 0.375rem;
692
+ }
693
+
694
+ /* ── Session Meta (Session page) ── */
695
+ .radar .session-meta-row {
696
+ display: flex;
697
+ flex-wrap: wrap;
698
+ gap: 1.5rem;
699
+ margin-bottom: 0.75rem;
700
+ }
701
+ .radar .session-meta-item {
702
+ display: flex;
703
+ flex-direction: column;
704
+ }
705
+ .radar .session-meta-item__label {
706
+ font-family: var(--font-mono);
707
+ font-size: 9px;
708
+ text-transform: uppercase;
709
+ letter-spacing: 0.05em;
710
+ color: var(--on-surface-variant);
711
+ }
712
+ .radar .session-meta-item__value {
713
+ font-family: var(--font-display);
714
+ font-size: 0.875rem;
715
+ font-weight: 600;
716
+ color: var(--on-surface);
717
+ }
718
+
719
+ .radar .stat-grid-inline {
720
+ display: grid;
721
+ grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
722
+ gap: 0.5rem;
723
+ }
724
+ .radar .stat-card-sm {
725
+ background: var(--surface-lowest);
726
+ border: 1px solid var(--ghost);
727
+ border-radius: var(--radius-sm);
728
+ padding: 0.75rem;
729
+ text-align: center;
730
+ }
731
+ .radar .stat-card-sm__label {
732
+ font-family: var(--font-mono);
733
+ font-size: 9px;
734
+ text-transform: uppercase;
735
+ letter-spacing: 0.05em;
736
+ color: var(--on-surface-variant);
737
+ margin-bottom: 0.125rem;
738
+ }
739
+ .radar .stat-card-sm__value {
740
+ font-family: var(--font-display);
741
+ font-size: 1.25rem;
742
+ font-weight: 700;
743
+ color: var(--on-surface);
744
+ }
745
+
746
+ /* ── Dev Take ── */
747
+ .radar .dev-take {
748
+ border-left: 2px solid var(--accent);
749
+ padding-left: 1rem;
750
+ max-width: 65ch;
751
+ }
752
+ .radar .dev-take p {
753
+ font-size: 1rem;
754
+ font-style: italic;
755
+ color: var(--on-surface);
756
+ line-height: 1.7;
757
+ }
758
+
759
+ /* ── Two Column Session Layout ── */
760
+ .radar .session-layout {
761
+ display: grid;
762
+ grid-template-columns: 1fr 280px;
763
+ gap: 2rem;
764
+ align-items: start;
765
+ }
766
+
767
+ /* ── Sidebar Card ── */
768
+ .radar .sidebar-card {
769
+ background: var(--surface-lowest);
770
+ border: 1px solid var(--ghost);
771
+ border-radius: var(--radius-sm);
772
+ padding: 1rem;
773
+ margin-bottom: 1rem;
774
+ }
775
+
776
+ /* ── Tools Table ── */
777
+ .radar .tools-table { width: 100%; border-collapse: collapse; }
778
+ .radar .tools-table th {
779
+ text-align: left;
780
+ padding: 0.375rem 0;
781
+ font-family: var(--font-mono);
782
+ font-size: 9px;
783
+ text-transform: uppercase;
784
+ letter-spacing: 0.05em;
785
+ color: var(--accent);
786
+ border-bottom: 1px solid var(--ghost);
787
+ font-weight: 400;
788
+ }
789
+ .radar .tools-table td {
790
+ padding: 0.375rem 0;
791
+ border-bottom: 1px solid var(--ghost);
792
+ font-family: var(--font-mono);
793
+ font-size: 0.8125rem;
794
+ color: var(--on-surface);
795
+ }
796
+ .radar .tools-table td:last-child {
797
+ text-align: right;
798
+ color: var(--on-surface-variant);
799
+ }
800
+
801
+ /* ── Files Table ── */
802
+ .radar .files-table { width: 100%; border-collapse: collapse; }
803
+ .radar .files-table th {
804
+ text-align: left;
805
+ padding: 0.375rem 0;
806
+ font-family: var(--font-mono);
807
+ font-size: 9px;
808
+ text-transform: uppercase;
809
+ letter-spacing: 0.05em;
810
+ color: var(--accent);
811
+ border-bottom: 1px solid var(--ghost);
812
+ font-weight: 400;
813
+ }
814
+ .radar .files-table td {
815
+ padding: 0.375rem 0;
816
+ border-bottom: 1px solid var(--ghost);
817
+ font-family: var(--font-mono);
818
+ font-size: 0.6875rem;
819
+ color: var(--on-surface);
820
+ word-break: break-all;
821
+ }
822
+ .radar .files-table td:last-child {
823
+ text-align: right;
824
+ color: var(--green);
825
+ white-space: nowrap;
826
+ padding-left: 0.5rem;
827
+ }
828
+
829
+ /* ── Execution Path / Beats ── */
830
+ .radar .beat-list {
831
+ list-style: none;
832
+ position: relative;
833
+ padding-left: 1.25rem;
834
+ }
835
+ .radar .beat-list__line {
836
+ position: absolute;
837
+ left: 0.25rem;
838
+ top: 0.375rem;
839
+ bottom: 0.375rem;
840
+ width: 2px;
841
+ background: var(--ghost);
842
+ border-radius: 1px;
843
+ }
844
+ .radar .beat-item {
845
+ position: relative;
846
+ padding-bottom: 1.5rem;
847
+ }
848
+ .radar .beat-item:last-child { padding-bottom: 0; }
849
+ .radar .beat-item__dot {
850
+ position: absolute;
851
+ left: -1.25rem;
852
+ top: 0.25rem;
853
+ width: 8px;
854
+ height: 8px;
855
+ border-radius: 50%;
856
+ background: var(--accent);
857
+ box-shadow: 0 0 0 3px var(--accent-dim);
858
+ }
859
+ .radar .beat-item__number {
860
+ font-family: var(--font-mono);
861
+ font-size: 9px;
862
+ color: var(--accent);
863
+ text-transform: uppercase;
864
+ letter-spacing: 0.05em;
865
+ margin-bottom: 0.25rem;
866
+ }
867
+ .radar .beat-item__title {
868
+ font-family: var(--font-display);
869
+ font-size: 0.875rem;
870
+ font-weight: 600;
871
+ color: var(--on-surface);
872
+ margin-bottom: 0.25rem;
873
+ }
874
+ .radar .beat-item__desc {
875
+ font-size: 0.8125rem;
876
+ color: var(--on-surface-variant);
877
+ line-height: 1.6;
878
+ }
879
+
880
+ /* ── Q&A Section ── */
881
+ .radar .qa-item {
882
+ padding: 1rem 0;
883
+ border-bottom: 1px solid var(--ghost);
884
+ }
885
+ .radar .qa-item:last-child { border-bottom: none; }
886
+ .radar .qa-question {
887
+ font-family: var(--font-display);
888
+ font-size: 0.875rem;
889
+ font-weight: 600;
890
+ color: var(--on-surface);
891
+ margin-bottom: 0.5rem;
892
+ display: flex;
893
+ align-items: flex-start;
894
+ gap: 0.5rem;
895
+ }
896
+ .radar .qa-question::before {
897
+ content: 'Q';
898
+ display: inline-flex;
899
+ align-items: center;
900
+ justify-content: center;
901
+ width: 20px;
902
+ height: 20px;
903
+ flex-shrink: 0;
904
+ font-family: var(--font-mono);
905
+ font-size: 10px;
906
+ font-weight: 500;
907
+ color: var(--accent);
908
+ background: var(--accent-faint);
909
+ border: 1px solid var(--ghost);
910
+ border-radius: var(--radius-sm);
911
+ }
912
+ .radar .qa-answer {
913
+ font-size: 0.8125rem;
914
+ color: var(--on-surface-variant);
915
+ line-height: 1.7;
916
+ padding-left: 1.75rem;
917
+ }
918
+
919
+ /* ── Agent Summary ── */
920
+ .radar .agent-layout {
921
+ display: grid;
922
+ grid-template-columns: 1fr 1fr;
923
+ gap: 1.5rem;
924
+ }
925
+ .radar .agent-table { width: 100%; border-collapse: collapse; }
926
+ .radar .agent-table th {
927
+ text-align: left;
928
+ padding: 0.5rem 0;
929
+ font-family: var(--font-mono);
930
+ font-size: 9px;
931
+ text-transform: uppercase;
932
+ letter-spacing: 0.05em;
933
+ color: var(--accent);
934
+ border-bottom: 1px solid var(--ghost);
935
+ font-weight: 400;
936
+ }
937
+ .radar .agent-table td {
938
+ padding: 0.5rem 0;
939
+ border-bottom: 1px solid var(--ghost);
940
+ font-size: 0.8125rem;
941
+ color: var(--on-surface);
942
+ }
943
+ .radar .agent-table td:nth-child(2),
944
+ .radar .agent-table td:nth-child(3) {
945
+ font-family: var(--font-mono);
946
+ text-align: right;
947
+ color: var(--on-surface-variant);
948
+ }
949
+
950
+ /* ── Agent Role Color Dots ── */
951
+ .radar .agent-dot {
952
+ display: inline-block;
953
+ width: 8px;
954
+ height: 8px;
955
+ border-radius: 50%;
956
+ margin-right: 0.5rem;
957
+ vertical-align: middle;
958
+ }
959
+ .radar .agent-dot--backend { background: #0891b2; }
960
+ .radar .agent-dot--backend-dev { background: #0891b2; }
961
+ .radar .agent-dot--qa { background: #059669; }
962
+ .radar .agent-dot--qa-engineer { background: #059669; }
963
+ .radar .agent-dot--frontend { background: #7c3aed; }
964
+ .radar .agent-dot--frontend-dev { background: #7c3aed; }
965
+ .radar .agent-dot--security { background: #475569; }
966
+ .radar .agent-dot--security-engineer { background: #475569; }
967
+ .radar .agent-dot--reviewer { background: #e11d48; }
968
+ .radar .agent-dot--code-reviewer { background: #e11d48; }
969
+
970
+ /* ── Agent Duration Bar Chart ── */
971
+ .radar .agent-bar-chart {
972
+ margin-top: 1rem;
973
+ }
974
+ .radar .agent-bar-row {
975
+ display: flex;
976
+ align-items: center;
977
+ gap: 0.5rem;
978
+ margin-bottom: 0.375rem;
979
+ }
980
+ .radar .agent-bar-row__label {
981
+ font-family: var(--font-mono);
982
+ font-size: 0.6875rem;
983
+ color: var(--on-surface-variant);
984
+ width: 100px;
985
+ text-align: right;
986
+ flex-shrink: 0;
987
+ }
988
+ .radar .agent-bar-row__bar {
989
+ height: 3px;
990
+ border-radius: 1px;
991
+ flex: 1;
992
+ max-width: 200px;
993
+ }
994
+ .radar .agent-bar-row__value {
995
+ font-family: var(--font-mono);
996
+ font-size: 0.6875rem;
997
+ color: var(--on-surface-variant);
998
+ width: 40px;
999
+ flex-shrink: 0;
1000
+ }
1001
+
1002
+ /* ── Footer ── */
1003
+ .radar .radar-footer {
1004
+ padding-top: 1.5rem;
1005
+ border-top: 1px solid var(--ghost);
1006
+ text-align: center;
1007
+ }
1008
+ .radar .radar-footer__text {
1009
+ font-family: var(--font-mono);
1010
+ font-size: 10px;
1011
+ color: var(--on-surface-variant);
1012
+ text-transform: uppercase;
1013
+ letter-spacing: 0.05em;
1014
+ }
1015
+
1016
+ /* ── Skip Link ── */
1017
+ .radar .skip-link {
1018
+ position: absolute;
1019
+ top: -100%;
1020
+ left: 1rem;
1021
+ padding: 0.5rem 1rem;
1022
+ background: var(--accent);
1023
+ color: var(--surface);
1024
+ font-family: var(--font-mono);
1025
+ font-size: 0.75rem;
1026
+ border-radius: var(--radius-sm);
1027
+ z-index: 200;
1028
+ text-decoration: none;
1029
+ }
1030
+ .radar .skip-link:focus { top: 1rem; }
1031
+
1032
+ /* ── Responsive ── */
1033
+ @media (max-width: 768px) {
1034
+ .radar .portfolio-header { flex-direction: column; gap: 1rem; }
1035
+ .radar .portfolio-photo { width: 80px; height: 100px; }
1036
+ .radar .portfolio-stats { gap: 0.5rem; }
1037
+ .radar .portfolio-stat { min-width: 80px; padding: 0.5rem 0.75rem; }
1038
+ .radar .portfolio-projects { grid-template-columns: 1fr; }
1039
+ .radar .two-col { grid-template-columns: 1fr; }
1040
+ .radar .session-grid { grid-template-columns: 1fr; }
1041
+ .radar .stat-grid { grid-template-columns: repeat(2, 1fr); }
1042
+ .radar .session-layout { grid-template-columns: 1fr; }
1043
+ .radar .session-layout > aside { order: -1; }
1044
+ .radar .session-meta-row { gap: 1rem; }
1045
+ .radar .stat-grid-inline { grid-template-columns: repeat(2, 1fr); }
1046
+ .radar .agent-layout { grid-template-columns: 1fr; }
1047
+ }
1048
+
1049
+ @media (max-width: 480px) {
1050
+ .radar .agent-bar-row__label { width: 70px; }
1051
+ }
1052
+
1053
+
1054
+ /* Live-edit empty field hiding */
1055
+ [data-portfolio-empty="true"] { display: none; }