/* Chat Messages Styling - Odin-inspired clean design */

/* Chat Messages Container - Scrollable area */
.chat-messages-container {
  min-height: 150px; /* Start small */
  max-height: 600px; /* Max height before scrolling */
  overflow-y: auto;
  padding: 16px;
  background-color: var(--odin-bg-primary);
  border-radius: 10px;
}

/* Chat Message Container - handles alignment */
.chat-message-container {
  display: flex;
  flex-direction: column;
  margin-bottom: 8px;
}

.chat-message-container.user-message {
  align-items: flex-end;
}

.chat-message-container:not(.user-message) {
  align-items: flex-start;
}

/* Chat Message Row */
.chat-message-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  width: 100%;
}

.chat-message-row.user {
  justify-content: flex-end;
}

.chat-message-row:not(.user) {
  justify-content: flex-start;
}

/* Chat Message Bubble */
.chat-message-bubble {
  position: relative;
  padding: 12px 0;
  border-radius: 10px;
  word-wrap: break-word;
  width: auto;
}

.chat-message-bubble.user {
  min-width: 90%;
  max-width: 90%;
  padding: 12px;
  background-color: var(--odin-bg-agent-bar);
  color: var(--odin-bg-primary);
  border-radius: 12px;
}

.chat-message-bubble:not(.user) {
  max-width: 100%;
  background-color: var(--odin-bg-primary);
  color: var(--odin-fg-secondary);
  border-radius: 6px;
}

/* Context Labels */
.chat-context-labels {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}

.chat-context-label {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 500;
  width: fit-content;
  background-color: var(--odin-bg-primary);
  color: var(--odin-fg-primary);
}

.chat-message-bubble:not(.user) .chat-context-label {
  background-color: var(--odin-bg-tertiary);
  border: 1px solid var(--odin-bg-tertiary);
  color: var(--odin-fg-tertiary);
}

/* Markdown Content Styling */
.markdown-content {
  font-size: 14px;
  line-height: 1.6;
}

.chat-message-bubble.user .markdown-content {
  color: var(--odin-bg-primary);
}

.chat-message-bubble:not(.user) .markdown-content {
  color: var(--odin-fg-primary);
}

.markdown-content p {
  margin: 0 0 12px 0;
}

.markdown-content p:last-child {
  margin-bottom: 0;
}

.markdown-content strong {
  font-weight: 600;
}

.markdown-content em {
  font-style: italic;
}

.markdown-content code {
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.9em;
  font-family: var(--font-mono);
  color: var(--odin-fg-secondary);
}

.chat-message-bubble.user .markdown-content code {
  background-color: rgba(255, 255, 255, 0.2);
  color: var(--odin-bg-primary);
}

.chat-message-bubble:not(.user) .markdown-content code {
  color: var(--odin-fg-tertiary);
}

.markdown-content pre {
  padding: 12px 16px;
  border-radius: 6px;
  overflow-x: auto;
  margin: 12px 0;
  line-height: 1.5;
}

.chat-message-bubble.user .markdown-content pre {
  background-color: rgba(0, 0, 0, 0.2);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

.chat-message-bubble:not(.user) .markdown-content pre {
  background-color: var(--odin-bg-card);
  border: 1px solid var(--odin-bg-tertiary);
}

.markdown-content pre code {
  background-color: transparent;
  padding: 0;
}

.chat-message-bubble.user .markdown-content pre code {
  color: var(--odin-bg-primary);
}

.chat-message-bubble:not(.user) .markdown-content pre code {
  color: var(--odin-fg-secondary);
}

.markdown-content h1,
.markdown-content h2,
.markdown-content h3,
.markdown-content h4,
.markdown-content h5,
.markdown-content h6 {
  margin: 16px 0 8px 0;
  font-weight: 600;
}

.markdown-content h1:first-child,
.markdown-content h2:first-child,
.markdown-content h3:first-child {
  margin-top: 0;
}

.markdown-content p {
  margin: 8px 0;
  line-height: 1.6;
}

.markdown-content p:first-child {
  margin-top: 0;
}

.markdown-content p:last-child {
  margin-bottom: 0;
}

.markdown-content ul,
.markdown-content ol {
  margin: 12px 0;
  padding-left: 24px;
  line-height: 1.6;
}

.markdown-content li {
  margin: 4px 0;
}

.markdown-content blockquote {
  margin: 12px 0;
  padding-left: 16px;
  border-left: 3px solid;
}

.chat-message-bubble.user .markdown-content blockquote {
  border-left-color: rgba(255, 255, 255, 0.3);
  color: rgba(255, 255, 255, 0.9);
}

.chat-message-bubble:not(.user) .markdown-content blockquote {
  border-left-color: var(--odin-bg-tertiary);
  color: var(--odin-fg-tertiary);
}

.markdown-content a {
  text-decoration: underline;
}

.chat-message-bubble.user .markdown-content a {
  color: var(--odin-bg-agent-bar);
}

.chat-message-bubble:not(.user) .markdown-content a {
  color: var(--odin-bg-agent-bar); /* brand-glint-500 */
}

.markdown-content .mention {
    @apply font-semibold text-(--odin-info);
    background-color: rgba(30, 174, 235, 0.1);
    padding: 2px 4px;
    border-radius: 3px;
    cursor: help;
}

.markdown-content .page-mention {
    @apply font-semibold text-(--odin-info);
    text-decoration: underline;
    cursor: pointer;
}

.markdown-content .page-mention:hover {
    @apply text-(--odin-info);
    opacity: 0.8;
}

.markdown-content .page-mention-invalid {
    @apply font-semibold text-(--odin-fg-tertiary);
    font-style: italic;
}

.markdown-content a:hover {
  opacity: 0.8;
}

/* Agent Messages - Non-user messages with headers, metadata, etc. */
.enhanced-message:not(.user-message) {
  background-color: var(--odin-bg-card);
  border-radius: 8px;
  margin-bottom: 12px;
  overflow: hidden;
  transition: all 0.2s ease;
}

.enhanced-message:not(.user-message):hover {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

/* Message Header (for non-user messages) */
.message-header {
  padding: 12px 16px;
  background-color: var(--odin-bg-card);
  border-bottom: 1px solid var(--odin-bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.message-type-badge {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 4px 8px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.message-header .timestamp {
  font-size: 12px;
  color: var(--odin-fg-tertiary);
}

/* Status Indicator */
.status-indicator {
  font-size: 11px;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.status-pending {
  color: var(--odin-warning-content);
}

.status-success {
  color: var(--odin-success-content);
}

.status-error {
  color: var(--odin-error-content);
}

/* Tool Call Container - Collapsible Odin Style */
.tool-call-container {
  background-color: var(--odin-bg-card);
  border-radius: 10px;
  /* margin-bottom: 8px; */
  overflow: visible !important;
}

.tool-call-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 16px 4px 4px;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.tool-call-header-row:hover {
  background-color: var(--odin-bg-card);
}

.tool-call-header-left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
}

/* Tool icon container - shows status icon by default, caret on hover */
.tool-icon-container {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
}

.tool-status-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  transition: opacity 0.2s ease;
}

.tool-status-icon svg {
  width: 16px;
  height: 16px;
}

/* Status icon colors */
.tool-status-icon.status-pending svg {
  color: var(--odin-warning);
}

.tool-status-icon.status-success svg {
  color: var(--odin-success);
}

.tool-status-icon.status-error svg {
  color: var(--odin-error);
}

.tool-caret-icon {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: all 0.2s ease;
  color: var(--odin-fg-secondary);
}

.tool-caret-icon svg {
  width: 16px;
  height: 16px;
}

/* On hover, hide status icon and show caret */
.tool-call-header-row:hover .tool-status-icon {
  opacity: 0;
}

.tool-call-header-row:hover .tool-caret-icon {
  opacity: 1;
}

/* Rotate caret when expanded */
.tool-call-container.expanded .tool-caret-icon {
  transform: rotate(90deg);
}

.tool-name-text {
  font-size: 12px;
  font-weight: 500;
  color: var(--odin-fg-secondary);
  font-family: var(--input-mono);
}

.tool-call-expanded-status {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 16px;
}

.tool-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 600;
}

.tool-status-badge.status-pending {
  color: var(--odin-info);
}

.tool-status-badge.status-success {
  color: var(--odin-success);
}

.tool-status-badge.status-error {
  color: var(--odin-error);
}

.tool-timestamp {
  font-size: 12px;
  color: var(--odin-fg-tertiary);
  font-family: var(--font-mono);
}

/* Tool Call Expanded Content */
.tool-call-expanded-content {
  overflow: visible !important;
}

.tool-detail-section {
  padding: 16px;
  border-bottom: 1px solid var(--odin-bg-tertiary);
}

.tool-detail-section:last-of-type {
  border-bottom: none;
}

.tool-detail-heading {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--odin-fg-tertiary);
  letter-spacing: 0.5px;
  margin-bottom: 12px;
}

.tool-detail-content {
  font-size: 13px;
  line-height: 1.6;
  color: var(--odin-fg-primary);
}

.tool-detail-content.error-content {
  color: var(--odin-error);
}

.tool-detail-content pre {
  margin: 0;
  padding: 12px;
  background-color: var(--odin-bg-card);
  border: 1px solid var(--odin-bg-tertiary);
  border-radius: 6px;
  overflow-x: auto;
  font-family: var(--input-mono);
  font-size: 12px;
}

.tool-detail-content code {
  font-family: var(--input-mono);
  background-color: transparent;
}

.tool-detail-metadata {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.metadata-item {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-size: 13px;
}

.metadata-item .metadata-label {
  font-weight: 600;
  color: var(--odin-fg-tertiary);
  min-width: 80px;
}

.metadata-item .metadata-value {
  color: var(--odin-fg-primary);
  font-family: var(--input-mono);
}

/* Tool Actions */
.tool-actions {
  padding: 12px 16px;
  border-top: 1px solid var(--odin-bg-tertiary);
  display: flex;
  gap: 8px;
  background-color: var(--odin-bg-card);
}

.tool-action-btn {
  padding: 6px 12px;
  border-radius: 6px;
  border: 1px solid var(--odin-bg-tertiary);
  background-color: var(--odin-bg-card);
  color: var(--odin-fg-secondary);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.tool-action-btn:hover {
  background-color: var(--odin-bg-card);
  border-color: var(--odin-fg-tertiary);
  color: var(--odin-fg-primary);
}

.success-message,
.error-message {
  padding: 12px;
  border-radius: 6px;
  margin-bottom: 12px;
}

.success-message {
  border: 1px solid var(--odin-success);
  color: var(--odin-success-content);
}

.error-message {
  border: 1px solid var(--odin-error);
  color: var(--odin-error-content);
}

.success-message .font-semibold,
.error-message .font-semibold {
  font-weight: 600;
  margin-bottom: 8px;
}

/* Expandable Details */
.expandable-details {
  margin-top: 12px;
}

.expandable-details h4 {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--odin-fg-tertiary);
  margin-bottom: 8px;
}

.arguments-section,
.result-section,
.metadata-section {
  margin-bottom: 16px;
}

.metadata-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.metadata-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-size: 13px;
}

.metadata-label {
  font-weight: 600;
  color: var(--odin-fg-tertiary);
  min-width: 80px;
}

.metadata-value {
  color: var(--odin-fg-primary);
  font-family: var(--input-mono);
}

/* Message Actions */
.message-actions {
  padding: 12px 16px;
  border-top: 1px solid var(--odin-bg-tertiary);
  display: flex;
  gap: 8px;
  background-color: var(--odin-bg-card);
}

.message-actions button {
  padding: 6px 12px;
  border-radius: 4px;
  border: 1px solid var(--odin-bg-tertiary);
  background-color: var(--odin-bg-card);
  color: var(--odin-fg-secondary);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s ease;
}

.message-actions button:hover {
  background-color: var(--odin-bg-card);
  border-color: var(--odin-fg-tertiary);
}

/* Context Section Styles */
.special-hidden-context-section {
  margin-top: 1rem;
  border-radius: 10px;
  background-color: var(--odin-bg-tertiary);
  display: none; /* Hidden by default */
}

/* Global Context Toggle Switch */
.context-toggle-label {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  cursor: pointer;
  font-size: 0.875rem;
  color: var(--odin-fg-tertiary);
  user-select: none;
}

.context-toggle-input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.context-toggle-switch {
  position: relative;
  width: 44px;
  height: 24px;
  background-color: var(--odin-bg-card);
  border-radius: 12px;
  transition: background-color 0.2s ease;
  flex-shrink: 0;
}

.context-toggle-thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  background-color: var(--odin-bg-primary);
  border-radius: 50%;
  transition: transform 0.2s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.context-toggle-input:checked ~ .context-toggle-switch {
  background-color: var(--odin-fg-tertiary) !important;
}

.context-toggle-input:checked ~ .context-toggle-switch .context-toggle-thumb {
  transform: translateX(20px) !important;
}

.context-toggle-text {
  font-weight: 500;
  color: var(--odin-fg-tertiary);
  transition: color 0.2s ease;
}

.context-toggle {
  width: 100%;
  padding: 0.75rem 1rem;
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--odin-fg-tertiary);
  transition: background-color 0.2s ease;
}

.context-toggle:hover {
  background-color: var(--odin-bg-tertiary);
}

.context-icon {
  font-size: 1rem;
}

/* .chat-context-label {
  flex: 1;
  font-weight: 500;
} */

.context-caret {
  font-size: 0.75rem;
  transition: transform 0.2s ease;
}

.context-content {
  padding: 0 1rem 1rem 1rem;
  border-top: 1px solid var(--odin-bg-tertiary);
}

.context-item {
  margin-bottom: 1rem;
}

.context-item:last-child {
  margin-bottom: 0;
}

.context-tag {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--odin-fg-secondary);
  margin: 0 0 0.5rem 0;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.context-text {
  font-size: 0.875rem;
  color: var(--odin-fg-secondary);
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
}

/* Debug Section (for messages that don't match our current types) */
.debug-section-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--odin-warning-content);
  margin: 0 0 1rem 0;
}

.debug-message-item {
  margin-bottom: 1.5rem;
  padding: 1rem;
  background-color: var(--odin-bg-tertiary);
  border: 1px solid var(--odin-warning);
  border-radius: 6px;
}

.debug-message-item:last-child {
  margin-bottom: 0;
}

.debug-message-type {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--odin-warning-content);
  margin: 0 0 0.75rem 0;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.debug-message-content {
  font-size: 0.875rem;
  color: var(--odin-warning-content);
  line-height: 1.5;
}

.debug-message-content strong {
  font-weight: 600;
  color: var(--odin-warning-content);
}

.debug-code {
  border-radius: 4px;
  padding: 0.75rem;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--odin-warning-content);
  overflow-x: auto;
  white-space: pre-wrap;
  word-break: break-all;
  margin: 0.5rem 0;
}

/* Control Message Request (PR requests, stop requests, etc.) */
.control-message-request {
  background-color: var(--odin-bg-card);
  border: 1px solid var(--brand-coal-300);
  border-radius: 8px;
  padding: 16px 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--odin-fg-secondary);
  font-size: 0.9375rem;
  line-height: 1.5;
}

.control-message-request svg {
  flex-shrink: 0;
}

.control-message-request.control-message-error svg {
  color: var(--odin-error);
}

/* PR Result Items */
.pr-results-list {
  margin-top: 12px;
  padding-left: 0;
  list-style: none;
}

.pr-result-item {
  display: flex;
  align-items: center;
  gap: 12px;
}

.pr-result-item:last-child {
  border-bottom: none;
}

.pr-result-item .repository-name {
  font-weight: 500;
  color: var(--odin-fg-secondary);
  flex-shrink: 0;
}

.pr-result-item .pr-link {
  color: var(--odin-info);
  text-decoration: none;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
}

.pr-result-item .pr-link:hover {
  text-decoration: underline;
}