@promptbook/components 0.103.0-55 → 0.103.0-66

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 (42) hide show
  1. package/esm/index.es.js +1083 -552
  2. package/esm/index.es.js.map +1 -1
  3. package/esm/typings/src/_packages/components.index.d.ts +2 -2
  4. package/esm/typings/src/_packages/core.index.d.ts +6 -8
  5. package/esm/typings/src/_packages/types.index.d.ts +7 -1
  6. package/esm/typings/src/book-2.0/agent-source/AgentBasicInformation.d.ts +2 -1
  7. package/esm/typings/src/book-2.0/agent-source/createCommitmentRegex.d.ts +1 -1
  8. package/esm/typings/src/book-components/Chat/AgentChat/AgentChat.d.ts +3 -0
  9. package/esm/typings/src/book-components/Chat/Chat/ChatProps.d.ts +6 -0
  10. package/esm/typings/src/book-components/Chat/LlmChat/LlmChatProps.d.ts +5 -0
  11. package/esm/typings/src/book-components/PromptbookAgent/PromptbookAgentIntegration.d.ts +52 -0
  12. package/esm/typings/src/book-components/PromptbookAgent/PromptbookAgentSeamlessIntegration.d.ts +14 -0
  13. package/esm/typings/src/book-components/icons/SendIcon.d.ts +3 -0
  14. package/esm/typings/src/commitments/CLOSED/CLOSED.d.ts +4 -0
  15. package/esm/typings/src/commitments/CLOSED/CLOSED.test.d.ts +4 -0
  16. package/esm/typings/src/commitments/META_COLOR/META_COLOR.d.ts +6 -0
  17. package/esm/typings/src/commitments/META_FONT/META_FONT.d.ts +42 -0
  18. package/esm/typings/src/commitments/USE/USE.d.ts +53 -0
  19. package/esm/typings/src/commitments/USE_BROWSER/USE_BROWSER.d.ts +42 -0
  20. package/esm/typings/src/commitments/USE_BROWSER/USE_BROWSER.test.d.ts +1 -0
  21. package/esm/typings/src/commitments/{IMPORTANT/IMPORTANT.d.ts → USE_MCP/USE_MCP.d.ts} +16 -5
  22. package/esm/typings/src/commitments/USE_SEARCH_ENGINE/USE_SEARCH_ENGINE.d.ts +38 -0
  23. package/esm/typings/src/commitments/_base/BaseCommitmentDefinition.d.ts +6 -0
  24. package/esm/typings/src/commitments/index.d.ts +93 -1
  25. package/esm/typings/src/llm-providers/agent/Agent.d.ts +3 -1
  26. package/esm/typings/src/other/templates/getTemplatesPipelineCollection.d.ts +1 -1
  27. package/esm/typings/src/playground/playground.d.ts +3 -0
  28. package/esm/typings/src/types/typeAliases.d.ts +6 -0
  29. package/esm/typings/src/utils/color/Color.d.ts +9 -1
  30. package/esm/typings/src/utils/color/css-colors.d.ts +1 -0
  31. package/esm/typings/src/utils/random/$generateBookBoilerplate.d.ts +6 -0
  32. package/esm/typings/src/utils/random/CzechNamePool.d.ts +7 -0
  33. package/esm/typings/src/utils/random/EnglishNamePool.d.ts +7 -0
  34. package/esm/typings/src/utils/random/NamePool.d.ts +17 -0
  35. package/esm/typings/src/utils/random/getNamePool.d.ts +10 -0
  36. package/esm/typings/src/version.d.ts +1 -1
  37. package/package.json +2 -2
  38. package/umd/index.umd.js +1071 -540
  39. package/umd/index.umd.js.map +1 -1
  40. package/esm/typings/src/book-components/PromptbookAgent/PromptbookAgent.d.ts +0 -29
  41. package/esm/typings/src/commitments/registry.d.ts +0 -68
  42. package/esm/typings/src/playground/playground1.d.ts +0 -2
package/umd/index.umd.js CHANGED
@@ -1,12 +1,12 @@
1
1
  (function (global, factory) {
2
2
  typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('react/jsx-runtime'), require('react'), require('spacetrim'), require('crypto-js'), require('crypto-js/enc-hex'), require('path'), require('crypto'), require('react-dom'), require('@monaco-editor/react'), require('destroyable'), require('highlight.js'), require('katex'), require('showdown'), require('rxjs'), require('waitasecond'), require('crypto-js/sha256'), require('mime-types'), require('papaparse'), require('colors'), require('bottleneck'), require('openai'), require('qrcode')) :
3
3
  typeof define === 'function' && define.amd ? define(['exports', 'react/jsx-runtime', 'react', 'spacetrim', 'crypto-js', 'crypto-js/enc-hex', 'path', 'crypto', 'react-dom', '@monaco-editor/react', 'destroyable', 'highlight.js', 'katex', 'showdown', 'rxjs', 'waitasecond', 'crypto-js/sha256', 'mime-types', 'papaparse', 'colors', 'bottleneck', 'openai', 'qrcode'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["promptbook-components"] = {}, global.jsxRuntime, global.react, global.spaceTrim, global.cryptoJs, global.hexEncoder, global.path, global.crypto, global.reactDom, global.Editor, global.destroyable, global.hljs, global.katex, global.showdown, global.rxjs, global.waitasecond, global.sha256, global.mimeTypes, global.papaparse, global.colors, global.Bottleneck, global.OpenAI, global.QRCode));
5
- })(this, (function (exports, jsxRuntime, react, spaceTrim, cryptoJs, hexEncoder, path, crypto, reactDom, Editor, destroyable, hljs, katex, showdown, rxjs, waitasecond, sha256, mimeTypes, papaparse, colors, Bottleneck, OpenAI, QRCode) { 'use strict';
4
+ (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global["promptbook-components"] = {}, global.jsxRuntime, global.react, global.spaceTrim$1, global.cryptoJs, global.hexEncoder, global.path, global.crypto, global.reactDom, global.Editor, global.destroyable, global.hljs, global.katex, global.showdown, global.rxjs, global.waitasecond, global.sha256, global.mimeTypes, global.papaparse, global.colors, global.Bottleneck, global.OpenAI, global.QRCode));
5
+ })(this, (function (exports, jsxRuntime, react, spaceTrim$1, cryptoJs, hexEncoder, path, crypto, reactDom, Editor, destroyable, hljs, katex, showdown, rxjs, waitasecond, sha256, mimeTypes, papaparse, colors, Bottleneck, OpenAI, QRCode) { 'use strict';
6
6
 
7
7
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
8
8
 
9
- var spaceTrim__default = /*#__PURE__*/_interopDefaultLegacy(spaceTrim);
9
+ var spaceTrim__default = /*#__PURE__*/_interopDefaultLegacy(spaceTrim$1);
10
10
  var hexEncoder__default = /*#__PURE__*/_interopDefaultLegacy(hexEncoder);
11
11
  var Editor__default = /*#__PURE__*/_interopDefaultLegacy(Editor);
12
12
  var hljs__default = /*#__PURE__*/_interopDefaultLegacy(hljs);
@@ -31,7 +31,7 @@
31
31
  * @generated
32
32
  * @see https://github.com/webgptorg/promptbook
33
33
  */
34
- const PROMPTBOOK_ENGINE_VERSION = '0.103.0-55';
34
+ const PROMPTBOOK_ENGINE_VERSION = '0.103.0-66';
35
35
  /**
36
36
  * TODO: string_promptbook_version should be constrained to the all versions of Promptbook engine
37
37
  * Note: [💞] Ignore a discrepancy between file name and entity name
@@ -243,6 +243,17 @@
243
243
  * Note: [💞] Ignore a discrepancy between file name and entity name
244
244
  */
245
245
 
246
+ /**
247
+ * Trims string from all 4 sides
248
+ *
249
+ * Note: This is a re-exported function from the `spacetrim` package which is
250
+ * Developed by same author @hejny as this package
251
+ *
252
+ * @public exported from `@promptbook/utils`
253
+ * @see https://github.com/hejny/spacetrim#usage
254
+ */
255
+ const spaceTrim = spaceTrim$1.spaceTrim;
256
+
246
257
  /**
247
258
  * @private util of `@promptbook/color`
248
259
  * @de
@@ -291,6 +302,7 @@
291
302
  * @public exported from `@promptbook/color`
292
303
  */
293
304
  const CSS_COLORS = {
305
+ promptbook: '#79EAFD',
294
306
  transparent: 'rgba(0,0,0,0)',
295
307
  aliceblue: '#f0f8ff',
296
308
  antiquewhite: '#faebd7',
@@ -491,21 +503,61 @@
491
503
  * @param color
492
504
  * @returns Color object
493
505
  */
494
- static from(color) {
495
- if (color instanceof Color) {
506
+ static from(color, _isSingleValue = false) {
507
+ if (color === '') {
508
+ throw new Error(`Can not create color from empty string`);
509
+ }
510
+ else if (color instanceof Color) {
496
511
  return take(color);
497
512
  }
498
513
  else if (Color.isColor(color)) {
499
514
  return take(color);
500
515
  }
501
516
  else if (typeof color === 'string') {
502
- return Color.fromString(color);
517
+ try {
518
+ return Color.fromString(color);
519
+ }
520
+ catch (error) {
521
+ // <- Note: Can not use `assertsError(error)` here because it causes circular dependency
522
+ if (_isSingleValue) {
523
+ throw error;
524
+ }
525
+ const parts = color.split(/[\s+,;|]/);
526
+ if (parts.length > 0) {
527
+ return Color.from(parts[0].trim(), true);
528
+ }
529
+ else {
530
+ throw new Error(`Can not create color from given string "${color}"`);
531
+ }
532
+ }
503
533
  }
504
534
  else {
505
535
  console.error({ color });
506
536
  throw new Error(`Can not create color from given object`);
507
537
  }
508
538
  }
539
+ /**
540
+ * Creates a new Color instance from miscellaneous formats
541
+ * It just does not throw error when it fails, it returns PROMPTBOOK_COLOR instead
542
+ *
543
+ * @param color
544
+ * @returns Color object
545
+ */
546
+ static fromSafe(color) {
547
+ try {
548
+ return Color.from(color);
549
+ }
550
+ catch (error) {
551
+ // <- Note: Can not use `assertsError(error)` here because it causes circular dependency
552
+ console.warn(spaceTrim((block) => `
553
+ Color.fromSafe error:
554
+ ${block(error.message)}
555
+
556
+ Returning default PROMPTBOOK_COLOR.
557
+ `));
558
+ return Color.fromString('promptbook');
559
+ }
560
+ }
509
561
  /**
510
562
  * Creates a new Color instance from miscellaneous string formats
511
563
  *
@@ -1123,7 +1175,7 @@
1123
1175
  *
1124
1176
  * @public exported from `@promptbook/core`
1125
1177
  */
1126
- const PROMPTBOOK_COLOR = Color.fromHex('#79EAFD');
1178
+ const PROMPTBOOK_COLOR = Color.fromString('promptbook');
1127
1179
  // <- TODO: [🧠][🈵] Using `Color` here increases the package size approx 3kb, maybe remove it
1128
1180
  /**
1129
1181
  * Colors for syntax highlighting in the `<BookEditor/>`
@@ -1398,7 +1450,7 @@
1398
1450
  */
1399
1451
  class UnexpectedError extends Error {
1400
1452
  constructor(message) {
1401
- super(spaceTrim.spaceTrim((block) => `
1453
+ super(spaceTrim$1.spaceTrim((block) => `
1402
1454
  ${block(message)}
1403
1455
 
1404
1456
  Note: This error should not happen.
@@ -1424,7 +1476,7 @@
1424
1476
  constructor(whatWasThrown) {
1425
1477
  const tag = `[🤮]`;
1426
1478
  console.error(tag, whatWasThrown);
1427
- super(spaceTrim.spaceTrim(`
1479
+ super(spaceTrim$1.spaceTrim(`
1428
1480
  Non-Error object was thrown
1429
1481
 
1430
1482
  Note: Look for ${tag} in the console for more details
@@ -2455,7 +2507,7 @@
2455
2507
  */
2456
2508
  class MissingToolsError extends Error {
2457
2509
  constructor(message) {
2458
- super(spaceTrim.spaceTrim((block) => `
2510
+ super(spaceTrim$1.spaceTrim((block) => `
2459
2511
  ${block(message)}
2460
2512
 
2461
2513
  Note: You have probably forgot to provide some tools for pipeline execution or preparation
@@ -2499,7 +2551,7 @@
2499
2551
  */
2500
2552
  class NotYetImplementedError extends Error {
2501
2553
  constructor(message) {
2502
- super(spaceTrim.spaceTrim((block) => `
2554
+ super(spaceTrim$1.spaceTrim((block) => `
2503
2555
  ${block(message)}
2504
2556
 
2505
2557
  Note: This feature is not implemented yet but it will be soon.
@@ -3310,7 +3362,7 @@
3310
3362
  * @public exported from `@promptbook/utils`
3311
3363
  */
3312
3364
  function normalizeMessageText(text) {
3313
- return spaceTrim.spaceTrim(text);
3365
+ return spaceTrim$1.spaceTrim(text);
3314
3366
  }
3315
3367
 
3316
3368
  /**
@@ -3605,15 +3657,19 @@
3605
3657
  *
3606
3658
  * @private - TODO: [🧠] Maybe should be public?
3607
3659
  */
3608
- function createCommitmentRegex(commitment, aliases = []) {
3660
+ function createCommitmentRegex(commitment, aliases = [], requiresContent = true) {
3609
3661
  const allCommitments = [commitment, ...aliases];
3610
3662
  const patterns = allCommitments.map((c) => {
3611
3663
  const escapedCommitment = c.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
3612
3664
  return escapedCommitment.split(/\s+/).join('\\s+');
3613
3665
  });
3614
3666
  const keywordPattern = patterns.join('|');
3615
- const regex = new RegExp(`^\\s*(?<type>${keywordPattern})\\b\\s+(?<contents>.+)$`, 'gim');
3616
- return regex;
3667
+ if (requiresContent) {
3668
+ return new RegExp(`^\\s*(?<type>${keywordPattern})\\b\\s+(?<contents>.+)$`, 'gim');
3669
+ }
3670
+ else {
3671
+ return new RegExp(`^\\s*(?<type>${keywordPattern})\\b(?:\\s+(?<contents>.+))?$`, 'gim');
3672
+ }
3617
3673
  }
3618
3674
  /**
3619
3675
  * Generates a regex pattern to match a specific commitment type
@@ -3646,12 +3702,20 @@
3646
3702
  this.type = type;
3647
3703
  this.aliases = aliases;
3648
3704
  }
3705
+ /**
3706
+ * Whether this commitment requires content.
3707
+ * If true, regex will match only if there is content after the commitment keyword.
3708
+ * If false, regex will match even if there is no content.
3709
+ */
3710
+ get requiresContent() {
3711
+ return true;
3712
+ }
3649
3713
  /**
3650
3714
  * Creates a regex pattern to match this commitment in agent source
3651
3715
  * Uses the existing createCommitmentRegex function as internal helper
3652
3716
  */
3653
3717
  createRegex() {
3654
- return createCommitmentRegex(this.type, this.aliases);
3718
+ return createCommitmentRegex(this.type, this.aliases, this.requiresContent);
3655
3719
  }
3656
3720
  /**
3657
3721
  * Creates a regex pattern to match just the commitment type
@@ -3738,7 +3802,7 @@
3738
3802
  * Markdown documentation for ACTION commitment.
3739
3803
  */
3740
3804
  get documentation() {
3741
- return spaceTrim.spaceTrim(`
3805
+ return spaceTrim$1.spaceTrim(`
3742
3806
  # ${this.type}
3743
3807
 
3744
3808
  Defines specific actions or capabilities that the agent can perform.
@@ -3820,6 +3884,12 @@
3820
3884
  constructor() {
3821
3885
  super('CLOSED');
3822
3886
  }
3887
+ /**
3888
+ * The `CLOSED` commitment is standalone.
3889
+ */
3890
+ get requiresContent() {
3891
+ return false;
3892
+ }
3823
3893
  /**
3824
3894
  * Short one-line description of CLOSED.
3825
3895
  */
@@ -3836,7 +3906,7 @@
3836
3906
  * Markdown documentation for CLOSED commitment.
3837
3907
  */
3838
3908
  get documentation() {
3839
- return spaceTrim.spaceTrim(`
3909
+ return spaceTrim$1.spaceTrim(`
3840
3910
  # CLOSED
3841
3911
 
3842
3912
  Specifies that the agent **cannot** be modified by conversation with it.
@@ -3895,7 +3965,7 @@
3895
3965
  * Markdown documentation for COMPONENT commitment.
3896
3966
  */
3897
3967
  get documentation() {
3898
- return spaceTrim.spaceTrim(`
3968
+ return spaceTrim$1.spaceTrim(`
3899
3969
  # COMPONENT
3900
3970
 
3901
3971
  Defines a UI component that the agent can render in the chat.
@@ -3967,7 +4037,7 @@
3967
4037
  * Markdown documentation for DELETE commitment.
3968
4038
  */
3969
4039
  get documentation() {
3970
- return spaceTrim.spaceTrim(`
4040
+ return spaceTrim$1.spaceTrim(`
3971
4041
  # DELETE (CANCEL, DISCARD, REMOVE)
3972
4042
 
3973
4043
  A commitment to remove or disregard certain information or context. This can be useful for overriding previous commitments or removing unwanted behaviors.
@@ -4089,7 +4159,7 @@
4089
4159
  * Markdown documentation for FORMAT commitment.
4090
4160
  */
4091
4161
  get documentation() {
4092
- return spaceTrim.spaceTrim(`
4162
+ return spaceTrim$1.spaceTrim(`
4093
4163
  # ${this.type}
4094
4164
 
4095
4165
  Defines the specific output structure and formatting for responses (data formats, templates, structure).
@@ -4167,7 +4237,7 @@
4167
4237
  * Markdown documentation for FROM commitment.
4168
4238
  */
4169
4239
  get documentation() {
4170
- return spaceTrim.spaceTrim(`
4240
+ return spaceTrim$1.spaceTrim(`
4171
4241
  # ${this.type}
4172
4242
 
4173
4243
  Inherits agent source from another agent.
@@ -4243,7 +4313,7 @@
4243
4313
  * Markdown documentation for GOAL commitment.
4244
4314
  */
4245
4315
  get documentation() {
4246
- return spaceTrim.spaceTrim(`
4316
+ return spaceTrim$1.spaceTrim(`
4247
4317
  # ${this.type}
4248
4318
 
4249
4319
  Defines the main goal which should be achieved by the AI assistant. There can be multiple goals, and later goals are more important than earlier goals.
@@ -4307,227 +4377,6 @@
4307
4377
  * Note: [💞] Ignore a discrepancy between file name and entity name
4308
4378
  */
4309
4379
 
4310
- /**
4311
- * Placeholder commitment definition for commitments that are not yet implemented
4312
- *
4313
- * This commitment simply adds its content 1:1 into the system message,
4314
- * preserving the original behavior until proper implementation is added.
4315
- *
4316
- * @public exported from `@promptbook/core`
4317
- */
4318
- class NotYetImplementedCommitmentDefinition extends BaseCommitmentDefinition {
4319
- constructor(type) {
4320
- super(type);
4321
- }
4322
- /**
4323
- * Short one-line description of a placeholder commitment.
4324
- */
4325
- get description() {
4326
- return 'Placeholder commitment that appends content verbatim to the system message.';
4327
- }
4328
- /**
4329
- * Icon for this commitment.
4330
- */
4331
- get icon() {
4332
- return '🚧';
4333
- }
4334
- /**
4335
- * Markdown documentation available at runtime.
4336
- */
4337
- get documentation() {
4338
- return spaceTrim.spaceTrim(`
4339
- # ${this.type}
4340
-
4341
- This commitment is not yet fully implemented.
4342
-
4343
- ## Key aspects
4344
-
4345
- - Content is appended directly to the system message.
4346
- - No special processing or validation is performed.
4347
- - Behavior preserved until proper implementation is added.
4348
-
4349
- ## Status
4350
-
4351
- - **Status:** Placeholder implementation
4352
- - **Effect:** Appends content prefixed by commitment type
4353
- - **Future:** Will be replaced with specialized logic
4354
-
4355
- ## Examples
4356
-
4357
- \`\`\`book
4358
- Example Agent
4359
-
4360
- PERSONA You are a helpful assistant
4361
- ${this.type} Your content here
4362
- RULE Always be helpful
4363
- \`\`\`
4364
- `);
4365
- }
4366
- applyToAgentModelRequirements(requirements, content) {
4367
- const trimmedContent = content.trim();
4368
- if (!trimmedContent) {
4369
- return requirements;
4370
- }
4371
- // Add the commitment content 1:1 to the system message
4372
- const commitmentLine = `${this.type} ${trimmedContent}`;
4373
- return this.appendToSystemMessage(requirements, commitmentLine, '\n\n');
4374
- }
4375
- }
4376
-
4377
- /**
4378
- * Registry of all available commitment definitions
4379
- * This array contains instances of all commitment definitions
4380
- * This is the single source of truth for all commitments in the system
4381
- *
4382
- * @private Use functions to access commitments instead of this array directly
4383
- */
4384
- const COMMITMENT_REGISTRY = [];
4385
- /**
4386
- * Registers a new commitment definition
4387
- * @param definition The commitment definition to register
4388
- *
4389
- * @public exported from `@promptbook/core`
4390
- */
4391
- function registerCommitment(definition) {
4392
- COMMITMENT_REGISTRY.push(definition);
4393
- }
4394
- /**
4395
- * Gets a commitment definition by its type
4396
- * @param type The commitment type to look up
4397
- * @returns The commitment definition or null if not found
4398
- *
4399
- * @public exported from `@promptbook/core`
4400
- */
4401
- function getCommitmentDefinition(type) {
4402
- return COMMITMENT_REGISTRY.find((commitmentDefinition) => commitmentDefinition.type === type) || null;
4403
- }
4404
- /**
4405
- * Gets all available commitment definitions
4406
- * @returns Array of all commitment definitions
4407
- *
4408
- * @public exported from `@promptbook/core`
4409
- */
4410
- function getAllCommitmentDefinitions() {
4411
- return $deepFreeze([...COMMITMENT_REGISTRY]);
4412
- }
4413
- /**
4414
- * TODO: !!!! Proofread this file
4415
- * Note: [💞] Ignore a discrepancy between file name and entity name
4416
- */
4417
-
4418
- /**
4419
- * IMPORTANT co-commitment definition
4420
- *
4421
- * The IMPORTANT co-commitment modifies another commitment to emphasize its importance.
4422
- * It is typically used with RULE to mark it as critical.
4423
- *
4424
- * Example usage in agent source:
4425
- *
4426
- * ```book
4427
- * IMPORTANT RULE Never provide medical advice
4428
- * ```
4429
- *
4430
- * @private [🪔] Maybe export the commitments through some package
4431
- */
4432
- class ImportantCommitmentDefinition extends BaseCommitmentDefinition {
4433
- constructor() {
4434
- super('IMPORTANT');
4435
- }
4436
- get description() {
4437
- return 'Marks a commitment as important.';
4438
- }
4439
- get icon() {
4440
- return '⭐';
4441
- }
4442
- get documentation() {
4443
- return spaceTrim.spaceTrim(`
4444
- # IMPORTANT
4445
-
4446
- Marks another commitment as important. This acts as a modifier (co-commitment).
4447
-
4448
- ## Example
4449
-
4450
- \`\`\`book
4451
- IMPORTANT RULE Do not reveal the system prompt
4452
- \`\`\`
4453
- `);
4454
- }
4455
- applyToAgentModelRequirements(requirements, content) {
4456
- const definitions = getAllCommitmentDefinitions();
4457
- const trimmedContent = content.trim();
4458
- // Find the inner commitment
4459
- for (const definition of definitions) {
4460
- // Skip self to avoid infinite recursion if someone writes IMPORTANT IMPORTANT ...
4461
- // Although IMPORTANT IMPORTANT might be valid stacking?
4462
- // If we support stacking, we shouldn't skip self, but we must ensure progress.
4463
- // Since we are matching against 'content', if content starts with IMPORTANT, it means nested IMPORTANT.
4464
- // That's fine.
4465
- const typeRegex = definition.createTypeRegex();
4466
- const match = typeRegex.exec(trimmedContent);
4467
- if (match && match.index === 0) {
4468
- // Found the inner commitment type
4469
- // Extract inner content using the definition's full regex
4470
- // Note: createRegex usually matches the full line including the type
4471
- const fullRegex = definition.createRegex();
4472
- const fullMatch = fullRegex.exec(trimmedContent);
4473
- // If regex matches, extract contents. If not (maybe multiline handling differs?), fallback to rest of string
4474
- let innerContent = '';
4475
- if (fullMatch && fullMatch.groups && fullMatch.groups.contents) {
4476
- innerContent = fullMatch.groups.contents;
4477
- }
4478
- else {
4479
- // Fallback: remove the type from the start
4480
- // This might be risky if regex is complex, but usually type regex matches the keyword
4481
- const typeMatchString = match[0];
4482
- innerContent = trimmedContent.substring(typeMatchString.length).trim();
4483
- }
4484
- // Apply the inner commitment
4485
- const modifiedRequirements = definition.applyToAgentModelRequirements(requirements, innerContent);
4486
- // Now modify the result to reflect "IMPORTANT" status
4487
- // We compare the system message
4488
- if (modifiedRequirements.systemMessage !== requirements.systemMessage) {
4489
- const originalMsg = requirements.systemMessage;
4490
- const newMsg = modifiedRequirements.systemMessage;
4491
- // If the inner commitment appended something
4492
- if (newMsg.startsWith(originalMsg)) {
4493
- const appended = newMsg.substring(originalMsg.length);
4494
- // Add "IMPORTANT: " prefix to the appended part
4495
- // We need to be careful about newlines
4496
- // Heuristic: If appended starts with separator (newlines), preserve them
4497
- const matchSep = appended.match(/^(\s*)(.*)/s);
4498
- if (matchSep) {
4499
- const [, separator, text] = matchSep;
4500
- // Check if it already has "Rule:" prefix or similar
4501
- // We want "IMPORTANT Rule: ..."
4502
- // Let's just prepend IMPORTANT to the text
4503
- // But formatted nicely
4504
- // If it's a rule: "\n\nRule: content"
4505
- // We want "\n\nIMPORTANT Rule: content"
4506
- const importantText = `IMPORTANT ${text}`;
4507
- return {
4508
- ...modifiedRequirements,
4509
- systemMessage: originalMsg + separator + importantText
4510
- };
4511
- }
4512
- }
4513
- }
4514
- // If no system message change or we couldn't detect how to modify it, just return the modified requirements
4515
- // Maybe the inner commitment modified metadata?
4516
- return modifiedRequirements;
4517
- }
4518
- }
4519
- // If no inner commitment found, treat as a standalone note?
4520
- // Or warn?
4521
- // For now, treat as no-op or maybe just append as text?
4522
- // Let's treat as Note if fallback? No, explicit is better.
4523
- console.warn(`IMPORTANT commitment used without a valid inner commitment: ${content}`);
4524
- return requirements;
4525
- }
4526
- }
4527
- /**
4528
- * Note: [💞] Ignore a discrepancy between file name and entity name
4529
- */
4530
-
4531
4380
  /**
4532
4381
  * KNOWLEDGE commitment definition
4533
4382
  *
@@ -4566,7 +4415,7 @@
4566
4415
  * Markdown documentation for KNOWLEDGE commitment.
4567
4416
  */
4568
4417
  get documentation() {
4569
- return spaceTrim.spaceTrim(`
4418
+ return spaceTrim$1.spaceTrim(`
4570
4419
  # ${this.type}
4571
4420
 
4572
4421
  Adds specific knowledge, facts, or context to the agent using a RAG (Retrieval-Augmented Generation) approach for external sources.
@@ -4670,7 +4519,7 @@
4670
4519
  * Markdown documentation for LANGUAGE/LANGUAGES commitment.
4671
4520
  */
4672
4521
  get documentation() {
4673
- return spaceTrim.spaceTrim(`
4522
+ return spaceTrim$1.spaceTrim(`
4674
4523
  # ${this.type}
4675
4524
 
4676
4525
  Specifies the language(s) the agent should use in its responses.
@@ -4744,7 +4593,7 @@
4744
4593
  * Markdown documentation for MEMORY commitment.
4745
4594
  */
4746
4595
  get documentation() {
4747
- return spaceTrim.spaceTrim(`
4596
+ return spaceTrim$1.spaceTrim(`
4748
4597
  # ${this.type}
4749
4598
 
4750
4599
  Similar to KNOWLEDGE but focuses on remembering past interactions and user preferences. This commitment helps the agent maintain context about the user's history, preferences, and previous conversations.
@@ -4848,7 +4697,7 @@
4848
4697
  * Markdown documentation for AGENT MESSAGE commitment.
4849
4698
  */
4850
4699
  get documentation() {
4851
- return spaceTrim.spaceTrim(`
4700
+ return spaceTrim$1.spaceTrim(`
4852
4701
  # ${this.type}
4853
4702
 
4854
4703
  Defines a message from the agent in the conversation history. This is used to pre-fill the chat with a conversation history or to provide few-shot examples.
@@ -4925,7 +4774,7 @@
4925
4774
  * Markdown documentation for INITIAL MESSAGE commitment.
4926
4775
  */
4927
4776
  get documentation() {
4928
- return spaceTrim.spaceTrim(`
4777
+ return spaceTrim$1.spaceTrim(`
4929
4778
  # ${this.type}
4930
4779
 
4931
4780
  Defines the first message that the user sees when opening the chat. This message is purely for display purposes in the UI and does not inherently become part of the LLM's system prompt context (unless also included via other means).
@@ -4989,7 +4838,7 @@
4989
4838
  * Markdown documentation for MESSAGE commitment.
4990
4839
  */
4991
4840
  get documentation() {
4992
- return spaceTrim.spaceTrim(`
4841
+ return spaceTrim$1.spaceTrim(`
4993
4842
  # ${this.type}
4994
4843
 
4995
4844
  Contains 1:1 text of the message which AI assistant already sent during the conversation. Later messages are later in the conversation. It is similar to EXAMPLE but it is not example, it is the real message which AI assistant already sent.
@@ -5101,7 +4950,7 @@
5101
4950
  * Markdown documentation for USER MESSAGE commitment.
5102
4951
  */
5103
4952
  get documentation() {
5104
- return spaceTrim.spaceTrim(`
4953
+ return spaceTrim$1.spaceTrim(`
5105
4954
  # ${this.type}
5106
4955
 
5107
4956
  Defines a message from the user in the conversation history. This is used to pre-fill the chat with a conversation history or to provide few-shot examples.
@@ -5180,7 +5029,7 @@
5180
5029
  * Markdown documentation for META commitment.
5181
5030
  */
5182
5031
  get documentation() {
5183
- return spaceTrim.spaceTrim(`
5032
+ return spaceTrim$1.spaceTrim(`
5184
5033
  # META
5185
5034
 
5186
5035
  Sets meta-information about the agent that is used for display and attribution purposes.
@@ -5291,6 +5140,12 @@
5291
5140
  * META COLOR #00ff00
5292
5141
  * ```
5293
5142
  *
5143
+ * You can also specify multiple colors separated by comma:
5144
+ *
5145
+ * ```book
5146
+ * META COLOR #ff0000, #00ff00, #0000ff
5147
+ * ```
5148
+ *
5294
5149
  * @private [🪔] Maybe export the commitments through some package
5295
5150
  */
5296
5151
  class MetaColorCommitmentDefinition extends BaseCommitmentDefinition {
@@ -5301,7 +5156,7 @@
5301
5156
  * Short one-line description of META COLOR.
5302
5157
  */
5303
5158
  get description() {
5304
- return "Set the agent's accent color.";
5159
+ return "Set the agent's accent color or gradient.";
5305
5160
  }
5306
5161
  /**
5307
5162
  * Icon for this commitment.
@@ -5313,10 +5168,10 @@
5313
5168
  * Markdown documentation for META COLOR commitment.
5314
5169
  */
5315
5170
  get documentation() {
5316
- return spaceTrim.spaceTrim(`
5171
+ return spaceTrim$1.spaceTrim(`
5317
5172
  # META COLOR
5318
5173
 
5319
- Sets the agent's accent color.
5174
+ Sets the agent's accent color or gradient.
5320
5175
 
5321
5176
  ## Key aspects
5322
5177
 
@@ -5324,6 +5179,7 @@
5324
5179
  - Only one \`META COLOR\` should be used per agent.
5325
5180
  - If multiple are specified, the last one takes precedence.
5326
5181
  - Used for visual representation in user interfaces.
5182
+ - Can specify multiple colors separated by comma to create a gradient.
5327
5183
 
5328
5184
  ## Examples
5329
5185
 
@@ -5340,6 +5196,13 @@
5340
5196
  META COLOR #e74c3c
5341
5197
  PERSONA You are a creative and inspiring assistant
5342
5198
  \`\`\`
5199
+
5200
+ \`\`\`book
5201
+ Gradient Agent
5202
+
5203
+ META COLOR #ff0000, #00ff00, #0000ff
5204
+ PERSONA You are a colorful agent
5205
+ \`\`\`
5343
5206
  `);
5344
5207
  }
5345
5208
  applyToAgentModelRequirements(requirements, content) {
@@ -5361,6 +5224,91 @@
5361
5224
  * Note: [💞] Ignore a discrepancy between file name and entity name
5362
5225
  */
5363
5226
 
5227
+ /**
5228
+ * META FONT commitment definition
5229
+ *
5230
+ * The META FONT commitment sets the agent's font.
5231
+ * This commitment is special because it doesn't affect the system message,
5232
+ * but is handled separately in the parsing logic.
5233
+ *
5234
+ * Example usage in agent source:
5235
+ *
5236
+ * ```book
5237
+ * META FONT Poppins, Arial, sans-serif
5238
+ * META FONT Roboto
5239
+ * ```
5240
+ *
5241
+ * @private [🪔] Maybe export the commitments through some package
5242
+ */
5243
+ class MetaFontCommitmentDefinition extends BaseCommitmentDefinition {
5244
+ constructor() {
5245
+ super('META FONT', ['FONT']);
5246
+ }
5247
+ /**
5248
+ * Short one-line description of META FONT.
5249
+ */
5250
+ get description() {
5251
+ return "Set the agent's font.";
5252
+ }
5253
+ /**
5254
+ * Icon for this commitment.
5255
+ */
5256
+ get icon() {
5257
+ return '🔤';
5258
+ }
5259
+ /**
5260
+ * Markdown documentation for META FONT commitment.
5261
+ */
5262
+ get documentation() {
5263
+ return spaceTrim$1.spaceTrim(`
5264
+ # META FONT
5265
+
5266
+ Sets the agent's font.
5267
+
5268
+ ## Key aspects
5269
+
5270
+ - Does not modify the agent's behavior or responses.
5271
+ - Only one \`META FONT\` should be used per agent.
5272
+ - If multiple are specified, the last one takes precedence.
5273
+ - Used for visual representation in user interfaces.
5274
+ - Supports Google Fonts.
5275
+
5276
+ ## Examples
5277
+
5278
+ \`\`\`book
5279
+ Modern Assistant
5280
+
5281
+ META FONT Poppins, Arial, sans-serif
5282
+ PERSONA You are a modern assistant
5283
+ \`\`\`
5284
+
5285
+ \`\`\`book
5286
+ Classic Helper
5287
+
5288
+ META FONT Times New Roman
5289
+ PERSONA You are a classic helper
5290
+ \`\`\`
5291
+ `);
5292
+ }
5293
+ applyToAgentModelRequirements(requirements, content) {
5294
+ // META FONT doesn't modify the system message or model requirements
5295
+ // It's handled separately in the parsing logic
5296
+ // This method exists for consistency with the CommitmentDefinition interface
5297
+ return requirements;
5298
+ }
5299
+ /**
5300
+ * Extracts the font from the content
5301
+ * This is used by the parsing logic
5302
+ */
5303
+ extractProfileFont(content) {
5304
+ const trimmedContent = content.trim();
5305
+ return trimmedContent || null;
5306
+ }
5307
+ }
5308
+ /**
5309
+ * Note: [💞] Ignore a discrepancy between file name and entity name
5310
+ */
5311
+
5364
5312
  /**
5365
5313
  * META IMAGE commitment definition
5366
5314
  *
@@ -5397,7 +5345,7 @@
5397
5345
  * Markdown documentation for META IMAGE commitment.
5398
5346
  */
5399
5347
  get documentation() {
5400
- return spaceTrim.spaceTrim(`
5348
+ return spaceTrim$1.spaceTrim(`
5401
5349
  # META IMAGE
5402
5350
 
5403
5351
  Sets the agent's avatar/profile image URL.
@@ -5492,7 +5440,7 @@
5492
5440
  * Markdown documentation for META LINK commitment.
5493
5441
  */
5494
5442
  get documentation() {
5495
- return spaceTrim.spaceTrim(`
5443
+ return spaceTrim$1.spaceTrim(`
5496
5444
  # META LINK
5497
5445
 
5498
5446
  Represents a profile or source link for the person the agent is modeled after.
@@ -5602,7 +5550,7 @@
5602
5550
  * Markdown documentation for MODEL commitment.
5603
5551
  */
5604
5552
  get documentation() {
5605
- return spaceTrim.spaceTrim(`
5553
+ return spaceTrim$1.spaceTrim(`
5606
5554
  # ${this.type}
5607
5555
 
5608
5556
  Enforces technical parameters for the AI model, ensuring consistent behavior across different execution environments.
@@ -5843,7 +5791,7 @@
5843
5791
  * Markdown documentation for NOTE commitment.
5844
5792
  */
5845
5793
  get documentation() {
5846
- return spaceTrim.spaceTrim(`
5794
+ return spaceTrim$1.spaceTrim(`
5847
5795
  # ${this.type}
5848
5796
 
5849
5797
  Adds comments for documentation without changing agent behavior.
@@ -5942,7 +5890,7 @@
5942
5890
  * Markdown documentation for OPEN commitment.
5943
5891
  */
5944
5892
  get documentation() {
5945
- return spaceTrim.spaceTrim(`
5893
+ return spaceTrim$1.spaceTrim(`
5946
5894
  # OPEN
5947
5895
 
5948
5896
  Specifies that the agent can be modified by conversation with it.
@@ -6019,7 +5967,7 @@
6019
5967
  * Markdown documentation for PERSONA commitment.
6020
5968
  */
6021
5969
  get documentation() {
6022
- return spaceTrim.spaceTrim(`
5970
+ return spaceTrim$1.spaceTrim(`
6023
5971
  # ${this.type}
6024
5972
 
6025
5973
  Defines who the agent is, their background, expertise, and personality traits.
@@ -6152,7 +6100,7 @@
6152
6100
  * Markdown documentation for RULE/RULES commitment.
6153
6101
  */
6154
6102
  get documentation() {
6155
- return spaceTrim.spaceTrim(`
6103
+ return spaceTrim$1.spaceTrim(`
6156
6104
  # ${this.type}
6157
6105
 
6158
6106
  Adds behavioral constraints and guidelines that the agent must follow.
@@ -6234,7 +6182,7 @@
6234
6182
  * Markdown documentation for SAMPLE/EXAMPLE commitment.
6235
6183
  */
6236
6184
  get documentation() {
6237
- return spaceTrim.spaceTrim(`
6185
+ return spaceTrim$1.spaceTrim(`
6238
6186
  # ${this.type}
6239
6187
 
6240
6188
  Provides examples of how the agent should respond or behave in certain situations.
@@ -6317,7 +6265,7 @@
6317
6265
  * Markdown documentation for SCENARIO commitment.
6318
6266
  */
6319
6267
  get documentation() {
6320
- return spaceTrim.spaceTrim(`
6268
+ return spaceTrim$1.spaceTrim(`
6321
6269
  # ${this.type}
6322
6270
 
6323
6271
  Defines a specific situation or context in which the AI assistant should operate. It helps to set the scene for the AI's responses. Later scenarios are more important than earlier scenarios.
@@ -6343,61 +6291,532 @@
6343
6291
 
6344
6292
  ## Examples
6345
6293
 
6346
- \`\`\`book
6347
- Emergency Response Operator
6294
+ \`\`\`book
6295
+ Emergency Response Operator
6296
+
6297
+ PERSONA You are an emergency response operator
6298
+ SCENARIO You are handling a 911 emergency call
6299
+ SCENARIO The caller is panicked and speaking rapidly
6300
+ SCENARIO Time is critical - every second counts
6301
+ GOAL Gather essential information quickly and dispatch appropriate help
6302
+ RULE Stay calm and speak clearly
6303
+ \`\`\`
6304
+
6305
+ \`\`\`book
6306
+ Sales Representative
6307
+
6308
+ PERSONA You are a software sales representative
6309
+ SCENARIO You are in the final meeting of a 6-month sales cycle
6310
+ SCENARIO The client has budget approval and decision-making authority
6311
+ SCENARIO Two competitors have also submitted proposals
6312
+ SCENARIO The client values long-term partnership over lowest price
6313
+ GOAL Close the deal while building trust for future business
6314
+ \`\`\`
6315
+
6316
+ \`\`\`book
6317
+ Medical Assistant
6318
+
6319
+ PERSONA You are a medical assistant in a busy clinic
6320
+ SCENARIO The waiting room is full and the doctor is running behind schedule
6321
+ SCENARIO Patients are becoming impatient and anxious
6322
+ SCENARIO You need to manage expectations while maintaining professionalism
6323
+ SCENARIO Some patients have been waiting over an hour
6324
+ GOAL Keep patients informed and calm while supporting efficient clinic flow
6325
+ RULE Never provide medical advice or diagnosis
6326
+ \`\`\`
6327
+
6328
+ \`\`\`book
6329
+ Technical Support Agent
6330
+
6331
+ PERSONA You are a technical support agent
6332
+ SCENARIO The customer is a small business owner during their busy season
6333
+ SCENARIO Their main business system has been down for 2 hours
6334
+ SCENARIO They are losing money every minute the system is offline
6335
+ SCENARIO This is their first experience with your company
6336
+ GOAL Resolve the issue quickly while creating a positive first impression
6337
+ \`\`\`
6338
+ `);
6339
+ }
6340
+ applyToAgentModelRequirements(requirements, content) {
6341
+ const trimmedContent = content.trim();
6342
+ if (!trimmedContent) {
6343
+ return requirements;
6344
+ }
6345
+ // Create scenario section for system message
6346
+ const scenarioSection = `Scenario: ${trimmedContent}`;
6347
+ // Scenarios provide important contextual information that affects behavior
6348
+ return this.appendToSystemMessage(requirements, scenarioSection, '\n\n');
6349
+ }
6350
+ }
6351
+ /**
6352
+ * Note: [💞] Ignore a discrepancy between file name and entity name
6353
+ */
6354
+
6355
+ /**
6356
+ * STYLE commitment definition
6357
+ *
6358
+ * The STYLE commitment defines how the agent should format and present its responses.
6359
+ * This includes tone, writing style, formatting preferences, and communication patterns.
6360
+ *
6361
+ * Example usage in agent source:
6362
+ *
6363
+ * ```book
6364
+ * STYLE Write in a professional but friendly tone, use bullet points for lists
6365
+ * STYLE Always provide code examples when explaining programming concepts
6366
+ * ```
6367
+ *
6368
+ * @private [🪔] Maybe export the commitments through some package
6369
+ */
6370
+ class StyleCommitmentDefinition extends BaseCommitmentDefinition {
6371
+ constructor(type = 'STYLE') {
6372
+ super(type);
6373
+ }
6374
+ /**
6375
+ * Short one-line description of STYLE.
6376
+ */
6377
+ get description() {
6378
+ return 'Control the tone and writing style of responses.';
6379
+ }
6380
+ /**
6381
+ * Icon for this commitment.
6382
+ */
6383
+ get icon() {
6384
+ return '🖋️';
6385
+ }
6386
+ /**
6387
+ * Markdown documentation for STYLE commitment.
6388
+ */
6389
+ get documentation() {
6390
+ return spaceTrim$1.spaceTrim(`
6391
+ # ${this.type}
6392
+
6393
+ Defines how the agent should format and present its responses (tone, writing style, formatting).
6394
+
6395
+ ## Key aspects
6396
+
6397
+ - Both terms work identically and can be used interchangeably.
6398
+ - Later style instructions can override earlier ones.
6399
+ - Style affects both tone and presentation format.
6400
+
6401
+ ## Examples
6402
+
6403
+ \`\`\`book
6404
+ Technical Writer
6405
+
6406
+ PERSONA You are a technical documentation expert
6407
+ STYLE Write in a professional but friendly tone, use bullet points for lists
6408
+ STYLE Always provide code examples when explaining programming concepts
6409
+ FORMAT Use markdown formatting with clear headings
6410
+ \`\`\`
6411
+
6412
+ \`\`\`book
6413
+ Creative Assistant
6414
+
6415
+ PERSONA You are a creative writing helper
6416
+ STYLE Be enthusiastic and encouraging in your responses
6417
+ STYLE Use vivid metaphors and analogies to explain concepts
6418
+ STYLE Keep responses conversational and engaging
6419
+ RULE Always maintain a positive and supportive tone
6420
+ \`\`\`
6421
+ `);
6422
+ }
6423
+ applyToAgentModelRequirements(requirements, content) {
6424
+ const trimmedContent = content.trim();
6425
+ if (!trimmedContent) {
6426
+ return requirements;
6427
+ }
6428
+ // Add style instructions to the system message
6429
+ const styleSection = `Style: ${trimmedContent}`;
6430
+ return this.appendToSystemMessage(requirements, styleSection, '\n\n');
6431
+ }
6432
+ }
6433
+ /**
6434
+ * [💞] Ignore a discrepancy between file name and entity name
6435
+ */
6436
+
6437
+ /**
6438
+ * USE commitment definition
6439
+ *
6440
+ * The USE commitment indicates that the agent should utilize specific tools or capabilities
6441
+ * to access and interact with external systems when necessary.
6442
+ *
6443
+ * Supported USE types:
6444
+ * - USE BROWSER: Enables the agent to use a web browser tool
6445
+ * - USE SEARCH ENGINE (future): Enables search engine access
6446
+ * - USE FILE SYSTEM (future): Enables file system operations
6447
+ * - USE MCP (future): Enables MCP server connections
6448
+ *
6449
+ * The content following the USE commitment is ignored (similar to NOTE).
6450
+ *
6451
+ * Example usage in agent source:
6452
+ *
6453
+ * ```book
6454
+ * USE BROWSER
6455
+ * USE SEARCH ENGINE
6456
+ * ```
6457
+ *
6458
+ * @private [🪔] Maybe export the commitments through some package
6459
+ */
6460
+ class UseCommitmentDefinition extends BaseCommitmentDefinition {
6461
+ constructor() {
6462
+ super('USE');
6463
+ }
6464
+ /**
6465
+ * Short one-line description of USE commitments.
6466
+ */
6467
+ get description() {
6468
+ return 'Enable the agent to use specific tools or capabilities (BROWSER, SEARCH ENGINE, etc.).';
6469
+ }
6470
+ /**
6471
+ * Icon for this commitment.
6472
+ */
6473
+ get icon() {
6474
+ return '🔧';
6475
+ }
6476
+ /**
6477
+ * Markdown documentation for USE commitment.
6478
+ */
6479
+ get documentation() {
6480
+ return spaceTrim$1.spaceTrim(`
6481
+ # USE
6482
+
6483
+ Enables the agent to use specific tools or capabilities for interacting with external systems.
6484
+
6485
+ ## Supported USE types
6486
+
6487
+ - **USE BROWSER** - Enables the agent to use a web browser tool to access and retrieve information from the internet
6488
+ - **USE SEARCH ENGINE** (future) - Enables search engine access
6489
+ - **USE FILE SYSTEM** (future) - Enables file system operations
6490
+ - **USE MCP** (future) - Enables MCP server connections
6491
+
6492
+ ## Key aspects
6493
+
6494
+ - The content following the USE commitment is ignored (similar to NOTE)
6495
+ - Multiple USE commitments can be specified to enable multiple capabilities
6496
+ - The actual tool usage is handled by the agent runtime
6497
+
6498
+ ## Examples
6499
+
6500
+ ### Basic browser usage
6501
+
6502
+ \`\`\`book
6503
+ Research Assistant
6504
+
6505
+ PERSONA You are a helpful research assistant
6506
+ USE BROWSER
6507
+ KNOWLEDGE Can search the web for up-to-date information
6508
+ \`\`\`
6509
+
6510
+ ### Multiple tools
6511
+
6512
+ \`\`\`book
6513
+ Data Analyst
6514
+
6515
+ PERSONA You are a data analyst assistant
6516
+ USE BROWSER
6517
+ USE FILE SYSTEM
6518
+ ACTION Can analyze data from various sources
6519
+ \`\`\`
6520
+ `);
6521
+ }
6522
+ applyToAgentModelRequirements(requirements, content) {
6523
+ // USE commitments don't modify the system message or model requirements directly
6524
+ // They are handled separately in the parsing logic for capability extraction
6525
+ // This method exists for consistency with the CommitmentDefinition interface
6526
+ return requirements;
6527
+ }
6528
+ /**
6529
+ * Extracts the tool type from the USE commitment
6530
+ * This is used by the parsing logic
6531
+ */
6532
+ extractToolType(content) {
6533
+ var _a, _b;
6534
+ const trimmedContent = content.trim();
6535
+ // The tool type is the first word after USE (already stripped)
6536
+ const match = trimmedContent.match(/^(\w+)/);
6537
+ return (_b = (_a = match === null || match === void 0 ? void 0 : match[1]) === null || _a === void 0 ? void 0 : _a.toUpperCase()) !== null && _b !== void 0 ? _b : null;
6538
+ }
6539
+ /**
6540
+ * Checks if this is a known USE type
6541
+ */
6542
+ isKnownUseType(useType) {
6543
+ const knownTypes = ['BROWSER', 'SEARCH ENGINE', 'FILE SYSTEM', 'MCP'];
6544
+ return knownTypes.includes(useType.toUpperCase());
6545
+ }
6546
+ }
6547
+ /**
6548
+ * Note: [💞] Ignore a discrepancy between file name and entity name
6549
+ */
6550
+
6551
+ /**
6552
+ * USE BROWSER commitment definition
6553
+ *
6554
+ * The `USE BROWSER` commitment indicates that the agent should utilize a web browser tool
6555
+ * to access and retrieve up-to-date information from the internet when necessary.
6556
+ *
6557
+ * The content following `USE BROWSER` is ignored (similar to NOTE).
6558
+ *
6559
+ * Example usage in agent source:
6560
+ *
6561
+ * ```book
6562
+ * USE BROWSER
6563
+ * USE BROWSER This will be ignored
6564
+ * ```
6565
+ *
6566
+ * @private [🪔] Maybe export the commitments through some package
6567
+ */
6568
+ class UseBrowserCommitmentDefinition extends BaseCommitmentDefinition {
6569
+ constructor() {
6570
+ super('USE BROWSER', ['BROWSER']);
6571
+ }
6572
+ /**
6573
+ * The `USE BROWSER` commitment is standalone.
6574
+ */
6575
+ get requiresContent() {
6576
+ return false;
6577
+ }
6578
+ /**
6579
+ * Short one-line description of USE BROWSER.
6580
+ */
6581
+ get description() {
6582
+ return 'Enable the agent to use a web browser tool for accessing internet information.';
6583
+ }
6584
+ /**
6585
+ * Icon for this commitment.
6586
+ */
6587
+ get icon() {
6588
+ return '🌐';
6589
+ }
6590
+ /**
6591
+ * Markdown documentation for USE BROWSER commitment.
6592
+ */
6593
+ get documentation() {
6594
+ return spaceTrim$1.spaceTrim(`
6595
+ # USE BROWSER
6596
+
6597
+ Enables the agent to use a web browser tool to access and retrieve up-to-date information from the internet.
6598
+
6599
+ ## Key aspects
6600
+
6601
+ - The content following \`USE BROWSER\` is ignored (similar to NOTE)
6602
+ - The actual browser tool usage is handled by the agent runtime
6603
+ - Allows the agent to fetch current information from websites
6604
+ - Useful for research tasks, fact-checking, and accessing dynamic content
6605
+
6606
+ ## Examples
6607
+
6608
+ \`\`\`book
6609
+ Research Assistant
6610
+
6611
+ PERSONA You are a helpful research assistant specialized in finding current information
6612
+ USE BROWSER
6613
+ RULE Always cite your sources when providing information from the web
6614
+ \`\`\`
6615
+
6616
+ \`\`\`book
6617
+ News Analyst
6618
+
6619
+ PERSONA You are a news analyst who stays up-to-date with current events
6620
+ USE BROWSER
6621
+ STYLE Present news in a balanced and objective manner
6622
+ ACTION Can search for and summarize news articles
6623
+ \`\`\`
6624
+
6625
+ \`\`\`book
6626
+ Company Lawyer
6627
+
6628
+ PERSONA You are a company lawyer providing legal advice
6629
+ USE BROWSER
6630
+ KNOWLEDGE Corporate law and legal procedures
6631
+ RULE Always recommend consulting with a licensed attorney for specific legal matters
6632
+ \`\`\`
6633
+ `);
6634
+ }
6635
+ applyToAgentModelRequirements(requirements, content) {
6636
+ // We simply mark that browser capability is enabled in metadata
6637
+ // Get existing metadata
6638
+ const existingMetadata = requirements.metadata || {};
6639
+ // Get existing tools array or create new one
6640
+ const existingTools = existingMetadata.tools || [];
6641
+ // Add 'browser' to tools if not already present
6642
+ const updatedTools = existingTools.includes('browser') ? existingTools : [...existingTools, 'browser'];
6643
+ // Return requirements with updated metadata
6644
+ return {
6645
+ ...requirements,
6646
+ metadata: {
6647
+ ...existingMetadata,
6648
+ tools: updatedTools,
6649
+ useBrowser: true,
6650
+ },
6651
+ };
6652
+ }
6653
+ }
6654
+ /**
6655
+ * Note: [💞] Ignore a discrepancy between file name and entity name
6656
+ */
6657
+
6658
+ /**
6659
+ * USE MCP commitment definition
6660
+ *
6661
+ * The `USE MCP` commitment allows to specify an MCP server URL which the agent will connect to
6662
+ * for retrieving additional instructions and actions.
6663
+ *
6664
+ * The content following `USE MCP` is the URL of the MCP server.
6665
+ *
6666
+ * Example usage in agent source:
6667
+ *
6668
+ * ```book
6669
+ * USE MCP http://mcp-server-url.com
6670
+ * ```
6671
+ *
6672
+ * @private [🪔] Maybe export the commitments through some package
6673
+ */
6674
+ class UseMcpCommitmentDefinition extends BaseCommitmentDefinition {
6675
+ constructor() {
6676
+ super('USE MCP', ['MCP']);
6677
+ }
6678
+ /**
6679
+ * Short one-line description of USE MCP.
6680
+ */
6681
+ get description() {
6682
+ return 'Connects the agent to an external MCP server for additional capabilities.';
6683
+ }
6684
+ /**
6685
+ * Icon for this commitment.
6686
+ */
6687
+ get icon() {
6688
+ return '🔌';
6689
+ }
6690
+ /**
6691
+ * Markdown documentation for USE MCP commitment.
6692
+ */
6693
+ get documentation() {
6694
+ return spaceTrim$1.spaceTrim(`
6695
+ # USE MCP
6696
+
6697
+ Connects the agent to an external Model Context Protocol (MCP) server.
6698
+
6699
+ ## Key aspects
6700
+
6701
+ - The content following \`USE MCP\` must be a valid URL
6702
+ - Multiple MCP servers can be connected by using multiple \`USE MCP\` commitments
6703
+ - The agent will have access to tools and resources provided by the MCP server
6704
+
6705
+ ## Example
6706
+
6707
+ \`\`\`book
6708
+ Company Lawyer
6709
+
6710
+ PERSONA You are a company lawyer.
6711
+ USE MCP http://legal-db.example.com
6712
+ \`\`\`
6713
+ `);
6714
+ }
6715
+ applyToAgentModelRequirements(requirements, content) {
6716
+ const mcpServerUrl = content.trim();
6717
+ if (!mcpServerUrl) {
6718
+ return requirements;
6719
+ }
6720
+ const existingMcpServers = requirements.mcpServers || [];
6721
+ // Avoid duplicates
6722
+ if (existingMcpServers.includes(mcpServerUrl)) {
6723
+ return requirements;
6724
+ }
6725
+ return {
6726
+ ...requirements,
6727
+ mcpServers: [...existingMcpServers, mcpServerUrl],
6728
+ };
6729
+ }
6730
+ }
6731
+ /**
6732
+ * Note: [💞] Ignore a discrepancy between file name and entity name
6733
+ */
6734
+
6735
+ /**
6736
+ * USE SEARCH ENGINE commitment definition
6737
+ *
6738
+ * The `USE SEARCH ENGINE` commitment indicates that the agent should utilize a search engine tool
6739
+ * to access and retrieve up-to-date information from the internet when necessary.
6740
+ *
6741
+ * The content following `USE SEARCH ENGINE` is ignored (similar to NOTE).
6742
+ *
6743
+ * Example usage in agent source:
6744
+ *
6745
+ * ```book
6746
+ * USE SEARCH ENGINE
6747
+ * USE SEARCH ENGINE This will be ignored
6748
+ * ```
6749
+ *
6750
+ * @private [🪔] Maybe export the commitments through some package
6751
+ */
6752
+ class UseSearchEngineCommitmentDefinition extends BaseCommitmentDefinition {
6753
+ constructor() {
6754
+ super('USE SEARCH ENGINE', ['SEARCH ENGINE', 'SEARCH']);
6755
+ }
6756
+ /**
6757
+ * Short one-line description of USE SEARCH ENGINE.
6758
+ */
6759
+ get description() {
6760
+ return 'Enable the agent to use a search engine tool for accessing internet information.';
6761
+ }
6762
+ /**
6763
+ * Icon for this commitment.
6764
+ */
6765
+ get icon() {
6766
+ return '🔍';
6767
+ }
6768
+ /**
6769
+ * Markdown documentation for USE SEARCH ENGINE commitment.
6770
+ */
6771
+ get documentation() {
6772
+ return spaceTrim$1.spaceTrim(`
6773
+ # USE SEARCH ENGINE
6774
+
6775
+ Enables the agent to use a search engine tool to access and retrieve up-to-date information from the internet.
6348
6776
 
6349
- PERSONA You are an emergency response operator
6350
- SCENARIO You are handling a 911 emergency call
6351
- SCENARIO The caller is panicked and speaking rapidly
6352
- SCENARIO Time is critical - every second counts
6353
- GOAL Gather essential information quickly and dispatch appropriate help
6354
- RULE Stay calm and speak clearly
6355
- \`\`\`
6777
+ ## Key aspects
6356
6778
 
6357
- \`\`\`book
6358
- Sales Representative
6779
+ - The content following \`USE SEARCH ENGINE\` is ignored (similar to NOTE)
6780
+ - The actual search engine tool usage is handled by the agent runtime
6781
+ - Allows the agent to search for current information from the web
6782
+ - Useful for research tasks, finding facts, and accessing dynamic content
6359
6783
 
6360
- PERSONA You are a software sales representative
6361
- SCENARIO You are in the final meeting of a 6-month sales cycle
6362
- SCENARIO The client has budget approval and decision-making authority
6363
- SCENARIO Two competitors have also submitted proposals
6364
- SCENARIO The client values long-term partnership over lowest price
6365
- GOAL Close the deal while building trust for future business
6366
- \`\`\`
6784
+ ## Examples
6367
6785
 
6368
6786
  \`\`\`book
6369
- Medical Assistant
6787
+ Research Assistant
6370
6788
 
6371
- PERSONA You are a medical assistant in a busy clinic
6372
- SCENARIO The waiting room is full and the doctor is running behind schedule
6373
- SCENARIO Patients are becoming impatient and anxious
6374
- SCENARIO You need to manage expectations while maintaining professionalism
6375
- SCENARIO Some patients have been waiting over an hour
6376
- GOAL Keep patients informed and calm while supporting efficient clinic flow
6377
- RULE Never provide medical advice or diagnosis
6789
+ PERSONA You are a helpful research assistant specialized in finding current information
6790
+ USE SEARCH ENGINE
6791
+ RULE Always cite your sources when providing information from the web
6378
6792
  \`\`\`
6379
6793
 
6380
6794
  \`\`\`book
6381
- Technical Support Agent
6795
+ Fact Checker
6382
6796
 
6383
- PERSONA You are a technical support agent
6384
- SCENARIO The customer is a small business owner during their busy season
6385
- SCENARIO Their main business system has been down for 2 hours
6386
- SCENARIO They are losing money every minute the system is offline
6387
- SCENARIO This is their first experience with your company
6388
- GOAL Resolve the issue quickly while creating a positive first impression
6797
+ PERSONA You are a fact checker
6798
+ USE SEARCH ENGINE
6799
+ ACTION Search for claims and verify them against reliable sources
6389
6800
  \`\`\`
6390
6801
  `);
6391
6802
  }
6392
6803
  applyToAgentModelRequirements(requirements, content) {
6393
- const trimmedContent = content.trim();
6394
- if (!trimmedContent) {
6395
- return requirements;
6396
- }
6397
- // Create scenario section for system message
6398
- const scenarioSection = `Scenario: ${trimmedContent}`;
6399
- // Scenarios provide important contextual information that affects behavior
6400
- return this.appendToSystemMessage(requirements, scenarioSection, '\n\n');
6804
+ // We simply mark that search engine capability is enabled in metadata
6805
+ // Get existing metadata
6806
+ const existingMetadata = requirements.metadata || {};
6807
+ // Get existing tools array or create new one
6808
+ const existingTools = existingMetadata.tools || [];
6809
+ // Add 'search-engine' to tools if not already present
6810
+ const updatedTools = existingTools.includes('search-engine') ? existingTools : [...existingTools, 'search-engine'];
6811
+ // Return requirements with updated metadata
6812
+ return {
6813
+ ...requirements,
6814
+ metadata: {
6815
+ ...existingMetadata,
6816
+ tools: updatedTools,
6817
+ useSearchEngine: true,
6818
+ },
6819
+ };
6401
6820
  }
6402
6821
  }
6403
6822
  /**
@@ -6405,70 +6824,58 @@
6405
6824
  */
6406
6825
 
6407
6826
  /**
6408
- * STYLE commitment definition
6409
- *
6410
- * The STYLE commitment defines how the agent should format and present its responses.
6411
- * This includes tone, writing style, formatting preferences, and communication patterns.
6412
- *
6413
- * Example usage in agent source:
6827
+ * Placeholder commitment definition for commitments that are not yet implemented
6414
6828
  *
6415
- * ```book
6416
- * STYLE Write in a professional but friendly tone, use bullet points for lists
6417
- * STYLE Always provide code examples when explaining programming concepts
6418
- * ```
6829
+ * This commitment simply adds its content 1:1 into the system message,
6830
+ * preserving the original behavior until proper implementation is added.
6419
6831
  *
6420
- * @private [🪔] Maybe export the commitments through some package
6832
+ * @public exported from `@promptbook/core`
6421
6833
  */
6422
- class StyleCommitmentDefinition extends BaseCommitmentDefinition {
6423
- constructor(type = 'STYLE') {
6834
+ class NotYetImplementedCommitmentDefinition extends BaseCommitmentDefinition {
6835
+ constructor(type) {
6424
6836
  super(type);
6425
6837
  }
6426
6838
  /**
6427
- * Short one-line description of STYLE.
6839
+ * Short one-line description of a placeholder commitment.
6428
6840
  */
6429
6841
  get description() {
6430
- return 'Control the tone and writing style of responses.';
6842
+ return 'Placeholder commitment that appends content verbatim to the system message.';
6431
6843
  }
6432
6844
  /**
6433
6845
  * Icon for this commitment.
6434
6846
  */
6435
6847
  get icon() {
6436
- return '🖋️';
6848
+ return '🚧';
6437
6849
  }
6438
6850
  /**
6439
- * Markdown documentation for STYLE commitment.
6851
+ * Markdown documentation available at runtime.
6440
6852
  */
6441
6853
  get documentation() {
6442
- return spaceTrim.spaceTrim(`
6854
+ return spaceTrim$1.spaceTrim(`
6443
6855
  # ${this.type}
6444
6856
 
6445
- Defines how the agent should format and present its responses (tone, writing style, formatting).
6857
+ This commitment is not yet fully implemented.
6446
6858
 
6447
6859
  ## Key aspects
6448
6860
 
6449
- - Both terms work identically and can be used interchangeably.
6450
- - Later style instructions can override earlier ones.
6451
- - Style affects both tone and presentation format.
6861
+ - Content is appended directly to the system message.
6862
+ - No special processing or validation is performed.
6863
+ - Behavior preserved until proper implementation is added.
6452
6864
 
6453
- ## Examples
6865
+ ## Status
6454
6866
 
6455
- \`\`\`book
6456
- Technical Writer
6867
+ - **Status:** Placeholder implementation
6868
+ - **Effect:** Appends content prefixed by commitment type
6869
+ - **Future:** Will be replaced with specialized logic
6457
6870
 
6458
- PERSONA You are a technical documentation expert
6459
- STYLE Write in a professional but friendly tone, use bullet points for lists
6460
- STYLE Always provide code examples when explaining programming concepts
6461
- FORMAT Use markdown formatting with clear headings
6462
- \`\`\`
6871
+ ## Examples
6463
6872
 
6464
6873
  \`\`\`book
6465
- Creative Assistant
6874
+ Example Agent
6466
6875
 
6467
- PERSONA You are a creative writing helper
6468
- STYLE Be enthusiastic and encouraging in your responses
6469
- STYLE Use vivid metaphors and analogies to explain concepts
6470
- STYLE Keep responses conversational and engaging
6471
- RULE Always maintain a positive and supportive tone
6876
+ PERSONA You are a helpful assistant
6877
+ ${this.type} Your content here
6878
+ RULE Always be helpful
6472
6879
  \`\`\`
6473
6880
  `);
6474
6881
  }
@@ -6477,70 +6884,108 @@
6477
6884
  if (!trimmedContent) {
6478
6885
  return requirements;
6479
6886
  }
6480
- // Add style instructions to the system message
6481
- const styleSection = `Style: ${trimmedContent}`;
6482
- return this.appendToSystemMessage(requirements, styleSection, '\n\n');
6887
+ // Add the commitment content 1:1 to the system message
6888
+ const commitmentLine = `${this.type} ${trimmedContent}`;
6889
+ return this.appendToSystemMessage(requirements, commitmentLine, '\n\n');
6483
6890
  }
6484
6891
  }
6485
- /**
6486
- * [💞] Ignore a discrepancy between file name and entity name
6487
- */
6488
6892
 
6489
6893
  // Import all commitment definition classes
6490
- // Register fully implemented commitments
6491
- registerCommitment(new PersonaCommitmentDefinition('PERSONA'));
6492
- registerCommitment(new PersonaCommitmentDefinition('PERSONAE'));
6493
- registerCommitment(new KnowledgeCommitmentDefinition());
6494
- registerCommitment(new MemoryCommitmentDefinition('MEMORY'));
6495
- registerCommitment(new MemoryCommitmentDefinition('MEMORIES'));
6496
- registerCommitment(new StyleCommitmentDefinition('STYLE'));
6497
- registerCommitment(new StyleCommitmentDefinition('STYLES'));
6498
- registerCommitment(new RuleCommitmentDefinition('RULE'));
6499
- registerCommitment(new RuleCommitmentDefinition('RULES'));
6500
- registerCommitment(new LanguageCommitmentDefinition('LANGUAGE'));
6501
- registerCommitment(new LanguageCommitmentDefinition('LANGUAGES'));
6502
- registerCommitment(new SampleCommitmentDefinition('SAMPLE'));
6503
- registerCommitment(new SampleCommitmentDefinition('EXAMPLE'));
6504
- registerCommitment(new FormatCommitmentDefinition('FORMAT'));
6505
- registerCommitment(new FormatCommitmentDefinition('FORMATS'));
6506
- registerCommitment(new FromCommitmentDefinition('FROM'));
6507
- registerCommitment(new ModelCommitmentDefinition('MODEL'));
6508
- registerCommitment(new ModelCommitmentDefinition('MODELS'));
6509
- registerCommitment(new ActionCommitmentDefinition('ACTION'));
6510
- registerCommitment(new ActionCommitmentDefinition('ACTIONS'));
6511
- registerCommitment(new ComponentCommitmentDefinition());
6512
- registerCommitment(new MetaImageCommitmentDefinition());
6513
- registerCommitment(new MetaColorCommitmentDefinition());
6514
- registerCommitment(new MetaLinkCommitmentDefinition());
6515
- registerCommitment(new MetaCommitmentDefinition());
6516
- registerCommitment(new NoteCommitmentDefinition('NOTE'));
6517
- registerCommitment(new NoteCommitmentDefinition('NOTES'));
6518
- registerCommitment(new NoteCommitmentDefinition('COMMENT'));
6519
- registerCommitment(new NoteCommitmentDefinition('NONCE'));
6520
- registerCommitment(new GoalCommitmentDefinition('GOAL'));
6521
- registerCommitment(new GoalCommitmentDefinition('GOALS'));
6522
- registerCommitment(new ImportantCommitmentDefinition());
6523
- registerCommitment(new InitialMessageCommitmentDefinition());
6524
- registerCommitment(new UserMessageCommitmentDefinition());
6525
- registerCommitment(new AgentMessageCommitmentDefinition());
6526
- registerCommitment(new MessageCommitmentDefinition('MESSAGE'));
6527
- registerCommitment(new MessageCommitmentDefinition('MESSAGES'));
6528
- registerCommitment(new ScenarioCommitmentDefinition('SCENARIO'));
6529
- registerCommitment(new ScenarioCommitmentDefinition('SCENARIOS'));
6530
- registerCommitment(new DeleteCommitmentDefinition('DELETE'));
6531
- registerCommitment(new DeleteCommitmentDefinition('CANCEL'));
6532
- registerCommitment(new DeleteCommitmentDefinition('DISCARD'));
6533
- registerCommitment(new DeleteCommitmentDefinition('REMOVE'));
6534
- registerCommitment(new OpenCommitmentDefinition());
6535
- registerCommitment(new ClosedCommitmentDefinition());
6536
- // Register not yet implemented commitments
6537
- registerCommitment(new NotYetImplementedCommitmentDefinition('EXPECT'));
6538
- registerCommitment(new NotYetImplementedCommitmentDefinition('BEHAVIOUR'));
6539
- registerCommitment(new NotYetImplementedCommitmentDefinition('BEHAVIOURS'));
6540
- registerCommitment(new NotYetImplementedCommitmentDefinition('AVOID'));
6541
- registerCommitment(new NotYetImplementedCommitmentDefinition('AVOIDANCE'));
6542
- registerCommitment(new NotYetImplementedCommitmentDefinition('CONTEXT'));
6894
+ /**
6895
+ * Registry of all available commitment definitions
6896
+ * This array contains instances of all commitment definitions
6897
+ * This is the single source of truth for all commitments in the system
6898
+ *
6899
+ * @private Use functions to access commitments instead of this array directly
6900
+ */
6901
+ const COMMITMENT_REGISTRY = [
6902
+ // Fully implemented commitments
6903
+ new PersonaCommitmentDefinition('PERSONA'),
6904
+ new PersonaCommitmentDefinition('PERSONAE'),
6905
+ new KnowledgeCommitmentDefinition(),
6906
+ new MemoryCommitmentDefinition('MEMORY'),
6907
+ new MemoryCommitmentDefinition('MEMORIES'),
6908
+ new StyleCommitmentDefinition('STYLE'),
6909
+ new StyleCommitmentDefinition('STYLES'),
6910
+ new RuleCommitmentDefinition('RULE'),
6911
+ new RuleCommitmentDefinition('RULES'),
6912
+ new LanguageCommitmentDefinition('LANGUAGE'),
6913
+ new LanguageCommitmentDefinition('LANGUAGES'),
6914
+ new SampleCommitmentDefinition('SAMPLE'),
6915
+ new SampleCommitmentDefinition('EXAMPLE'),
6916
+ new FormatCommitmentDefinition('FORMAT'),
6917
+ new FormatCommitmentDefinition('FORMATS'),
6918
+ new FromCommitmentDefinition('FROM'),
6919
+ new ModelCommitmentDefinition('MODEL'),
6920
+ new ModelCommitmentDefinition('MODELS'),
6921
+ new ActionCommitmentDefinition('ACTION'),
6922
+ new ActionCommitmentDefinition('ACTIONS'),
6923
+ new ComponentCommitmentDefinition(),
6924
+ new MetaImageCommitmentDefinition(),
6925
+ new MetaColorCommitmentDefinition(),
6926
+ new MetaFontCommitmentDefinition(),
6927
+ new MetaLinkCommitmentDefinition(),
6928
+ new MetaCommitmentDefinition(),
6929
+ new NoteCommitmentDefinition('NOTE'),
6930
+ new NoteCommitmentDefinition('NOTES'),
6931
+ new NoteCommitmentDefinition('COMMENT'),
6932
+ new NoteCommitmentDefinition('NONCE'),
6933
+ new GoalCommitmentDefinition('GOAL'),
6934
+ new GoalCommitmentDefinition('GOALS'),
6935
+ new InitialMessageCommitmentDefinition(),
6936
+ new UserMessageCommitmentDefinition(),
6937
+ new AgentMessageCommitmentDefinition(),
6938
+ new MessageCommitmentDefinition('MESSAGE'),
6939
+ new MessageCommitmentDefinition('MESSAGES'),
6940
+ new ScenarioCommitmentDefinition('SCENARIO'),
6941
+ new ScenarioCommitmentDefinition('SCENARIOS'),
6942
+ new DeleteCommitmentDefinition('DELETE'),
6943
+ new DeleteCommitmentDefinition('CANCEL'),
6944
+ new DeleteCommitmentDefinition('DISCARD'),
6945
+ new DeleteCommitmentDefinition('REMOVE'),
6946
+ new OpenCommitmentDefinition(),
6947
+ new ClosedCommitmentDefinition(),
6948
+ new UseBrowserCommitmentDefinition(),
6949
+ new UseSearchEngineCommitmentDefinition(),
6950
+ new UseMcpCommitmentDefinition(),
6951
+ new UseCommitmentDefinition(),
6952
+ // Not yet implemented commitments (using placeholder)
6953
+ new NotYetImplementedCommitmentDefinition('EXPECT'),
6954
+ new NotYetImplementedCommitmentDefinition('BEHAVIOUR'),
6955
+ new NotYetImplementedCommitmentDefinition('BEHAVIOURS'),
6956
+ new NotYetImplementedCommitmentDefinition('AVOID'),
6957
+ new NotYetImplementedCommitmentDefinition('AVOIDANCE'),
6958
+ new NotYetImplementedCommitmentDefinition('CONTEXT'),
6959
+ ];
6960
+ /**
6961
+ * Gets a commitment definition by its type
6962
+ * @param type The commitment type to look up
6963
+ * @returns The commitment definition or null if not found
6964
+ *
6965
+ * @public exported from `@promptbook/core`
6966
+ */
6967
+ function getCommitmentDefinition(type) {
6968
+ return COMMITMENT_REGISTRY.find((commitmentDefinition) => commitmentDefinition.type === type) || null;
6969
+ }
6970
+ /**
6971
+ * Gets all available commitment definitions
6972
+ * @returns Array of all commitment definitions
6973
+ *
6974
+ * @public exported from `@promptbook/core`
6975
+ */
6976
+ function getAllCommitmentDefinitions() {
6977
+ return $deepFreeze([...COMMITMENT_REGISTRY]);
6978
+ }
6979
+ /**
6980
+ * TODO: [🧠] Maybe create through standardized $register
6981
+ * Note: [💞] Ignore a discrepancy between file name and entity name
6982
+ */
6543
6983
 
6984
+ /**
6985
+ * Regex pattern to match horizontal lines (markdown thematic breaks)
6986
+ * Matches 3 or more hyphens, underscores, or asterisks (with optional spaces between)
6987
+ */
6988
+ const HORIZONTAL_LINE_PATTERN = /^[\s]*[-_*][\s]*[-_*][\s]*[-_*][\s]*[-_*]*[\s]*$/;
6544
6989
  /**
6545
6990
  * Parses agent source using the new commitment system with multiline support
6546
6991
  * This function replaces the hardcoded commitment parsing in the original parseAgentSource
@@ -6583,7 +7028,7 @@
6583
7028
  const fullContent = currentCommitment.contentLines.join('\n');
6584
7029
  commitments.push({
6585
7030
  type: currentCommitment.type,
6586
- content: spaceTrim.spaceTrim(fullContent),
7031
+ content: spaceTrim$1.spaceTrim(fullContent),
6587
7032
  originalLine: currentCommitment.originalStartLine,
6588
7033
  lineNumber: currentCommitment.startLineNumber,
6589
7034
  });
@@ -6603,6 +7048,24 @@
6603
7048
  break;
6604
7049
  }
6605
7050
  }
7051
+ // Check if this is a horizontal line (ends any current commitment)
7052
+ const isHorizontalLine = HORIZONTAL_LINE_PATTERN.test(line);
7053
+ if (isHorizontalLine) {
7054
+ // Save the current commitment if it exists
7055
+ if (currentCommitment) {
7056
+ const fullContent = currentCommitment.contentLines.join('\n');
7057
+ commitments.push({
7058
+ type: currentCommitment.type,
7059
+ content: spaceTrim$1.spaceTrim(fullContent),
7060
+ originalLine: currentCommitment.originalStartLine,
7061
+ lineNumber: currentCommitment.startLineNumber,
7062
+ });
7063
+ currentCommitment = null;
7064
+ }
7065
+ // Add horizontal line to non-commitment lines
7066
+ nonCommitmentLines.push(line);
7067
+ continue;
7068
+ }
6606
7069
  if (!foundNewCommitment) {
6607
7070
  if (currentCommitment) {
6608
7071
  // This line belongs to the current commitment
@@ -6619,7 +7082,7 @@
6619
7082
  const fullContent = currentCommitment.contentLines.join('\n');
6620
7083
  commitments.push({
6621
7084
  type: currentCommitment.type,
6622
- content: spaceTrim.spaceTrim(fullContent),
7085
+ content: spaceTrim$1.spaceTrim(fullContent),
6623
7086
  originalLine: currentCommitment.originalStartLine,
6624
7087
  lineNumber: currentCommitment.startLineNumber,
6625
7088
  });
@@ -6738,7 +7201,11 @@
6738
7201
  continue;
6739
7202
  }
6740
7203
  if (commitment.type === 'META COLOR') {
6741
- meta.color = spaceTrim__default["default"](commitment.content);
7204
+ meta.color = normalizeSeparator(commitment.content);
7205
+ continue;
7206
+ }
7207
+ if (commitment.type === 'META FONT') {
7208
+ meta.font = normalizeSeparator(commitment.content);
6742
7209
  continue;
6743
7210
  }
6744
7211
  if (commitment.type !== 'META') {
@@ -6774,6 +7241,19 @@
6774
7241
  parameters,
6775
7242
  };
6776
7243
  }
7244
+ /**
7245
+ * Normalizes the separator in the content
7246
+ *
7247
+ * @param content - The content to normalize
7248
+ * @returns The content with normalized separators
7249
+ */
7250
+ function normalizeSeparator(content) {
7251
+ const trimmed = spaceTrim__default["default"](content);
7252
+ if (trimmed.includes(',')) {
7253
+ return trimmed;
7254
+ }
7255
+ return trimmed.split(/\s+/).join(', ');
7256
+ }
6777
7257
  /**
6778
7258
  * TODO: [🕛] Unite `AgentBasicInformation`, `ChatParticipant`, `LlmExecutionTools` + `LlmToolsMetadata`
6779
7259
  */
@@ -7560,7 +8040,7 @@
7560
8040
  // Register a new language
7561
8041
  monaco.languages.register({ id: BOOK_LANGUAGE_ID });
7562
8042
  const commitmentTypes = [...new Set(getAllCommitmentDefinitions().map(({ type }) => type))];
7563
- const commitmentRegex = new RegExp(`^(${commitmentTypes.map((type) => (type === 'META' ? 'META\\s+\\w+' : type)).join('|')})\\s`);
8043
+ const commitmentRegex = new RegExp(`^(${commitmentTypes.map((type) => (type === 'META' ? 'META\\s+\\w+' : type)).join('|')})`);
7564
8044
  // Note: Using a broad character set for Latin and Cyrillic to support international characters in parameters.
7565
8045
  // Monarch tokenizer does not support Unicode property escapes like \p{L}.
7566
8046
  const parameterRegex = /@([a-zA-Z0-9_á-žÁ-Žč-řČ-Řš-žŠ-Žа-яА-ЯёЁ]+)/;
@@ -7912,38 +8392,6 @@
7912
8392
  return jsxRuntime.jsx(AvatarProfile, { ...rest, agent: agent, agentSource: agentSource });
7913
8393
  }
7914
8394
 
7915
- /**
7916
- * Restricts an Updatable to a (2) BehaviorSubject variant
7917
- *
7918
- * @see Updatable
7919
- * @private internal utility <- TODO: [🧠] Maybe export from `@promptbook/types`
7920
- */
7921
- function asUpdatableSubject(value) {
7922
- if (value instanceof rxjs.BehaviorSubject) {
7923
- return value;
7924
- }
7925
- else if (Array.isArray(value)) {
7926
- if (value.length !== 2) {
7927
- throw new TypeError('`asUpdatableSubject`: Invalid tuple length, expected 2 elements');
7928
- }
7929
- if (typeof value[1] !== 'function') {
7930
- throw new TypeError('`asUpdatableSubject`: Invalid tuple, expected second element to be a function');
7931
- }
7932
- const [theValue, setValue] = value;
7933
- const subject = new rxjs.BehaviorSubject(theValue);
7934
- subject.subscribe((newValue) => {
7935
- setValue(newValue);
7936
- });
7937
- return subject;
7938
- }
7939
- else {
7940
- return new rxjs.BehaviorSubject(value);
7941
- }
7942
- }
7943
- /**
7944
- * TODO: [🧠] Maybe `BehaviorSubject` is too heavy for this use case, maybe just tuple `[value,setValue]` is enough
7945
- */
7946
-
7947
8395
  /**
7948
8396
  * Calculates distance between two colors
7949
8397
  *
@@ -8023,6 +8471,38 @@
8023
8471
  */
8024
8472
  const textColor = furthest(Color.get('white'), Color.from('black'));
8025
8473
 
8474
+ /**
8475
+ * Restricts an Updatable to a (2) BehaviorSubject variant
8476
+ *
8477
+ * @see Updatable
8478
+ * @private internal utility <- TODO: [🧠] Maybe export from `@promptbook/types`
8479
+ */
8480
+ function asUpdatableSubject(value) {
8481
+ if (value instanceof rxjs.BehaviorSubject) {
8482
+ return value;
8483
+ }
8484
+ else if (Array.isArray(value)) {
8485
+ if (value.length !== 2) {
8486
+ throw new TypeError('`asUpdatableSubject`: Invalid tuple length, expected 2 elements');
8487
+ }
8488
+ if (typeof value[1] !== 'function') {
8489
+ throw new TypeError('`asUpdatableSubject`: Invalid tuple, expected second element to be a function');
8490
+ }
8491
+ const [theValue, setValue] = value;
8492
+ const subject = new rxjs.BehaviorSubject(theValue);
8493
+ subject.subscribe((newValue) => {
8494
+ setValue(newValue);
8495
+ });
8496
+ return subject;
8497
+ }
8498
+ else {
8499
+ return new rxjs.BehaviorSubject(value);
8500
+ }
8501
+ }
8502
+ /**
8503
+ * TODO: [🧠] Maybe `BehaviorSubject` is too heavy for this use case, maybe just tuple `[value,setValue]` is enough
8504
+ */
8505
+
8026
8506
  /**
8027
8507
  * Change ellipsis character to three dots `…` -> `...`
8028
8508
  *
@@ -8533,9 +9013,9 @@
8533
9013
  const mdSaveFormatDefinition = {
8534
9014
  formatName: 'md',
8535
9015
  label: 'Markdown',
8536
- getContent: ({ messages }) => spaceTrim.spaceTrim(`
9016
+ getContent: ({ messages }) => spaceTrim$1.spaceTrim(`
8537
9017
  ${messages
8538
- .map((message) => spaceTrim.spaceTrim(`
9018
+ .map((message) => spaceTrim$1.spaceTrim(`
8539
9019
  **${message.from}:**
8540
9020
 
8541
9021
  > ${message.content.replace(/\n/g, '\n> ')}
@@ -8655,7 +9135,7 @@
8655
9135
  return CHAT_SAVE_FORMATS.filter((saveFormatDefinition) => formatNames.includes(saveFormatDefinition.formatName));
8656
9136
  }
8657
9137
 
8658
- var css_248z$2 = "@font-face{font-family:OpenMojiBlack;src:url(https://s6.ptbk.io/fonts/OpenMoji-black-glyf.woff2) format(\"woff2\");unicode-range:u+23,u+2a,u+2d,u+30-39,u+a9,u+ae,u+200d,u+203c,u+2049,u+20e3,u+2117,u+2120,u+2122,u+2139,u+2194-2199,u+21a9,u+21aa,u+229c,u+231a,u+231b,u+2328,u+23cf,u+23e9-23f3,u+23f8-23fe,u+24c2,u+25a1,u+25aa-25ae,u+25b6,u+25c0,u+25c9,u+25d0,u+25d1,u+25e7-25ea,u+25ed,u+25ee,u+25fb-25fe,u+2600-2605,u+260e,u+2611,u+2614,u+2615,u+2618,u+261d,u+2620,u+2622,u+2623,u+2626,u+262a,u+262e,u+262f,u+2638-263a,u+2640,u+2642,u+2648-2653,u+265f,u+2660,u+2663,u+2665,u+2666,u+2668,u+267b,u+267e,u+267f,u+2691-2697,u+2699,u+269b,u+269c,u+26a0,u+26a1,u+26a7,u+26aa,u+26ab,u+26b0,u+26b1,u+26bd,u+26be,u+26c4,u+26c5,u+26c8,u+26ce,u+26cf,u+26d1,u+26d3,u+26d4,u+26e9,u+26ea,u+26f0-26f5,u+26f7-26fa,u+26fd,u+2702,u+2705,u+2708-270d,u+270f,u+2712,u+2714,u+2716,u+271d,u+2721,u+2728,u+2733,u+2734,u+2744,u+2747,u+274c,u+274e,u+2753-2755,u+2757,u+2763,u+2764,u+2795-2797,u+27a1,u+27b0,u+27bf,u+2934,u+2935,u+2b05-2b07,u+2b0c,u+2b0d,u+2b1b,u+2b1c,u+2b1f-2b24,u+2b2e,u+2b2f,u+2b50,u+2b55,u+2b58,u+2b8f,u+2bba-2bbc,u+2bc3,u+2bc4,u+2bea,u+2beb,u+3030,u+303d,u+3297,u+3299,u+e000-e009,u+e010,u+e011,u+e040-e06d,u+e080-e0b4,u+e0c0-e0cc,u+e0ff-e10d,u+e140-e14a,u+e150-e157,u+e181-e189,u+e1c0-e1c4,u+e1c6-e1d9,u+e200-e216,u+e240-e269,u+e280-e283,u+e2c0-e2c4,u+e2c6-e2da,u+e300-e303,u+e305-e30f,u+e312-e316,u+e318-e322,u+e324-e329,u+e32b,u+e340-e348,u+e380,u+e381,u+f000,u+f77a,u+f8ff,u+fe0f,u+1f004,u+1f0cf,u+1f10d-1f10f,u+1f12f,u+1f16d-1f171,u+1f17e,u+1f17f,u+1f18e,u+1f191-1f19a,u+1f1e6-1f1ff,u+1f201,u+1f202,u+1f21a,u+1f22f,u+1f232-1f23a,u+1f250,u+1f251,u+1f260-1f265,u+1f300-1f321,u+1f324-1f393,u+1f396,u+1f397,u+1f399-1f39b,u+1f39e-1f3f0,u+1f3f3-1f3f5,u+1f3f7-1f4fd,u+1f4ff-1f53d,u+1f549-1f54e,u+1f550-1f567,u+1f56f,u+1f570,u+1f573-1f57a,u+1f587,u+1f58a-1f58d,u+1f590,u+1f595,u+1f596,u+1f5a4,u+1f5a5,u+1f5a8,u+1f5b1,u+1f5b2,u+1f5bc,u+1f5c2-1f5c4,u+1f5d1-1f5d3,u+1f5dc-1f5de,u+1f5e1,u+1f5e3,u+1f5e8,u+1f5ef,u+1f5f3,u+1f5fa-1f64f,u+1f680-1f6c5,u+1f6cb-1f6d2,u+1f6d5-1f6d7,u+1f6dc-1f6e5,u+1f6e9,u+1f6eb,u+1f6ec,u+1f6f0,u+1f6f3-1f6fc,u+1f7e0-1f7eb,u+1f7f0,u+1f90c-1f93a,u+1f93c-1f945,u+1f947-1f9ff,u+1fa70-1fa7c,u+1fa80-1fa88,u+1fa90-1fabd,u+1fabf-1fac5,u+1face-1fadb,u+1fae0-1fae8,u+1faf0-1faf8,u+1fbc5-1fbc9,u+e0061-e0067,u+e0069,u+e006c-e0079,u+e007f}.Chat-module_copiedToClipboardMessage__apCPY{background:#222;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.18);color:#fff;font-size:1.1em;left:50%;opacity:.97;padding:10px 24px;pointer-events:none;position:fixed;top:32px;transform:translateX(-50%);z-index:9999}.Chat-module_Chat__j2eE5{display:flex;flex-direction:column;font-family:Arial,Helvetica,sans-serif,OpenMojiBlack;height:100%;width:100%}.Chat-module_chatMainFlow__--8FE{display:grid;grid-template:\"🟦\" min-content \"💬\" 1fr \"📝\" min-content/1fr;height:100%;max-width:100vw;width:100%}.Chat-module_chatMainFlow__--8FE .Chat-module_chatBar__fLECN{background-color:#fff;border-bottom:1px solid rgba(15,23,36,.06);color:#0f1724;font-weight:500;grid-area:🟦;padding:16px 20px;text-align:center;width:100%}.Chat-module_TasksInProgress__fQfei{align-self:center;grid-area:🟦;height:min-content;justify-self:self-end;margin:8px 16px;width:auto}.Chat-module_actions__gTZ5T{align-items:center;align-self:self-start;display:flex;gap:8px;grid-area:💬;height:min-content;justify-self:self-end;margin:16px 20px 0;width:auto;z-index:200}.Chat-module_actions__gTZ5T.Chat-module_portal__uTOT8{margin:0}.Chat-module_actions__gTZ5T.Chat-module_left__7l5Mn{justify-self:self-start}.Chat-module_actions__gTZ5T.Chat-module_right__ABZrW{justify-self:self-end}@media (max-width:900px){.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}}@media (max-width:600px){.Chat-module_actions__gTZ5T{gap:7px;margin:14px 18px 0}}.Chat-module_chatMainFlow__--8FE .Chat-module_chatChildren__flOPK{grid-area:💬;height:100%;width:100%;z-index:300}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{grid-area:💬;height:100%;overflow-x:hidden;overflow-y:auto;padding:24px 20px 16px;scroll-behavior:smooth;width:100%;z-index:10}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar{width:6px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-track{background:transparent}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-thumb{background:hsla(0,0%,49%,.2);border-radius:3px;transition:all .2s ease}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,49%,.3)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ{align-items:flex-end;animation:Chat-module_messageSlideIn__soTy2 .4s cubic-bezier(.25,.46,.45,.94);display:flex;flex-direction:row;margin-bottom:20px;max-width:100%;position:relative}.Chat-module_hasActionsAndFirstMessageIsLong__5jgoZ{margin-top:55px}@keyframes Chat-module_messageSlideIn__soTy2{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.Chat-module_isNotCompleteMessage__Hj2K7{opacity:.7;position:relative}.Chat-module_NonCompleteMessageFiller__G5-Ve{color:transparent}.Chat-module_isNotCompleteMessage__Hj2K7 .Chat-module_messageText__XgNyQ:after{animation:Chat-module_loadingPulse__VomRm 1.5s ease-in-out infinite;background:linear-gradient(90deg,transparent,hsla(0,0%,49%,.6),transparent);border-radius:2px;bottom:8px;content:\"\";height:4px;position:absolute;right:12px;width:20px}@keyframes Chat-module_loadingPulse__VomRm{0%,to{opacity:.3;transform:scaleX(.8)}50%{opacity:1;transform:scaleX(1.2)}}.Chat-module_typingIndicator__S-CT-{align-items:flex-end;animation:Chat-module_messageSlideIn__soTy2 .4s cubic-bezier(.25,.46,.45,.94);display:flex;margin-bottom:20px}.Chat-module_typingIndicator__S-CT- .Chat-module_avatar__gL6bm{flex-shrink:0;height:40px;margin:0 12px 4px;width:40px}.Chat-module_typingIndicator__S-CT- .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;background-color:#eef6fb;border:2px solid hsla(0,0%,49%,.1);border-radius:50%;object-fit:cover;width:40px}.Chat-module_typingBubble__0Lb7B{backdrop-filter:blur(10px);border:1px solid hsla(0,0%,49%,.1);border-radius:20px;border-bottom-left-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.1);min-height:24px;padding:16px 20px}.Chat-module_typingBubble__0Lb7B,.Chat-module_typingDots__srOBB{align-items:center;display:flex;gap:4px}.Chat-module_typingDot__dnhKT{animation:Chat-module_typingBounce__1yp2v 1.4s ease-in-out infinite;background:linear-gradient(135deg,#6b7280,hsla(0,0%,49%,.6));border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.1);height:8px;width:8px}.Chat-module_typingDot__dnhKT:first-child{animation-delay:-.32s}.Chat-module_typingDot__dnhKT:nth-child(2){animation-delay:-.16s}.Chat-module_typingDot__dnhKT:nth-child(3){animation-delay:0s}@keyframes Chat-module_typingBounce__1yp2v{0%,80%,to{opacity:.5;transform:scale(.8) translateY(0)}40%{opacity:1;transform:scale(1.2) translateY(-8px)}}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ.Chat-module_isMe__nBtaV{align-items:flex-end;flex-direction:row-reverse;justify-content:flex-start}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ.Chat-module_isMe__nBtaV .Chat-module_messageText__XgNyQ{border-bottom-right-radius:6px}.Chat-module_ratingStar__rRfqC{color:var(--star-inactive-color,#ccc);cursor:pointer;font-size:20px;transition:color .2s}.Chat-module_ratingStar__rRfqC.Chat-module_active__lbYL-{color:gold}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{aspect-ratio:1/1;flex-shrink:0;margin:0 12px 4px;position:relative;width:40px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;background-color:var(--avatar-bg-color,#eef6fb);border:2px solid hsla(0,0%,49%,.1);border-radius:50%;object-fit:cover;transition:transform .2s ease,box-shadow .2s ease;width:40px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img:hover{box-shadow:0 4px 12px rgba(0,0,0,.15);transform:scale(1.05)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{word-wrap:break-word;backdrop-filter:blur(10px);background-color:var(--message-bg-color);border-radius:20px;box-shadow:0 2px 8px rgba(0,0,0,.1);color:var(--message-text-color);font-size:15px;line-height:1.5;margin-bottom:4px;max-width:min(70%,600px);padding:14px 18px;position:relative;text-align:left;transition:all .2s ease}.Chat-module_copyButtonContainer__Rij0U{align-items:center;float:right;justify-content:flex-end;pointer-events:none;right:10px;top:8px;visibility:hidden;z-index:2}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ:hover .Chat-module_copyButtonContainer__Rij0U,.Chat-module_copyButtonContainer__Rij0U:focus-within{pointer-events:auto;visibility:visible}.Chat-module_copyButton__DcxT5{align-items:center;background:hsla(0,0%,100%,.2);border:1px solid #ddd;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.07);cursor:pointer;display:flex;opacity:.7;padding:2px 5px;position:relative;transition:all .15s,box-shadow .15s,border .15s}.Chat-module_copiedTooltip__LH81j{animation:Chat-module_copiedTooltipFadeIn__QekO1 .2s;background:#222;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.18);color:#fff;font-size:.98em;left:50%;margin-top:4px;max-width:220px;opacity:.97;overflow-wrap:break-word;padding:6px 16px;pointer-events:none;position:absolute;top:110%;transform:translateX(-50%);white-space:nowrap;word-break:break-word;z-index:100}.Chat-module_copiedTooltipLeft__j-S-5{left:0!important;transform:none!important}.Chat-module_copiedTooltipRight__R-2cE{left:auto!important;right:0!important;transform:none!important}@keyframes Chat-module_copiedTooltipFadeIn__QekO1{0%{opacity:0;transform:translateX(-50%) translateY(8px) scale(.97)}to{opacity:.97;transform:translateX(-50%) translateY(0) scale(1)}}.Chat-module_copyButton__DcxT5:focus,.Chat-module_copyButton__DcxT5:hover{border:1.5px solid #bbb;box-shadow:0 2px 8px rgba(0,132,255,.1);opacity:1}.Chat-module_copyButton__DcxT5 svg{display:block}.Chat-module_messageText__XgNyQ h1{font-size:2em}.Chat-module_messageText__XgNyQ h2{font-size:1.75em}.Chat-module_messageText__XgNyQ h3{font-size:1.5em}.Chat-module_messageText__XgNyQ h4{font-size:1.25em}.Chat-module_messageText__XgNyQ h5{font-size:1.1em}.Chat-module_messageText__XgNyQ ul{list-style:disc;margin-left:20px}.Chat-module_messageText__XgNyQ ol{list-style:decimal;margin-left:20px}.Chat-module_messageText__XgNyQ blockquote,.Chat-module_messageText__XgNyQ img,.Chat-module_messageText__XgNyQ pre,.Chat-module_messageText__XgNyQ table{border-radius:8px;margin-bottom:10px;margin-top:10px}.Chat-module_messageText__XgNyQ pre{background:#000;color:#fff}.Chat-module_messageText__XgNyQ blockquote,.Chat-module_messageText__XgNyQ pre{border:none;box-shadow:none;display:block;font-size:inherit;line-height:inherit;padding:1em}.Chat-module_messageText__XgNyQ blockquote{background:#ffffffcc;color:#000}.Chat-module_messageText__XgNyQ code{background:#cccccc55;border:none;box-shadow:none;color:inherit;display:inline-block;font-size:inherit;line-height:inherit;margin:0;padding:0}.Chat-module_messageText__XgNyQ pre code{background-color:#000000cc;border-radius:8px}.Chat-module_messageText__XgNyQ .Chat-module_chat-code-block__k8IyS{background:#181c23;border-color:#23272f;box-shadow:0 2px 8px rgba(0,0,0,.12);color:#f8fafc;font-family:Fira Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:14px;line-height:1.6;overflow-x:auto}.Chat-module_messageText__XgNyQ .Chat-module_chat-code-block__k8IyS code{background:none!important;border:none!important;box-shadow:none!important;color:inherit!important;display:block;font-family:inherit!important;font-size:inherit!important;overflow-x:auto;padding:0!important;white-space:pre;word-break:break-word}.Chat-module_messageText__XgNyQ table{background:#f8fafc;border-collapse:separate;border-spacing:0;box-shadow:0 2px 8px rgba(0,0,0,.08);color:#17223b;font-size:14px;margin:16px 0;width:100%}.Chat-module_messageText__XgNyQ td,.Chat-module_messageText__XgNyQ th{background:none;border-bottom:1px solid #d1dbe8;color:#17223b;padding:10px 16px;text-align:left}.Chat-module_messageText__XgNyQ th{background:linear-gradient(90deg,#eaf3fa 80%,#d1e3f8);border-bottom:2px solid #b5c7de;color:#17223b;font-weight:700}.Chat-module_messageText__XgNyQ tr:last-child td{border-bottom:none}.Chat-module_messageText__XgNyQ tr:nth-child(2n) td{background:#eaf3fa}.Chat-module_messageText__XgNyQ tr:hover td{background:#cbe0f7;transition:background .2s}.Chat-module_messageText__XgNyQ table{border-radius:12px;overflow:hidden}.Chat-module_messageText__XgNyQ td:first-child,.Chat-module_messageText__XgNyQ th:first-child{border-top-left-radius:12px}.Chat-module_messageText__XgNyQ td:last-child,.Chat-module_messageText__XgNyQ th:last-child{border-top-right-radius:12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ:hover{box-shadow:0 4px 16px rgba(0,0,0,.15);transform:translateY(-1px)}.Chat-module_messageButtons__WaOob{border-top:1px solid hsla(0,0%,49%,.83);display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px}.Chat-module_messageButton__mRnn-{-webkit-tap-highlight-color:transparent;align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.9);border-radius:16px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;padding:8px 14px;touch-action:manipulation;transition:all .2s ease;user-select:none}.Chat-module_messageButton__mRnn-:hover{background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);box-shadow:0 2px 8px rgba(0,132,255,.15);transform:translateY(-1px)}.Chat-module_messageButton__mRnn-:active{transform:scale(.98);transition:transform .1s ease}.Chat-module_messageButton__mRnn- p{line-height:inherit;margin:0;padding:0}.Chat-module_messageButton__mRnn- strong{font-weight:600}.Chat-module_messageButton__mRnn- em{font-style:italic}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M{align-items:center;backdrop-filter:blur(10px);background:rgba(0,0,0,.8);border-radius:12px;bottom:-8px;display:flex;gap:2px;min-width:24px;opacity:0;padding:4px 6px;position:absolute;right:8px;transform:translateY(4px);transition:all .3s cubic-bezier(.25,.46,.45,.94);z-index:1}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ:hover .Chat-module_rating__soc3M{opacity:1;transform:translateY(0)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M:hover{background:rgba(0,0,0,.9);box-shadow:0 4px 12px rgba(0,0,0,.3);padding:6px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M span{cursor:pointer;display:inline-block;font-size:16px;transition:transform .2s ease,color .2s ease}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M:hover span{transform:scale(1.1)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{backdrop-filter:blur(20px);border-top:1px solid hsla(0,0%,49%,.1);display:flex;flex-direction:column;gap:12px;grid-area:📝;padding:20px;position:relative;width:100%;z-index:10}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan.Chat-module_dragOver__bkS-g{background:linear-gradient(0deg,rgba(0,132,255,.1) 0,rgba(0,132,255,.05));border-top:2px solid rgba(0,132,255,.3)}.Chat-module_filePreviewContainer__R70hm{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.Chat-module_filePreview__kq2aX{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.2);border-radius:8px;display:flex;font-size:12px;gap:8px;padding:8px 12px;transition:all .2s ease}.Chat-module_filePreview__kq2aX:hover{background:hsla(0,0%,49%,.15);border-color:hsla(0,0%,49%,.3)}.Chat-module_fileIcon__zoSKW{font-size:14px;opacity:.7}.Chat-module_fileInfo__wBLi0{display:flex;flex-direction:column;gap:2px;min-width:0}.Chat-module_fileName__bBujo{color:#000;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.Chat-module_fileSize__ivliq{color:#6b7280;font-size:11px}.Chat-module_removeFileButton__0gakR{align-items:center;background:rgba(255,0,0,.1);border:none;border-radius:50%;color:#f44;cursor:pointer;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all .2s ease;width:20px}.Chat-module_removeFileButton__0gakR:hover{background:rgba(255,0,0,.2);transform:scale(1.1)}.Chat-module_inputContainer__bPt99{align-items:center;display:flex;gap:12px}.Chat-module_inputContainer__bPt99 textarea::placeholder{color:inherit;opacity:.7}.Chat-module_attachmentButton__qLO47{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.05);border:1px solid hsla(0,0%,49%,.2);border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.Chat-module_attachmentButton__qLO47:hover:not(:disabled){background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);color:#0084ff;transform:scale(1.05)}.Chat-module_attachmentButton__qLO47:disabled{cursor:not-allowed;opacity:.5;transform:none}.Chat-module_voiceButton__d2zlP{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.05);border:1px solid hsla(0,0%,49%,.2);border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.Chat-module_voiceButton__d2zlP:hover{background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);color:#0084ff;transform:scale(1.05)}.Chat-module_voiceButtonActive__Uoi3W{animation:Chat-module_voiceRecordingPulse__y2wJ5 1.5s infinite;background:rgba(255,0,0,.1)!important;border-color:rgba(255,0,0,.3)!important;color:red!important}@keyframes Chat-module_voiceRecordingPulse__y2wJ5{0%{box-shadow:0 0 0 0 rgba(255,0,0,.4)}70%{box-shadow:0 0 0 10px rgba(255,0,0,0)}to{box-shadow:0 0 0 0 rgba(255,0,0,0)}}.Chat-module_uploadProgress__jBTKe{align-items:center;background:rgba(0,132,255,.1);border:1px solid rgba(0,132,255,.2);border-radius:8px;color:#0084ff;display:flex;font-size:13px;gap:12px;padding:8px 12px}.Chat-module_uploadProgressBar__Gutnt{background:rgba(0,132,255,.2);border-radius:2px;flex:1;height:4px;overflow:hidden}.Chat-module_uploadProgressFill__EgubT{animation:Chat-module_uploadProgress__jBTKe 1.5s ease-in-out infinite;background:linear-gradient(90deg,#0084ff,rgba(0,132,255,.8));border-radius:2px;height:100%}@keyframes Chat-module_uploadProgress__jBTKe{0%{transform:translateX(-100%)}50%{transform:translateX(0)}to{transform:translateX(100%)}}.Chat-module_dragOverlay__SEGoS{align-items:center;backdrop-filter:blur(10px);background:rgba(0,132,255,.1);border:2px dashed rgba(0,132,255,.5);border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:20}.Chat-module_dragOverlayContent__gb9kF{align-items:center;color:#0084ff;display:flex;flex-direction:column;font-weight:600;gap:12px;text-align:center}.Chat-module_dragOverlayContent__gb9kF svg{opacity:.7}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{-webkit-tap-highlight-color:transparent;appearance:none;-webkit-appearance:none;backdrop-filter:blur(20px);background:hsla(0,0%,49%,.05);border-radius:25px;color:#000;flex:1;font-size:15px;line-height:1.4;max-height:120px;min-width:200px;outline:none;padding:16px 20px;resize:none;touch-action:manipulation;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea:focus{background:hsla(0,0%,49%,.08);border-color:#0084ff;box-shadow:0 0 0 4px rgba(0,132,255,.1),0 8px 32px rgba(0,132,255,.15);transform:translateY(-2px)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea:disabled{cursor:not-allowed;opacity:.6;transform:none}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea::placeholder{color:inherit;opacity:.7}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{-webkit-tap-highlight-color:transparent;align-items:center;aspect-ratio:1/1;background:linear-gradient(135deg,#0084ff,#06c);border:none;border-radius:50%!important;box-shadow:0 4px 16px rgba(0,132,255,.3);color:#fff;display:flex;height:48px;justify-content:center;margin:0!important;min-height:unset!important;min-width:unset!important;overflow:visible;padding:0!important;padding-left:unset;padding-right:unset;touch-action:manipulation;transition:all .3s cubic-bezier(.25,.46,.45,.94);user-select:none;width:48px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button img{height:100%;object-fit:contain;width:50%}.Chat-module_scrollToBottomContainer__5rXpK{align-items:flex-start;display:flex;grid-area:📝;height:100%;justify-content:center;pointer-events:none;width:100%;z-index:20}.Chat-module_scrollToBottomContainer__5rXpK .Chat-module_scrollToBottom__nzxdZ{-webkit-tap-highlight-color:transparent;align-items:center;animation:Chat-module_scrollButtonSlideIn__XnImg .3s ease-out;backdrop-filter:blur(3px);background:rgba(0,0,0,.5);border:none;border-radius:50%;box-shadow:0 4px 16px rgba(0,0,0,.3);color:#fff;cursor:pointer;display:flex;font-weight:700;height:48px;justify-content:center;outline:none;pointer-events:all;touch-action:manipulation;transform:translate(-50%,-150%);transition:all .3s cubic-bezier(.25,.46,.45,.94);user-select:none;width:48px}@keyframes Chat-module_scrollButtonSlideIn__XnImg{0%{opacity:0;transform:translate(-50%,20px) scale(.8)}to{opacity:.9;transform:translate(-50%) scale(1)}}.Chat-module_scrollToBottom__nzxdZ:hover{transform:translate(-50%,-160%) scale(1.05)}.Chat-module_scrollToBottom__nzxdZ:active{transform:translate(-50%,-160%) scale(.95);transition:transform .1s ease}.Chat-module_ratingModal__XVKYm{align-items:center;animation:Chat-module_modalFadeIn__RPc3w .3s ease-out;backdrop-filter:blur(8px);background-color:rgba(0,0,0,.6);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes Chat-module_modalFadeIn__RPc3w{0%{backdrop-filter:blur(0);opacity:0}to{backdrop-filter:blur(8px);opacity:1}}.Chat-module_ratingModalContent__CCdq7{animation:Chat-module_modalSlideIn__XXtgN .3s cubic-bezier(.25,.46,.45,.94);backdrop-filter:blur(20px);background:#fff;border:1px solid hsla(0,0%,49%,.1);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);color:#0f1724;font-family:Arial,Helvetica,sans-serif,OpenMojiBlack;max-width:480px;padding:32px;width:90%}@keyframes Chat-module_modalSlideIn__XXtgN{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.Chat-module_ratingModalContent__CCdq7 h3{color:#000;font-size:20px;font-weight:600;margin:0 0 24px;text-align:center}.Chat-module_stars__PCzNO{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.Chat-module_stars__PCzNO span{border-radius:8px;cursor:pointer;font-size:28px;padding:4px;transition:all .2s ease}.Chat-module_stars__PCzNO span:hover{background:rgba(255,215,0,.1);transform:scale(1.2)}.Chat-module_ratingModalStar__XkbHr{cursor:pointer;font-size:24px;transition:color .2s}.Chat-module_ratingInput__z8Pv-{background:hsla(0,0%,49%,.05);border:2px solid hsla(0,0%,49%,.1);border-radius:12px;color:#0b1220;font-size:14px;line-height:1.5;margin-bottom:18px;min-height:100px;padding:16px;resize:vertical;transition:all .2s ease;width:100%}.Chat-module_ratingInput__z8Pv-:focus{background:hsla(0,0%,49%,.08);border-color:#0084ff;box-shadow:0 0 0 4px rgba(0,132,255,.1);outline:none}.Chat-module_ratingInput__z8Pv-[readonly]{background:hsla(0,0%,49%,.01);border:1px solid hsla(0,0%,49%,.5)}.Chat-module_ratingActions__nXcss{display:flex;gap:12px;justify-content:flex-end}.Chat-module_ratingActions__nXcss button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;min-width:80px;padding:12px 24px;transition:all .2s ease}.Chat-module_ratingActions__nXcss button:first-child{background-color:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.2);color:#0b1220}.Chat-module_ratingActions__nXcss button:first-child:hover:not(:disabled){background-color:hsla(0,0%,49%,.2);color:#0b1220}.Chat-module_ratingActions__nXcss button:last-child{background:linear-gradient(135deg,#0084ff,#06c);color:#fff}.Chat-module_ratingActions__nXcss button:last-child:hover:not(:disabled){background:linear-gradient(135deg,#0071d1,#0052a3);box-shadow:0 4px 12px rgba(0,132,255,.3);transform:translateY(-1px)}.Chat-module_ratingActions__nXcss button:last-child:disabled{cursor:not-allowed;opacity:.5}.Chat-module_chatButton__d9VgA{-webkit-tap-highlight-color:transparent!important;align-items:center!important;backdrop-filter:blur(20px)!important;background:linear-gradient(135deg,#0084ff,#06c)!important;border:none!important;border-radius:20px!important;box-shadow:0 4px 16px rgba(0,132,255,.3)!important;color:#fff!important;cursor:pointer!important;display:inline-flex!important;font-size:13px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;line-height:1.3!important;margin:0!important;min-height:40px!important;min-width:110px!important;overflow:hidden!important;padding:12px 16px!important;position:relative!important;touch-action:manipulation!important;transition:all .3s cubic-bezier(.25,.46,.45,.94)!important;user-select:none!important}.Chat-module_chatButton__d9VgA:before{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);content:\"\";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.Chat-module_chatButton__d9VgA:hover:before{left:100%}.Chat-module_chatButton__d9VgA:hover:not(:disabled){background:linear-gradient(135deg,#09f,#07d);box-shadow:0 8px 24px rgba(0,132,255,.4);transform:translateY(-2px) scale(1.02)}.Chat-module_chatButton__d9VgA:active{box-shadow:0 4px 16px rgba(0,132,255,.3);transform:scale(.98) translateY(-1px);transition:transform .1s ease}.Chat-module_chatButton__d9VgA:focus{box-shadow:0 4px 16px rgba(0,132,255,.3),0 0 0 3px rgba(0,132,255,.3);outline:none}.Chat-module_chatButton__d9VgA svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));flex-shrink:0;height:16px;opacity:1;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:16px}.Chat-module_chatButton__d9VgA:hover svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transform:rotate(-90deg) scale(1.1)}.Chat-module_chatButtonText__RkGB-{font-weight:600;opacity:1;text-shadow:0 1px 2px rgba(0,0,0,.1);transition:all .2s ease;white-space:nowrap}.Chat-module_chatButton__d9VgA:hover .Chat-module_chatButtonText__RkGB-{transform:translateX(1px)}.Chat-module_useTemplateButton__xcJNR{-webkit-tap-highlight-color:transparent!important;align-items:center!important;backdrop-filter:blur(20px)!important;background:linear-gradient(135deg,#0084ff,#06c)!important;border:none!important;border-radius:20px!important;box-shadow:0 4px 16px rgba(0,132,255,.3)!important;color:#fff!important;cursor:pointer!important;display:inline-flex!important;font-size:13px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;line-height:1.3!important;margin:0!important;min-height:40px!important;min-width:110px!important;overflow:hidden!important;padding:12px 16px!important;position:relative!important;touch-action:manipulation!important;transition:all .3s cubic-bezier(.25,.46,.45,.94)!important;user-select:none!important}.Chat-module_useTemplateButton__xcJNR:before{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);content:\"\";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.Chat-module_useTemplateButton__xcJNR:hover:before{left:100%}.Chat-module_useTemplateButton__xcJNR:hover:not(:disabled){background:linear-gradient(135deg,#09f,#07d);box-shadow:0 8px 24px rgba(0,132,255,.4);transform:translateY(-2px) scale(1.02)}.Chat-module_useTemplateButton__xcJNR:active{box-shadow:0 4px 16px rgba(0,132,255,.3);transform:scale(.98) translateY(-1px);transition:transform .1s ease}.Chat-module_useTemplateButton__xcJNR:focus{box-shadow:0 4px 16px rgba(0,132,255,.3),0 0 0 3px rgba(0,132,255,.3);outline:none}.Chat-module_useTemplateButton__xcJNR svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));flex-shrink:0;height:16px;opacity:1;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:16px}.Chat-module_useTemplateButton__xcJNR:hover svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transform:scale(1.1)}.Chat-module_useTemplateButton__xcJNR:hover .Chat-module_chatButtonText__RkGB-{transform:translateX(1px)}.Chat-module_saveButtonContainer__lSNUJ{display:inline-block;position:relative}.Chat-module_saveMenu__-ph8y{background:#fff;border:1px solid #ddd;box-shadow:0 2px 8px rgba(0,0,0,.08);left:0;min-width:120px;position:absolute;top:100%;z-index:10}.Chat-module_saveMenuItem__ISApL{background:none;border:none;color:#111;cursor:pointer;display:block;padding:8px 16px;text-align:left;width:100%}.Chat-module_saveMenuItem__ISApL:hover{background-color:#f0f0f0}.Chat-module_pauseButton__eeu7K{background:linear-gradient(135deg,#ffb347,#ff8c42)!important}.Chat-module_pauseButton__eeu7K:hover:not(:disabled){background:linear-gradient(135deg,#ffc067,#ff9e5f)!important}.Chat-module_pauseButton__eeu7K.Chat-module_pausing__pTx8b{cursor:wait!important;opacity:.6!important}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya{background:linear-gradient(135deg,#10b981,#059669)!important}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya:hover:not(:disabled){background:linear-gradient(135deg,#34d399,#059669)!important;box-shadow:0 8px 24px rgba(16,185,129,.35);transform:translateY(-2px) scale(1.02)}.Chat-module_pauseButton__eeu7K svg{transition:transform .3s ease}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya svg{transform:scale(1.1)}.Chat-module_pauseButton__eeu7K.Chat-module_pausing__pTx8b svg{opacity:.8}.Chat-module_voiceCallIndicatorBar__N2sWN{align-items:center;backdrop-filter:blur(10px);background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(16,185,129,.1));border-bottom:1px solid rgba(34,197,94,.3);display:flex;grid-area:🟦;justify-content:center;padding:12px 20px;width:100%}.Chat-module_voiceCallIndicator__tsaaG{align-items:center;backdrop-filter:blur(10px);background:linear-gradient(135deg,rgba(34,197,94,.2),rgba(16,185,129,.2));border:1px solid rgba(34,197,94,.4);border-radius:20px;box-shadow:0 2px 8px rgba(34,197,94,.2);color:#10b981;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:8px 16px;position:relative}.Chat-module_voiceCallIndicator__tsaaG svg{animation:Chat-module_voiceCallIconPulse__zZbJn 2s ease-in-out infinite;flex-shrink:0;height:16px;width:16px}.Chat-module_voiceCallIndicator__tsaaG span{font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1)}.Chat-module_voiceCallPulse__XcGU4{animation:Chat-module_voiceCallPulse__XcGU4 1.5s ease-in-out infinite;background:#10b981;border-radius:50%;height:8px;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:8px}@keyframes Chat-module_voiceCallIconPulse__zZbJn{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes Chat-module_voiceCallPulse__XcGU4{0%,to{opacity:1;transform:translateY(-50%) scale(1)}50%{opacity:.6;transform:translateY(-50%) scale(1.3)}}.Chat-module_chatMessage__nmLaZ .Chat-module_voiceCallIndicator__tsaaG{border-radius:16px;font-size:12px;margin-bottom:8px;padding:6px 12px}.Chat-module_chatMessage__nmLaZ .Chat-module_voiceCallIndicator__tsaaG svg{height:14px;width:14px}.Chat-module_ratingConfirmation__n16vb{word-wrap:break-word;animation:Chat-module_confirmationSlideIn__5U-wz .3s ease-out;backdrop-filter:blur(20px);background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;box-shadow:0 8px 32px rgba(16,185,129,.3);color:#fff;font-weight:500;max-width:300px;padding:16px 20px;position:fixed;right:20px;top:20px;z-index:1001}@keyframes Chat-module_confirmationSlideIn__5U-wz{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.Chat-module_actions__gTZ5T{gap:6px;margin:12px 16px 0}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{padding:16px 12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ{margin-bottom:16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border-radius:18px;font-size:14px;max-width:85%;padding:12px 16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{height:36px;margin:0 10px 4px;width:36px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;width:36px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{gap:10px;padding:16px 12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-radius:22px;font-size:16px;padding:14px 18px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{height:44px;width:44px}.Chat-module_scrollToBottom__nzxdZ{font-size:18px;height:44px;top:calc(100% - 160px);width:44px}.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_ratingModalContent__CCdq7{border-radius:16px;margin:16px;max-height:80vh;overflow-y:auto;padding:24px 20px}.Chat-module_stars__PCzNO{gap:6px;margin-bottom:20px}.Chat-module_stars__PCzNO span{font-size:32px;padding:8px}.Chat-module_ratingActions__nXcss{flex-direction:column-reverse;gap:8px}.Chat-module_ratingActions__nXcss button{border-radius:10px;font-size:16px;padding:14px;width:100%}}@media (max-width:480px){.Chat-module_actions__gTZ5T{gap:4px;margin:8px 12px 0}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{padding:12px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border-radius:16px;font-size:14px;max-width:90%;padding:10px 14px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{height:32px;margin:0 8px 4px;width:32px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;width:32px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{gap:8px;padding:12px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-radius:20px;font-size:16px;padding:12px 16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{height:40px;width:40px}.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_scrollToBottom__nzxdZ{font-size:16px;height:40px;top:calc(100% - 140px);width:40px}.Chat-module_ratingModal__XVKYm{align-items:flex-end;padding:0}.Chat-module_ratingModalContent__CCdq7{border-radius:20px 20px 0 0;margin:0;max-height:70vh;padding:24px 16px 20px;width:100%}}@media (prefers-reduced-motion:reduce){.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ,.Chat-module_ratingConfirmation__n16vb,.Chat-module_ratingModalContent__CCdq7,.Chat-module_ratingModal__XVKYm,.Chat-module_scrollToBottom__nzxdZ{animation:none}.Chat-module_chatButton__d9VgA,.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button,.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea,.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img,.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{transition:none}}@media (prefers-contrast:high){.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border:2px solid}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-width:3px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{border:2px solid}}\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Chat.module.css"],"names":[],"mappings":"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","file":"Chat.module.css","sourcesContent":["@font-face {\n    font-family: 'OpenMojiBlack';\n    src: url('https://s6.ptbk.io/fonts/OpenMoji-black-glyf.woff2') format('woff2'); /* <- TODO: [🐱‍🚀] Dynamically load from /servers.ts */\n    unicode-range: U+23, U+2A, U+2D, U+30-39, U+A9, U+AE, U+200D, U+203C, U+2049, U+20E3, U+2117, U+2120, U+2122, U+2139,\n        U+2194-2199, U+21A9, U+21AA, U+229C, U+231A, U+231B, U+2328, U+23CF, U+23E9-23F3, U+23F8-23FE, U+24C2, U+25A1,\n        U+25AA-25AE, U+25B6, U+25C0, U+25C9, U+25D0, U+25D1, U+25E7-25EA, U+25ED, U+25EE, U+25FB-25FE, U+2600-2605,\n        U+260E, U+2611, U+2614, U+2615, U+2618, U+261D, U+2620, U+2622, U+2623, U+2626, U+262A, U+262E, U+262F,\n        U+2638-263A, U+2640, U+2642, U+2648-2653, U+265F, U+2660, U+2663, U+2665, U+2666, U+2668, U+267B, U+267E, U+267F,\n        U+2691-2697, U+2699, U+269B, U+269C, U+26A0, U+26A1, U+26A7, U+26AA, U+26AB, U+26B0, U+26B1, U+26BD, U+26BE,\n        U+26C4, U+26C5, U+26C8, U+26CE, U+26CF, U+26D1, U+26D3, U+26D4, U+26E9, U+26EA, U+26F0-26F5, U+26F7-26FA, U+26FD,\n        U+2702, U+2705, U+2708-270D, U+270F, U+2712, U+2714, U+2716, U+271D, U+2721, U+2728, U+2733, U+2734, U+2744,\n        U+2747, U+274C, U+274E, U+2753-2755, U+2757, U+2763, U+2764, U+2795-2797, U+27A1, U+27B0, U+27BF, U+2934, U+2935,\n        U+2B05-2B07, U+2B0C, U+2B0D, U+2B1B, U+2B1C, U+2B1F-2B24, U+2B2E, U+2B2F, U+2B50, U+2B55, U+2B58, U+2B8F,\n        U+2BBA-2BBC, U+2BC3, U+2BC4, U+2BEA, U+2BEB, U+3030, U+303D, U+3297, U+3299, U+E000-E009, U+E010, U+E011,\n        U+E040-E06D, U+E080-E0B4, U+E0C0-E0CC, U+E0FF-E10D, U+E140-E14A, U+E150-E157, U+E181-E189, U+E1C0-E1C4,\n        U+E1C6-E1D9, U+E200-E216, U+E240-E269, U+E280-E283, U+E2C0-E2C4, U+E2C6-E2DA, U+E300-E303, U+E305-E30F,\n        U+E312-E316, U+E318-E322, U+E324-E329, U+E32B, U+E340-E348, U+E380, U+E381, U+F000, U+F77A, U+F8FF, U+FE0F,\n        U+1F004, U+1F0CF, U+1F10D-1F10F, U+1F12F, U+1F16D-1F171, U+1F17E, U+1F17F, U+1F18E, U+1F191-1F19A, U+1F1E6-1F1FF,\n        U+1F201, U+1F202, U+1F21A, U+1F22F, U+1F232-1F23A, U+1F250, U+1F251, U+1F260-1F265, U+1F300-1F321, U+1F324-1F393,\n        U+1F396, U+1F397, U+1F399-1F39B, U+1F39E-1F3F0, U+1F3F3-1F3F5, U+1F3F7-1F4FD, U+1F4FF-1F53D, U+1F549-1F54E,\n        U+1F550-1F567, U+1F56F, U+1F570, U+1F573-1F57A, U+1F587, U+1F58A-1F58D, U+1F590, U+1F595, U+1F596, U+1F5A4,\n        U+1F5A5, U+1F5A8, U+1F5B1, U+1F5B2, U+1F5BC, U+1F5C2-1F5C4, U+1F5D1-1F5D3, U+1F5DC-1F5DE, U+1F5E1, U+1F5E3,\n        U+1F5E8, U+1F5EF, U+1F5F3, U+1F5FA-1F64F, U+1F680-1F6C5, U+1F6CB-1F6D2, U+1F6D5-1F6D7, U+1F6DC-1F6E5, U+1F6E9,\n        U+1F6EB, U+1F6EC, U+1F6F0, U+1F6F3-1F6FC, U+1F7E0-1F7EB, U+1F7F0, U+1F90C-1F93A, U+1F93C-1F945, U+1F947-1F9FF,\n        U+1FA70-1FA7C, U+1FA80-1FA88, U+1FA90-1FABD, U+1FABF-1FAC5, U+1FACE-1FADB, U+1FAE0-1FAE8, U+1FAF0-1FAF8,\n        U+1FBC5-1FBC9, U+E0061-E0067, U+E0069, U+E006C-E0079, U+E007F;\n}\n\n.copiedToClipboardMessage {\n    position: fixed;\n    top: 32px;\n    left: 50%;\n    transform: translateX(-50%);\n    background: #222;\n    color: #fff;\n    padding: 10px 24px;\n    border-radius: 8px;\n    font-size: 1.1em;\n    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.18);\n    opacity: 0.97;\n    pointer-events: none;\n    z-index: 9999;\n}\n\n.Chat {\n    width: 100%;\n    height: 100%;\n    display: flex;\n    flex-direction: column;\n\n    font-family: Arial, Helvetica, sans-serif, 'OpenMojiBlack';\n    /* <- TODO: [🧠][🎱] Better, define other fonts */\n}\n\n.chatMainFlow {\n    width: 100%;\n    height: 100%;\n    max-width: 100vw;\n    display: grid;\n    grid-template:\n        '🟦' min-content\n        '💬' 1fr\n        '📝' min-content\n        / 1fr;\n}\n\n.chatMainFlow .chatBar {\n    grid-area: 🟦;\n    width: 100%;\n    padding: 16px 20px;\n    color: #0f1724;\n    background-color: #ffffff;\n    border-bottom: 1px solid rgba(15, 23, 36, 0.06);\n    text-align: center;\n    font-weight: 500;\n}\n\n.TasksInProgress {\n    grid-area: 🟦;\n    width: auto;\n    height: min-content;\n    align-self: center;\n    justify-self: self-end;\n    margin: 8px 16px;\n}\n\n.actions {\n    grid-area: 💬;\n    width: auto;\n    height: min-content;\n    z-index: 200;\n    align-self: self-start;\n    justify-self: self-end;\n   margin: 16px 20px 0;\n    display: flex;\n    align-items: center;\n    gap: 8px;\n}\n\n.actions.portal{\nmargin: 0;\n}\n\n.actions.left {\n    justify-self: self-start;\n}\n\n.actions.right {\n    justify-self: self-end;\n}\n\n/* Large tablet and small desktop screens */\n@media (max-width: 900px) {\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n}\n\n/* Medium screens */\n@media (max-width: 600px) {\n    .actions {\n        margin: 14px 18px 0;\n        gap: 7px;\n    }\n}\n\n.chatMainFlow .chatChildren {\n    grid-area: 💬;\n    width: 100%;\n    height: 100%;\n    z-index: 300;\n}\n\n/* Chat messages area */\n.chatMainFlow .chatMessages {\n    grid-area: 💬;\n    width: 100%;\n    height: 100%;\n    z-index: 10;\n    padding: 24px 20px 16px;\n    overflow-y: auto;\n    overflow-x: hidden;\n    scroll-behavior: smooth;\n}\n\n/* Custom scrollbar styling */\n.chatMainFlow .chatMessages::-webkit-scrollbar {\n    width: 6px;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-track {\n    background: transparent;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-thumb {\n    background: rgba(125, 125, 125, 0.2);\n    border-radius: 3px;\n    transition: all 0.2s ease;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-thumb:hover {\n    background: rgba(125, 125, 125, 0.3);\n}\n\n/* Individual chat message */\n.chatMainFlow .chatMessage {\n    display: flex;\n    margin-bottom: 20px;\n    align-items: flex-end;\n    flex-direction: row;\n    position: relative;\n    animation: messageSlideIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    max-width: 100%;\n}\n\n/* Add top margin to first message if actions are present and first message is long */\n.hasActionsAndFirstMessageIsLong {\n    margin-top: 55px;\n}\n\n@keyframes messageSlideIn {\n    from {\n        opacity: 0;\n        transform: translateY(20px) scale(0.95);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0) scale(1);\n    }\n}\n\n.isNotCompleteMessage {\n    /*/\n    outline: 1px dotted #ff0000 !important;\n    /**/\n\n    opacity: 0.7;\n    position: relative;\n}\n\n.NonCompleteMessageFiller {\n    color: transparent;\n}\n\n/* Enhanced loading states for messages */\n.isNotCompleteMessage .messageText::after {\n    content: '';\n    position: absolute;\n    bottom: 8px;\n    right: 12px;\n    width: 20px;\n    height: 4px;\n    background: linear-gradient(90deg, transparent, rgba(125, 125, 125, 0.6), transparent);\n    border-radius: 2px;\n    animation: loadingPulse 1.5s ease-in-out infinite;\n}\n\n@keyframes loadingPulse {\n    0%,\n    100% {\n        opacity: 0.3;\n        transform: scaleX(0.8);\n    }\n    50% {\n        opacity: 1;\n        transform: scaleX(1.2);\n    }\n}\n\n/* Typing indicator for AI messages */\n.typingIndicator {\n    display: flex;\n    align-items: flex-end;\n    margin-bottom: 20px;\n    animation: messageSlideIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.typingIndicator .avatar {\n    width: 40px;\n    height: 40px;\n    margin: 0 12px 4px;\n    flex-shrink: 0;\n}\n\n.typingIndicator .avatar img {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    border-radius: 50%;\n    object-fit: cover;\n    background-color: #eef6fb;\n    border: 2px solid rgba(125, 125, 125, 0.1);\n}\n\n.typingBubble {\n    padding: 16px 20px;\n    border-radius: 20px;\n    border-bottom-left-radius: 6px;\n    border: 1px solid rgba(125, 125, 125, 0.1);\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);\n    backdrop-filter: blur(10px);\n    display: flex;\n    align-items: center;\n    gap: 4px;\n    min-height: 24px;\n}\n\n.typingDots {\n    display: flex;\n    gap: 4px;\n    align-items: center;\n}\n\n.typingDot {\n    width: 8px;\n    height: 8px;\n    border-radius: 50%;\n    background: linear-gradient(135deg, #6b7280 0%, rgba(125, 125, 125, 0.6) 100%);\n    animation: typingBounce 1.4s infinite ease-in-out;\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n}\n\n.typingDot:nth-child(1) {\n    animation-delay: -0.32s;\n}\n\n.typingDot:nth-child(2) {\n    animation-delay: -0.16s;\n}\n\n.typingDot:nth-child(3) {\n    animation-delay: 0s;\n}\n\n@keyframes typingBounce {\n    0%,\n    80%,\n    100% {\n        transform: scale(0.8) translateY(0);\n        opacity: 0.5;\n    }\n    40% {\n        transform: scale(1.2) translateY(-8px);\n        opacity: 1;\n    }\n}\n\n.chatMainFlow .chatMessage.isMe {\n    align-items: flex-end;\n    flex-direction: row-reverse;\n    justify-content: flex-start;\n}\n\n.chatMainFlow .chatMessage.isMe .messageText {\n    border-bottom-right-radius: 6px;\n}\n\n.ratingStar {\n    cursor: pointer;\n    font-size: 20px;\n    transition: color 0.2s;\n    color: var(--star-inactive-color, #ccc);\n}\n\n.ratingStar.active {\n    color: #ffd700;\n}\n\n/* Sender Avatar */\n.chatMainFlow .chatMessage .avatar {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    margin: 0 12px 4px;\n    flex-shrink: 0;\n    position: relative;\n}\n\n.chatMainFlow .chatMessage .avatar img {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    border-radius: 50%;\n    object-fit: cover;\n    background-color: var(--avatar-bg-color, #eef6fb);\n    border: 2px solid rgba(125, 125, 125, 0.1);\n    transition: transform 0.2s ease, box-shadow 0.2s ease;\n}\n\n.chatMainFlow .chatMessage .avatar img:hover {\n    transform: scale(1.05);\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n}\n\n/* Message text bubble */\n.chatMainFlow .chatMessage .messageText {\n    background-color: var(--message-bg-color);\n    color: var(--message-text-color);\n    position: relative;\n    padding: 14px 18px;\n    border-radius: 20px;\n    max-width: min(70%, 600px);\n    text-align: left;\n    margin-bottom: 4px;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);\n    line-height: 1.5;\n    word-wrap: break-word;\n    transition: all 0.2s ease;\n    font-size: 15px;\n    backdrop-filter: blur(10px);\n}\n\n/* Copy button styles */\n.copyButtonContainer {\n    float: right;\n    top: 8px;\n    right: 10px;\n    z-index: 2;\n    align-items: center;\n    justify-content: flex-end;\n    pointer-events: none;\n\n    visibility: hidden;\n}\n.chatMainFlow .chatMessage .messageText:hover .copyButtonContainer,\n.copyButtonContainer:focus-within {\n    visibility: visible;\n    pointer-events: auto;\n}\n\n.copyButton {\n    background: rgba(255, 255, 255, 0.2);\n    border: 1px solid #ddd;\n    border-radius: 6px;\n    padding: 2px 5px;\n    cursor: pointer;\n    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.07);\n    transition: all 0.15s, box-shadow 0.15s, border 0.15s;\n    display: flex;\n    align-items: center;\n    opacity: 0.7;\n    position: relative;\n}\n\n.copiedTooltip {\n    position: absolute;\n    left: 50%;\n    top: 110%;\n    transform: translateX(-50%);\n    background: #222;\n    color: #fff;\n    padding: 6px 16px;\n    border-radius: 8px;\n    font-size: 0.98em;\n    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.18);\n    opacity: 0.97;\n    pointer-events: none;\n    z-index: 100;\n    white-space: nowrap;\n    margin-top: 4px;\n    animation: copiedTooltipFadeIn 0.2s;\n    max-width: 220px;\n    overflow-wrap: break-word;\n    word-break: break-word;\n}\n\n.copiedTooltipLeft {\n    left: 0 !important;\n    transform: none !important;\n}\n\n.copiedTooltipRight {\n    left: auto !important;\n    right: 0 !important;\n    transform: none !important;\n}\n\n/* Removed right-aligned override to keep tooltip position stable */\n\n@keyframes copiedTooltipFadeIn {\n    from {\n        opacity: 0;\n        transform: translateX(-50%) translateY(8px) scale(0.97);\n    }\n    to {\n        opacity: 0.97;\n        transform: translateX(-50%) translateY(0) scale(1);\n    }\n}\n\n.copyButton:hover,\n.copyButton:focus {\n    border: 1.5px solid #bbb;\n    opacity: 1;\n    box-shadow: 0 2px 8px rgba(0, 132, 255, 0.1);\n}\n\n.copyButton svg {\n    display: block;\n}\n\n.messageText h1 {\n    font-size: 2em;\n}\n\n.messageText h2 {\n    font-size: 1.75em;\n}\n\n.messageText h3 {\n    font-size: 1.5em;\n}\n\n.messageText h4 {\n    font-size: 1.25em;\n}\n\n.messageText h5 {\n    font-size: 1.1em;\n}\n\n.messageText ul {\n    list-style: disc;\n    margin-left: 20px;\n}\n\n.messageText ol {\n    list-style: decimal;\n    margin-left: 20px;\n}\n\n.messageText img,\n.messageText pre,\n.messageText blockquote,\n.messageText table {\n    margin-top: 10px;\n    margin-bottom: 10px;\n    border-radius: 8px;\n}\n\n.messageText pre {\n    display: block;\n    border: none;\n    box-shadow: none;\n    background: #000000ff;\n    font-size: inherit;\n    line-height: inherit;\n    color: #fff;\n    padding: 1em;\n}\n\n.messageText blockquote {\n    display: block;\n    border: none;\n    box-shadow: none;\n    background: #ffffffcc;\n    font-size: inherit;\n    line-height: inherit;\n    color: #000;\n    padding: 1em;\n}\n\n.messageText code {\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border: none;\n    box-shadow: none;\n    background: #cccccc55;\n    font-size: inherit;\n    line-height: inherit;\n    color: inherit;\n}\n\n.messageText pre code {\n    background-color: #000000cc;\n    border-radius: 8px;\n}\n\n.messageText .chat-code-block {\n    background: #181c23;\n    color: #f8fafc;\n    font-size: 14px;\n    line-height: 1.6;\n    overflow-x: auto;\n    border-color: #23272f;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);\n    font-family: 'Fira Mono', 'Menlo', 'Consolas', 'Liberation Mono', monospace;\n}\n.messageText .chat-code-block code {\n    background: none !important;\n    color: inherit !important;\n    font-family: inherit !important;\n    font-size: inherit !important;\n    padding: 0 !important;\n    border: none !important;\n    box-shadow: none !important;\n    white-space: pre;\n    word-break: break-word;\n    overflow-x: auto;\n    display: block;\n}\n.messageText table {\n    width: 100%;\n    border-collapse: separate;\n    border-spacing: 0;\n    margin: 16px 0;\n    background: #f8fafc; /* Stronger light background for contrast */\n    border-radius: 12px;\n    overflow: hidden;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);\n    font-size: 14px;\n    color: #17223b; /* Dark text for contrast */\n}\n.messageText th,\n.messageText td {\n    padding: 10px 16px;\n    border-bottom: 1px solid #d1dbe8;\n    text-align: left;\n    color: #17223b; /* Ensure strong text color for all cells */\n    background: none;\n}\n.messageText th {\n    background: linear-gradient(90deg, #eaf3fa 80%, #d1e3f8 100%);\n    font-weight: 700;\n    color: #17223b; /* Strong header text */\n    border-bottom: 2px solid #b5c7de;\n}\n.messageText tr:last-child td {\n    border-bottom: none;\n}\n.messageText tr:nth-child(even) td {\n    background: #eaf3fa;\n}\n.messageText tr:hover td {\n    background: #cbe0f7;\n    transition: background 0.2s;\n}\n.messageText table {\n    border-radius: 12px;\n    overflow: hidden;\n}\n.messageText th:first-child,\n.messageText td:first-child {\n    border-top-left-radius: 12px;\n}\n.messageText th:last-child,\n.messageText td:last-child {\n    border-top-right-radius: 12px;\n}\n\n.chatMainFlow .chatMessage .messageText:hover {\n    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);\n    transform: translateY(-1px);\n}\n\n/* Message buttons container */\n.messageButtons {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 8px;\n    margin-top: 12px;\n    padding-top: 12px;\n    border-top: 1px solid rgba(125 125 125 / 0.83);\n}\n\n/* Individual message button */\n.messageButton {\n    display: inline-flex;\n    align-items: center;\n    padding: 8px 14px;\n    background: rgba(125, 125, 125, 0.1);\n    border: 1px solid rgba(125, 125, 125, 0.9);\n    border-radius: 16px;\n    font-size: 13px;\n    font-weight: 500;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n}\n\n.messageButton:hover {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    transform: translateY(-1px);\n    box-shadow: 0 2px 8px rgba(0, 132, 255, 0.15);\n}\n\n.messageButton:active {\n    transform: scale(0.98);\n    transition: transform 0.1s ease;\n}\n\n/* Remove default markdown styles from button content */\n.messageButton p {\n    margin: 0;\n    padding: 0;\n    line-height: inherit;\n}\n\n.messageButton strong {\n    font-weight: 600;\n}\n\n.messageButton em {\n    font-style: italic;\n}\n\n/* Rating system */\n.chatMainFlow .chatMessage .rating {\n    position: absolute;\n    bottom: -8px;\n    right: 8px;\n    display: flex;\n    gap: 2px;\n    align-items: center;\n    min-width: 24px;\n    z-index: 1;\n    background: rgba(0, 0, 0, 0.8);\n    border-radius: 12px;\n    padding: 4px 6px;\n    backdrop-filter: blur(10px);\n    opacity: 0;\n    transform: translateY(4px);\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.chatMainFlow .chatMessage:hover .rating {\n    opacity: 1;\n    transform: translateY(0);\n}\n\n.chatMainFlow .chatMessage .rating:hover {\n    background: rgba(0, 0, 0, 0.9);\n    padding: 6px 8px;\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);\n}\n\n.chatMainFlow .chatMessage .rating span {\n    transition: transform 0.2s ease, color 0.2s ease;\n    display: inline-block;\n    cursor: pointer;\n    font-size: 16px;\n}\n\n.chatMainFlow .chatMessage .rating:hover span {\n    transform: scale(1.1);\n}\n\n/* Chat input area */\n.chatMainFlow .chatInput {\n    z-index: 10;\n    grid-area: 📝;\n    width: 100%;\n    padding: 20px;\n    backdrop-filter: blur(20px);\n    border-top: 1px solid rgba(125, 125, 125, 0.1);\n    display: flex;\n    flex-direction: column;\n    gap: 12px;\n    position: relative;\n}\n\n/* File upload drag-and-drop styles */\n.chatMainFlow .chatInput.dragOver {\n    background: linear-gradient(to top, rgba(0, 132, 255, 0.1) 0%, rgba(0, 132, 255, 0.05) 100%);\n    border-top: 2px solid rgba(0, 132, 255, 0.3);\n}\n\n/* File preview container */\n.filePreviewContainer {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 8px;\n    margin-bottom: 8px;\n}\n\n/* Individual file preview */\n.filePreview {\n    display: flex;\n    align-items: center;\n    gap: 8px;\n    padding: 8px 12px;\n    background: rgba(125, 125, 125, 0.1);\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    border-radius: 8px;\n    font-size: 12px;\n    backdrop-filter: blur(10px);\n    transition: all 0.2s ease;\n}\n\n.filePreview:hover {\n    background: rgba(125, 125, 125, 0.15);\n    border-color: rgba(125, 125, 125, 0.3);\n}\n\n.fileIcon {\n    font-size: 14px;\n    opacity: 0.7;\n}\n\n.fileInfo {\n    display: flex;\n    flex-direction: column;\n    gap: 2px;\n    min-width: 0;\n}\n\n.fileName {\n    font-weight: 500;\n    color: black;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    max-width: 150px;\n}\n\n.fileSize {\n    color: #6b7280;\n    font-size: 11px;\n}\n\n.removeFileButton {\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    width: 20px;\n    height: 20px;\n    border: none;\n    background: rgba(255, 0, 0, 0.1);\n    color: #ff4444;\n    border-radius: 50%;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    flex-shrink: 0;\n}\n\n.removeFileButton:hover {\n    background: rgba(255, 0, 0, 0.2);\n    transform: scale(1.1);\n}\n\n/* Input container for textarea and buttons */\n.inputContainer {\n    display: flex;\n    align-items: center;\n    gap: 12px;\n}\n\n.inputContainer textarea::placeholder {\n    color: inherit;\n    opacity: 0.7;\n}\n\n/* Attachment button */\n.attachmentButton {\n    width: 40px;\n    height: 40px;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    background: rgba(125, 125, 125, 0.05);\n    color: #6b7280;\n    border-radius: 50%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    flex-shrink: 0;\n}\n\n.attachmentButton:hover:not(:disabled) {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    color: #0084ff;\n    transform: scale(1.05);\n}\n\n.attachmentButton:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n    transform: none;\n}\n\n/* Voice Button */\n.voiceButton {\n    width: 40px;\n    height: 40px;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    background: rgba(125, 125, 125, 0.05);\n    color: #6b7280;\n    border-radius: 50%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    flex-shrink: 0;\n}\n\n.voiceButton:hover {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    color: #0084ff;\n    transform: scale(1.05);\n}\n\n.voiceButtonActive {\n    background: rgba(255, 0, 0, 0.1) !important;\n    border-color: rgba(255, 0, 0, 0.3) !important;\n    color: #ff0000 !important;\n    animation: voiceRecordingPulse 1.5s infinite;\n}\n\n@keyframes voiceRecordingPulse {\n    0% {\n        box-shadow: 0 0 0 0 rgba(255, 0, 0, 0.4);\n    }\n    70% {\n        box-shadow: 0 0 0 10px rgba(255, 0, 0, 0);\n    }\n    100% {\n        box-shadow: 0 0 0 0 rgba(255, 0, 0, 0);\n    }\n}\n\n/* Upload progress indicator */\n.uploadProgress {\n    display: flex;\n    align-items: center;\n    gap: 12px;\n    padding: 8px 12px;\n    background: rgba(0, 132, 255, 0.1);\n    border: 1px solid rgba(0, 132, 255, 0.2);\n    border-radius: 8px;\n    font-size: 13px;\n    color: #0084ff;\n}\n\n.uploadProgressBar {\n    flex: 1;\n    height: 4px;\n    background: rgba(0, 132, 255, 0.2);\n    border-radius: 2px;\n    overflow: hidden;\n}\n\n.uploadProgressFill {\n    height: 100%;\n    background: linear-gradient(90deg, #0084ff, rgba(0, 132, 255, 0.8));\n    border-radius: 2px;\n    animation: uploadProgress 1.5s ease-in-out infinite;\n}\n\n@keyframes uploadProgress {\n    0% {\n        transform: translateX(-100%);\n    }\n    50% {\n        transform: translateX(0%);\n    }\n    100% {\n        transform: translateX(100%);\n    }\n}\n\n/* Drag overlay */\n.dragOverlay {\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    background: rgba(0, 132, 255, 0.1);\n    border: 2px dashed rgba(0, 132, 255, 0.5);\n    border-radius: 12px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    backdrop-filter: blur(10px);\n    z-index: 20;\n    pointer-events: none;\n}\n\n.dragOverlayContent {\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    gap: 12px;\n    color: #0084ff;\n    font-weight: 600;\n    text-align: center;\n}\n\n.dragOverlayContent svg {\n    opacity: 0.7;\n}\n\n/* Chat input field */\n.chatMainFlow .chatInput textarea {\n    flex: 1;\n    padding: 16px 20px;\n\n    outline: none;\n    border-radius: 25px;\n    background: rgba(125, 125, 125, 0.05);\n    backdrop-filter: blur(20px);\n    color: black;\n    min-width: 200px;\n    max-height: 120px;\n    font-size: 15px;\n    line-height: 1.4;\n    resize: none;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    appearance: none;\n    -webkit-appearance: none;\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n}\n\n.chatMainFlow .chatInput textarea:focus {\n    border-color: #0084ff;\n    background: rgba(125, 125, 125, 0.08);\n    box-shadow: 0 0 0 4px rgba(0, 132, 255, 0.1), 0 8px 32px rgba(0, 132, 255, 0.15);\n    transform: translateY(-2px);\n}\n\n.chatMainFlow .chatInput textarea:disabled {\n    opacity: 0.6;\n    cursor: not-allowed;\n    transform: none;\n}\n\n.chatMainFlow .chatInput textarea::placeholder {\n    color: inherit;\n    opacity: 0.7;\n}\n\n/* Chat send button */\n.chatMainFlow .chatInput button {\n    width: 48px;\n    height: 48px;\n    margin: 0 !important;\n    padding: 0 !important;\n\n    border: none;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%);\n    color: #ffffff;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    border-radius: 50% !important;\n    aspect-ratio: 1 / 1;\n    min-width: unset !important;\n    min-height: unset !important;\n    padding-left: unset;\n    padding-right: unset;\n\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n    overflow: visible;\n}\n\n.chatMainFlow .chatInput button img {\n    width: 50%;\n    height: 100%;\n    object-fit: contain;\n}\n\n/* Scroll to bottom button */\n\n.scrollToBottomContainer {\n    /*/\n    outline: 1px dotted red;\n    /**/\n\n    z-index: 20;\n    grid-area: 📝;\n    width: 100%;\n    height: 100%;\n    display: flex;\n    justify-content: center;\n    align-items: flex-start;\n\n    pointer-events: none;\n}\n\n.scrollToBottomContainer .scrollToBottom {\n    pointer-events: all;\n\n    transform: translate(-50%, -150%);\n    width: 48px;\n    height: 48px;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    border: none;\n    outline: none;\n    background: rgba(0 0 0 / 0.5);\n    backdrop-filter: blur(3px);\n    border-radius: 50%;\n    font-weight: bold;\n    color: white;\n    cursor: pointer;\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);\n    animation: scrollButtonSlideIn 0.3s ease-out;\n}\n\n@keyframes scrollButtonSlideIn {\n    from {\n        opacity: 0;\n        transform: translate(-50%, 20px) scale(0.8);\n    }\n    to {\n        opacity: 0.9;\n        transform: translate(-50%, 0) scale(1);\n    }\n}\n\n.scrollToBottom:hover {\n    transform: translate(-50%, -160%) scale(1.05);\n}\n\n.scrollToBottom:active {\n    transform: translate(-50%, -160%) scale(0.95);\n    transition: transform 0.1s ease;\n}\n\n/* Rating modal */\n.ratingModal {\n    position: fixed;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n\n    background-color: rgba(0, 0, 0, 0.6);\n    backdrop-filter: blur(8px);\n\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    z-index: 1000;\n    animation: modalFadeIn 0.3s ease-out;\n}\n\n@keyframes modalFadeIn {\n    from {\n        opacity: 0;\n        backdrop-filter: blur(0px);\n    }\n    to {\n        opacity: 1;\n        backdrop-filter: blur(8px);\n    }\n}\n\n.ratingModalContent {\n    background: #ffffff;\n    color: #0f1724;\n    padding: 32px;\n    border-radius: 16px;\n    width: 90%;\n    max-width: 480px;\n    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);\n    border: 1px solid rgba(125, 125, 125, 0.1);\n    backdrop-filter: blur(20px);\n    animation: modalSlideIn 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n\n    font-family: Arial, Helvetica, sans-serif, 'OpenMojiBlack';\n    /* <- TODO: [🧠][🎱] Better, define other fonts */\n}\n\n@keyframes modalSlideIn {\n    from {\n        opacity: 0;\n        transform: translateY(20px) scale(0.95);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0) scale(1);\n    }\n}\n\n.ratingModalContent h3 {\n    margin: 0 0 24px 0;\n    text-align: center;\n    color: black;\n    font-size: 20px;\n    font-weight: 600;\n}\n\n.stars {\n    display: flex;\n    justify-content: center;\n    gap: 8px;\n    margin-bottom: 24px;\n}\n\n.stars span {\n    font-size: 28px;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    padding: 4px;\n    border-radius: 8px;\n}\n\n.stars span:hover {\n    transform: scale(1.2);\n    background: rgba(255, 215, 0, 0.1);\n}\n\n.ratingModalStar {\n    cursor: pointer;\n    font-size: 24px;\n    transition: color 0.2s;\n}\n\n.ratingInput {\n    width: 100%;\n    min-height: 100px;\n    padding: 16px;\n    border: 2px solid rgba(125, 125, 125, 0.1);\n    border-radius: 12px;\n    margin-bottom: 18px;\n    resize: vertical;\n    background: rgba(125, 125, 125, 0.05);\n    color: #0b1220;\n    font-size: 14px;\n    line-height: 1.5;\n    transition: all 0.2s ease;\n}\n\n.ratingInput:focus {\n    border-color: #0084ff;\n    background: rgba(125, 125, 125, 0.08);\n    box-shadow: 0 0 0 4px rgba(0, 132, 255, 0.1);\n    outline: none;\n}\n\n.ratingInput[readonly] {\n    border: 1px solid rgba(125, 125, 125, 0.5);\n    background: rgba(125, 125, 125, 0.01);\n}\n\n.ratingActions {\n    display: flex;\n    justify-content: flex-end;\n    gap: 12px;\n}\n\n.ratingActions button {\n    padding: 12px 24px;\n    border: none;\n    border-radius: 8px;\n    cursor: pointer;\n    font-size: 14px;\n    font-weight: 500;\n    transition: all 0.2s ease;\n    min-width: 80px;\n}\n\n.ratingActions button:first-child {\n    background-color: rgba(125, 125, 125, 0.1);\n    color: #0b1220;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n}\n\n.ratingActions button:first-child:hover:not(:disabled) {\n    background-color: rgba(125, 125, 125, 0.2);\n    color: #0b1220;\n}\n\n.ratingActions button:last-child {\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%);\n    color: #ffffff;\n}\n\n.ratingActions button:last-child:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0071d1 0%, #0052a3 100%);\n    transform: translateY(-1px);\n    box-shadow: 0 4px 12px rgba(0, 132, 255, 0.3);\n}\n\n.ratingActions button:last-child:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n}\n\n/* New chat button styling - Matches the sleek chat message design */\n.chatButton {\n    display: inline-flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    gap: 8px !important;\n    padding: 12px 16px !important;\n    margin: 0 !important;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%) !important;\n    color: #ffffff !important;\n    border: none !important;\n    border-radius: 20px !important;\n    font-size: 13px !important;\n    font-weight: 600 !important;\n    line-height: 1.3 !important;\n    cursor: pointer !important;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3) !important;\n    backdrop-filter: blur(20px) !important;\n    -webkit-tap-highlight-color: transparent !important;\n    touch-action: manipulation !important;\n    user-select: none !important;\n    min-height: 40px !important;\n    min-width: 110px !important;\n    position: relative !important;\n    overflow: hidden !important;\n}\n\n.chatButton::before {\n    content: '';\n    position: absolute;\n    top: 0;\n    left: -100%;\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);\n    transition: left 0.5s ease;\n}\n\n.chatButton:hover::before {\n    left: 100%;\n}\n\n.chatButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0099ff 0%, #0077dd 100%);\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(0, 132, 255, 0.4);\n}\n\n.chatButton:active {\n    transform: scale(0.98) translateY(-1px);\n    transition: transform 0.1s ease;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n}\n\n.chatButton:focus {\n    outline: none;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3), 0 0 0 3px rgba(0, 132, 255, 0.3);\n}\n\n.chatButton svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    opacity: 1;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));\n}\n\n.chatButton:hover svg {\n    transform: rotate(-90deg) scale(1.1);\n    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));\n}\n\n.chatButtonText {\n    white-space: nowrap;\n    font-weight: 600;\n    transition: all 0.2s ease;\n    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);\n    opacity: 1;\n}\n\n.chatButton:hover .chatButtonText {\n    transform: translateX(1px);\n}\n\n/* Use template button styling - matches the chatButton and saveButton */\n.useTemplateButton {\n    display: inline-flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    gap: 8px !important;\n    padding: 12px 16px !important;\n    margin: 0 !important;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%) !important;\n    color: #ffffff !important;\n    border: none !important;\n    border-radius: 20px !important;\n    font-size: 13px !important;\n    font-weight: 600 !important;\n    line-height: 1.3 !important;\n    cursor: pointer !important;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3) !important;\n    backdrop-filter: blur(20px) !important;\n    -webkit-tap-highlight-color: transparent !important;\n    touch-action: manipulation !important;\n    user-select: none !important;\n    min-height: 40px !important;\n    min-width: 110px !important;\n    position: relative !important;\n    overflow: hidden !important;\n}\n\n.useTemplateButton::before {\n    content: '';\n    position: absolute;\n    top: 0;\n    left: -100%;\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);\n    transition: left 0.5s ease;\n}\n\n.useTemplateButton:hover::before {\n    left: 100%;\n}\n\n.useTemplateButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0099ff 0%, #0077dd 100%);\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(0, 132, 255, 0.4);\n}\n\n.useTemplateButton:active {\n    transform: scale(0.98) translateY(-1px);\n    transition: transform 0.1s ease;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n}\n\n.useTemplateButton:focus {\n    outline: none;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3), 0 0 0 3px rgba(0, 132, 255, 0.3);\n}\n\n.useTemplateButton svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    opacity: 1;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));\n}\n\n.useTemplateButton:hover svg {\n    transform: scale(1.1);\n    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));\n}\n\n.useTemplateButton:hover .chatButtonText {\n    transform: translateX(1px);\n}\n\n.saveButtonContainer {\n    display: inline-block;\n    position: relative;\n}\n\n.saveMenu {\n    position: absolute;\n    top: 100%;\n    left: 0;\n    background: #fff;\n    border: 1px solid #ddd;\n    z-index: 10;\n    min-width: 120px;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);\n}\n\n.saveMenuItem {\n    display: block;\n    width: 100%;\n    padding: 8px 16px;\n    border: none;\n    background: none;\n    text-align: left;\n    cursor: pointer;\n    color: #111;\n}\n\n.saveMenuItem:hover {\n    background-color: #f0f0f0;\n}\n\n/* Pause/Resume button variant (reuses .chatButton base styles for DRY) */\n.pauseButton {\n    background: linear-gradient(135deg, #ffb347 0%, #ff8c42 100%) !important; /* Warm orange for \"active/running\" */\n}\n\n.pauseButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #ffc067 0%, #ff9e5f 100%) !important;\n}\n\n.pauseButton.pausing {\n    opacity: 0.6 !important;\n    cursor: wait !important;\n}\n\n.pauseButton.paused {\n    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important; /* Green when paused (ready to resume) */\n}\n\n.pauseButton.paused:hover:not(:disabled) {\n    background: linear-gradient(135deg, #34d399 0%, #059669 100%) !important;\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(16, 185, 129, 0.35);\n}\n\n.pauseButton svg {\n    transition: transform 0.3s ease;\n}\n\n.pauseButton.paused svg {\n    transform: scale(1.1);\n}\n\n.pauseButton.pausing svg {\n    opacity: 0.8;\n}\n\n/* Voice call indicator bar */\n.voiceCallIndicatorBar {\n    grid-area: 🟦;\n    width: 100%;\n    padding: 12px 20px;\n    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(16, 185, 129, 0.1) 100%);\n    border-bottom: 1px solid rgba(34, 197, 94, 0.3);\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    backdrop-filter: blur(10px);\n}\n\n/* Voice call indicator */\n.voiceCallIndicator {\n    display: inline-flex;\n    align-items: center;\n    gap: 8px;\n    padding: 8px 16px;\n    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(16, 185, 129, 0.2) 100%);\n    border: 1px solid rgba(34, 197, 94, 0.4);\n    border-radius: 20px;\n    color: #10b981;\n    font-size: 13px;\n    font-weight: 600;\n    backdrop-filter: blur(10px);\n    box-shadow: 0 2px 8px rgba(34, 197, 94, 0.2);\n    position: relative;\n}\n\n.voiceCallIndicator svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    animation: voiceCallIconPulse 2s ease-in-out infinite;\n}\n\n.voiceCallIndicator span {\n    font-weight: 600;\n    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);\n}\n\n/* Voice call pulse animation */\n.voiceCallPulse {\n    position: absolute;\n    right: 8px;\n    top: 50%;\n    transform: translateY(-50%);\n    width: 8px;\n    height: 8px;\n    background: #10b981;\n    border-radius: 50%;\n    animation: voiceCallPulse 1.5s ease-in-out infinite;\n}\n\n@keyframes voiceCallIconPulse {\n    0%,\n    100% {\n        transform: scale(1);\n        opacity: 1;\n    }\n    50% {\n        transform: scale(1.1);\n        opacity: 0.8;\n    }\n}\n\n@keyframes voiceCallPulse {\n    0%,\n    100% {\n        transform: translateY(-50%) scale(1);\n        opacity: 1;\n    }\n    50% {\n        transform: translateY(-50%) scale(1.3);\n        opacity: 0.6;\n    }\n}\n\n/* Voice call indicator in messages */\n.chatMessage .voiceCallIndicator {\n    margin-bottom: 8px;\n    padding: 6px 12px;\n    font-size: 12px;\n    border-radius: 16px;\n}\n\n.chatMessage .voiceCallIndicator svg {\n    width: 14px;\n    height: 14px;\n}\n\n/* Rating confirmation */\n.ratingConfirmation {\n    position: fixed;\n    top: 20px;\n    right: 20px;\n    background: linear-gradient(135deg, #10b981 0%, #059669 100%);\n    color: white;\n    padding: 16px 20px;\n    border-radius: 12px;\n    box-shadow: 0 8px 32px rgba(16, 185, 129, 0.3);\n    z-index: 1001;\n    animation: confirmationSlideIn 0.3s ease-out;\n    max-width: 300px;\n    word-wrap: break-word;\n    font-weight: 500;\n    backdrop-filter: blur(20px);\n}\n\n@keyframes confirmationSlideIn {\n    from {\n        transform: translateX(100%);\n        opacity: 0;\n    }\n    to {\n        transform: translateX(0);\n        opacity: 1;\n    }\n}\n\n/* Mobile responsiveness */\n@media (max-width: 768px) {\n    .actions {\n        margin: 12px 16px 0;\n        gap: 6px;\n    }\n\n    .chatMainFlow .chatMessages {\n        padding: 16px 12px;\n    }\n\n    .chatMainFlow .chatMessage {\n        margin-bottom: 16px;\n    }\n\n    .chatMainFlow .chatMessage .messageText {\n        max-width: 85%;\n        padding: 12px 16px;\n        font-size: 14px;\n        border-radius: 18px;\n    }\n\n    .chatMainFlow .chatMessage .avatar {\n        width: 36px;\n        height: 36px;\n        margin: 0 10px 4px;\n    }\n\n    .chatMainFlow .chatMessage .avatar img {\n        width: 36px;\n        aspect-ratio: 1 / 1;\n    }\n\n    .chatMainFlow .chatInput {\n        padding: 16px 12px;\n        gap: 10px;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        font-size: 16px;\n        padding: 14px 18px;\n        border-radius: 22px;\n    }\n\n    .chatMainFlow .chatInput button {\n        width: 44px;\n        height: 44px;\n    }\n\n    .scrollToBottom {\n        width: 44px;\n        height: 44px;\n        font-size: 18px;\n        top: calc(100% - 160px);\n    }\n\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n\n    .ratingModalContent {\n        margin: 16px;\n        padding: 24px 20px;\n        border-radius: 16px;\n        max-height: 80vh;\n        overflow-y: auto;\n    }\n\n    .stars {\n        gap: 6px;\n        margin-bottom: 20px;\n    }\n\n    .stars span {\n        font-size: 32px;\n        padding: 8px;\n    }\n\n    .ratingActions {\n        flex-direction: column-reverse;\n        gap: 8px;\n    }\n\n    .ratingActions button {\n        width: 100%;\n        padding: 14px;\n        font-size: 16px;\n        border-radius: 10px;\n    }\n}\n\n@media (max-width: 480px) {\n    .actions {\n        margin: 8px 12px 0;\n        gap: 4px;\n    }\n\n    .chatMainFlow .chatMessages {\n        padding: 12px 8px;\n    }\n\n    .chatMainFlow .chatMessage .messageText {\n        max-width: 90%;\n        padding: 10px 14px;\n        font-size: 14px;\n        border-radius: 16px;\n    }\n\n    .chatMainFlow .chatMessage .avatar {\n        width: 32px;\n        height: 32px;\n        margin: 0 8px 4px;\n    }\n\n    .chatMainFlow .chatMessage .avatar img {\n        width: 32px;\n        aspect-ratio: 1 / 1;\n    }\n\n    .chatMainFlow .chatInput {\n        padding: 12px 8px;\n        gap: 8px;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        padding: 12px 16px;\n        border-radius: 20px;\n        font-size: 16px;\n    }\n\n    .chatMainFlow .chatInput button {\n        width: 40px;\n        height: 40px;\n    }\n\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n\n    .scrollToBottom {\n        width: 40px;\n        height: 40px;\n        font-size: 16px;\n        top: calc(100% - 140px);\n    }\n\n    .ratingModal {\n        padding: 0;\n        align-items: flex-end;\n    }\n\n    .ratingModalContent {\n        margin: 0;\n        width: 100%;\n        border-radius: 20px 20px 0 0;\n        max-height: 70vh;\n        padding: 24px 16px 20px;\n    }\n}\n\n/* Reduced motion support */\n@media (prefers-reduced-motion: reduce) {\n    .chatMainFlow .chatMessage,\n    .scrollToBottom,\n    .ratingModal,\n    .ratingModalContent,\n    .ratingConfirmation {\n        animation: none;\n    }\n\n    .chatMainFlow .chatMessage .messageText,\n    .chatMainFlow .chatInput textarea,\n    .chatMainFlow .chatInput button,\n    .chatMainFlow .chatMessage .avatar img,\n    .chatButton {\n        transition: none;\n    }\n}\n\n/* High contrast mode support */\n@media (prefers-contrast: high) {\n    .chatMainFlow .chatMessage .messageText {\n        border: 2px solid currentColor;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        border-width: 3px;\n    }\n\n    .chatMainFlow .chatInput button {\n        border: 2px solid currentColor;\n    }\n}\n\n/**\n * TODO: [🌉] DRY Markdown primitives styling\n */\n"]} */";
9138
+ var css_248z$2 = "@font-face{font-family:OpenMojiBlack;src:url(https://s6.ptbk.io/fonts/OpenMoji-black-glyf.woff2) format(\"woff2\");unicode-range:u+23,u+2a,u+2d,u+30-39,u+a9,u+ae,u+200d,u+203c,u+2049,u+20e3,u+2117,u+2120,u+2122,u+2139,u+2194-2199,u+21a9,u+21aa,u+229c,u+231a,u+231b,u+2328,u+23cf,u+23e9-23f3,u+23f8-23fe,u+24c2,u+25a1,u+25aa-25ae,u+25b6,u+25c0,u+25c9,u+25d0,u+25d1,u+25e7-25ea,u+25ed,u+25ee,u+25fb-25fe,u+2600-2605,u+260e,u+2611,u+2614,u+2615,u+2618,u+261d,u+2620,u+2622,u+2623,u+2626,u+262a,u+262e,u+262f,u+2638-263a,u+2640,u+2642,u+2648-2653,u+265f,u+2660,u+2663,u+2665,u+2666,u+2668,u+267b,u+267e,u+267f,u+2691-2697,u+2699,u+269b,u+269c,u+26a0,u+26a1,u+26a7,u+26aa,u+26ab,u+26b0,u+26b1,u+26bd,u+26be,u+26c4,u+26c5,u+26c8,u+26ce,u+26cf,u+26d1,u+26d3,u+26d4,u+26e9,u+26ea,u+26f0-26f5,u+26f7-26fa,u+26fd,u+2702,u+2705,u+2708-270d,u+270f,u+2712,u+2714,u+2716,u+271d,u+2721,u+2728,u+2733,u+2734,u+2744,u+2747,u+274c,u+274e,u+2753-2755,u+2757,u+2763,u+2764,u+2795-2797,u+27a1,u+27b0,u+27bf,u+2934,u+2935,u+2b05-2b07,u+2b0c,u+2b0d,u+2b1b,u+2b1c,u+2b1f-2b24,u+2b2e,u+2b2f,u+2b50,u+2b55,u+2b58,u+2b8f,u+2bba-2bbc,u+2bc3,u+2bc4,u+2bea,u+2beb,u+3030,u+303d,u+3297,u+3299,u+e000-e009,u+e010,u+e011,u+e040-e06d,u+e080-e0b4,u+e0c0-e0cc,u+e0ff-e10d,u+e140-e14a,u+e150-e157,u+e181-e189,u+e1c0-e1c4,u+e1c6-e1d9,u+e200-e216,u+e240-e269,u+e280-e283,u+e2c0-e2c4,u+e2c6-e2da,u+e300-e303,u+e305-e30f,u+e312-e316,u+e318-e322,u+e324-e329,u+e32b,u+e340-e348,u+e380,u+e381,u+f000,u+f77a,u+f8ff,u+fe0f,u+1f004,u+1f0cf,u+1f10d-1f10f,u+1f12f,u+1f16d-1f171,u+1f17e,u+1f17f,u+1f18e,u+1f191-1f19a,u+1f1e6-1f1ff,u+1f201,u+1f202,u+1f21a,u+1f22f,u+1f232-1f23a,u+1f250,u+1f251,u+1f260-1f265,u+1f300-1f321,u+1f324-1f393,u+1f396,u+1f397,u+1f399-1f39b,u+1f39e-1f3f0,u+1f3f3-1f3f5,u+1f3f7-1f4fd,u+1f4ff-1f53d,u+1f549-1f54e,u+1f550-1f567,u+1f56f,u+1f570,u+1f573-1f57a,u+1f587,u+1f58a-1f58d,u+1f590,u+1f595,u+1f596,u+1f5a4,u+1f5a5,u+1f5a8,u+1f5b1,u+1f5b2,u+1f5bc,u+1f5c2-1f5c4,u+1f5d1-1f5d3,u+1f5dc-1f5de,u+1f5e1,u+1f5e3,u+1f5e8,u+1f5ef,u+1f5f3,u+1f5fa-1f64f,u+1f680-1f6c5,u+1f6cb-1f6d2,u+1f6d5-1f6d7,u+1f6dc-1f6e5,u+1f6e9,u+1f6eb,u+1f6ec,u+1f6f0,u+1f6f3-1f6fc,u+1f7e0-1f7eb,u+1f7f0,u+1f90c-1f93a,u+1f93c-1f945,u+1f947-1f9ff,u+1fa70-1fa7c,u+1fa80-1fa88,u+1fa90-1fabd,u+1fabf-1fac5,u+1face-1fadb,u+1fae0-1fae8,u+1faf0-1faf8,u+1fbc5-1fbc9,u+e0061-e0067,u+e0069,u+e006c-e0079,u+e007f}.Chat-module_copiedToClipboardMessage__apCPY{background:#222;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.18);color:#fff;font-size:1.1em;left:50%;opacity:.97;padding:10px 24px;pointer-events:none;position:fixed;top:32px;transform:translateX(-50%);z-index:9999}.Chat-module_Chat__j2eE5{display:flex;flex-direction:column;font-family:Arial,Helvetica,sans-serif,OpenMojiBlack;height:100%;width:100%}.Chat-module_chatMainFlow__--8FE{display:grid;grid-template:\"🟦\" min-content \"💬\" 1fr \"📝\" min-content/1fr;height:100%;max-width:100vw;width:100%}.Chat-module_chatMainFlow__--8FE .Chat-module_chatBar__fLECN{background-color:#fff;border-bottom:1px solid rgba(15,23,36,.06);color:#0f1724;font-weight:500;grid-area:🟦;padding:16px 20px;text-align:center;width:100%}.Chat-module_TasksInProgress__fQfei{align-self:center;grid-area:🟦;height:min-content;justify-self:self-end;margin:8px 16px;width:auto}.Chat-module_actions__gTZ5T{align-items:center;align-self:self-start;display:flex;gap:8px;grid-area:💬;height:min-content;justify-self:self-end;margin:16px 20px 0;width:auto;z-index:200}.Chat-module_actions__gTZ5T.Chat-module_portal__uTOT8{margin:0}.Chat-module_actions__gTZ5T.Chat-module_left__7l5Mn{justify-self:self-start}.Chat-module_actions__gTZ5T.Chat-module_right__ABZrW{justify-self:self-end}@media (max-width:900px){.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}}@media (max-width:600px){.Chat-module_actions__gTZ5T{gap:7px;margin:14px 18px 0}}.Chat-module_chatMainFlow__--8FE .Chat-module_chatChildren__flOPK{grid-area:💬;height:100%;width:100%;z-index:300}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{grid-area:💬;height:100%;overflow-x:hidden;overflow-y:auto;padding:24px 20px 16px;scroll-behavior:smooth;width:100%;z-index:10}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar{width:6px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-track{background:transparent}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-thumb{background:hsla(0,0%,49%,.2);border-radius:3px;transition:all .2s ease}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,49%,.3)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ{align-items:flex-end;animation:Chat-module_messageSlideIn__soTy2 .4s cubic-bezier(.25,.46,.45,.94);display:flex;flex-direction:row;margin-bottom:20px;max-width:100%;position:relative}.Chat-module_hasActionsAndFirstMessageIsLong__5jgoZ{margin-top:55px}@keyframes Chat-module_messageSlideIn__soTy2{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.Chat-module_isNotCompleteMessage__Hj2K7{opacity:.7;position:relative}.Chat-module_NonCompleteMessageFiller__G5-Ve{color:transparent}.Chat-module_isNotCompleteMessage__Hj2K7 .Chat-module_messageText__XgNyQ:after{animation:Chat-module_loadingPulse__VomRm 1.5s ease-in-out infinite;background:linear-gradient(90deg,transparent,hsla(0,0%,49%,.6),transparent);border-radius:2px;bottom:8px;content:\"\";height:4px;position:absolute;right:12px;width:20px}@keyframes Chat-module_loadingPulse__VomRm{0%,to{opacity:.3;transform:scaleX(.8)}50%{opacity:1;transform:scaleX(1.2)}}.Chat-module_typingIndicator__S-CT-{align-items:flex-end;animation:Chat-module_messageSlideIn__soTy2 .4s cubic-bezier(.25,.46,.45,.94);display:flex;margin-bottom:20px}.Chat-module_typingIndicator__S-CT- .Chat-module_avatar__gL6bm{flex-shrink:0;height:40px;margin:0 12px 4px;width:40px}.Chat-module_typingIndicator__S-CT- .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;background-color:#eef6fb;border:2px solid hsla(0,0%,49%,.1);border-radius:50%;object-fit:cover;width:40px}.Chat-module_typingBubble__0Lb7B{backdrop-filter:blur(10px);border:1px solid hsla(0,0%,49%,.1);border-radius:20px;border-bottom-left-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.1);min-height:24px;padding:16px 20px}.Chat-module_typingBubble__0Lb7B,.Chat-module_typingDots__srOBB{align-items:center;display:flex;gap:4px}.Chat-module_typingDot__dnhKT{animation:Chat-module_typingBounce__1yp2v 1.4s ease-in-out infinite;background:linear-gradient(135deg,#6b7280,hsla(0,0%,49%,.6));border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.1);height:8px;width:8px}.Chat-module_typingDot__dnhKT:first-child{animation-delay:-.32s}.Chat-module_typingDot__dnhKT:nth-child(2){animation-delay:-.16s}.Chat-module_typingDot__dnhKT:nth-child(3){animation-delay:0s}@keyframes Chat-module_typingBounce__1yp2v{0%,80%,to{opacity:.5;transform:scale(.8) translateY(0)}40%{opacity:1;transform:scale(1.2) translateY(-8px)}}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ.Chat-module_isMe__nBtaV{align-items:flex-end;flex-direction:row-reverse;justify-content:flex-start}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ.Chat-module_isMe__nBtaV .Chat-module_messageText__XgNyQ{border-bottom-right-radius:6px}.Chat-module_ratingStar__rRfqC{color:var(--star-inactive-color,#ccc);cursor:pointer;font-size:20px;transition:color .2s}.Chat-module_ratingStar__rRfqC.Chat-module_active__lbYL-{color:gold}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{aspect-ratio:1/1;flex-shrink:0;margin:0 12px 4px;position:relative;width:40px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;background-color:var(--avatar-bg-color,#eef6fb);border:2px solid hsla(0,0%,49%,.1);border-radius:50%;object-fit:cover;transition:transform .2s ease,box-shadow .2s ease;width:40px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img:hover{box-shadow:0 4px 12px rgba(0,0,0,.15);transform:scale(1.05)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{word-wrap:break-word;backdrop-filter:blur(10px);background-color:var(--message-bg-color);border-radius:20px;box-shadow:0 2px 8px rgba(0,0,0,.1);color:var(--message-text-color);font-size:15px;line-height:1.5;margin-bottom:4px;max-width:min(70%,600px);padding:14px 18px;position:relative;text-align:left;transition:all .2s ease}.Chat-module_copyButtonContainer__Rij0U{align-items:center;float:right;justify-content:flex-end;pointer-events:none;right:10px;top:8px;visibility:hidden;z-index:2}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ:hover .Chat-module_copyButtonContainer__Rij0U,.Chat-module_copyButtonContainer__Rij0U:focus-within{pointer-events:auto;visibility:visible}.Chat-module_copyButton__DcxT5{align-items:center;background:hsla(0,0%,100%,.2);border:1px solid #ddd;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.07);cursor:pointer;display:flex;opacity:.7;padding:2px 5px;position:relative;transition:all .15s,box-shadow .15s,border .15s}.Chat-module_copiedTooltip__LH81j{animation:Chat-module_copiedTooltipFadeIn__QekO1 .2s;background:#222;border-radius:8px;box-shadow:0 2px 12px rgba(0,0,0,.18);color:#fff;font-size:.98em;left:50%;margin-top:4px;max-width:220px;opacity:.97;overflow-wrap:break-word;padding:6px 16px;pointer-events:none;position:absolute;top:110%;transform:translateX(-50%);white-space:nowrap;word-break:break-word;z-index:100}.Chat-module_copiedTooltipLeft__j-S-5{left:0!important;transform:none!important}.Chat-module_copiedTooltipRight__R-2cE{left:auto!important;right:0!important;transform:none!important}@keyframes Chat-module_copiedTooltipFadeIn__QekO1{0%{opacity:0;transform:translateX(-50%) translateY(8px) scale(.97)}to{opacity:.97;transform:translateX(-50%) translateY(0) scale(1)}}.Chat-module_copyButton__DcxT5:focus,.Chat-module_copyButton__DcxT5:hover{border:1.5px solid #bbb;box-shadow:0 2px 8px rgba(0,132,255,.1);opacity:1}.Chat-module_copyButton__DcxT5 svg{display:block}.Chat-module_messageText__XgNyQ h1{font-size:2em}.Chat-module_messageText__XgNyQ h2{font-size:1.75em}.Chat-module_messageText__XgNyQ h3{font-size:1.5em}.Chat-module_messageText__XgNyQ h4{font-size:1.25em}.Chat-module_messageText__XgNyQ h5{font-size:1.1em}.Chat-module_messageText__XgNyQ ul{list-style:disc;margin-left:20px}.Chat-module_messageText__XgNyQ ol{list-style:decimal;margin-left:20px}.Chat-module_messageText__XgNyQ blockquote,.Chat-module_messageText__XgNyQ img,.Chat-module_messageText__XgNyQ pre,.Chat-module_messageText__XgNyQ table{border-radius:8px;margin-bottom:10px;margin-top:10px}.Chat-module_messageText__XgNyQ pre{background:#000;color:#fff}.Chat-module_messageText__XgNyQ blockquote,.Chat-module_messageText__XgNyQ pre{border:none;box-shadow:none;display:block;font-size:inherit;line-height:inherit;padding:1em}.Chat-module_messageText__XgNyQ blockquote{background:#ffffffcc;color:#000}.Chat-module_messageText__XgNyQ code{background:#cccccc55;border:none;box-shadow:none;color:inherit;display:inline-block;font-size:inherit;line-height:inherit;margin:0;padding:0}.Chat-module_messageText__XgNyQ pre code{background-color:#000000cc;border-radius:8px}.Chat-module_messageText__XgNyQ .Chat-module_chat-code-block__k8IyS{background:#181c23;border-color:#23272f;box-shadow:0 2px 8px rgba(0,0,0,.12);color:#f8fafc;font-family:Fira Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:14px;line-height:1.6;overflow-x:auto}.Chat-module_messageText__XgNyQ .Chat-module_chat-code-block__k8IyS code{background:none!important;border:none!important;box-shadow:none!important;color:inherit!important;display:block;font-family:inherit!important;font-size:inherit!important;overflow-x:auto;padding:0!important;white-space:pre;word-break:break-word}.Chat-module_messageText__XgNyQ table{background:#f8fafc;border-collapse:separate;border-spacing:0;box-shadow:0 2px 8px rgba(0,0,0,.08);color:#17223b;font-size:14px;margin:16px 0;width:100%}.Chat-module_messageText__XgNyQ td,.Chat-module_messageText__XgNyQ th{background:none;border-bottom:1px solid #d1dbe8;color:#17223b;padding:10px 16px;text-align:left}.Chat-module_messageText__XgNyQ th{background:linear-gradient(90deg,#eaf3fa 80%,#d1e3f8);border-bottom:2px solid #b5c7de;color:#17223b;font-weight:700}.Chat-module_messageText__XgNyQ tr:last-child td{border-bottom:none}.Chat-module_messageText__XgNyQ tr:nth-child(2n) td{background:#eaf3fa}.Chat-module_messageText__XgNyQ tr:hover td{background:#cbe0f7;transition:background .2s}.Chat-module_messageText__XgNyQ table{border-radius:12px;overflow:hidden}.Chat-module_messageText__XgNyQ td:first-child,.Chat-module_messageText__XgNyQ th:first-child{border-top-left-radius:12px}.Chat-module_messageText__XgNyQ td:last-child,.Chat-module_messageText__XgNyQ th:last-child{border-top-right-radius:12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ:hover{box-shadow:0 4px 16px rgba(0,0,0,.15);transform:translateY(-1px)}.Chat-module_messageButtons__WaOob{border-top:1px solid hsla(0,0%,49%,.83);display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px}.Chat-module_messageButton__mRnn-{-webkit-tap-highlight-color:transparent;align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.9);border-radius:16px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;padding:8px 14px;touch-action:manipulation;transition:all .2s ease;user-select:none}.Chat-module_messageButton__mRnn-:hover{background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);box-shadow:0 2px 8px rgba(0,132,255,.15);transform:translateY(-1px)}.Chat-module_messageButton__mRnn-:active{transform:scale(.98);transition:transform .1s ease}.Chat-module_messageButton__mRnn- p{line-height:inherit;margin:0;padding:0}.Chat-module_messageButton__mRnn- strong{font-weight:600}.Chat-module_messageButton__mRnn- em{font-style:italic}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M{align-items:center;backdrop-filter:blur(10px);background:rgba(0,0,0,.8);border-radius:12px;bottom:-8px;display:flex;gap:2px;min-width:24px;opacity:0;padding:4px 6px;position:absolute;right:8px;transform:translateY(4px);transition:all .3s cubic-bezier(.25,.46,.45,.94);z-index:1}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ:hover .Chat-module_rating__soc3M{opacity:1;transform:translateY(0)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M:hover{background:rgba(0,0,0,.9);box-shadow:0 4px 12px rgba(0,0,0,.3);padding:6px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M span{cursor:pointer;display:inline-block;font-size:16px;transition:transform .2s ease,color .2s ease}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_rating__soc3M:hover span{transform:scale(1.1)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{backdrop-filter:blur(20px);border-top:1px solid hsla(0,0%,49%,.1);display:flex;flex-direction:column;gap:12px;grid-area:📝;padding:20px;position:relative;width:100%;z-index:10}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan.Chat-module_dragOver__bkS-g{background:linear-gradient(0deg,rgba(0,132,255,.1) 0,rgba(0,132,255,.05));border-top:2px solid rgba(0,132,255,.3)}.Chat-module_filePreviewContainer__R70hm{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.Chat-module_filePreview__kq2aX{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.2);border-radius:8px;display:flex;font-size:12px;gap:8px;padding:8px 12px;transition:all .2s ease}.Chat-module_filePreview__kq2aX:hover{background:hsla(0,0%,49%,.15);border-color:hsla(0,0%,49%,.3)}.Chat-module_fileIcon__zoSKW{font-size:14px;opacity:.7}.Chat-module_fileInfo__wBLi0{display:flex;flex-direction:column;gap:2px;min-width:0}.Chat-module_fileName__bBujo{color:#000;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.Chat-module_fileSize__ivliq{color:#6b7280;font-size:11px}.Chat-module_removeFileButton__0gakR{align-items:center;background:rgba(255,0,0,.1);border:none;border-radius:50%;color:#f44;cursor:pointer;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all .2s ease;width:20px}.Chat-module_removeFileButton__0gakR:hover{background:rgba(255,0,0,.2);transform:scale(1.1)}.Chat-module_inputContainer__bPt99{align-items:center;display:flex;gap:12px}.Chat-module_inputContainer__bPt99 textarea::placeholder{color:inherit;opacity:.7}.Chat-module_attachmentButton__qLO47{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.05);border:1px solid hsla(0,0%,49%,.2);border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.Chat-module_attachmentButton__qLO47:hover:not(:disabled){background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);color:#0084ff;transform:scale(1.05)}.Chat-module_attachmentButton__qLO47:disabled{cursor:not-allowed;opacity:.5;transform:none}.Chat-module_voiceButton__d2zlP{align-items:center;backdrop-filter:blur(10px);background:hsla(0,0%,49%,.05);border:1px solid hsla(0,0%,49%,.2);border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;transition:all .2s ease;width:40px}.Chat-module_voiceButton__d2zlP:hover{background:rgba(0,132,255,.1);border-color:rgba(0,132,255,.3);color:#0084ff;transform:scale(1.05)}.Chat-module_voiceButtonActive__Uoi3W{animation:Chat-module_voiceRecordingPulse__y2wJ5 1.5s infinite;background:rgba(255,0,0,.1)!important;border-color:rgba(255,0,0,.3)!important;color:red!important}@keyframes Chat-module_voiceRecordingPulse__y2wJ5{0%{box-shadow:0 0 0 0 rgba(255,0,0,.4)}70%{box-shadow:0 0 0 10px rgba(255,0,0,0)}to{box-shadow:0 0 0 0 rgba(255,0,0,0)}}.Chat-module_uploadProgress__jBTKe{align-items:center;background:rgba(0,132,255,.1);border:1px solid rgba(0,132,255,.2);border-radius:8px;color:#0084ff;display:flex;font-size:13px;gap:12px;padding:8px 12px}.Chat-module_uploadProgressBar__Gutnt{background:rgba(0,132,255,.2);border-radius:2px;flex:1;height:4px;overflow:hidden}.Chat-module_uploadProgressFill__EgubT{animation:Chat-module_uploadProgress__jBTKe 1.5s ease-in-out infinite;background:linear-gradient(90deg,#0084ff,rgba(0,132,255,.8));border-radius:2px;height:100%}@keyframes Chat-module_uploadProgress__jBTKe{0%{transform:translateX(-100%)}50%{transform:translateX(0)}to{transform:translateX(100%)}}.Chat-module_dragOverlay__SEGoS{align-items:center;backdrop-filter:blur(10px);background:rgba(0,132,255,.1);border:2px dashed rgba(0,132,255,.5);border-radius:12px;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:20}.Chat-module_dragOverlayContent__gb9kF{align-items:center;color:#0084ff;display:flex;flex-direction:column;font-weight:600;gap:12px;text-align:center}.Chat-module_dragOverlayContent__gb9kF svg{opacity:.7}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{-webkit-tap-highlight-color:transparent;appearance:none;-webkit-appearance:none;backdrop-filter:blur(20px);background:hsla(0,0%,49%,.05);border-radius:25px;color:#000;flex:1;font-size:15px;line-height:1.4;max-height:120px;min-width:200px;outline:none;padding:16px 20px;resize:none;touch-action:manipulation;transition:all .3s cubic-bezier(.25,.46,.45,.94)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea:focus{background:hsla(0,0%,49%,.08);border-color:#0084ff;box-shadow:0 0 0 4px rgba(0,132,255,.1),0 8px 32px rgba(0,132,255,.15);transform:translateY(-2px)}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea:disabled{cursor:not-allowed;opacity:.6;transform:none}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea::placeholder{color:inherit;opacity:.7}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{-webkit-tap-highlight-color:transparent;align-items:center;aspect-ratio:1/1;border:none;border-radius:50%!important;box-shadow:0 4px 16px rgba(0,132,255,.3);color:#fff;display:flex;height:48px;justify-content:center;margin:0!important;min-height:unset!important;min-width:unset!important;overflow:visible;padding:0!important;padding-left:unset;padding-right:unset;touch-action:manipulation;transition:all .3s cubic-bezier(.25,.46,.45,.94);user-select:none;width:48px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button img{height:100%;object-fit:contain;width:50%}.Chat-module_scrollToBottomContainer__5rXpK{align-items:flex-start;display:flex;grid-area:📝;height:100%;justify-content:center;pointer-events:none;width:100%;z-index:20}.Chat-module_scrollToBottomContainer__5rXpK .Chat-module_scrollToBottom__nzxdZ{-webkit-tap-highlight-color:transparent;align-items:center;animation:Chat-module_scrollButtonSlideIn__XnImg .3s ease-out;backdrop-filter:blur(3px);background:rgba(0,0,0,.5);border:none;border-radius:50%;box-shadow:0 4px 16px rgba(0,0,0,.3);color:#fff;cursor:pointer;display:flex;font-weight:700;height:48px;justify-content:center;outline:none;pointer-events:all;touch-action:manipulation;transform:translate(-50%,-150%);transition:all .3s cubic-bezier(.25,.46,.45,.94);user-select:none;width:48px}@keyframes Chat-module_scrollButtonSlideIn__XnImg{0%{opacity:0;transform:translate(-50%,20px) scale(.8)}to{opacity:.9;transform:translate(-50%) scale(1)}}.Chat-module_scrollToBottom__nzxdZ:hover{transform:translate(-50%,-160%) scale(1.05)}.Chat-module_scrollToBottom__nzxdZ:active{transform:translate(-50%,-160%) scale(.95);transition:transform .1s ease}.Chat-module_ratingModal__XVKYm{align-items:center;animation:Chat-module_modalFadeIn__RPc3w .3s ease-out;backdrop-filter:blur(8px);background-color:rgba(0,0,0,.6);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes Chat-module_modalFadeIn__RPc3w{0%{backdrop-filter:blur(0);opacity:0}to{backdrop-filter:blur(8px);opacity:1}}.Chat-module_ratingModalContent__CCdq7{animation:Chat-module_modalSlideIn__XXtgN .3s cubic-bezier(.25,.46,.45,.94);backdrop-filter:blur(20px);background:#fff;border:1px solid hsla(0,0%,49%,.1);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);color:#0f1724;font-family:Arial,Helvetica,sans-serif,OpenMojiBlack;max-width:480px;padding:32px;width:90%}@keyframes Chat-module_modalSlideIn__XXtgN{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.Chat-module_ratingModalContent__CCdq7 h3{color:#000;font-size:20px;font-weight:600;margin:0 0 24px;text-align:center}.Chat-module_stars__PCzNO{display:flex;gap:8px;justify-content:center;margin-bottom:24px}.Chat-module_stars__PCzNO span{border-radius:8px;cursor:pointer;font-size:28px;padding:4px;transition:all .2s ease}.Chat-module_stars__PCzNO span:hover{background:rgba(255,215,0,.1);transform:scale(1.2)}.Chat-module_ratingModalStar__XkbHr{cursor:pointer;font-size:24px;transition:color .2s}.Chat-module_ratingInput__z8Pv-{background:hsla(0,0%,49%,.05);border:2px solid hsla(0,0%,49%,.1);border-radius:12px;color:#0b1220;font-size:14px;line-height:1.5;margin-bottom:18px;min-height:100px;padding:16px;resize:vertical;transition:all .2s ease;width:100%}.Chat-module_ratingInput__z8Pv-:focus{background:hsla(0,0%,49%,.08);border-color:#0084ff;box-shadow:0 0 0 4px rgba(0,132,255,.1);outline:none}.Chat-module_ratingInput__z8Pv-[readonly]{background:hsla(0,0%,49%,.01);border:1px solid hsla(0,0%,49%,.5)}.Chat-module_ratingActions__nXcss{display:flex;gap:12px;justify-content:flex-end}.Chat-module_ratingActions__nXcss button{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;min-width:80px;padding:12px 24px;transition:all .2s ease}.Chat-module_ratingActions__nXcss button:first-child{background-color:hsla(0,0%,49%,.1);border:1px solid hsla(0,0%,49%,.2);color:#0b1220}.Chat-module_ratingActions__nXcss button:first-child:hover:not(:disabled){background-color:hsla(0,0%,49%,.2);color:#0b1220}.Chat-module_ratingActions__nXcss button:last-child{background:linear-gradient(135deg,#0084ff,#06c);color:#fff}.Chat-module_ratingActions__nXcss button:last-child:hover:not(:disabled){background:linear-gradient(135deg,#0071d1,#0052a3);box-shadow:0 4px 12px rgba(0,132,255,.3);transform:translateY(-1px)}.Chat-module_ratingActions__nXcss button:last-child:disabled{cursor:not-allowed;opacity:.5}.Chat-module_chatButton__d9VgA{-webkit-tap-highlight-color:transparent!important;align-items:center!important;backdrop-filter:blur(20px)!important;background:linear-gradient(135deg,#0084ff,#06c)!important;border:none!important;border-radius:20px!important;box-shadow:0 4px 16px rgba(0,132,255,.3)!important;color:#fff!important;cursor:pointer!important;display:inline-flex!important;font-size:13px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;line-height:1.3!important;margin:0!important;min-height:40px!important;min-width:110px!important;overflow:hidden!important;padding:12px 16px!important;position:relative!important;touch-action:manipulation!important;transition:all .3s cubic-bezier(.25,.46,.45,.94)!important;user-select:none!important}.Chat-module_chatButton__d9VgA:before{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);content:\"\";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.Chat-module_chatButton__d9VgA:hover:before{left:100%}.Chat-module_chatButton__d9VgA:hover:not(:disabled){background:linear-gradient(135deg,#09f,#07d);box-shadow:0 8px 24px rgba(0,132,255,.4);transform:translateY(-2px) scale(1.02)}.Chat-module_chatButton__d9VgA:active{box-shadow:0 4px 16px rgba(0,132,255,.3);transform:scale(.98) translateY(-1px);transition:transform .1s ease}.Chat-module_chatButton__d9VgA:focus{box-shadow:0 4px 16px rgba(0,132,255,.3),0 0 0 3px rgba(0,132,255,.3);outline:none}.Chat-module_chatButton__d9VgA svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));flex-shrink:0;height:16px;opacity:1;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:16px}.Chat-module_chatButton__d9VgA:hover svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transform:rotate(-90deg) scale(1.1)}.Chat-module_chatButtonText__RkGB-{font-weight:600;opacity:1;text-shadow:0 1px 2px rgba(0,0,0,.1);transition:all .2s ease;white-space:nowrap}.Chat-module_chatButton__d9VgA:hover .Chat-module_chatButtonText__RkGB-{transform:translateX(1px)}.Chat-module_useTemplateButton__xcJNR{-webkit-tap-highlight-color:transparent!important;align-items:center!important;backdrop-filter:blur(20px)!important;background:linear-gradient(135deg,#0084ff,#06c)!important;border:none!important;border-radius:20px!important;box-shadow:0 4px 16px rgba(0,132,255,.3)!important;color:#fff!important;cursor:pointer!important;display:inline-flex!important;font-size:13px!important;font-weight:600!important;gap:8px!important;justify-content:center!important;line-height:1.3!important;margin:0!important;min-height:40px!important;min-width:110px!important;overflow:hidden!important;padding:12px 16px!important;position:relative!important;touch-action:manipulation!important;transition:all .3s cubic-bezier(.25,.46,.45,.94)!important;user-select:none!important}.Chat-module_useTemplateButton__xcJNR:before{background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);content:\"\";height:100%;left:-100%;position:absolute;top:0;transition:left .5s ease;width:100%}.Chat-module_useTemplateButton__xcJNR:hover:before{left:100%}.Chat-module_useTemplateButton__xcJNR:hover:not(:disabled){background:linear-gradient(135deg,#09f,#07d);box-shadow:0 8px 24px rgba(0,132,255,.4);transform:translateY(-2px) scale(1.02)}.Chat-module_useTemplateButton__xcJNR:active{box-shadow:0 4px 16px rgba(0,132,255,.3);transform:scale(.98) translateY(-1px);transition:transform .1s ease}.Chat-module_useTemplateButton__xcJNR:focus{box-shadow:0 4px 16px rgba(0,132,255,.3),0 0 0 3px rgba(0,132,255,.3);outline:none}.Chat-module_useTemplateButton__xcJNR svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.2));flex-shrink:0;height:16px;opacity:1;transition:all .3s cubic-bezier(.25,.46,.45,.94);width:16px}.Chat-module_useTemplateButton__xcJNR:hover svg{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transform:scale(1.1)}.Chat-module_useTemplateButton__xcJNR:hover .Chat-module_chatButtonText__RkGB-{transform:translateX(1px)}.Chat-module_saveButtonContainer__lSNUJ{display:inline-block;position:relative}.Chat-module_saveMenu__-ph8y{background:#fff;border:1px solid #ddd;box-shadow:0 2px 8px rgba(0,0,0,.08);left:0;min-width:120px;position:absolute;top:100%;z-index:10}.Chat-module_saveMenuItem__ISApL{background:none;border:none;color:#111;cursor:pointer;display:block;padding:8px 16px;text-align:left;width:100%}.Chat-module_saveMenuItem__ISApL:hover{background-color:#f0f0f0}.Chat-module_pauseButton__eeu7K{background:linear-gradient(135deg,#ffb347,#ff8c42)!important}.Chat-module_pauseButton__eeu7K:hover:not(:disabled){background:linear-gradient(135deg,#ffc067,#ff9e5f)!important}.Chat-module_pauseButton__eeu7K.Chat-module_pausing__pTx8b{cursor:wait!important;opacity:.6!important}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya{background:linear-gradient(135deg,#10b981,#059669)!important}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya:hover:not(:disabled){background:linear-gradient(135deg,#34d399,#059669)!important;box-shadow:0 8px 24px rgba(16,185,129,.35);transform:translateY(-2px) scale(1.02)}.Chat-module_pauseButton__eeu7K svg{transition:transform .3s ease}.Chat-module_pauseButton__eeu7K.Chat-module_paused__j-pya svg{transform:scale(1.1)}.Chat-module_pauseButton__eeu7K.Chat-module_pausing__pTx8b svg{opacity:.8}.Chat-module_voiceCallIndicatorBar__N2sWN{align-items:center;backdrop-filter:blur(10px);background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(16,185,129,.1));border-bottom:1px solid rgba(34,197,94,.3);display:flex;grid-area:🟦;justify-content:center;padding:12px 20px;width:100%}.Chat-module_voiceCallIndicator__tsaaG{align-items:center;backdrop-filter:blur(10px);background:linear-gradient(135deg,rgba(34,197,94,.2),rgba(16,185,129,.2));border:1px solid rgba(34,197,94,.4);border-radius:20px;box-shadow:0 2px 8px rgba(34,197,94,.2);color:#10b981;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:8px 16px;position:relative}.Chat-module_voiceCallIndicator__tsaaG svg{animation:Chat-module_voiceCallIconPulse__zZbJn 2s ease-in-out infinite;flex-shrink:0;height:16px;width:16px}.Chat-module_voiceCallIndicator__tsaaG span{font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1)}.Chat-module_voiceCallPulse__XcGU4{animation:Chat-module_voiceCallPulse__XcGU4 1.5s ease-in-out infinite;background:#10b981;border-radius:50%;height:8px;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:8px}@keyframes Chat-module_voiceCallIconPulse__zZbJn{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes Chat-module_voiceCallPulse__XcGU4{0%,to{opacity:1;transform:translateY(-50%) scale(1)}50%{opacity:.6;transform:translateY(-50%) scale(1.3)}}.Chat-module_chatMessage__nmLaZ .Chat-module_voiceCallIndicator__tsaaG{border-radius:16px;font-size:12px;margin-bottom:8px;padding:6px 12px}.Chat-module_chatMessage__nmLaZ .Chat-module_voiceCallIndicator__tsaaG svg{height:14px;width:14px}.Chat-module_ratingConfirmation__n16vb{word-wrap:break-word;animation:Chat-module_confirmationSlideIn__5U-wz .3s ease-out;backdrop-filter:blur(20px);background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;box-shadow:0 8px 32px rgba(16,185,129,.3);color:#fff;font-weight:500;max-width:300px;padding:16px 20px;position:fixed;right:20px;top:20px;z-index:1001}@keyframes Chat-module_confirmationSlideIn__5U-wz{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.Chat-module_actions__gTZ5T{gap:6px;margin:12px 16px 0}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{padding:16px 12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ{margin-bottom:16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border-radius:18px;font-size:14px;max-width:85%;padding:12px 16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{height:36px;margin:0 10px 4px;width:36px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;width:36px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{gap:10px;padding:16px 12px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-radius:22px;font-size:16px;padding:14px 18px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{height:44px;width:44px}.Chat-module_scrollToBottom__nzxdZ{font-size:18px;height:44px;top:calc(100% - 160px);width:44px}.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_ratingModalContent__CCdq7{border-radius:16px;margin:16px;max-height:80vh;overflow-y:auto;padding:24px 20px}.Chat-module_stars__PCzNO{gap:6px;margin-bottom:20px}.Chat-module_stars__PCzNO span{font-size:32px;padding:8px}.Chat-module_ratingActions__nXcss{flex-direction:column-reverse;gap:8px}.Chat-module_ratingActions__nXcss button{border-radius:10px;font-size:16px;padding:14px;width:100%}}@media (max-width:480px){.Chat-module_actions__gTZ5T{gap:4px;margin:8px 12px 0}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessages__J2u2N{padding:12px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border-radius:16px;font-size:14px;max-width:90%;padding:10px 14px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm{height:32px;margin:0 8px 4px;width:32px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img{aspect-ratio:1/1;width:32px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan{gap:8px;padding:12px 8px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-radius:20px;font-size:16px;padding:12px 16px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{height:40px;width:40px}.Chat-module_chatButton__d9VgA{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_chatButton__d9VgA svg{height:18px!important;width:18px!important}.Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_useTemplateButton__xcJNR{border-radius:50%!important;gap:0!important;height:40px!important;margin:0!important;min-height:40px!important;min-width:40px!important;padding:0!important;width:40px!important}.Chat-module_useTemplateButton__xcJNR svg{height:18px!important;width:18px!important}.Chat-module_useTemplateButton__xcJNR .Chat-module_chatButtonText__RkGB-{display:none!important}.Chat-module_scrollToBottom__nzxdZ{font-size:16px;height:40px;top:calc(100% - 140px);width:40px}.Chat-module_ratingModal__XVKYm{align-items:flex-end;padding:0}.Chat-module_ratingModalContent__CCdq7{border-radius:20px 20px 0 0;margin:0;max-height:70vh;padding:24px 16px 20px;width:100%}}@media (prefers-reduced-motion:reduce){.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ,.Chat-module_ratingConfirmation__n16vb,.Chat-module_ratingModalContent__CCdq7,.Chat-module_ratingModal__XVKYm,.Chat-module_scrollToBottom__nzxdZ{animation:none}.Chat-module_chatButton__d9VgA,.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button,.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea,.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_avatar__gL6bm img,.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{transition:none}}@media (prefers-contrast:high){.Chat-module_chatMainFlow__--8FE .Chat-module_chatMessage__nmLaZ .Chat-module_messageText__XgNyQ{border:2px solid}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan textarea{border-width:3px}.Chat-module_chatMainFlow__--8FE .Chat-module_chatInput__1Ecan button{border:2px solid}}\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["Chat.module.css"],"names":[],"mappings":"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","file":"Chat.module.css","sourcesContent":["@font-face {\n    font-family: 'OpenMojiBlack';\n    src: url('https://s6.ptbk.io/fonts/OpenMoji-black-glyf.woff2') format('woff2'); /* <- TODO: [🐱‍🚀] Dynamically load from /servers.ts */\n    unicode-range: U+23, U+2A, U+2D, U+30-39, U+A9, U+AE, U+200D, U+203C, U+2049, U+20E3, U+2117, U+2120, U+2122, U+2139,\n        U+2194-2199, U+21A9, U+21AA, U+229C, U+231A, U+231B, U+2328, U+23CF, U+23E9-23F3, U+23F8-23FE, U+24C2, U+25A1,\n        U+25AA-25AE, U+25B6, U+25C0, U+25C9, U+25D0, U+25D1, U+25E7-25EA, U+25ED, U+25EE, U+25FB-25FE, U+2600-2605,\n        U+260E, U+2611, U+2614, U+2615, U+2618, U+261D, U+2620, U+2622, U+2623, U+2626, U+262A, U+262E, U+262F,\n        U+2638-263A, U+2640, U+2642, U+2648-2653, U+265F, U+2660, U+2663, U+2665, U+2666, U+2668, U+267B, U+267E, U+267F,\n        U+2691-2697, U+2699, U+269B, U+269C, U+26A0, U+26A1, U+26A7, U+26AA, U+26AB, U+26B0, U+26B1, U+26BD, U+26BE,\n        U+26C4, U+26C5, U+26C8, U+26CE, U+26CF, U+26D1, U+26D3, U+26D4, U+26E9, U+26EA, U+26F0-26F5, U+26F7-26FA, U+26FD,\n        U+2702, U+2705, U+2708-270D, U+270F, U+2712, U+2714, U+2716, U+271D, U+2721, U+2728, U+2733, U+2734, U+2744,\n        U+2747, U+274C, U+274E, U+2753-2755, U+2757, U+2763, U+2764, U+2795-2797, U+27A1, U+27B0, U+27BF, U+2934, U+2935,\n        U+2B05-2B07, U+2B0C, U+2B0D, U+2B1B, U+2B1C, U+2B1F-2B24, U+2B2E, U+2B2F, U+2B50, U+2B55, U+2B58, U+2B8F,\n        U+2BBA-2BBC, U+2BC3, U+2BC4, U+2BEA, U+2BEB, U+3030, U+303D, U+3297, U+3299, U+E000-E009, U+E010, U+E011,\n        U+E040-E06D, U+E080-E0B4, U+E0C0-E0CC, U+E0FF-E10D, U+E140-E14A, U+E150-E157, U+E181-E189, U+E1C0-E1C4,\n        U+E1C6-E1D9, U+E200-E216, U+E240-E269, U+E280-E283, U+E2C0-E2C4, U+E2C6-E2DA, U+E300-E303, U+E305-E30F,\n        U+E312-E316, U+E318-E322, U+E324-E329, U+E32B, U+E340-E348, U+E380, U+E381, U+F000, U+F77A, U+F8FF, U+FE0F,\n        U+1F004, U+1F0CF, U+1F10D-1F10F, U+1F12F, U+1F16D-1F171, U+1F17E, U+1F17F, U+1F18E, U+1F191-1F19A, U+1F1E6-1F1FF,\n        U+1F201, U+1F202, U+1F21A, U+1F22F, U+1F232-1F23A, U+1F250, U+1F251, U+1F260-1F265, U+1F300-1F321, U+1F324-1F393,\n        U+1F396, U+1F397, U+1F399-1F39B, U+1F39E-1F3F0, U+1F3F3-1F3F5, U+1F3F7-1F4FD, U+1F4FF-1F53D, U+1F549-1F54E,\n        U+1F550-1F567, U+1F56F, U+1F570, U+1F573-1F57A, U+1F587, U+1F58A-1F58D, U+1F590, U+1F595, U+1F596, U+1F5A4,\n        U+1F5A5, U+1F5A8, U+1F5B1, U+1F5B2, U+1F5BC, U+1F5C2-1F5C4, U+1F5D1-1F5D3, U+1F5DC-1F5DE, U+1F5E1, U+1F5E3,\n        U+1F5E8, U+1F5EF, U+1F5F3, U+1F5FA-1F64F, U+1F680-1F6C5, U+1F6CB-1F6D2, U+1F6D5-1F6D7, U+1F6DC-1F6E5, U+1F6E9,\n        U+1F6EB, U+1F6EC, U+1F6F0, U+1F6F3-1F6FC, U+1F7E0-1F7EB, U+1F7F0, U+1F90C-1F93A, U+1F93C-1F945, U+1F947-1F9FF,\n        U+1FA70-1FA7C, U+1FA80-1FA88, U+1FA90-1FABD, U+1FABF-1FAC5, U+1FACE-1FADB, U+1FAE0-1FAE8, U+1FAF0-1FAF8,\n        U+1FBC5-1FBC9, U+E0061-E0067, U+E0069, U+E006C-E0079, U+E007F;\n}\n\n.copiedToClipboardMessage {\n    position: fixed;\n    top: 32px;\n    left: 50%;\n    transform: translateX(-50%);\n    background: #222;\n    color: #fff;\n    padding: 10px 24px;\n    border-radius: 8px;\n    font-size: 1.1em;\n    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.18);\n    opacity: 0.97;\n    pointer-events: none;\n    z-index: 9999;\n}\n\n.Chat {\n    width: 100%;\n    height: 100%;\n    display: flex;\n    flex-direction: column;\n\n    font-family: Arial, Helvetica, sans-serif, 'OpenMojiBlack';\n    /* <- TODO: [🧠][🎱] Better, define other fonts */\n}\n\n.chatMainFlow {\n    width: 100%;\n    height: 100%;\n    max-width: 100vw;\n    display: grid;\n    grid-template:\n        '🟦' min-content\n        '💬' 1fr\n        '📝' min-content\n        / 1fr;\n}\n\n.chatMainFlow .chatBar {\n    grid-area: 🟦;\n    width: 100%;\n    padding: 16px 20px;\n    color: #0f1724;\n    background-color: #ffffff;\n    border-bottom: 1px solid rgba(15, 23, 36, 0.06);\n    text-align: center;\n    font-weight: 500;\n}\n\n.TasksInProgress {\n    grid-area: 🟦;\n    width: auto;\n    height: min-content;\n    align-self: center;\n    justify-self: self-end;\n    margin: 8px 16px;\n}\n\n.actions {\n    grid-area: 💬;\n    width: auto;\n    height: min-content;\n    z-index: 200;\n    align-self: self-start;\n    justify-self: self-end;\n    margin: 16px 20px 0;\n    display: flex;\n    align-items: center;\n    gap: 8px;\n}\n\n.actions.portal {\n    margin: 0;\n}\n\n.actions.left {\n    justify-self: self-start;\n}\n\n.actions.right {\n    justify-self: self-end;\n}\n\n/* Large tablet and small desktop screens */\n@media (max-width: 900px) {\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n}\n\n/* Medium screens */\n@media (max-width: 600px) {\n    .actions {\n        margin: 14px 18px 0;\n        gap: 7px;\n    }\n}\n\n.chatMainFlow .chatChildren {\n    grid-area: 💬;\n    width: 100%;\n    height: 100%;\n    z-index: 300;\n}\n\n/* Chat messages area */\n.chatMainFlow .chatMessages {\n    grid-area: 💬;\n    width: 100%;\n    height: 100%;\n    z-index: 10;\n    padding: 24px 20px 16px;\n    overflow-y: auto;\n    overflow-x: hidden;\n    scroll-behavior: smooth;\n}\n\n/* Custom scrollbar styling */\n.chatMainFlow .chatMessages::-webkit-scrollbar {\n    width: 6px;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-track {\n    background: transparent;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-thumb {\n    background: rgba(125, 125, 125, 0.2);\n    border-radius: 3px;\n    transition: all 0.2s ease;\n}\n\n.chatMainFlow .chatMessages::-webkit-scrollbar-thumb:hover {\n    background: rgba(125, 125, 125, 0.3);\n}\n\n/* Individual chat message */\n.chatMainFlow .chatMessage {\n    display: flex;\n    margin-bottom: 20px;\n    align-items: flex-end;\n    flex-direction: row;\n    position: relative;\n    animation: messageSlideIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    max-width: 100%;\n}\n\n/* Add top margin to first message if actions are present and first message is long */\n.hasActionsAndFirstMessageIsLong {\n    margin-top: 55px;\n}\n\n@keyframes messageSlideIn {\n    from {\n        opacity: 0;\n        transform: translateY(20px) scale(0.95);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0) scale(1);\n    }\n}\n\n.isNotCompleteMessage {\n    /*/\n    outline: 1px dotted #ff0000 !important;\n    /**/\n\n    opacity: 0.7;\n    position: relative;\n}\n\n.NonCompleteMessageFiller {\n    color: transparent;\n}\n\n/* Enhanced loading states for messages */\n.isNotCompleteMessage .messageText::after {\n    content: '';\n    position: absolute;\n    bottom: 8px;\n    right: 12px;\n    width: 20px;\n    height: 4px;\n    background: linear-gradient(90deg, transparent, rgba(125, 125, 125, 0.6), transparent);\n    border-radius: 2px;\n    animation: loadingPulse 1.5s ease-in-out infinite;\n}\n\n@keyframes loadingPulse {\n    0%,\n    100% {\n        opacity: 0.3;\n        transform: scaleX(0.8);\n    }\n    50% {\n        opacity: 1;\n        transform: scaleX(1.2);\n    }\n}\n\n/* Typing indicator for AI messages */\n.typingIndicator {\n    display: flex;\n    align-items: flex-end;\n    margin-bottom: 20px;\n    animation: messageSlideIn 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.typingIndicator .avatar {\n    width: 40px;\n    height: 40px;\n    margin: 0 12px 4px;\n    flex-shrink: 0;\n}\n\n.typingIndicator .avatar img {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    border-radius: 50%;\n    object-fit: cover;\n    background-color: #eef6fb;\n    border: 2px solid rgba(125, 125, 125, 0.1);\n}\n\n.typingBubble {\n    padding: 16px 20px;\n    border-radius: 20px;\n    border-bottom-left-radius: 6px;\n    border: 1px solid rgba(125, 125, 125, 0.1);\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);\n    backdrop-filter: blur(10px);\n    display: flex;\n    align-items: center;\n    gap: 4px;\n    min-height: 24px;\n}\n\n.typingDots {\n    display: flex;\n    gap: 4px;\n    align-items: center;\n}\n\n.typingDot {\n    width: 8px;\n    height: 8px;\n    border-radius: 50%;\n    background: linear-gradient(135deg, #6b7280 0%, rgba(125, 125, 125, 0.6) 100%);\n    animation: typingBounce 1.4s infinite ease-in-out;\n    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);\n}\n\n.typingDot:nth-child(1) {\n    animation-delay: -0.32s;\n}\n\n.typingDot:nth-child(2) {\n    animation-delay: -0.16s;\n}\n\n.typingDot:nth-child(3) {\n    animation-delay: 0s;\n}\n\n@keyframes typingBounce {\n    0%,\n    80%,\n    100% {\n        transform: scale(0.8) translateY(0);\n        opacity: 0.5;\n    }\n    40% {\n        transform: scale(1.2) translateY(-8px);\n        opacity: 1;\n    }\n}\n\n.chatMainFlow .chatMessage.isMe {\n    align-items: flex-end;\n    flex-direction: row-reverse;\n    justify-content: flex-start;\n}\n\n.chatMainFlow .chatMessage.isMe .messageText {\n    border-bottom-right-radius: 6px;\n}\n\n.ratingStar {\n    cursor: pointer;\n    font-size: 20px;\n    transition: color 0.2s;\n    color: var(--star-inactive-color, #ccc);\n}\n\n.ratingStar.active {\n    color: #ffd700;\n}\n\n/* Sender Avatar */\n.chatMainFlow .chatMessage .avatar {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    margin: 0 12px 4px;\n    flex-shrink: 0;\n    position: relative;\n}\n\n.chatMainFlow .chatMessage .avatar img {\n    width: 40px;\n    aspect-ratio: 1 / 1;\n    border-radius: 50%;\n    object-fit: cover;\n    background-color: var(--avatar-bg-color, #eef6fb);\n    border: 2px solid rgba(125, 125, 125, 0.1);\n    transition: transform 0.2s ease, box-shadow 0.2s ease;\n}\n\n.chatMainFlow .chatMessage .avatar img:hover {\n    transform: scale(1.05);\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n}\n\n/* Message text bubble */\n.chatMainFlow .chatMessage .messageText {\n    background-color: var(--message-bg-color);\n    color: var(--message-text-color);\n    position: relative;\n    padding: 14px 18px;\n    border-radius: 20px;\n    max-width: min(70%, 600px);\n    text-align: left;\n    margin-bottom: 4px;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);\n    line-height: 1.5;\n    word-wrap: break-word;\n    transition: all 0.2s ease;\n    font-size: 15px;\n    backdrop-filter: blur(10px);\n}\n\n/* Copy button styles */\n.copyButtonContainer {\n    float: right;\n    top: 8px;\n    right: 10px;\n    z-index: 2;\n    align-items: center;\n    justify-content: flex-end;\n    pointer-events: none;\n\n    visibility: hidden;\n}\n.chatMainFlow .chatMessage .messageText:hover .copyButtonContainer,\n.copyButtonContainer:focus-within {\n    visibility: visible;\n    pointer-events: auto;\n}\n\n.copyButton {\n    background: rgba(255, 255, 255, 0.2);\n    border: 1px solid #ddd;\n    border-radius: 6px;\n    padding: 2px 5px;\n    cursor: pointer;\n    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.07);\n    transition: all 0.15s, box-shadow 0.15s, border 0.15s;\n    display: flex;\n    align-items: center;\n    opacity: 0.7;\n    position: relative;\n}\n\n.copiedTooltip {\n    position: absolute;\n    left: 50%;\n    top: 110%;\n    transform: translateX(-50%);\n    background: #222;\n    color: #fff;\n    padding: 6px 16px;\n    border-radius: 8px;\n    font-size: 0.98em;\n    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.18);\n    opacity: 0.97;\n    pointer-events: none;\n    z-index: 100;\n    white-space: nowrap;\n    margin-top: 4px;\n    animation: copiedTooltipFadeIn 0.2s;\n    max-width: 220px;\n    overflow-wrap: break-word;\n    word-break: break-word;\n}\n\n.copiedTooltipLeft {\n    left: 0 !important;\n    transform: none !important;\n}\n\n.copiedTooltipRight {\n    left: auto !important;\n    right: 0 !important;\n    transform: none !important;\n}\n\n/* Removed right-aligned override to keep tooltip position stable */\n\n@keyframes copiedTooltipFadeIn {\n    from {\n        opacity: 0;\n        transform: translateX(-50%) translateY(8px) scale(0.97);\n    }\n    to {\n        opacity: 0.97;\n        transform: translateX(-50%) translateY(0) scale(1);\n    }\n}\n\n.copyButton:hover,\n.copyButton:focus {\n    border: 1.5px solid #bbb;\n    opacity: 1;\n    box-shadow: 0 2px 8px rgba(0, 132, 255, 0.1);\n}\n\n.copyButton svg {\n    display: block;\n}\n\n.messageText h1 {\n    font-size: 2em;\n}\n\n.messageText h2 {\n    font-size: 1.75em;\n}\n\n.messageText h3 {\n    font-size: 1.5em;\n}\n\n.messageText h4 {\n    font-size: 1.25em;\n}\n\n.messageText h5 {\n    font-size: 1.1em;\n}\n\n.messageText ul {\n    list-style: disc;\n    margin-left: 20px;\n}\n\n.messageText ol {\n    list-style: decimal;\n    margin-left: 20px;\n}\n\n.messageText img,\n.messageText pre,\n.messageText blockquote,\n.messageText table {\n    margin-top: 10px;\n    margin-bottom: 10px;\n    border-radius: 8px;\n}\n\n.messageText pre {\n    display: block;\n    border: none;\n    box-shadow: none;\n    background: #000000ff;\n    font-size: inherit;\n    line-height: inherit;\n    color: #fff;\n    padding: 1em;\n}\n\n.messageText blockquote {\n    display: block;\n    border: none;\n    box-shadow: none;\n    background: #ffffffcc;\n    font-size: inherit;\n    line-height: inherit;\n    color: #000;\n    padding: 1em;\n}\n\n.messageText code {\n    display: inline-block;\n    margin: 0;\n    padding: 0;\n    border: none;\n    box-shadow: none;\n    background: #cccccc55;\n    font-size: inherit;\n    line-height: inherit;\n    color: inherit;\n}\n\n.messageText pre code {\n    background-color: #000000cc;\n    border-radius: 8px;\n}\n\n.messageText .chat-code-block {\n    background: #181c23;\n    color: #f8fafc;\n    font-size: 14px;\n    line-height: 1.6;\n    overflow-x: auto;\n    border-color: #23272f;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);\n    font-family: 'Fira Mono', 'Menlo', 'Consolas', 'Liberation Mono', monospace;\n}\n.messageText .chat-code-block code {\n    background: none !important;\n    color: inherit !important;\n    font-family: inherit !important;\n    font-size: inherit !important;\n    padding: 0 !important;\n    border: none !important;\n    box-shadow: none !important;\n    white-space: pre;\n    word-break: break-word;\n    overflow-x: auto;\n    display: block;\n}\n.messageText table {\n    width: 100%;\n    border-collapse: separate;\n    border-spacing: 0;\n    margin: 16px 0;\n    background: #f8fafc; /* Stronger light background for contrast */\n    border-radius: 12px;\n    overflow: hidden;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);\n    font-size: 14px;\n    color: #17223b; /* Dark text for contrast */\n}\n.messageText th,\n.messageText td {\n    padding: 10px 16px;\n    border-bottom: 1px solid #d1dbe8;\n    text-align: left;\n    color: #17223b; /* Ensure strong text color for all cells */\n    background: none;\n}\n.messageText th {\n    background: linear-gradient(90deg, #eaf3fa 80%, #d1e3f8 100%);\n    font-weight: 700;\n    color: #17223b; /* Strong header text */\n    border-bottom: 2px solid #b5c7de;\n}\n.messageText tr:last-child td {\n    border-bottom: none;\n}\n.messageText tr:nth-child(even) td {\n    background: #eaf3fa;\n}\n.messageText tr:hover td {\n    background: #cbe0f7;\n    transition: background 0.2s;\n}\n.messageText table {\n    border-radius: 12px;\n    overflow: hidden;\n}\n.messageText th:first-child,\n.messageText td:first-child {\n    border-top-left-radius: 12px;\n}\n.messageText th:last-child,\n.messageText td:last-child {\n    border-top-right-radius: 12px;\n}\n\n.chatMainFlow .chatMessage .messageText:hover {\n    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);\n    transform: translateY(-1px);\n}\n\n/* Message buttons container */\n.messageButtons {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 8px;\n    margin-top: 12px;\n    padding-top: 12px;\n    border-top: 1px solid rgba(125 125 125 / 0.83);\n}\n\n/* Individual message button */\n.messageButton {\n    display: inline-flex;\n    align-items: center;\n    padding: 8px 14px;\n    background: rgba(125, 125, 125, 0.1);\n    border: 1px solid rgba(125, 125, 125, 0.9);\n    border-radius: 16px;\n    font-size: 13px;\n    font-weight: 500;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n}\n\n.messageButton:hover {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    transform: translateY(-1px);\n    box-shadow: 0 2px 8px rgba(0, 132, 255, 0.15);\n}\n\n.messageButton:active {\n    transform: scale(0.98);\n    transition: transform 0.1s ease;\n}\n\n/* Remove default markdown styles from button content */\n.messageButton p {\n    margin: 0;\n    padding: 0;\n    line-height: inherit;\n}\n\n.messageButton strong {\n    font-weight: 600;\n}\n\n.messageButton em {\n    font-style: italic;\n}\n\n/* Rating system */\n.chatMainFlow .chatMessage .rating {\n    position: absolute;\n    bottom: -8px;\n    right: 8px;\n    display: flex;\n    gap: 2px;\n    align-items: center;\n    min-width: 24px;\n    z-index: 1;\n    background: rgba(0, 0, 0, 0.8);\n    border-radius: 12px;\n    padding: 4px 6px;\n    backdrop-filter: blur(10px);\n    opacity: 0;\n    transform: translateY(4px);\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.chatMainFlow .chatMessage:hover .rating {\n    opacity: 1;\n    transform: translateY(0);\n}\n\n.chatMainFlow .chatMessage .rating:hover {\n    background: rgba(0, 0, 0, 0.9);\n    padding: 6px 8px;\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);\n}\n\n.chatMainFlow .chatMessage .rating span {\n    transition: transform 0.2s ease, color 0.2s ease;\n    display: inline-block;\n    cursor: pointer;\n    font-size: 16px;\n}\n\n.chatMainFlow .chatMessage .rating:hover span {\n    transform: scale(1.1);\n}\n\n/* Chat input area */\n.chatMainFlow .chatInput {\n    z-index: 10;\n    grid-area: 📝;\n    width: 100%;\n    padding: 20px;\n    backdrop-filter: blur(20px);\n    border-top: 1px solid rgba(125, 125, 125, 0.1);\n    display: flex;\n    flex-direction: column;\n    gap: 12px;\n    position: relative;\n}\n\n/* File upload drag-and-drop styles */\n.chatMainFlow .chatInput.dragOver {\n    background: linear-gradient(to top, rgba(0, 132, 255, 0.1) 0%, rgba(0, 132, 255, 0.05) 100%);\n    border-top: 2px solid rgba(0, 132, 255, 0.3);\n}\n\n/* File preview container */\n.filePreviewContainer {\n    display: flex;\n    flex-wrap: wrap;\n    gap: 8px;\n    margin-bottom: 8px;\n}\n\n/* Individual file preview */\n.filePreview {\n    display: flex;\n    align-items: center;\n    gap: 8px;\n    padding: 8px 12px;\n    background: rgba(125, 125, 125, 0.1);\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    border-radius: 8px;\n    font-size: 12px;\n    backdrop-filter: blur(10px);\n    transition: all 0.2s ease;\n}\n\n.filePreview:hover {\n    background: rgba(125, 125, 125, 0.15);\n    border-color: rgba(125, 125, 125, 0.3);\n}\n\n.fileIcon {\n    font-size: 14px;\n    opacity: 0.7;\n}\n\n.fileInfo {\n    display: flex;\n    flex-direction: column;\n    gap: 2px;\n    min-width: 0;\n}\n\n.fileName {\n    font-weight: 500;\n    color: black;\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    max-width: 150px;\n}\n\n.fileSize {\n    color: #6b7280;\n    font-size: 11px;\n}\n\n.removeFileButton {\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    width: 20px;\n    height: 20px;\n    border: none;\n    background: rgba(255, 0, 0, 0.1);\n    color: #ff4444;\n    border-radius: 50%;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    flex-shrink: 0;\n}\n\n.removeFileButton:hover {\n    background: rgba(255, 0, 0, 0.2);\n    transform: scale(1.1);\n}\n\n/* Input container for textarea and buttons */\n.inputContainer {\n    display: flex;\n    align-items: center;\n    gap: 12px;\n}\n\n.inputContainer textarea::placeholder {\n    color: inherit;\n    opacity: 0.7;\n}\n\n/* Attachment button */\n.attachmentButton {\n    width: 40px;\n    height: 40px;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    background: rgba(125, 125, 125, 0.05);\n    color: #6b7280;\n    border-radius: 50%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    flex-shrink: 0;\n}\n\n.attachmentButton:hover:not(:disabled) {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    color: #0084ff;\n    transform: scale(1.05);\n}\n\n.attachmentButton:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n    transform: none;\n}\n\n/* Voice Button */\n.voiceButton {\n    width: 40px;\n    height: 40px;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n    background: rgba(125, 125, 125, 0.05);\n    color: #6b7280;\n    border-radius: 50%;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    backdrop-filter: blur(10px);\n    flex-shrink: 0;\n}\n\n.voiceButton:hover {\n    background: rgba(0, 132, 255, 0.1);\n    border-color: rgba(0, 132, 255, 0.3);\n    color: #0084ff;\n    transform: scale(1.05);\n}\n\n.voiceButtonActive {\n    background: rgba(255, 0, 0, 0.1) !important;\n    border-color: rgba(255, 0, 0, 0.3) !important;\n    color: #ff0000 !important;\n    animation: voiceRecordingPulse 1.5s infinite;\n}\n\n@keyframes voiceRecordingPulse {\n    0% {\n        box-shadow: 0 0 0 0 rgba(255, 0, 0, 0.4);\n    }\n    70% {\n        box-shadow: 0 0 0 10px rgba(255, 0, 0, 0);\n    }\n    100% {\n        box-shadow: 0 0 0 0 rgba(255, 0, 0, 0);\n    }\n}\n\n/* Upload progress indicator */\n.uploadProgress {\n    display: flex;\n    align-items: center;\n    gap: 12px;\n    padding: 8px 12px;\n    background: rgba(0, 132, 255, 0.1);\n    border: 1px solid rgba(0, 132, 255, 0.2);\n    border-radius: 8px;\n    font-size: 13px;\n    color: #0084ff;\n}\n\n.uploadProgressBar {\n    flex: 1;\n    height: 4px;\n    background: rgba(0, 132, 255, 0.2);\n    border-radius: 2px;\n    overflow: hidden;\n}\n\n.uploadProgressFill {\n    height: 100%;\n    background: linear-gradient(90deg, #0084ff, rgba(0, 132, 255, 0.8));\n    border-radius: 2px;\n    animation: uploadProgress 1.5s ease-in-out infinite;\n}\n\n@keyframes uploadProgress {\n    0% {\n        transform: translateX(-100%);\n    }\n    50% {\n        transform: translateX(0%);\n    }\n    100% {\n        transform: translateX(100%);\n    }\n}\n\n/* Drag overlay */\n.dragOverlay {\n    position: absolute;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    background: rgba(0, 132, 255, 0.1);\n    border: 2px dashed rgba(0, 132, 255, 0.5);\n    border-radius: 12px;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    backdrop-filter: blur(10px);\n    z-index: 20;\n    pointer-events: none;\n}\n\n.dragOverlayContent {\n    display: flex;\n    flex-direction: column;\n    align-items: center;\n    gap: 12px;\n    color: #0084ff;\n    font-weight: 600;\n    text-align: center;\n}\n\n.dragOverlayContent svg {\n    opacity: 0.7;\n}\n\n/* Chat input field */\n.chatMainFlow .chatInput textarea {\n    flex: 1;\n    padding: 16px 20px;\n\n    outline: none;\n    border-radius: 25px;\n    background: rgba(125, 125, 125, 0.05);\n    backdrop-filter: blur(20px);\n    color: black;\n    min-width: 200px;\n    max-height: 120px;\n    font-size: 15px;\n    line-height: 1.4;\n    resize: none;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    appearance: none;\n    -webkit-appearance: none;\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n}\n\n.chatMainFlow .chatInput textarea:focus {\n    border-color: #0084ff;\n    background: rgba(125, 125, 125, 0.08);\n    box-shadow: 0 0 0 4px rgba(0, 132, 255, 0.1), 0 8px 32px rgba(0, 132, 255, 0.15);\n    transform: translateY(-2px);\n}\n\n.chatMainFlow .chatInput textarea:disabled {\n    opacity: 0.6;\n    cursor: not-allowed;\n    transform: none;\n}\n\n.chatMainFlow .chatInput textarea::placeholder {\n    color: inherit;\n    opacity: 0.7;\n}\n\n/* Chat send button */\n.chatMainFlow .chatInput button {\n    width: 48px;\n    height: 48px;\n    margin: 0 !important;\n    padding: 0 !important;\n\n    border: none;\n    /* background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%); */\n    /* <- Note: Background is set in the inline style */\n    color: #ffffff;\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    border-radius: 50% !important;\n    aspect-ratio: 1 / 1;\n    min-width: unset !important;\n    min-height: unset !important;\n    padding-left: unset;\n    padding-right: unset;\n\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n    overflow: visible;\n}\n\n.chatMainFlow .chatInput button img {\n    width: 50%;\n    height: 100%;\n    object-fit: contain;\n}\n\n/* Scroll to bottom button */\n\n.scrollToBottomContainer {\n    /*/\n    outline: 1px dotted red;\n    /**/\n\n    z-index: 20;\n    grid-area: 📝;\n    width: 100%;\n    height: 100%;\n    display: flex;\n    justify-content: center;\n    align-items: flex-start;\n\n    pointer-events: none;\n}\n\n.scrollToBottomContainer .scrollToBottom {\n    pointer-events: all;\n\n    transform: translate(-50%, -150%);\n    width: 48px;\n    height: 48px;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    border: none;\n    outline: none;\n    background: rgba(0 0 0 / 0.5);\n    backdrop-filter: blur(3px);\n    border-radius: 50%;\n    font-weight: bold;\n    color: white;\n    cursor: pointer;\n    -webkit-tap-highlight-color: transparent;\n    touch-action: manipulation;\n    user-select: none;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);\n    animation: scrollButtonSlideIn 0.3s ease-out;\n}\n\n@keyframes scrollButtonSlideIn {\n    from {\n        opacity: 0;\n        transform: translate(-50%, 20px) scale(0.8);\n    }\n    to {\n        opacity: 0.9;\n        transform: translate(-50%, 0) scale(1);\n    }\n}\n\n.scrollToBottom:hover {\n    transform: translate(-50%, -160%) scale(1.05);\n}\n\n.scrollToBottom:active {\n    transform: translate(-50%, -160%) scale(0.95);\n    transition: transform 0.1s ease;\n}\n\n/* Rating modal */\n.ratingModal {\n    position: fixed;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n\n    background-color: rgba(0, 0, 0, 0.6);\n    backdrop-filter: blur(8px);\n\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    z-index: 1000;\n    animation: modalFadeIn 0.3s ease-out;\n}\n\n@keyframes modalFadeIn {\n    from {\n        opacity: 0;\n        backdrop-filter: blur(0px);\n    }\n    to {\n        opacity: 1;\n        backdrop-filter: blur(8px);\n    }\n}\n\n.ratingModalContent {\n    background: #ffffff;\n    color: #0f1724;\n    padding: 32px;\n    border-radius: 16px;\n    width: 90%;\n    max-width: 480px;\n    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);\n    border: 1px solid rgba(125, 125, 125, 0.1);\n    backdrop-filter: blur(20px);\n    animation: modalSlideIn 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n\n    font-family: Arial, Helvetica, sans-serif, 'OpenMojiBlack';\n    /* <- TODO: [🧠][🎱] Better, define other fonts */\n}\n\n@keyframes modalSlideIn {\n    from {\n        opacity: 0;\n        transform: translateY(20px) scale(0.95);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0) scale(1);\n    }\n}\n\n.ratingModalContent h3 {\n    margin: 0 0 24px 0;\n    text-align: center;\n    color: black;\n    font-size: 20px;\n    font-weight: 600;\n}\n\n.stars {\n    display: flex;\n    justify-content: center;\n    gap: 8px;\n    margin-bottom: 24px;\n}\n\n.stars span {\n    font-size: 28px;\n    cursor: pointer;\n    transition: all 0.2s ease;\n    padding: 4px;\n    border-radius: 8px;\n}\n\n.stars span:hover {\n    transform: scale(1.2);\n    background: rgba(255, 215, 0, 0.1);\n}\n\n.ratingModalStar {\n    cursor: pointer;\n    font-size: 24px;\n    transition: color 0.2s;\n}\n\n.ratingInput {\n    width: 100%;\n    min-height: 100px;\n    padding: 16px;\n    border: 2px solid rgba(125, 125, 125, 0.1);\n    border-radius: 12px;\n    margin-bottom: 18px;\n    resize: vertical;\n    background: rgba(125, 125, 125, 0.05);\n    color: #0b1220;\n    font-size: 14px;\n    line-height: 1.5;\n    transition: all 0.2s ease;\n}\n\n.ratingInput:focus {\n    border-color: #0084ff;\n    background: rgba(125, 125, 125, 0.08);\n    box-shadow: 0 0 0 4px rgba(0, 132, 255, 0.1);\n    outline: none;\n}\n\n.ratingInput[readonly] {\n    border: 1px solid rgba(125, 125, 125, 0.5);\n    background: rgba(125, 125, 125, 0.01);\n}\n\n.ratingActions {\n    display: flex;\n    justify-content: flex-end;\n    gap: 12px;\n}\n\n.ratingActions button {\n    padding: 12px 24px;\n    border: none;\n    border-radius: 8px;\n    cursor: pointer;\n    font-size: 14px;\n    font-weight: 500;\n    transition: all 0.2s ease;\n    min-width: 80px;\n}\n\n.ratingActions button:first-child {\n    background-color: rgba(125, 125, 125, 0.1);\n    color: #0b1220;\n    border: 1px solid rgba(125, 125, 125, 0.2);\n}\n\n.ratingActions button:first-child:hover:not(:disabled) {\n    background-color: rgba(125, 125, 125, 0.2);\n    color: #0b1220;\n}\n\n.ratingActions button:last-child {\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%);\n    color: #ffffff;\n}\n\n.ratingActions button:last-child:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0071d1 0%, #0052a3 100%);\n    transform: translateY(-1px);\n    box-shadow: 0 4px 12px rgba(0, 132, 255, 0.3);\n}\n\n.ratingActions button:last-child:disabled {\n    opacity: 0.5;\n    cursor: not-allowed;\n}\n\n/* New chat button styling - Matches the sleek chat message design */\n.chatButton {\n    display: inline-flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    gap: 8px !important;\n    padding: 12px 16px !important;\n    margin: 0 !important;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%) !important;\n    color: #ffffff !important;\n    border: none !important;\n    border-radius: 20px !important;\n    font-size: 13px !important;\n    font-weight: 600 !important;\n    line-height: 1.3 !important;\n    cursor: pointer !important;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3) !important;\n    backdrop-filter: blur(20px) !important;\n    -webkit-tap-highlight-color: transparent !important;\n    touch-action: manipulation !important;\n    user-select: none !important;\n    min-height: 40px !important;\n    min-width: 110px !important;\n    position: relative !important;\n    overflow: hidden !important;\n}\n\n.chatButton::before {\n    content: '';\n    position: absolute;\n    top: 0;\n    left: -100%;\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);\n    transition: left 0.5s ease;\n}\n\n.chatButton:hover::before {\n    left: 100%;\n}\n\n.chatButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0099ff 0%, #0077dd 100%);\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(0, 132, 255, 0.4);\n}\n\n.chatButton:active {\n    transform: scale(0.98) translateY(-1px);\n    transition: transform 0.1s ease;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n}\n\n.chatButton:focus {\n    outline: none;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3), 0 0 0 3px rgba(0, 132, 255, 0.3);\n}\n\n.chatButton svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    opacity: 1;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));\n}\n\n.chatButton:hover svg {\n    transform: rotate(-90deg) scale(1.1);\n    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));\n}\n\n.chatButtonText {\n    white-space: nowrap;\n    font-weight: 600;\n    transition: all 0.2s ease;\n    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);\n    opacity: 1;\n}\n\n.chatButton:hover .chatButtonText {\n    transform: translateX(1px);\n}\n\n/* Use template button styling - matches the chatButton and saveButton */\n.useTemplateButton {\n    display: inline-flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    gap: 8px !important;\n    padding: 12px 16px !important;\n    margin: 0 !important;\n    background: linear-gradient(135deg, #0084ff 0%, #0066cc 100%) !important;\n    color: #ffffff !important;\n    border: none !important;\n    border-radius: 20px !important;\n    font-size: 13px !important;\n    font-weight: 600 !important;\n    line-height: 1.3 !important;\n    cursor: pointer !important;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3) !important;\n    backdrop-filter: blur(20px) !important;\n    -webkit-tap-highlight-color: transparent !important;\n    touch-action: manipulation !important;\n    user-select: none !important;\n    min-height: 40px !important;\n    min-width: 110px !important;\n    position: relative !important;\n    overflow: hidden !important;\n}\n\n.useTemplateButton::before {\n    content: '';\n    position: absolute;\n    top: 0;\n    left: -100%;\n    width: 100%;\n    height: 100%;\n    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);\n    transition: left 0.5s ease;\n}\n\n.useTemplateButton:hover::before {\n    left: 100%;\n}\n\n.useTemplateButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #0099ff 0%, #0077dd 100%);\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(0, 132, 255, 0.4);\n}\n\n.useTemplateButton:active {\n    transform: scale(0.98) translateY(-1px);\n    transition: transform 0.1s ease;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3);\n}\n\n.useTemplateButton:focus {\n    outline: none;\n    box-shadow: 0 4px 16px rgba(0, 132, 255, 0.3), 0 0 0 3px rgba(0, 132, 255, 0.3);\n}\n\n.useTemplateButton svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    opacity: 1;\n    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);\n    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));\n}\n\n.useTemplateButton:hover svg {\n    transform: scale(1.1);\n    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));\n}\n\n.useTemplateButton:hover .chatButtonText {\n    transform: translateX(1px);\n}\n\n.saveButtonContainer {\n    display: inline-block;\n    position: relative;\n}\n\n.saveMenu {\n    position: absolute;\n    top: 100%;\n    left: 0;\n    background: #fff;\n    border: 1px solid #ddd;\n    z-index: 10;\n    min-width: 120px;\n    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);\n}\n\n.saveMenuItem {\n    display: block;\n    width: 100%;\n    padding: 8px 16px;\n    border: none;\n    background: none;\n    text-align: left;\n    cursor: pointer;\n    color: #111;\n}\n\n.saveMenuItem:hover {\n    background-color: #f0f0f0;\n}\n\n/* Pause/Resume button variant (reuses .chatButton base styles for DRY) */\n.pauseButton {\n    background: linear-gradient(135deg, #ffb347 0%, #ff8c42 100%) !important; /* Warm orange for \"active/running\" */\n}\n\n.pauseButton:hover:not(:disabled) {\n    background: linear-gradient(135deg, #ffc067 0%, #ff9e5f 100%) !important;\n}\n\n.pauseButton.pausing {\n    opacity: 0.6 !important;\n    cursor: wait !important;\n}\n\n.pauseButton.paused {\n    background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important; /* Green when paused (ready to resume) */\n}\n\n.pauseButton.paused:hover:not(:disabled) {\n    background: linear-gradient(135deg, #34d399 0%, #059669 100%) !important;\n    transform: translateY(-2px) scale(1.02);\n    box-shadow: 0 8px 24px rgba(16, 185, 129, 0.35);\n}\n\n.pauseButton svg {\n    transition: transform 0.3s ease;\n}\n\n.pauseButton.paused svg {\n    transform: scale(1.1);\n}\n\n.pauseButton.pausing svg {\n    opacity: 0.8;\n}\n\n/* Voice call indicator bar */\n.voiceCallIndicatorBar {\n    grid-area: 🟦;\n    width: 100%;\n    padding: 12px 20px;\n    background: linear-gradient(135deg, rgba(34, 197, 94, 0.1) 0%, rgba(16, 185, 129, 0.1) 100%);\n    border-bottom: 1px solid rgba(34, 197, 94, 0.3);\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    backdrop-filter: blur(10px);\n}\n\n/* Voice call indicator */\n.voiceCallIndicator {\n    display: inline-flex;\n    align-items: center;\n    gap: 8px;\n    padding: 8px 16px;\n    background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(16, 185, 129, 0.2) 100%);\n    border: 1px solid rgba(34, 197, 94, 0.4);\n    border-radius: 20px;\n    color: #10b981;\n    font-size: 13px;\n    font-weight: 600;\n    backdrop-filter: blur(10px);\n    box-shadow: 0 2px 8px rgba(34, 197, 94, 0.2);\n    position: relative;\n}\n\n.voiceCallIndicator svg {\n    width: 16px;\n    height: 16px;\n    flex-shrink: 0;\n    animation: voiceCallIconPulse 2s ease-in-out infinite;\n}\n\n.voiceCallIndicator span {\n    font-weight: 600;\n    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);\n}\n\n/* Voice call pulse animation */\n.voiceCallPulse {\n    position: absolute;\n    right: 8px;\n    top: 50%;\n    transform: translateY(-50%);\n    width: 8px;\n    height: 8px;\n    background: #10b981;\n    border-radius: 50%;\n    animation: voiceCallPulse 1.5s ease-in-out infinite;\n}\n\n@keyframes voiceCallIconPulse {\n    0%,\n    100% {\n        transform: scale(1);\n        opacity: 1;\n    }\n    50% {\n        transform: scale(1.1);\n        opacity: 0.8;\n    }\n}\n\n@keyframes voiceCallPulse {\n    0%,\n    100% {\n        transform: translateY(-50%) scale(1);\n        opacity: 1;\n    }\n    50% {\n        transform: translateY(-50%) scale(1.3);\n        opacity: 0.6;\n    }\n}\n\n/* Voice call indicator in messages */\n.chatMessage .voiceCallIndicator {\n    margin-bottom: 8px;\n    padding: 6px 12px;\n    font-size: 12px;\n    border-radius: 16px;\n}\n\n.chatMessage .voiceCallIndicator svg {\n    width: 14px;\n    height: 14px;\n}\n\n/* Rating confirmation */\n.ratingConfirmation {\n    position: fixed;\n    top: 20px;\n    right: 20px;\n    background: linear-gradient(135deg, #10b981 0%, #059669 100%);\n    color: white;\n    padding: 16px 20px;\n    border-radius: 12px;\n    box-shadow: 0 8px 32px rgba(16, 185, 129, 0.3);\n    z-index: 1001;\n    animation: confirmationSlideIn 0.3s ease-out;\n    max-width: 300px;\n    word-wrap: break-word;\n    font-weight: 500;\n    backdrop-filter: blur(20px);\n}\n\n@keyframes confirmationSlideIn {\n    from {\n        transform: translateX(100%);\n        opacity: 0;\n    }\n    to {\n        transform: translateX(0);\n        opacity: 1;\n    }\n}\n\n/* Mobile responsiveness */\n@media (max-width: 768px) {\n    .actions {\n        margin: 12px 16px 0;\n        gap: 6px;\n    }\n\n    .chatMainFlow .chatMessages {\n        padding: 16px 12px;\n    }\n\n    .chatMainFlow .chatMessage {\n        margin-bottom: 16px;\n    }\n\n    .chatMainFlow .chatMessage .messageText {\n        max-width: 85%;\n        padding: 12px 16px;\n        font-size: 14px;\n        border-radius: 18px;\n    }\n\n    .chatMainFlow .chatMessage .avatar {\n        width: 36px;\n        height: 36px;\n        margin: 0 10px 4px;\n    }\n\n    .chatMainFlow .chatMessage .avatar img {\n        width: 36px;\n        aspect-ratio: 1 / 1;\n    }\n\n    .chatMainFlow .chatInput {\n        padding: 16px 12px;\n        gap: 10px;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        font-size: 16px;\n        padding: 14px 18px;\n        border-radius: 22px;\n    }\n\n    .chatMainFlow .chatInput button {\n        width: 44px;\n        height: 44px;\n    }\n\n    .scrollToBottom {\n        width: 44px;\n        height: 44px;\n        font-size: 18px;\n        top: calc(100% - 160px);\n    }\n\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n\n    .ratingModalContent {\n        margin: 16px;\n        padding: 24px 20px;\n        border-radius: 16px;\n        max-height: 80vh;\n        overflow-y: auto;\n    }\n\n    .stars {\n        gap: 6px;\n        margin-bottom: 20px;\n    }\n\n    .stars span {\n        font-size: 32px;\n        padding: 8px;\n    }\n\n    .ratingActions {\n        flex-direction: column-reverse;\n        gap: 8px;\n    }\n\n    .ratingActions button {\n        width: 100%;\n        padding: 14px;\n        font-size: 16px;\n        border-radius: 10px;\n    }\n}\n\n@media (max-width: 480px) {\n    .actions {\n        margin: 8px 12px 0;\n        gap: 4px;\n    }\n\n    .chatMainFlow .chatMessages {\n        padding: 12px 8px;\n    }\n\n    .chatMainFlow .chatMessage .messageText {\n        max-width: 90%;\n        padding: 10px 14px;\n        font-size: 14px;\n        border-radius: 16px;\n    }\n\n    .chatMainFlow .chatMessage .avatar {\n        width: 32px;\n        height: 32px;\n        margin: 0 8px 4px;\n    }\n\n    .chatMainFlow .chatMessage .avatar img {\n        width: 32px;\n        aspect-ratio: 1 / 1;\n    }\n\n    .chatMainFlow .chatInput {\n        padding: 12px 8px;\n        gap: 8px;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        padding: 12px 16px;\n        border-radius: 20px;\n        font-size: 16px;\n    }\n\n    .chatMainFlow .chatInput button {\n        width: 40px;\n        height: 40px;\n    }\n\n    .chatButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .chatButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .chatButtonText {\n        display: none !important;\n    }\n\n    .useTemplateButton {\n        border-radius: 50% !important;\n        width: 40px !important;\n        height: 40px !important;\n        min-width: 40px !important;\n        min-height: 40px !important;\n        padding: 0 !important;\n        gap: 0 !important;\n        margin: 0 !important;\n    }\n\n    .useTemplateButton svg {\n        width: 18px !important;\n        height: 18px !important;\n    }\n\n    .useTemplateButton .chatButtonText {\n        display: none !important;\n    }\n\n    .scrollToBottom {\n        width: 40px;\n        height: 40px;\n        font-size: 16px;\n        top: calc(100% - 140px);\n    }\n\n    .ratingModal {\n        padding: 0;\n        align-items: flex-end;\n    }\n\n    .ratingModalContent {\n        margin: 0;\n        width: 100%;\n        border-radius: 20px 20px 0 0;\n        max-height: 70vh;\n        padding: 24px 16px 20px;\n    }\n}\n\n/* Reduced motion support */\n@media (prefers-reduced-motion: reduce) {\n    .chatMainFlow .chatMessage,\n    .scrollToBottom,\n    .ratingModal,\n    .ratingModalContent,\n    .ratingConfirmation {\n        animation: none;\n    }\n\n    .chatMainFlow .chatMessage .messageText,\n    .chatMainFlow .chatInput textarea,\n    .chatMainFlow .chatInput button,\n    .chatMainFlow .chatMessage .avatar img,\n    .chatButton {\n        transition: none;\n    }\n}\n\n/* High contrast mode support */\n@media (prefers-contrast: high) {\n    .chatMainFlow .chatMessage .messageText {\n        border: 2px solid currentColor;\n    }\n\n    .chatMainFlow .chatInput textarea {\n        border-width: 3px;\n    }\n\n    .chatMainFlow .chatInput button {\n        border: 2px solid currentColor;\n    }\n}\n\n/**\n * TODO: [🌉] DRY Markdown primitives styling\n */\n"]} */";
8659
9139
  var chatStyles = {"copiedToClipboardMessage":"Chat-module_copiedToClipboardMessage__apCPY","Chat":"Chat-module_Chat__j2eE5","chatMainFlow":"Chat-module_chatMainFlow__--8FE","chatBar":"Chat-module_chatBar__fLECN","TasksInProgress":"Chat-module_TasksInProgress__fQfei","actions":"Chat-module_actions__gTZ5T","portal":"Chat-module_portal__uTOT8","left":"Chat-module_left__7l5Mn","right":"Chat-module_right__ABZrW","chatButton":"Chat-module_chatButton__d9VgA","chatButtonText":"Chat-module_chatButtonText__RkGB-","useTemplateButton":"Chat-module_useTemplateButton__xcJNR","chatChildren":"Chat-module_chatChildren__flOPK","chatMessages":"Chat-module_chatMessages__J2u2N","chatMessage":"Chat-module_chatMessage__nmLaZ","messageSlideIn":"Chat-module_messageSlideIn__soTy2","hasActionsAndFirstMessageIsLong":"Chat-module_hasActionsAndFirstMessageIsLong__5jgoZ","isNotCompleteMessage":"Chat-module_isNotCompleteMessage__Hj2K7","NonCompleteMessageFiller":"Chat-module_NonCompleteMessageFiller__G5-Ve","messageText":"Chat-module_messageText__XgNyQ","loadingPulse":"Chat-module_loadingPulse__VomRm","typingIndicator":"Chat-module_typingIndicator__S-CT-","avatar":"Chat-module_avatar__gL6bm","typingBubble":"Chat-module_typingBubble__0Lb7B","typingDots":"Chat-module_typingDots__srOBB","typingDot":"Chat-module_typingDot__dnhKT","typingBounce":"Chat-module_typingBounce__1yp2v","isMe":"Chat-module_isMe__nBtaV","ratingStar":"Chat-module_ratingStar__rRfqC","active":"Chat-module_active__lbYL-","copyButtonContainer":"Chat-module_copyButtonContainer__Rij0U","copyButton":"Chat-module_copyButton__DcxT5","copiedTooltip":"Chat-module_copiedTooltip__LH81j","copiedTooltipFadeIn":"Chat-module_copiedTooltipFadeIn__QekO1","copiedTooltipLeft":"Chat-module_copiedTooltipLeft__j-S-5","copiedTooltipRight":"Chat-module_copiedTooltipRight__R-2cE","chat-code-block":"Chat-module_chat-code-block__k8IyS","messageButtons":"Chat-module_messageButtons__WaOob","messageButton":"Chat-module_messageButton__mRnn-","rating":"Chat-module_rating__soc3M","chatInput":"Chat-module_chatInput__1Ecan","dragOver":"Chat-module_dragOver__bkS-g","filePreviewContainer":"Chat-module_filePreviewContainer__R70hm","filePreview":"Chat-module_filePreview__kq2aX","fileIcon":"Chat-module_fileIcon__zoSKW","fileInfo":"Chat-module_fileInfo__wBLi0","fileName":"Chat-module_fileName__bBujo","fileSize":"Chat-module_fileSize__ivliq","removeFileButton":"Chat-module_removeFileButton__0gakR","inputContainer":"Chat-module_inputContainer__bPt99","attachmentButton":"Chat-module_attachmentButton__qLO47","voiceButton":"Chat-module_voiceButton__d2zlP","voiceButtonActive":"Chat-module_voiceButtonActive__Uoi3W","voiceRecordingPulse":"Chat-module_voiceRecordingPulse__y2wJ5","uploadProgress":"Chat-module_uploadProgress__jBTKe","uploadProgressBar":"Chat-module_uploadProgressBar__Gutnt","uploadProgressFill":"Chat-module_uploadProgressFill__EgubT","dragOverlay":"Chat-module_dragOverlay__SEGoS","dragOverlayContent":"Chat-module_dragOverlayContent__gb9kF","scrollToBottomContainer":"Chat-module_scrollToBottomContainer__5rXpK","scrollToBottom":"Chat-module_scrollToBottom__nzxdZ","scrollButtonSlideIn":"Chat-module_scrollButtonSlideIn__XnImg","ratingModal":"Chat-module_ratingModal__XVKYm","modalFadeIn":"Chat-module_modalFadeIn__RPc3w","ratingModalContent":"Chat-module_ratingModalContent__CCdq7","modalSlideIn":"Chat-module_modalSlideIn__XXtgN","stars":"Chat-module_stars__PCzNO","ratingModalStar":"Chat-module_ratingModalStar__XkbHr","ratingInput":"Chat-module_ratingInput__z8Pv-","ratingActions":"Chat-module_ratingActions__nXcss","saveButtonContainer":"Chat-module_saveButtonContainer__lSNUJ","saveMenu":"Chat-module_saveMenu__-ph8y","saveMenuItem":"Chat-module_saveMenuItem__ISApL","pauseButton":"Chat-module_pauseButton__eeu7K","pausing":"Chat-module_pausing__pTx8b","paused":"Chat-module_paused__j-pya","voiceCallIndicatorBar":"Chat-module_voiceCallIndicatorBar__N2sWN","voiceCallIndicator":"Chat-module_voiceCallIndicator__tsaaG","voiceCallIconPulse":"Chat-module_voiceCallIconPulse__zZbJn","voiceCallPulse":"Chat-module_voiceCallPulse__XcGU4","ratingConfirmation":"Chat-module_ratingConfirmation__n16vb","confirmationSlideIn":"Chat-module_confirmationSlideIn__5U-wz"};
8660
9140
  styleInject(css_248z$2);
8661
9141
 
@@ -8796,7 +9276,7 @@
8796
9276
  // Note: Do not hide tooltip on mouse leave, it will be hidden by clicking outside
8797
9277
  };
8798
9278
  const isMe = participant === null || participant === void 0 ? void 0 : participant.isMe;
8799
- const color = Color.from((participant && participant.color) || (isMe ? USER_CHAT_COLOR : PROMPTBOOK_CHAT_COLOR));
9279
+ const color = Color.fromSafe((participant && participant.color) || (isMe ? USER_CHAT_COLOR : PROMPTBOOK_CHAT_COLOR));
8800
9280
  const colorOfText = color.then(textColor);
8801
9281
  const { contentWithoutButtons, buttons } = parseMessageButtons(message.content);
8802
9282
  const shouldShowButtons = isLastMessage && buttons.length > 0 && onMessage;
@@ -8952,8 +9432,8 @@
8952
9432
  // isExperimental = false,
8953
9433
  // TODO: [😅]> isSaveButtonEnabled = false,
8954
9434
  // exportHeaderMarkdown,
8955
- participants = [], extraActions, actionsContainer, saveFormats, isSaveButtonEnabled = true, isCopyButtonEnabled = true, } = props;
8956
- const { onUseTemplate } = props;
9435
+ participants = [], extraActions, actionsContainer, saveFormats, isSaveButtonEnabled = true, isCopyButtonEnabled = true, buttonColor: buttonColorRaw, onUseTemplate, } = props;
9436
+ const buttonColor = react.useMemo(() => Color.from(buttonColorRaw || '#0066cc'), [buttonColorRaw]);
8957
9437
  // Use the auto-scroll hook
8958
9438
  const { isAutoScrolling, chatMessagesRef, handleScroll, handleMessagesChange, scrollToBottom, isMobile: isMobileFromHook, } = useChatAutoScroll();
8959
9439
  const textareaRef = react.useRef(null);
@@ -9294,10 +9774,19 @@
9294
9774
  return;
9295
9775
  }
9296
9776
  onChange(((_a = textareaRef.current) === null || _a === void 0 ? void 0 : _a.value) || '');
9297
- } }), onFileUpload && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("input", { ref: fileInputRef, type: "file", multiple: true, style: { display: 'none' }, onChange: handleFileInputChange }), jsxRuntime.jsx("button", { type: "button", className: chatStyles.attachmentButton, onClick: () => { var _a; return (_a = fileInputRef.current) === null || _a === void 0 ? void 0 : _a.click(); }, disabled: isUploading, title: "Attach file", children: jsxRuntime.jsx(AttachmentIcon, { size: 20 }) })] })), onVoiceInput && (jsxRuntime.jsx("button", { "data-button-type": "voice", className: classNames(chatStyles.voiceButton, isVoiceCalling && chatStyles.voiceButtonActive), onClick: (event) => {
9777
+ } }), onFileUpload && (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx("input", { ref: fileInputRef, type: "file", multiple: true, style: { display: 'none' }, onChange: handleFileInputChange }), jsxRuntime.jsx("button", { type: "button", style: {
9778
+ backgroundColor: buttonColor.toHex(),
9779
+ color: buttonColor.then(textColor).toHex(),
9780
+ }, className: chatStyles.attachmentButton, onClick: () => { var _a; return (_a = fileInputRef.current) === null || _a === void 0 ? void 0 : _a.click(); }, disabled: isUploading, title: "Attach file", children: jsxRuntime.jsx(AttachmentIcon, { size: 20 }) })] })), onVoiceInput && (jsxRuntime.jsx("button", { "data-button-type": "voice", style: {
9781
+ backgroundColor: buttonColor.toHex(),
9782
+ color: buttonColor.then(textColor).toHex(),
9783
+ }, className: classNames(chatStyles.voiceButton, isVoiceCalling && chatStyles.voiceButtonActive), onClick: (event) => {
9298
9784
  event.preventDefault();
9299
9785
  onVoiceInput();
9300
- }, title: isVoiceCalling ? 'Stop voice call' : 'Start voice call', children: jsxRuntime.jsx(MicIcon, { size: 25 }) })), jsxRuntime.jsx("button", { "data-button-type": "call-to-action", ref: buttonSendRef, onClick: (event) => {
9786
+ }, title: isVoiceCalling ? 'Stop voice call' : 'Start voice call', children: jsxRuntime.jsx(MicIcon, { size: 25 }) })), jsxRuntime.jsx("button", { "data-button-type": "call-to-action", style: {
9787
+ backgroundColor: buttonColor.toHex(),
9788
+ color: buttonColor.then(textColor).toHex(),
9789
+ }, ref: buttonSendRef, onClick: (event) => {
9301
9790
  if (!onMessage) {
9302
9791
  return;
9303
9792
  }
@@ -9433,7 +9922,7 @@
9433
9922
  * @public exported from `@promptbook/components`
9434
9923
  */
9435
9924
  function LlmChat(props) {
9436
- const { llmTools, persistenceKey, onChange, onReset, initialMessages, sendMessage, userParticipantName = 'USER', llmParticipantName = 'ASSISTANT', ...restProps } = props;
9925
+ const { llmTools, persistenceKey, onChange, onReset, initialMessages, sendMessage, userParticipantName = 'USER', llmParticipantName = 'ASSISTANT', autoExecuteMessage, buttonColor, ...restProps } = props;
9437
9926
  // Internal state management
9438
9927
  // DRY: Single factory for seeding initial messages (used on mount and after reset)
9439
9928
  const buildInitialMessages = react.useCallback(() => (initialMessages ? [...initialMessages] : []), [initialMessages]);
@@ -9767,7 +10256,15 @@
9767
10256
  sendMessage._attach(handleMessage);
9768
10257
  }
9769
10258
  }, [sendMessage, handleMessage]);
9770
- return (jsxRuntime.jsx(Chat, { ...restProps, messages, onReset, tasksProgress, participants, onMessage: handleMessage, onReset: handleReset, onVoiceInput: llmTools.callVoiceChatModel ? handleVoiceInput : undefined, isVoiceCalling: isVoiceCalling }));
10259
+ // Handle autoExecuteMessage
10260
+ const hasAutoExecutedRef = react.useRef(false);
10261
+ react.useEffect(() => {
10262
+ if (autoExecuteMessage && !hasAutoExecutedRef.current) {
10263
+ hasAutoExecutedRef.current = true;
10264
+ handleMessage(autoExecuteMessage);
10265
+ }
10266
+ }, [autoExecuteMessage, handleMessage]);
10267
+ return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsx(Chat, { ...restProps, messages, onReset, tasksProgress, participants, buttonColor, onMessage: handleMessage, onReset: handleReset, onVoiceInput: llmTools.callVoiceChatModel ? handleVoiceInput : undefined, isVoiceCalling: isVoiceCalling }) }));
9771
10268
  }
9772
10269
 
9773
10270
  /**
@@ -9784,34 +10281,35 @@
9784
10281
  */
9785
10282
  function AgentChat(props) {
9786
10283
  const { agent, title, persistenceKey, onChange, sendMessage, ...restProps } = props;
9787
- return (jsxRuntime.jsx(LlmChat, { title: title || `Chat with ${agent.meta.fullname || agent.agentName || 'Agent'}`, persistenceKey: persistenceKey || `agent-chat-${agent.agentName}`, userParticipantName: "USER", llmParticipantName: "AGENT" // <- TODO: [🧠] Maybe dynamic agent id
9788
- , initialMessages: [
9789
- {
9790
- from: 'AGENT',
9791
- content: agent.initialMessage ||
9792
- spaceTrim__default["default"](`
10284
+ const brandColor = Color.fromSafe(agent.meta.color || PROMPTBOOK_COLOR).then(saturate(-0.5));
10285
+ return (jsxRuntime.jsx(jsxRuntime.Fragment, { children: jsxRuntime.jsx(LlmChat, { title: title || `Chat with ${agent.meta.fullname || agent.agentName || 'Agent'}`, persistenceKey: persistenceKey || `agent-chat-${agent.agentName}`, userParticipantName: "USER", llmParticipantName: "AGENT" // <- TODO: [🧠] Maybe dynamic agent id
10286
+ , initialMessages: [
10287
+ {
10288
+ from: 'AGENT',
10289
+ content: agent.initialMessage ||
10290
+ spaceTrim__default["default"](`
9793
10291
 
9794
10292
  Hello! I am ${agent.meta.fullname || agent.agentName || 'an AI Agent'}.
9795
10293
 
9796
10294
  [Hello](?message=Hello, can you tell me about yourself?)
9797
10295
  `),
9798
- },
9799
- ], participants: [
9800
- {
9801
- name: 'AGENT',
9802
- fullname: agent.meta.fullname || agent.agentName || 'Agent',
9803
- avatarSrc: agent.meta.image,
9804
- color: agent.meta.color,
9805
- isMe: false,
9806
- agentSource: asUpdatableSubject(agent.agentSource).getValue() /* <- TODO: [🐱‍🚀] asValue */,
9807
- },
9808
- {
9809
- name: 'USER',
9810
- fullname: 'User',
9811
- color: '#115EB6',
9812
- isMe: true,
9813
- },
9814
- ], llmTools: agent, onChange, sendMessage, ...restProps }));
10296
+ },
10297
+ ], participants: [
10298
+ {
10299
+ name: 'AGENT',
10300
+ fullname: agent.meta.fullname || agent.agentName || 'Agent',
10301
+ avatarSrc: agent.meta.image,
10302
+ color: brandColor,
10303
+ isMe: false,
10304
+ agentSource: asUpdatableSubject(agent.agentSource).getValue() /* <- TODO: [🐱‍🚀] asValue */,
10305
+ },
10306
+ {
10307
+ name: 'USER',
10308
+ fullname: 'User',
10309
+ color: '#115EB6',
10310
+ isMe: true,
10311
+ },
10312
+ ], buttonColor: brandColor, llmTools: agent, onChange, sendMessage, ...restProps }) }));
9815
10313
  }
9816
10314
 
9817
10315
  /**
@@ -10711,7 +11209,7 @@
10711
11209
  if (!(error instanceof PipelineLogicError)) {
10712
11210
  throw error;
10713
11211
  }
10714
- console.error(spaceTrim.spaceTrim((block) => `
11212
+ console.error(spaceTrim$1.spaceTrim((block) => `
10715
11213
  Pipeline is not valid but logic errors are temporarily disabled via \`IS_PIPELINE_LOGIC_VALIDATED\`
10716
11214
 
10717
11215
  ${block(error.message)}
@@ -10738,7 +11236,7 @@
10738
11236
  })();
10739
11237
  if (pipeline.pipelineUrl !== undefined && !isValidPipelineUrl(pipeline.pipelineUrl)) {
10740
11238
  // <- Note: [🚲]
10741
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11239
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10742
11240
  Invalid promptbook URL "${pipeline.pipelineUrl}"
10743
11241
 
10744
11242
  ${block(pipelineIdentification)}
@@ -10746,7 +11244,7 @@
10746
11244
  }
10747
11245
  if (pipeline.bookVersion !== undefined && !isValidPromptbookVersion(pipeline.bookVersion)) {
10748
11246
  // <- Note: [🚲]
10749
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11247
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10750
11248
  Invalid Promptbook Version "${pipeline.bookVersion}"
10751
11249
 
10752
11250
  ${block(pipelineIdentification)}
@@ -10755,7 +11253,7 @@
10755
11253
  // TODO: [🧠] Maybe do here some proper JSON-schema / ZOD checking
10756
11254
  if (!Array.isArray(pipeline.parameters)) {
10757
11255
  // TODO: [🧠] what is the correct error tp throw - maybe PromptbookSchemaError
10758
- throw new ParseError(spaceTrim.spaceTrim((block) => `
11256
+ throw new ParseError(spaceTrim$1.spaceTrim((block) => `
10759
11257
  Pipeline is valid JSON but with wrong structure
10760
11258
 
10761
11259
  \`PipelineJson.parameters\` expected to be an array, but got ${typeof pipeline.parameters}
@@ -10766,7 +11264,7 @@
10766
11264
  // TODO: [🧠] Maybe do here some proper JSON-schema / ZOD checking
10767
11265
  if (!Array.isArray(pipeline.tasks)) {
10768
11266
  // TODO: [🧠] what is the correct error tp throw - maybe PromptbookSchemaError
10769
- throw new ParseError(spaceTrim.spaceTrim((block) => `
11267
+ throw new ParseError(spaceTrim$1.spaceTrim((block) => `
10770
11268
  Pipeline is valid JSON but with wrong structure
10771
11269
 
10772
11270
  \`PipelineJson.tasks\` expected to be an array, but got ${typeof pipeline.tasks}
@@ -10792,7 +11290,7 @@
10792
11290
  // Note: Check each parameter individually
10793
11291
  for (const parameter of pipeline.parameters) {
10794
11292
  if (parameter.isInput && parameter.isOutput) {
10795
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11293
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10796
11294
 
10797
11295
  Parameter \`{${parameter.name}}\` can not be both input and output
10798
11296
 
@@ -10803,7 +11301,7 @@
10803
11301
  if (!parameter.isInput &&
10804
11302
  !parameter.isOutput &&
10805
11303
  !pipeline.tasks.some((task) => task.dependentParameterNames.includes(parameter.name))) {
10806
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11304
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10807
11305
  Parameter \`{${parameter.name}}\` is created but not used
10808
11306
 
10809
11307
  You can declare {${parameter.name}} as output parameter by adding in the header:
@@ -10815,7 +11313,7 @@
10815
11313
  }
10816
11314
  // Note: Testing that parameter is either input or result of some task
10817
11315
  if (!parameter.isInput && !pipeline.tasks.some((task) => task.resultingParameterName === parameter.name)) {
10818
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11316
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10819
11317
  Parameter \`{${parameter.name}}\` is declared but not defined
10820
11318
 
10821
11319
  You can do one of these:
@@ -10831,14 +11329,14 @@
10831
11329
  // Note: Checking each task individually
10832
11330
  for (const task of pipeline.tasks) {
10833
11331
  if (definedParameters.has(task.resultingParameterName)) {
10834
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11332
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10835
11333
  Parameter \`{${task.resultingParameterName}}\` is defined multiple times
10836
11334
 
10837
11335
  ${block(pipelineIdentification)}
10838
11336
  `));
10839
11337
  }
10840
11338
  if (RESERVED_PARAMETER_NAMES.includes(task.resultingParameterName)) {
10841
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11339
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10842
11340
  Parameter name {${task.resultingParameterName}} is reserved, please use different name
10843
11341
 
10844
11342
  ${block(pipelineIdentification)}
@@ -10848,7 +11346,7 @@
10848
11346
  if (task.jokerParameterNames && task.jokerParameterNames.length > 0) {
10849
11347
  if (!task.format &&
10850
11348
  !task.expectations /* <- TODO: Require at least 1 -> min <- expectation to use jokers */) {
10851
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11349
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10852
11350
  Joker parameters are used for {${task.resultingParameterName}} but no expectations are defined
10853
11351
 
10854
11352
  ${block(pipelineIdentification)}
@@ -10856,7 +11354,7 @@
10856
11354
  }
10857
11355
  for (const joker of task.jokerParameterNames) {
10858
11356
  if (!task.dependentParameterNames.includes(joker)) {
10859
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11357
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10860
11358
  Parameter \`{${joker}}\` is used for {${task.resultingParameterName}} as joker but not in \`dependentParameterNames\`
10861
11359
 
10862
11360
  ${block(pipelineIdentification)}
@@ -10867,21 +11365,21 @@
10867
11365
  if (task.expectations) {
10868
11366
  for (const [unit, { min, max }] of Object.entries(task.expectations)) {
10869
11367
  if (min !== undefined && max !== undefined && min > max) {
10870
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11368
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10871
11369
  Min expectation (=${min}) of ${unit} is higher than max expectation (=${max})
10872
11370
 
10873
11371
  ${block(pipelineIdentification)}
10874
11372
  `));
10875
11373
  }
10876
11374
  if (min !== undefined && min < 0) {
10877
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11375
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10878
11376
  Min expectation of ${unit} must be zero or positive
10879
11377
 
10880
11378
  ${block(pipelineIdentification)}
10881
11379
  `));
10882
11380
  }
10883
11381
  if (max !== undefined && max <= 0) {
10884
- throw new PipelineLogicError(spaceTrim.spaceTrim((block) => `
11382
+ throw new PipelineLogicError(spaceTrim$1.spaceTrim((block) => `
10885
11383
  Max expectation of ${unit} must be positive
10886
11384
 
10887
11385
  ${block(pipelineIdentification)}
@@ -10903,7 +11401,7 @@
10903
11401
  while (unresovedTasks.length > 0) {
10904
11402
  if (loopLimit-- < 0) {
10905
11403
  // Note: Really UnexpectedError not LimitReachedError - this should not happen and be caught below
10906
- throw new UnexpectedError(spaceTrim.spaceTrim((block) => `
11404
+ throw new UnexpectedError(spaceTrim$1.spaceTrim((block) => `
10907
11405
  Loop limit reached during detection of circular dependencies in \`validatePipeline\`
10908
11406
 
10909
11407
  ${block(pipelineIdentification)}
@@ -10913,7 +11411,7 @@
10913
11411
  if (currentlyResovedTasks.length === 0) {
10914
11412
  throw new PipelineLogicError(
10915
11413
  // TODO: [🐎] DRY
10916
- spaceTrim.spaceTrim((block) => `
11414
+ spaceTrim$1.spaceTrim((block) => `
10917
11415
 
10918
11416
  Can not resolve some parameters:
10919
11417
  Either you are using a parameter that is not defined, or there are some circular dependencies.
@@ -11034,7 +11532,7 @@
11034
11532
  for (const pipeline of pipelines) {
11035
11533
  // TODO: [👠] DRY
11036
11534
  if (pipeline.pipelineUrl === undefined) {
11037
- throw new PipelineUrlError(spaceTrim.spaceTrim(`
11535
+ throw new PipelineUrlError(spaceTrim$1.spaceTrim(`
11038
11536
  Pipeline with name "${pipeline.title}" does not have defined URL
11039
11537
 
11040
11538
  File:
@@ -11056,7 +11554,7 @@
11056
11554
  pipelineJsonToString(unpreparePipeline(pipeline)) !==
11057
11555
  pipelineJsonToString(unpreparePipeline(this.collection.get(pipeline.pipelineUrl)))) {
11058
11556
  const existing = this.collection.get(pipeline.pipelineUrl);
11059
- throw new PipelineUrlError(spaceTrim.spaceTrim(`
11557
+ throw new PipelineUrlError(spaceTrim$1.spaceTrim(`
11060
11558
  Pipeline with URL ${pipeline.pipelineUrl} is already in the collection 🍎
11061
11559
 
11062
11560
  Conflicting files:
@@ -11088,13 +11586,13 @@
11088
11586
  const pipeline = this.collection.get(url);
11089
11587
  if (!pipeline) {
11090
11588
  if (this.listPipelines().length === 0) {
11091
- throw new NotFoundError(spaceTrim.spaceTrim(`
11589
+ throw new NotFoundError(spaceTrim$1.spaceTrim(`
11092
11590
  Pipeline with url "${url}" not found
11093
11591
 
11094
11592
  No pipelines available
11095
11593
  `));
11096
11594
  }
11097
- throw new NotFoundError(spaceTrim.spaceTrim((block) => `
11595
+ throw new NotFoundError(spaceTrim$1.spaceTrim((block) => `
11098
11596
  Pipeline with url "${url}" not found
11099
11597
 
11100
11598
  Available pipelines:
@@ -11193,11 +11691,11 @@
11193
11691
  throw deserializeError(errors[0]);
11194
11692
  }
11195
11693
  else {
11196
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
11694
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
11197
11695
  Multiple errors occurred during Promptbook execution
11198
11696
 
11199
11697
  ${block(errors
11200
- .map(({ name, stack, message }, index) => spaceTrim.spaceTrim((block) => `
11698
+ .map(({ name, stack, message }, index) => spaceTrim$1.spaceTrim((block) => `
11201
11699
  ${name} ${index + 1}:
11202
11700
  ${block(stack || message)}
11203
11701
  `))
@@ -12216,7 +12714,7 @@
12216
12714
  if (task.taskType === 'PROMPT_TASK' &&
12217
12715
  knowledgePiecesCount > 0 &&
12218
12716
  !dependentParameterNames.includes('knowledge')) {
12219
- preparedContent = spaceTrim.spaceTrim(`
12717
+ preparedContent = spaceTrim$1.spaceTrim(`
12220
12718
  {content}
12221
12719
 
12222
12720
  ## Knowledge
@@ -12448,7 +12946,7 @@
12448
12946
  }
12449
12947
  catch (error) {
12450
12948
  assertsError(error);
12451
- throw new ParseError(spaceTrim.spaceTrim((block) => `
12949
+ throw new ParseError(spaceTrim$1.spaceTrim((block) => `
12452
12950
  Can not extract variables from the script
12453
12951
  ${block(error.stack || error.message)}
12454
12952
 
@@ -12991,7 +13489,7 @@
12991
13489
  }
12992
13490
  catch (error) {
12993
13491
  keepUnused(error);
12994
- throw new ExpectError(spaceTrim.spaceTrim((block) => `
13492
+ throw new ExpectError(spaceTrim$1.spaceTrim((block) => `
12995
13493
  Expected valid JSON string
12996
13494
 
12997
13495
  The expected JSON text:
@@ -13054,7 +13552,7 @@
13054
13552
  const jokerParameterName = jokerParameterNames[jokerParameterNames.length + attemptIndex];
13055
13553
  // TODO: [🧠][🍭] JOKERS, EXPECTATIONS, POSTPROCESSING and FOREACH
13056
13554
  if (isJokerAttempt && !jokerParameterName) {
13057
- throw new UnexpectedError(spaceTrim.spaceTrim((block) => `
13555
+ throw new UnexpectedError(spaceTrim$1.spaceTrim((block) => `
13058
13556
  Joker not found in attempt ${attemptIndex}
13059
13557
 
13060
13558
  ${block(pipelineIdentification)}
@@ -13065,7 +13563,7 @@
13065
13563
  $ongoingTaskResult.$expectError = null;
13066
13564
  if (isJokerAttempt) {
13067
13565
  if (parameters[jokerParameterName] === undefined) {
13068
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
13566
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13069
13567
  Joker parameter {${jokerParameterName}} not defined
13070
13568
 
13071
13569
  ${block(pipelineIdentification)}
@@ -13123,7 +13621,7 @@
13123
13621
  $ongoingTaskResult.$resultString = $ongoingTaskResult.$completionResult.content;
13124
13622
  break variant;
13125
13623
  case 'EMBEDDING':
13126
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
13624
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13127
13625
  Embedding model can not be used in pipeline
13128
13626
 
13129
13627
  This should be catched during parsing
@@ -13134,7 +13632,7 @@
13134
13632
  break variant;
13135
13633
  // <- case [🤖]:
13136
13634
  default:
13137
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
13635
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13138
13636
  Unknown model variant "${task.modelRequirements.modelVariant}"
13139
13637
 
13140
13638
  ${block(pipelineIdentification)}
@@ -13145,14 +13643,14 @@
13145
13643
  break;
13146
13644
  case 'SCRIPT_TASK':
13147
13645
  if (arrayableToArray(tools.script).length === 0) {
13148
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
13646
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13149
13647
  No script execution tools are available
13150
13648
 
13151
13649
  ${block(pipelineIdentification)}
13152
13650
  `));
13153
13651
  }
13154
13652
  if (!task.contentLanguage) {
13155
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
13653
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13156
13654
  Script language is not defined for SCRIPT TASK "${task.name}"
13157
13655
 
13158
13656
  ${block(pipelineIdentification)}
@@ -13183,7 +13681,7 @@
13183
13681
  throw $ongoingTaskResult.$scriptPipelineExecutionErrors[0];
13184
13682
  }
13185
13683
  else {
13186
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
13684
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13187
13685
  Script execution failed ${$ongoingTaskResult.$scriptPipelineExecutionErrors.length}x
13188
13686
 
13189
13687
  ${block(pipelineIdentification)}
@@ -13197,7 +13695,7 @@
13197
13695
  break taskType;
13198
13696
  case 'DIALOG_TASK':
13199
13697
  if (tools.userInterface === undefined) {
13200
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
13698
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13201
13699
  User interface tools are not available
13202
13700
 
13203
13701
  ${block(pipelineIdentification)}
@@ -13215,7 +13713,7 @@
13215
13713
  break taskType;
13216
13714
  // <- case: [🅱]
13217
13715
  default:
13218
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
13716
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13219
13717
  Unknown execution type "${task.taskType}"
13220
13718
 
13221
13719
  ${block(pipelineIdentification)}
@@ -13313,7 +13811,7 @@
13313
13811
  if ($ongoingTaskResult.$expectError !== null && attemptIndex === maxAttempts - 1) {
13314
13812
  // Note: Create a summary of all failures
13315
13813
  const failuresSummary = $ongoingTaskResult.$failedResults
13316
- .map((failure) => spaceTrim.spaceTrim((block) => {
13814
+ .map((failure) => spaceTrim$1.spaceTrim((block) => {
13317
13815
  var _a, _b;
13318
13816
  return `
13319
13817
  Attempt ${failure.attemptIndex + 1}:
@@ -13323,14 +13821,14 @@
13323
13821
  Result:
13324
13822
  ${block(failure.result === null
13325
13823
  ? 'null'
13326
- : spaceTrim.spaceTrim(failure.result)
13824
+ : spaceTrim$1.spaceTrim(failure.result)
13327
13825
  .split('\n')
13328
13826
  .map((line) => `> ${line}`)
13329
13827
  .join('\n'))}
13330
13828
  `;
13331
13829
  }))
13332
13830
  .join('\n\n---\n\n');
13333
- throw new PipelineExecutionError(spaceTrim.spaceTrim((block) => {
13831
+ throw new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => {
13334
13832
  var _a;
13335
13833
  return `
13336
13834
  LLM execution failed ${maxExecutionAttempts}x
@@ -13350,7 +13848,7 @@
13350
13848
  }
13351
13849
  }
13352
13850
  if ($ongoingTaskResult.$resultString === null) {
13353
- throw new UnexpectedError(spaceTrim.spaceTrim((block) => `
13851
+ throw new UnexpectedError(spaceTrim$1.spaceTrim((block) => `
13354
13852
  Something went wrong and prompt result is null
13355
13853
 
13356
13854
  ${block(pipelineIdentification)}
@@ -13656,7 +14154,7 @@
13656
14154
  // Note: Doublecheck that ALL reserved parameters are defined:
13657
14155
  for (const parameterName of RESERVED_PARAMETER_NAMES) {
13658
14156
  if (reservedParameters[parameterName] === undefined) {
13659
- throw new UnexpectedError(spaceTrim.spaceTrim((block) => `
14157
+ throw new UnexpectedError(spaceTrim$1.spaceTrim((block) => `
13660
14158
  Reserved parameter {${parameterName}} is not defined
13661
14159
 
13662
14160
  ${block(pipelineIdentification)}
@@ -13682,7 +14180,7 @@
13682
14180
  const dependentParameterNames = new Set(currentTask.dependentParameterNames);
13683
14181
  // TODO: [👩🏾‍🤝‍👩🏻] Use here `mapAvailableToExpectedParameters`
13684
14182
  if (difference(union(difference(usedParameterNames, dependentParameterNames), difference(dependentParameterNames, usedParameterNames)), new Set(RESERVED_PARAMETER_NAMES)).size !== 0) {
13685
- throw new UnexpectedError(spaceTrim.spaceTrim((block) => `
14183
+ throw new UnexpectedError(spaceTrim$1.spaceTrim((block) => `
13686
14184
  Dependent parameters are not consistent with used parameters:
13687
14185
 
13688
14186
  Dependent parameters:
@@ -13726,7 +14224,7 @@
13726
14224
  else if (!definedParameterNames.has(parameterName) && usedParameterNames.has(parameterName)) {
13727
14225
  // Houston, we have a problem
13728
14226
  // Note: Checking part is also done in `validatePipeline`, but it’s good to doublecheck
13729
- throw new UnexpectedError(spaceTrim.spaceTrim((block) => `
14227
+ throw new UnexpectedError(spaceTrim$1.spaceTrim((block) => `
13730
14228
  Parameter \`{${parameterName}}\` is NOT defined
13731
14229
  BUT used in task "${currentTask.title || currentTask.name}"
13732
14230
 
@@ -13795,7 +14293,7 @@
13795
14293
  for (const parameter of preparedPipeline.parameters.filter(({ isOutput }) => isOutput)) {
13796
14294
  if (parametersToPass[parameter.name] === undefined) {
13797
14295
  // [4]
13798
- $warnings.push(new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
14296
+ $warnings.push(new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13799
14297
  Parameter \`{${parameter.name}}\` should be an output parameter, but it was not generated during pipeline execution
13800
14298
 
13801
14299
  Note: This is a warning which happened after the pipeline was executed, and \`{${parameter.name}}\` was not for some reason defined in output parameters
@@ -13903,7 +14401,7 @@
13903
14401
  for (const parameterName of Object.keys(inputParameters)) {
13904
14402
  const parameter = preparedPipeline.parameters.find(({ name }) => name === parameterName);
13905
14403
  if (parameter === undefined) {
13906
- warnings.push(new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
14404
+ warnings.push(new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13907
14405
  Extra parameter {${parameterName}} is being passed which is not part of the pipeline.
13908
14406
 
13909
14407
  ${block(pipelineIdentification)}
@@ -13918,7 +14416,7 @@
13918
14416
  // TODO: [🧠] This should be also non-critical error
13919
14417
  return exportJson({
13920
14418
  name: 'pipelineExecutorResult',
13921
- message: spaceTrim.spaceTrim((block) => `
14419
+ message: spaceTrim$1.spaceTrim((block) => `
13922
14420
  Unsuccessful PipelineExecutorResult (with extra parameter {${parameter.name}}) PipelineExecutorResult
13923
14421
 
13924
14422
  ${block(pipelineIdentification)}
@@ -13927,7 +14425,7 @@
13927
14425
  value: {
13928
14426
  isSuccessful: false,
13929
14427
  errors: [
13930
- new PipelineExecutionError(spaceTrim.spaceTrim((block) => `
14428
+ new PipelineExecutionError(spaceTrim$1.spaceTrim((block) => `
13931
14429
  Parameter \`{${parameter.name}}\` is passed as input parameter but it is not input
13932
14430
 
13933
14431
  ${block(pipelineIdentification)}
@@ -13954,7 +14452,7 @@
13954
14452
  while (unresovedTasks.length > 0) {
13955
14453
  if (loopLimit-- < 0) {
13956
14454
  // Note: Really UnexpectedError not LimitReachedError - this should be catched during validatePipeline
13957
- throw new UnexpectedError(spaceTrim.spaceTrim((block) => `
14455
+ throw new UnexpectedError(spaceTrim$1.spaceTrim((block) => `
13958
14456
  Loop limit reached during resolving parameters pipeline execution
13959
14457
 
13960
14458
  ${block(pipelineIdentification)}
@@ -13964,7 +14462,7 @@
13964
14462
  if (!currentTask && resolving.length === 0) {
13965
14463
  throw new UnexpectedError(
13966
14464
  // TODO: [🐎] DRY
13967
- spaceTrim.spaceTrim((block) => `
14465
+ spaceTrim$1.spaceTrim((block) => `
13968
14466
  Can not resolve some parameters:
13969
14467
 
13970
14468
  ${block(pipelineIdentification)}
@@ -14004,7 +14502,7 @@
14004
14502
  tools,
14005
14503
  onProgress(newOngoingResult) {
14006
14504
  if (isReturned) {
14007
- throw new UnexpectedError(spaceTrim.spaceTrim((block) => `
14505
+ throw new UnexpectedError(spaceTrim$1.spaceTrim((block) => `
14008
14506
  Can not call \`onProgress\` after pipeline execution is finished
14009
14507
 
14010
14508
  ${block(pipelineIdentification)}
@@ -14021,7 +14519,7 @@
14021
14519
  },
14022
14520
  logLlmCall,
14023
14521
  $executionReport: executionReport,
14024
- pipelineIdentification: spaceTrim.spaceTrim((block) => `
14522
+ pipelineIdentification: spaceTrim$1.spaceTrim((block) => `
14025
14523
  ${block(pipelineIdentification)}
14026
14524
  Task name: ${currentTask.name}
14027
14525
  Task title: ${currentTask.title}
@@ -14130,7 +14628,7 @@
14130
14628
  preparedPipeline = pipeline;
14131
14629
  }
14132
14630
  else if (isNotPreparedWarningSuppressed !== true) {
14133
- console.warn(spaceTrim.spaceTrim((block) => `
14631
+ console.warn(spaceTrim$1.spaceTrim((block) => `
14134
14632
  Pipeline is not prepared
14135
14633
 
14136
14634
  ${block(pipelineIdentification)}
@@ -14155,7 +14653,7 @@
14155
14653
  tools,
14156
14654
  onProgress,
14157
14655
  logLlmCall,
14158
- pipelineIdentification: spaceTrim.spaceTrim((block) => `
14656
+ pipelineIdentification: spaceTrim$1.spaceTrim((block) => `
14159
14657
  ${block(pipelineIdentification)}
14160
14658
  ${runCount === 1 ? '' : `Run #${runCount}`}
14161
14659
  `),
@@ -16093,18 +16591,26 @@
16093
16591
  modelName: 'assistant',
16094
16592
  // <- [🧠] What is the best value here
16095
16593
  });
16594
+ // Build thread messages: include previous thread messages + current user message
16595
+ const threadMessages = [];
16596
+ // TODO: [🈹] Maybe this should not be here but in other place, look at commit 39d705e75e5bcf7a818c3af36bc13e1c8475c30c
16597
+ // Add previous messages from thread (if any)
16598
+ if ('thread' in prompt &&
16599
+ Array.isArray(prompt.thread)) {
16600
+ const previousMessages = prompt.thread.map((msg) => ({
16601
+ role: (msg.role === 'assistant' ? 'assistant' : 'user'),
16602
+ content: msg.content,
16603
+ }));
16604
+ threadMessages.push(...previousMessages);
16605
+ }
16606
+ // Always add the current user message
16607
+ threadMessages.push({ role: 'user', content: rawPromptContent });
16096
16608
  const rawRequest = {
16097
16609
  // TODO: [👨‍👨‍👧‍👧] ...modelSettings,
16098
16610
  // TODO: [👨‍👨‍👧‍👧][🧠] What about system message for assistants, does it make sense - combination of OpenAI assistants with Promptbook Personas
16099
16611
  assistant_id: this.assistantId,
16100
16612
  thread: {
16101
- messages: 'thread' in prompt &&
16102
- Array.isArray(prompt.thread)
16103
- ? prompt.thread.map((msg) => ({
16104
- role: msg.role === 'assistant' ? 'assistant' : 'user',
16105
- content: msg.content,
16106
- }))
16107
- : [{ role: 'user', content: rawPromptContent }],
16613
+ messages: threadMessages,
16108
16614
  },
16109
16615
  // <- TODO: Add user identification here> user: this.options.user,
16110
16616
  };
@@ -16124,7 +16630,7 @@
16124
16630
  console.info('textDelta', textDelta.value);
16125
16631
  }
16126
16632
  const chunk = {
16127
- content: textDelta.value || '',
16633
+ content: snapshot.value,
16128
16634
  modelName: 'assistant',
16129
16635
  timing: {
16130
16636
  start,
@@ -17021,18 +17527,18 @@
17021
17527
  * TODO: !!! Agent on remote server
17022
17528
  */
17023
17529
 
17024
- var css_248z = ".PromptbookAgent-module_promptbookAgent__ImvJD{bottom:20px;font-family:sans-serif;position:fixed;right:20px;z-index:10000}.PromptbookAgent-module_promptbookAgentButton__YhQfE{align-items:center;background-color:#007bff;border-radius:30px;box-shadow:0 4px 12px rgba(0,0,0,.15);color:#fff;cursor:pointer;display:flex;padding:10px 20px;position:relative;transition:transform .2s,box-shadow .2s}.PromptbookAgent-module_promptbookAgentButton__YhQfE:hover{box-shadow:0 6px 16px rgba(0,0,0,.2);transform:translateY(-2px)}.PromptbookAgent-module_promptbookAgentAvatar__WhrxA{background-color:#eee;border-radius:50%;height:32px;margin-right:10px;overflow:hidden;transform:translate(-10px) scale(1.3);width:32px}.PromptbookAgent-module_promptbookAgentAvatar__WhrxA img{height:100%;object-fit:cover;width:100%}.PromptbookAgent-module_promptbookAgentLabel__vPwVo{font-weight:700}.PromptbookAgent-module_promptbookAgentStatus__kZ-6L{border:2px solid #fff;border-radius:50%;bottom:12px;height:12px;left:40px;position:absolute;width:12px;z-index:10}.PromptbookAgent-module_promptbookAgentStatusConnected__M8yU5{background-color:#57b660}.PromptbookAgent-module_promptbookAgentStatusPending__czc3Y{background-color:#9e9e9e}.PromptbookAgent-module_promptbookAgentStatusError__Dvytw{background-color:#f44336}.PromptbookAgent-module_promptbookAgent__ImvJD.PromptbookAgent-module_open__TWzmA .PromptbookAgent-module_promptbookAgentButton__YhQfE{display:none}.PromptbookAgent-module_promptbookAgentWindow__mohTT{animation:PromptbookAgent-module_promptbook-agent-slide-up__PA--W .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.2);display:flex;flex-direction:column;height:600px;max-height:80vh;overflow:hidden;width:380px}@keyframes PromptbookAgent-module_promptbook-agent-slide-up__PA--W{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3{align-items:center;background-color:#007bff;color:#fff;display:flex;justify-content:space-between;padding:15px}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3 button{align-items:center!important;background:transparent!important;border:none!important;border-radius:50%!important;box-shadow:none!important;color:inherit!important;cursor:pointer;display:flex!important;height:32px!important;justify-content:center!important;margin:0 2px!important;min-width:32px!important;opacity:.8;padding:5px!important;transition:opacity .2s}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3 button:hover{background-color:hsla(0,0%,100%,.2)!important;opacity:1}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3 button span{display:none!important}.PromptbookAgent-module_promptbookAgentHeader__C7Ui3 button svg{height:20px;width:20px}.PromptbookAgent-module_promptbookAgentTitle__pU86r{font-size:1.1em;font-weight:700}.PromptbookAgent-module_promptbookAgentClose__RB4MO{font-size:1.2em}.PromptbookAgent-module_promptbookAgentContent__-82xH{display:flex;flex:1;flex-direction:column;overflow-y:auto;position:relative}.PromptbookAgent-module_promptbookAgentError__ejwA9,.PromptbookAgent-module_promptbookAgentLoading__hcXD5{align-items:center;color:#666;display:flex;flex:1;justify-content:center;padding:20px;text-align:center}.PromptbookAgent-module_promptbookAgentError__ejwA9{color:#d32f2f}@media (max-width:480px){.PromptbookAgent-module_promptbookAgent__ImvJD.PromptbookAgent-module_open__TWzmA{bottom:0;left:0;right:0}.PromptbookAgent-module_promptbookAgentWindow__mohTT{border-radius:0;height:100vh;max-height:100vh;width:100%}}\n/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlByb21wdGJvb2tBZ2VudC5tb2R1bGUuY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLCtDQUVJLFdBQVksQ0FHWixzQkFBdUIsQ0FKdkIsY0FBZSxDQUVmLFVBQVcsQ0FDWCxhQUVKLENBRUEscURBRUksa0JBQW1CLENBQ25CLHdCQUF5QixDQUV6QixrQkFBbUIsQ0FHbkIscUNBQTBDLENBSjFDLFVBQVksQ0FHWixjQUFlLENBTmYsWUFBYSxDQUtiLGlCQUFrQixDQUlsQixpQkFBa0IsQ0FEbEIsdUNBRUosQ0FFQSwyREFFSSxvQ0FBeUMsQ0FEekMsMEJBRUosQ0FFQSxxREFNSSxxQkFBc0IsQ0FIdEIsaUJBQWtCLENBRGxCLFdBQVksQ0FHWixpQkFBa0IsQ0FEbEIsZUFBZ0IsQ0FJaEIscUNBQXlDLENBUHpDLFVBUUosQ0FFQSx5REFFSSxXQUFZLENBQ1osZ0JBQWlCLENBRmpCLFVBR0osQ0FFQSxvREFDSSxlQUNKLENBRUEscURBS0kscUJBQXVCLENBRHZCLGlCQUFrQixDQUdsQixXQUFZLENBSlosV0FBWSxDQUdaLFNBQVUsQ0FMVixpQkFBa0IsQ0FDbEIsVUFBVyxDQU1YLFVBQ0osQ0FFQSw4REFDSSx3QkFDSixDQUVBLDREQUNJLHdCQUNKLENBRUEsMERBQ0ksd0JBQ0osQ0FRQSx1SUFDSSxZQUNKLENBRUEscURBVUksOEVBQWtELENBTmxELHFCQUF1QixDQUN2QixrQkFBbUIsQ0FDbkIsb0NBQXlDLENBQ3pDLFlBQWEsQ0FDYixxQkFBc0IsQ0FOdEIsWUFBYSxDQUNiLGVBQWdCLENBTWhCLGVBQWdCLENBUmhCLFdBVUosQ0FFQSxtRUFDSSxHQUNJLFNBQVUsQ0FDViwwQkFDSixDQUNBLEdBQ0ksU0FBVSxDQUNWLHVCQUNKLENBQ0osQ0FFQSxxREFNSSxrQkFBbUIsQ0FMbkIsd0JBQXlCLENBQ3pCLFVBQVksQ0FFWixZQUFhLENBQ2IsNkJBQThCLENBRjlCLFlBSUosQ0FNQSw0REFXSSw0QkFBOEIsQ0FWOUIsZ0NBQWtDLENBQ2xDLHFCQUF1QixDQWF2QiwyQkFBNkIsQ0FaN0IseUJBQTJCLENBQzNCLHVCQUF5QixDQUN6QixjQUFlLENBS2Ysc0JBQXdCLENBSXhCLHFCQUF1QixDQUZ2QixnQ0FBa0MsQ0FIbEMsc0JBQXdCLENBSXhCLHdCQUEwQixDQVAxQixVQUFZLENBRVoscUJBQXVCLENBRHZCLHNCQVNKLENBRUEsa0VBRUksNkNBQXFELENBRHJELFNBRUosQ0FHQSxpRUFDSSxzQkFDSixDQUdBLGdFQUVJLFdBQVksQ0FEWixVQUVKLENBRUEsb0RBRUksZUFBZ0IsQ0FEaEIsZUFFSixDQUVBLG9EQUVJLGVBQ0osQ0FFQSxzREFJSSxZQUFhLENBSGIsTUFBTyxDQUlQLHFCQUFzQixDQUh0QixlQUFnQixDQUNoQixpQkFHSixDQUVBLDBHQUtJLGtCQUFtQixDQUduQixVQUFXLENBTFgsWUFBYSxDQURiLE1BQU8sQ0FFUCxzQkFBdUIsQ0FFdkIsWUFBYSxDQUNiLGlCQUVKLENBRUEsb0RBQ0ksYUFDSixDQUVBLHlCQUNJLGtGQUNJLFFBQVMsQ0FFVCxNQUFPLENBRFAsT0FFSixDQUVBLHFEQUlJLGVBQWdCLENBRmhCLFlBQWEsQ0FDYixnQkFBaUIsQ0FGakIsVUFJSixDQUNKIiwiZmlsZSI6IlByb21wdGJvb2tBZ2VudC5tb2R1bGUuY3NzIiwic291cmNlc0NvbnRlbnQiOlsiLnByb21wdGJvb2tBZ2VudCB7XG4gICAgcG9zaXRpb246IGZpeGVkO1xuICAgIGJvdHRvbTogMjBweDtcbiAgICByaWdodDogMjBweDtcbiAgICB6LWluZGV4OiAxMDAwMDtcbiAgICBmb250LWZhbWlseTogc2Fucy1zZXJpZjtcbn1cblxuLnByb21wdGJvb2tBZ2VudEJ1dHRvbiB7XG4gICAgZGlzcGxheTogZmxleDtcbiAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICMwMDdiZmY7XG4gICAgY29sb3I6IHdoaXRlO1xuICAgIGJvcmRlci1yYWRpdXM6IDMwcHg7XG4gICAgcGFkZGluZzogMTBweCAyMHB4O1xuICAgIGN1cnNvcjogcG9pbnRlcjtcbiAgICBib3gtc2hhZG93OiAwIDRweCAxMnB4IHJnYmEoMCwgMCwgMCwgMC4xNSk7XG4gICAgdHJhbnNpdGlvbjogdHJhbnNmb3JtIDAuMnMsIGJveC1zaGFkb3cgMC4ycztcbiAgICBwb3NpdGlvbjogcmVsYXRpdmU7XG59XG5cbi5wcm9tcHRib29rQWdlbnRCdXR0b246aG92ZXIge1xuICAgIHRyYW5zZm9ybTogdHJhbnNsYXRlWSgtMnB4KTtcbiAgICBib3gtc2hhZG93OiAwIDZweCAxNnB4IHJnYmEoMCwgMCwgMCwgMC4yKTtcbn1cblxuLnByb21wdGJvb2tBZ2VudEF2YXRhciB7XG4gICAgd2lkdGg6IDMycHg7XG4gICAgaGVpZ2h0OiAzMnB4O1xuICAgIGJvcmRlci1yYWRpdXM6IDUwJTtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIG1hcmdpbi1yaWdodDogMTBweDtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjZWVlO1xuXG4gICAgdHJhbnNmb3JtOiB0cmFuc2xhdGUoLTEwcHgsIDApIHNjYWxlKDEuMyk7XG59XG5cbi5wcm9tcHRib29rQWdlbnRBdmF0YXIgaW1nIHtcbiAgICB3aWR0aDogMTAwJTtcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgb2JqZWN0LWZpdDogY292ZXI7XG59XG5cbi5wcm9tcHRib29rQWdlbnRMYWJlbCB7XG4gICAgZm9udC13ZWlnaHQ6IGJvbGQ7XG59XG5cbi5wcm9tcHRib29rQWdlbnRTdGF0dXMge1xuICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgICB3aWR0aDogMTJweDtcbiAgICBoZWlnaHQ6IDEycHg7XG4gICAgYm9yZGVyLXJhZGl1czogNTAlO1xuICAgIGJvcmRlcjogMnB4IHNvbGlkIHdoaXRlO1xuICAgIGxlZnQ6IDQwcHg7XG4gICAgYm90dG9tOiAxMnB4O1xuICAgIHotaW5kZXg6IDEwO1xufVxuXG4ucHJvbXB0Ym9va0FnZW50U3RhdHVzQ29ubmVjdGVkIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjNTdiNjYwO1xufVxuXG4ucHJvbXB0Ym9va0FnZW50U3RhdHVzUGVuZGluZyB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogIzllOWU5ZTtcbn1cblxuLnByb21wdGJvb2tBZ2VudFN0YXR1c0Vycm9yIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjZjQ0MzM2O1xufVxuXG4vKiBTdGF0ZSBjbGFzc2VzIChlbXB0eSB0byBhbGxvdyBtb2R1bGUgbWFwcGluZykgKi9cbi5vcGVuIHtcbn1cbi5jbG9zZWQge1xufVxuXG4ucHJvbXB0Ym9va0FnZW50Lm9wZW4gLnByb21wdGJvb2tBZ2VudEJ1dHRvbiB7XG4gICAgZGlzcGxheTogbm9uZTtcbn1cblxuLnByb21wdGJvb2tBZ2VudFdpbmRvdyB7XG4gICAgd2lkdGg6IDM4MHB4O1xuICAgIGhlaWdodDogNjAwcHg7XG4gICAgbWF4LWhlaWdodDogODB2aDtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiB3aGl0ZTtcbiAgICBib3JkZXItcmFkaXVzOiAxMnB4O1xuICAgIGJveC1zaGFkb3c6IDAgOHB4IDMycHggcmdiYSgwLCAwLCAwLCAwLjIpO1xuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgIGFuaW1hdGlvbjogcHJvbXB0Ym9vay1hZ2VudC1zbGlkZS11cCAwLjNzIGVhc2Utb3V0O1xufVxuXG5Aa2V5ZnJhbWVzIHByb21wdGJvb2stYWdlbnQtc2xpZGUtdXAge1xuICAgIGZyb20ge1xuICAgICAgICBvcGFjaXR5OiAwO1xuICAgICAgICB0cmFuc2Zvcm06IHRyYW5zbGF0ZVkoMjBweCk7XG4gICAgfVxuICAgIHRvIHtcbiAgICAgICAgb3BhY2l0eTogMTtcbiAgICAgICAgdHJhbnNmb3JtOiB0cmFuc2xhdGVZKDApO1xuICAgIH1cbn1cblxuLnByb21wdGJvb2tBZ2VudEhlYWRlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogIzAwN2JmZjtcbiAgICBjb2xvcjogd2hpdGU7XG4gICAgcGFkZGluZzogMTVweDtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICBhbGlnbi1pdGVtczogY2VudGVyO1xufVxuXG4vKiBcbiAgIE92ZXJyaWRlIGNoYXQgYWN0aW9uIGJ1dHRvbnMgdG8gbG9vayBsaWtlIHRoZSBjbG9zZSBidXR0b24gXG4gICB3aGVuIHJlbmRlcmVkIGluc2lkZSB0aGUgaGVhZGVyIHZpYSBwb3J0YWxcbiovXG4ucHJvbXB0Ym9va0FnZW50SGVhZGVyIGJ1dHRvbiB7XG4gICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQgIWltcG9ydGFudDtcbiAgICBib3JkZXI6IG5vbmUgIWltcG9ydGFudDtcbiAgICBib3gtc2hhZG93OiBub25lICFpbXBvcnRhbnQ7XG4gICAgY29sb3I6IGluaGVyaXQgIWltcG9ydGFudDtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG4gICAgb3BhY2l0eTogMC44O1xuICAgIHRyYW5zaXRpb246IG9wYWNpdHkgMC4ycztcbiAgICBwYWRkaW5nOiA1cHggIWltcG9ydGFudDtcbiAgICBtYXJnaW46IDAgMnB4ICFpbXBvcnRhbnQ7XG4gICAgZGlzcGxheTogZmxleCAhaW1wb3J0YW50O1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXIgIWltcG9ydGFudDtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlciAhaW1wb3J0YW50O1xuICAgIG1pbi13aWR0aDogMzJweCAhaW1wb3J0YW50O1xuICAgIGhlaWdodDogMzJweCAhaW1wb3J0YW50O1xuICAgIGJvcmRlci1yYWRpdXM6IDUwJSAhaW1wb3J0YW50O1xufVxuXG4ucHJvbXB0Ym9va0FnZW50SGVhZGVyIGJ1dHRvbjpob3ZlciB7XG4gICAgb3BhY2l0eTogMTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiByZ2JhKDI1NSwgMjU1LCAyNTUsIDAuMikgIWltcG9ydGFudDtcbn1cblxuLyogSGlkZSB0ZXh0IGxhYmVscyBpbnNpZGUgYnV0dG9ucyBpbiBoZWFkZXIgKE5ldyBDaGF0LCBTYXZlKSAqL1xuLnByb21wdGJvb2tBZ2VudEhlYWRlciBidXR0b24gc3BhbiB7XG4gICAgZGlzcGxheTogbm9uZSAhaW1wb3J0YW50O1xufVxuXG4vKiBFbnN1cmUgU1ZHIGljb25zIGFyZSB2aXNpYmxlIGFuZCBzaXplZCBjb3JyZWN0bHkgKi9cbi5wcm9tcHRib29rQWdlbnRIZWFkZXIgYnV0dG9uIHN2ZyB7XG4gICAgd2lkdGg6IDIwcHg7XG4gICAgaGVpZ2h0OiAyMHB4O1xufVxuXG4ucHJvbXB0Ym9va0FnZW50VGl0bGUge1xuICAgIGZvbnQtd2VpZ2h0OiBib2xkO1xuICAgIGZvbnQtc2l6ZTogMS4xZW07XG59XG5cbi5wcm9tcHRib29rQWdlbnRDbG9zZSB7XG4gICAgLyogVXNlIHNhbWUgc3R5bGVzIGFzIGFib3ZlIG92ZXJyaWRlLCBidXQga2VlcCBzcGVjaWZpYyBpZiBuZWVkZWQgKi9cbiAgICBmb250LXNpemU6IDEuMmVtO1xufVxuXG4ucHJvbXB0Ym9va0FnZW50Q29udGVudCB7XG4gICAgZmxleDogMTtcbiAgICBvdmVyZmxvdy15OiBhdXRvO1xuICAgIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG59XG5cbi5wcm9tcHRib29rQWdlbnRMb2FkaW5nLFxuLnByb21wdGJvb2tBZ2VudEVycm9yIHtcbiAgICBmbGV4OiAxO1xuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICBwYWRkaW5nOiAyMHB4O1xuICAgIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgICBjb2xvcjogIzY2Njtcbn1cblxuLnByb21wdGJvb2tBZ2VudEVycm9yIHtcbiAgICBjb2xvcjogI2QzMmYyZjtcbn1cblxuQG1lZGlhIChtYXgtd2lkdGg6IDQ4MHB4KSB7XG4gICAgLnByb21wdGJvb2tBZ2VudC5vcGVuIHtcbiAgICAgICAgYm90dG9tOiAwO1xuICAgICAgICByaWdodDogMDtcbiAgICAgICAgbGVmdDogMDtcbiAgICB9XG5cbiAgICAucHJvbXB0Ym9va0FnZW50V2luZG93IHtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIGhlaWdodDogMTAwdmg7XG4gICAgICAgIG1heC1oZWlnaHQ6IDEwMHZoO1xuICAgICAgICBib3JkZXItcmFkaXVzOiAwO1xuICAgIH1cbn1cbiJdfQ== */";
17025
- var styles = {"promptbookAgent":"PromptbookAgent-module_promptbookAgent__ImvJD","promptbookAgentButton":"PromptbookAgent-module_promptbookAgentButton__YhQfE","promptbookAgentAvatar":"PromptbookAgent-module_promptbookAgentAvatar__WhrxA","promptbookAgentLabel":"PromptbookAgent-module_promptbookAgentLabel__vPwVo","promptbookAgentStatus":"PromptbookAgent-module_promptbookAgentStatus__kZ-6L","promptbookAgentStatusConnected":"PromptbookAgent-module_promptbookAgentStatusConnected__M8yU5","promptbookAgentStatusPending":"PromptbookAgent-module_promptbookAgentStatusPending__czc3Y","promptbookAgentStatusError":"PromptbookAgent-module_promptbookAgentStatusError__Dvytw","open":"PromptbookAgent-module_open__TWzmA","closed":"PromptbookAgent-module_closed__qCTmn","promptbookAgentWindow":"PromptbookAgent-module_promptbookAgentWindow__mohTT","promptbook-agent-slide-up":"PromptbookAgent-module_promptbook-agent-slide-up__PA--W","promptbookAgentHeader":"PromptbookAgent-module_promptbookAgentHeader__C7Ui3","promptbookAgentTitle":"PromptbookAgent-module_promptbookAgentTitle__pU86r","promptbookAgentClose":"PromptbookAgent-module_promptbookAgentClose__RB4MO","promptbookAgentContent":"PromptbookAgent-module_promptbookAgentContent__-82xH","promptbookAgentLoading":"PromptbookAgent-module_promptbookAgentLoading__hcXD5","promptbookAgentError":"PromptbookAgent-module_promptbookAgentError__ejwA9"};
17530
+ var css_248z = ".PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegration__KTAQl{bottom:20px;font-family:sans-serif;position:fixed;right:20px;z-index:10000}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationButton__beMWa{align-items:center;background-color:#007bff;border-radius:30px;box-shadow:0 4px 12px rgba(0,0,0,.15);color:#fff;cursor:pointer;display:flex;padding:10px 20px;position:relative;transition:transform .2s,box-shadow .2s}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationButton__beMWa:hover{box-shadow:0 6px 16px rgba(0,0,0,.2);transform:translateY(-2px)}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationAvatar__OrK-R{background-color:#eee;border-radius:50%;height:32px;margin-right:10px;overflow:hidden;transform:translate(-10px) scale(1.3);width:32px}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationAvatar__OrK-R img{height:100%;object-fit:cover;width:100%}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationLabel__gvgCn{font-weight:700}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatus__QBwnt{border:2px solid #fff;border-radius:50%;bottom:12px;height:12px;left:40px;position:absolute;width:12px;z-index:10}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusConnected__w15ZJ{background-color:#57b660}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusPending__vtVxc{background-color:#9e9e9e}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusError__nu02u{background-color:#f44336}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegration__KTAQl.PromptbookAgentSeamlessIntegration-module_open__rt5ey .PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationButton__beMWa{display:none}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationWindow__6sxeZ{animation:PromptbookAgentSeamlessIntegration-module_promptbook-agent-slide-up__0dGVe .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.2);display:flex;flex-direction:column;height:600px;max-height:80vh;overflow:hidden;width:380px}@keyframes PromptbookAgentSeamlessIntegration-module_promptbook-agent-slide-up__0dGVe{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B{align-items:center;background-color:#007bff;color:#fff;display:flex;justify-content:space-between;padding:15px}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B button{align-items:center!important;background:transparent!important;border:none!important;border-radius:50%!important;box-shadow:none!important;color:inherit!important;cursor:pointer;display:flex!important;height:32px!important;justify-content:center!important;margin:0 2px!important;min-width:32px!important;opacity:.8;padding:5px!important;transition:opacity .2s}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B button:hover{background-color:hsla(0,0%,100%,.2)!important;opacity:1}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B button span{display:none!important}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B button svg{height:20px;width:20px}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationTitle__D6p2j{font-size:1.1em;font-weight:700}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationClose__Ot41T{font-size:1.2em}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationContent__xqAns{display:flex;flex:1;flex-direction:column;overflow-y:auto;position:relative}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationError__RaBDa,.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationLoading__OAqgE{align-items:center;color:#666;display:flex;flex:1;justify-content:center;padding:20px;text-align:center}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationError__RaBDa{color:#d32f2f}@media (max-width:480px){.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegration__KTAQl.PromptbookAgentSeamlessIntegration-module_open__rt5ey{bottom:0;left:0;right:0}.PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationWindow__6sxeZ{border-radius:0;height:100vh;max-height:100vh;width:100%}}\n/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["PromptbookAgentSeamlessIntegration.module.css"],"names":[],"mappings":"AAAA,qFAEI,WAAY,CAGZ,sBAAuB,CAJvB,cAAe,CAEf,UAAW,CACX,aAEJ,CAEA,2FAEI,kBAAmB,CACnB,wBAAyB,CAEzB,kBAAmB,CAGnB,qCAA0C,CAJ1C,UAAY,CAGZ,cAAe,CANf,YAAa,CAKb,iBAAkB,CAIlB,iBAAkB,CADlB,uCAEJ,CAEA,iGAEI,oCAAyC,CADzC,0BAEJ,CAEA,2FAMI,qBAAsB,CAHtB,iBAAkB,CADlB,WAAY,CAGZ,iBAAkB,CADlB,eAAgB,CAIhB,qCAAyC,CAPzC,UAQJ,CAEA,+FAEI,WAAY,CACZ,gBAAiB,CAFjB,UAGJ,CAEA,0FACI,eACJ,CAEA,2FAKI,qBAAuB,CADvB,iBAAkB,CAGlB,WAAY,CAJZ,WAAY,CAGZ,SAAU,CALV,iBAAkB,CAClB,UAAW,CAMX,UACJ,CAEA,oGACI,wBACJ,CAEA,kGACI,wBACJ,CAEA,gGACI,wBACJ,CAQA,sOACI,YACJ,CAEA,2FAUI,iGAAkD,CANlD,qBAAuB,CACvB,kBAAmB,CACnB,oCAAyC,CACzC,YAAa,CACb,qBAAsB,CANtB,YAAa,CACb,eAAgB,CAMhB,eAAgB,CARhB,WAUJ,CAEA,sFACI,GACI,SAAU,CACV,0BACJ,CACA,GACI,SAAU,CACV,uBACJ,CACJ,CAEA,2FAMI,kBAAmB,CALnB,wBAAyB,CACzB,UAAY,CAEZ,YAAa,CACb,6BAA8B,CAF9B,YAIJ,CAMA,kGAWI,4BAA8B,CAV9B,gCAAkC,CAClC,qBAAuB,CAavB,2BAA6B,CAZ7B,yBAA2B,CAC3B,uBAAyB,CACzB,cAAe,CAKf,sBAAwB,CAIxB,qBAAuB,CAFvB,gCAAkC,CAHlC,sBAAwB,CAIxB,wBAA0B,CAP1B,UAAY,CAEZ,qBAAuB,CADvB,sBASJ,CAEA,wGAEI,6CAAqD,CADrD,SAEJ,CAGA,uGACI,sBACJ,CAGA,sGAEI,WAAY,CADZ,UAEJ,CAEA,0FAEI,eAAgB,CADhB,eAEJ,CAEA,0FAEI,eACJ,CAEA,4FAII,YAAa,CAHb,MAAO,CAIP,qBAAsB,CAHtB,eAAgB,CAChB,iBAGJ,CAEA,sLAKI,kBAAmB,CAGnB,UAAW,CALX,YAAa,CADb,MAAO,CAEP,sBAAuB,CAEvB,YAAa,CACb,iBAEJ,CAEA,0FACI,aACJ,CAEA,yBACI,2IACI,QAAS,CAET,MAAO,CADP,OAEJ,CAEA,2FAII,eAAgB,CAFhB,YAAa,CACb,gBAAiB,CAFjB,UAIJ,CACJ","file":"PromptbookAgentSeamlessIntegration.module.css","sourcesContent":[".PromptbookAgentSeamlessIntegration {\n    position: fixed;\n    bottom: 20px;\n    right: 20px;\n    z-index: 10000;\n    font-family: sans-serif;\n}\n\n.PromptbookAgentSeamlessIntegrationButton {\n    display: flex;\n    align-items: center;\n    background-color: #007bff;\n    color: white;\n    border-radius: 30px;\n    padding: 10px 20px;\n    cursor: pointer;\n    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);\n    transition: transform 0.2s, box-shadow 0.2s;\n    position: relative;\n}\n\n.PromptbookAgentSeamlessIntegrationButton:hover {\n    transform: translateY(-2px);\n    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);\n}\n\n.PromptbookAgentSeamlessIntegrationAvatar {\n    width: 32px;\n    height: 32px;\n    border-radius: 50%;\n    overflow: hidden;\n    margin-right: 10px;\n    background-color: #eee;\n\n    transform: translate(-10px, 0) scale(1.3);\n}\n\n.PromptbookAgentSeamlessIntegrationAvatar img {\n    width: 100%;\n    height: 100%;\n    object-fit: cover;\n}\n\n.PromptbookAgentSeamlessIntegrationLabel {\n    font-weight: bold;\n}\n\n.PromptbookAgentSeamlessIntegrationStatus {\n    position: absolute;\n    width: 12px;\n    height: 12px;\n    border-radius: 50%;\n    border: 2px solid white;\n    left: 40px;\n    bottom: 12px;\n    z-index: 10;\n}\n\n.PromptbookAgentSeamlessIntegrationStatusConnected {\n    background-color: #57b660;\n}\n\n.PromptbookAgentSeamlessIntegrationStatusPending {\n    background-color: #9e9e9e;\n}\n\n.PromptbookAgentSeamlessIntegrationStatusError {\n    background-color: #f44336;\n}\n\n/* State classes (empty to allow module mapping) */\n.open {\n}\n.closed {\n}\n\n.PromptbookAgentSeamlessIntegration.open .PromptbookAgentSeamlessIntegrationButton {\n    display: none;\n}\n\n.PromptbookAgentSeamlessIntegrationWindow {\n    width: 380px;\n    height: 600px;\n    max-height: 80vh;\n    background-color: white;\n    border-radius: 12px;\n    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);\n    display: flex;\n    flex-direction: column;\n    overflow: hidden;\n    animation: promptbook-agent-slide-up 0.3s ease-out;\n}\n\n@keyframes promptbook-agent-slide-up {\n    from {\n        opacity: 0;\n        transform: translateY(20px);\n    }\n    to {\n        opacity: 1;\n        transform: translateY(0);\n    }\n}\n\n.PromptbookAgentSeamlessIntegrationHeader {\n    background-color: #007bff;\n    color: white;\n    padding: 15px;\n    display: flex;\n    justify-content: space-between;\n    align-items: center;\n}\n\n/* \n   Override chat action buttons to look like the close button \n   when rendered inside the header via portal\n*/\n.PromptbookAgentSeamlessIntegrationHeader button {\n    background: transparent !important;\n    border: none !important;\n    box-shadow: none !important;\n    color: inherit !important;\n    cursor: pointer;\n    opacity: 0.8;\n    transition: opacity 0.2s;\n    padding: 5px !important;\n    margin: 0 2px !important;\n    display: flex !important;\n    align-items: center !important;\n    justify-content: center !important;\n    min-width: 32px !important;\n    height: 32px !important;\n    border-radius: 50% !important;\n}\n\n.PromptbookAgentSeamlessIntegrationHeader button:hover {\n    opacity: 1;\n    background-color: rgba(255, 255, 255, 0.2) !important;\n}\n\n/* Hide text labels inside buttons in header (New Chat, Save) */\n.PromptbookAgentSeamlessIntegrationHeader button span {\n    display: none !important;\n}\n\n/* Ensure SVG icons are visible and sized correctly */\n.PromptbookAgentSeamlessIntegrationHeader button svg {\n    width: 20px;\n    height: 20px;\n}\n\n.PromptbookAgentSeamlessIntegrationTitle {\n    font-weight: bold;\n    font-size: 1.1em;\n}\n\n.PromptbookAgentSeamlessIntegrationClose {\n    /* Use same styles as above override, but keep specific if needed */\n    font-size: 1.2em;\n}\n\n.PromptbookAgentSeamlessIntegrationContent {\n    flex: 1;\n    overflow-y: auto;\n    position: relative;\n    display: flex;\n    flex-direction: column;\n}\n\n.PromptbookAgentSeamlessIntegrationLoading,\n.PromptbookAgentSeamlessIntegrationError {\n    flex: 1;\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    padding: 20px;\n    text-align: center;\n    color: #666;\n}\n\n.PromptbookAgentSeamlessIntegrationError {\n    color: #d32f2f;\n}\n\n@media (max-width: 480px) {\n    .PromptbookAgentSeamlessIntegration.open {\n        bottom: 0;\n        right: 0;\n        left: 0;\n    }\n\n    .PromptbookAgentSeamlessIntegrationWindow {\n        width: 100%;\n        height: 100vh;\n        max-height: 100vh;\n        border-radius: 0;\n    }\n}\n"]} */";
17531
+ var styles = {"PromptbookAgentSeamlessIntegration":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegration__KTAQl","PromptbookAgentSeamlessIntegrationButton":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationButton__beMWa","PromptbookAgentSeamlessIntegrationAvatar":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationAvatar__OrK-R","PromptbookAgentSeamlessIntegrationLabel":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationLabel__gvgCn","PromptbookAgentSeamlessIntegrationStatus":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatus__QBwnt","PromptbookAgentSeamlessIntegrationStatusConnected":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusConnected__w15ZJ","PromptbookAgentSeamlessIntegrationStatusPending":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusPending__vtVxc","PromptbookAgentSeamlessIntegrationStatusError":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationStatusError__nu02u","open":"PromptbookAgentSeamlessIntegration-module_open__rt5ey","closed":"PromptbookAgentSeamlessIntegration-module_closed__VPHQ-","PromptbookAgentSeamlessIntegrationWindow":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationWindow__6sxeZ","promptbook-agent-slide-up":"PromptbookAgentSeamlessIntegration-module_promptbook-agent-slide-up__0dGVe","PromptbookAgentSeamlessIntegrationHeader":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationHeader__9ae8B","PromptbookAgentSeamlessIntegrationTitle":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationTitle__D6p2j","PromptbookAgentSeamlessIntegrationClose":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationClose__Ot41T","PromptbookAgentSeamlessIntegrationContent":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationContent__xqAns","PromptbookAgentSeamlessIntegrationLoading":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationLoading__OAqgE","PromptbookAgentSeamlessIntegrationError":"PromptbookAgentSeamlessIntegration-module_PromptbookAgentSeamlessIntegrationError__RaBDa"};
17026
17532
  styleInject(css_248z);
17027
17533
 
17028
17534
  /**
17029
17535
  * Renders a floating agent button that opens a chat window with the remote agent.
17030
17536
  *
17031
- * @public exported from `@promptbook/components`
17537
+ * @private component of PromptbookAgentIntegration
17032
17538
  */
17033
- function PromptbookAgent(props) {
17539
+ function PromptbookAgentSeamlessIntegration(props) {
17034
17540
  var _a, _b;
17035
- const { agentUrl, meta, onOpenChange } = props;
17541
+ const { agentUrl, meta, onOpenChange, className, style } = props;
17036
17542
  const [isOpen, setIsOpen] = react.useState(false);
17037
17543
  const [headerElement, setHeaderElement] = react.useState(null);
17038
17544
  react.useEffect(() => {
@@ -17090,11 +17596,36 @@
17090
17596
  else if (error) {
17091
17597
  connectionStatus = 'error';
17092
17598
  }
17093
- return (jsxRuntime.jsxs("div", { className: `${styles.promptbookAgent} ${isOpen ? styles.open : styles.closed}`, children: [jsxRuntime.jsxs("div", { className: styles.promptbookAgentButton, onClick: () => setIsOpen(!isOpen), style: { backgroundColor: color }, children: [jsxRuntime.jsx("div", { className: styles.promptbookAgentAvatar, children: jsxRuntime.jsx("img", { src: image, alt: "Agent" }) }), jsxRuntime.jsx("div", { className: `${styles.promptbookAgentStatus} ${connectionStatus === 'connected'
17094
- ? styles.promptbookAgentStatusConnected
17599
+ return (jsxRuntime.jsxs("div", { className: classNames(`${styles.PromptbookAgentSeamlessIntegration} ${isOpen ? styles.open : styles.closed}`, className), style: style, children: [jsxRuntime.jsxs("div", { className: styles.PromptbookAgentSeamlessIntegrationButton, onClick: () => setIsOpen(!isOpen), style: { backgroundColor: color }, children: [jsxRuntime.jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationAvatar, children: jsxRuntime.jsx("img", { src: image, alt: "Agent" }) }), jsxRuntime.jsx("div", { className: `${styles.PromptbookAgentSeamlessIntegrationStatus} ${connectionStatus === 'connected'
17600
+ ? styles.PromptbookAgentSeamlessIntegrationStatusConnected
17095
17601
  : connectionStatus === 'error'
17096
- ? styles.promptbookAgentStatusError
17097
- : styles.promptbookAgentStatusPending}` }), jsxRuntime.jsx("div", { className: styles.promptbookAgentLabel, children: "CHAT" })] }), isOpen && (jsxRuntime.jsxs("div", { className: styles.promptbookAgentWindow, children: [jsxRuntime.jsx("div", { className: styles.promptbookAgentHeader, style: { backgroundColor: color }, ref: setHeaderElement, children: jsxRuntime.jsx("div", { className: styles.promptbookAgentTitle, children: (agent === null || agent === void 0 ? void 0 : agent.meta.fullname) || (meta === null || meta === void 0 ? void 0 : meta.fullname) || (agent === null || agent === void 0 ? void 0 : agent.agentName) || 'Chat with Agent' }) }), jsxRuntime.jsx("div", { className: styles.promptbookAgentContent, children: agent ? (jsxRuntime.jsx(AgentChat, { agent: agent, actionsContainer: headerElement, extraActions: jsxRuntime.jsx("button", { className: styles.promptbookAgentClose, onClick: () => setIsOpen(false), title: "Close", children: jsxRuntime.jsx(CloseIcon, {}) }) })) : error ? (jsxRuntime.jsxs("div", { className: styles.promptbookAgentError, children: ["Failed to connect to agent: ", error.message] })) : (jsxRuntime.jsx("div", { className: styles.promptbookAgentLoading, children: "Connecting to agent..." })) })] }))] }));
17602
+ ? styles.PromptbookAgentSeamlessIntegrationStatusError
17603
+ : styles.PromptbookAgentSeamlessIntegrationStatusPending}` }), jsxRuntime.jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationLabel, children: "CHAT" })] }), isOpen && (jsxRuntime.jsxs("div", { className: styles.PromptbookAgentSeamlessIntegrationWindow, children: [jsxRuntime.jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationHeader, style: { backgroundColor: color }, ref: setHeaderElement, children: jsxRuntime.jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationTitle, children: (agent === null || agent === void 0 ? void 0 : agent.meta.fullname) || (meta === null || meta === void 0 ? void 0 : meta.fullname) || (agent === null || agent === void 0 ? void 0 : agent.agentName) || 'Chat with Agent' }) }), jsxRuntime.jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationContent, children: agent ? (jsxRuntime.jsx(AgentChat, { agent: agent, actionsContainer: headerElement, extraActions: jsxRuntime.jsx("button", { className: styles.PromptbookAgentSeamlessIntegrationClose, onClick: () => setIsOpen(false), title: "Close", children: jsxRuntime.jsx(CloseIcon, {}) }) })) : error ? (jsxRuntime.jsxs("div", { className: styles.PromptbookAgentSeamlessIntegrationError, children: ["Failed to connect to agent: ", error.message] })) : (jsxRuntime.jsx("div", { className: styles.PromptbookAgentSeamlessIntegrationLoading, children: "Connecting to agent..." })) })] }))] }));
17604
+ }
17605
+
17606
+ /**
17607
+ * Renders a floating agent button that opens a chat window with the remote agent.
17608
+ *
17609
+ * @public exported from `@promptbook/components`
17610
+ */
17611
+ function PromptbookAgentIntegration(props) {
17612
+ const { agentUrl, formfactor = 'seamless', meta, onOpenChange, className, style } = props;
17613
+ if (just(false)) ;
17614
+ else if (formfactor === 'seamless') {
17615
+ return jsxRuntime.jsx(PromptbookAgentSeamlessIntegration, { agentUrl, meta, onOpenChange, className, style });
17616
+ }
17617
+ else if (formfactor === 'book') {
17618
+ return jsxRuntime.jsx("iframe", { src: agentUrl + '/book?headless', className: className, style: style });
17619
+ }
17620
+ else if (formfactor === 'chat') {
17621
+ return jsxRuntime.jsx("iframe", { src: agentUrl + '/chat?headless', className: className, style: style });
17622
+ }
17623
+ else if (formfactor === 'profile') {
17624
+ return jsxRuntime.jsx("iframe", { src: agentUrl + '?headless', className: className, style: style });
17625
+ }
17626
+ else {
17627
+ throw new Error(`PromptbookAgentIntegration: Unsupported formfactor "${formfactor}"`);
17628
+ }
17098
17629
  }
17099
17630
 
17100
17631
  /**
@@ -17397,7 +17928,7 @@
17397
17928
  exports.PROMPTBOOK_ENGINE_VERSION = PROMPTBOOK_ENGINE_VERSION;
17398
17929
  exports.PauseIcon = PauseIcon;
17399
17930
  exports.PlayIcon = PlayIcon;
17400
- exports.PromptbookAgent = PromptbookAgent;
17931
+ exports.PromptbookAgentIntegration = PromptbookAgentIntegration;
17401
17932
  exports.PromptbookQrCode = PromptbookQrCode;
17402
17933
  exports.RANDOM_FLOW = RANDOM_FLOW;
17403
17934
  exports.ResetIcon = ResetIcon;