|
|
|
|
|
.status-bar { |
|
|
padding: 12px 24px; |
|
|
background: var(--primary-50); |
|
|
border-bottom: 1px solid var(--primary-200); |
|
|
font-size: 13px; |
|
|
font-weight: 500; |
|
|
color: var(--primary-700); |
|
|
display: none; |
|
|
} |
|
|
|
|
|
.status-bar.show { |
|
|
display: block; |
|
|
} |
|
|
|
|
|
.status-bar.error { |
|
|
background: var(--error-50); |
|
|
border-color: var(--error-200); |
|
|
color: var(--error-700); |
|
|
} |
|
|
|
|
|
.status-bar.success { |
|
|
background: var(--success-50); |
|
|
border-color: var(--success-200); |
|
|
color: var(--success-700); |
|
|
} |
|
|
|
|
|
.status-bar.warning { |
|
|
background: var(--warning-50); |
|
|
border-color: var(--warning-200); |
|
|
color: var(--warning-700); |
|
|
} |
|
|
|
|
|
.progress-container { |
|
|
padding: 0 24px 16px; |
|
|
display: none; |
|
|
} |
|
|
|
|
|
.progress-container.show { |
|
|
display: block; |
|
|
} |
|
|
|
|
|
.progress-bar { |
|
|
width: 100%; |
|
|
height: 6px; |
|
|
background: var(--gray-200); |
|
|
border-radius: var(--radius-sm); |
|
|
overflow: hidden; |
|
|
} |
|
|
|
|
|
.progress-fill { |
|
|
height: 100%; |
|
|
background: linear-gradient(90deg, var(--primary-500), var(--primary-600)); |
|
|
width: 0%; |
|
|
transition: width 0.3s ease; |
|
|
border-radius: var(--radius-sm); |
|
|
} |
|
|
|
|
|
|
|
|
.image-upload { |
|
|
position: relative; |
|
|
background: white; |
|
|
border: 2px dashed var(--gray-300); |
|
|
border-radius: 16px; |
|
|
padding: 24px; |
|
|
text-align: center; |
|
|
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); |
|
|
cursor: pointer; |
|
|
} |
|
|
|
|
|
.image-upload:hover { |
|
|
border-color: var(--primary-400); |
|
|
background: var(--primary-50); |
|
|
transform: translateY(-1px); |
|
|
box-shadow: 0 4px 12px rgba(14, 165, 233, 0.15); |
|
|
} |
|
|
|
|
|
.image-upload.has-image { |
|
|
border-style: solid; |
|
|
border-color: var(--success-500); |
|
|
background: var(--success-50); |
|
|
} |
|
|
|
|
|
.image-upload.drag-over { |
|
|
border-color: var(--primary-500); |
|
|
background: var(--primary-100); |
|
|
transform: scale(1.02); |
|
|
box-shadow: 0 8px 24px rgba(14, 165, 233, 0.25); |
|
|
} |
|
|
|
|
|
.image-upload-text { |
|
|
margin-top: 12px; |
|
|
font-size: 14px; |
|
|
color: var(--gray-600); |
|
|
font-weight: 500; |
|
|
} |
|
|
|
|
|
.image-upload.has-image .image-upload-text { |
|
|
color: var(--success-700); |
|
|
} |
|
|
|
|
|
.image-upload-btn { |
|
|
display: inline-flex; |
|
|
align-items: center; |
|
|
gap: 12px; |
|
|
padding: 16px 24px; |
|
|
background: linear-gradient(135deg, var(--gray-50) 0%, var(--gray-100) 100%); |
|
|
color: var(--gray-700); |
|
|
border: 2px solid var(--gray-200); |
|
|
border-radius: 12px; |
|
|
cursor: pointer; |
|
|
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); |
|
|
font-size: 14px; |
|
|
font-weight: 600; |
|
|
letter-spacing: 0.01em; |
|
|
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.04); |
|
|
} |
|
|
|
|
|
.image-upload-btn:hover { |
|
|
background: linear-gradient(135deg, var(--primary-50) 0%, var(--primary-100) 100%); |
|
|
border-color: var(--primary-300); |
|
|
color: var(--primary-700); |
|
|
transform: translateY(-2px); |
|
|
box-shadow: 0 4px 12px rgba(14, 165, 233, 0.2); |
|
|
} |
|
|
|
|
|
.image-upload input { |
|
|
display: none; |
|
|
} |
|
|
|
|
|
.image-preview { |
|
|
margin-top: 20px; |
|
|
max-width: 100%; |
|
|
max-height: 240px; |
|
|
border-radius: 12px; |
|
|
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12); |
|
|
object-fit: cover; |
|
|
border: 3px solid white; |
|
|
} |
|
|
|
|
|
|
|
|
.expandable-message { |
|
|
position: relative; |
|
|
} |
|
|
|
|
|
.expand-toggle { |
|
|
display: inline-flex; |
|
|
align-items: center; |
|
|
gap: 6px; |
|
|
padding: 4px 8px; |
|
|
background: var(--gray-100); |
|
|
border: 1px solid var(--gray-200); |
|
|
border-radius: 6px; |
|
|
color: var(--gray-600); |
|
|
font-size: 12px; |
|
|
font-weight: 500; |
|
|
cursor: pointer; |
|
|
transition: all 0.2s ease; |
|
|
margin-left: 8px; |
|
|
vertical-align: middle; |
|
|
} |
|
|
|
|
|
.expand-toggle:hover { |
|
|
background: var(--gray-200); |
|
|
border-color: var(--gray-300); |
|
|
color: var(--gray-700); |
|
|
} |
|
|
|
|
|
.expand-toggle i { |
|
|
transition: transform 0.2s ease; |
|
|
} |
|
|
|
|
|
.expand-toggle.expanded i { |
|
|
transform: rotate(180deg); |
|
|
} |
|
|
|
|
|
.expandable-content { |
|
|
max-height: 0; |
|
|
overflow: hidden; |
|
|
transition: max-height 0.3s cubic-bezier(0.4, 0, 0.2, 1); |
|
|
margin-top: 12px; |
|
|
background: var(--gray-50); |
|
|
border-radius: 8px; |
|
|
border: 1px solid var(--gray-200); |
|
|
} |
|
|
|
|
|
.expandable-content.expanded { |
|
|
max-height: 400px; |
|
|
overflow-y: auto; |
|
|
} |
|
|
|
|
|
|
|
|
.expandable-content::-webkit-scrollbar { |
|
|
width: 6px; |
|
|
} |
|
|
|
|
|
.expandable-content::-webkit-scrollbar-track { |
|
|
background: var(--gray-100); |
|
|
border-radius: 3px; |
|
|
} |
|
|
|
|
|
.expandable-content::-webkit-scrollbar-thumb { |
|
|
background: var(--gray-400); |
|
|
border-radius: 3px; |
|
|
} |
|
|
|
|
|
.expandable-content::-webkit-scrollbar-thumb:hover { |
|
|
background: var(--gray-500); |
|
|
} |
|
|
|
|
|
.expandable-content-inner { |
|
|
padding: 16px; |
|
|
} |
|
|
|
|
|
.prompt-conversation { |
|
|
display: flex; |
|
|
flex-direction: column; |
|
|
gap: 12px; |
|
|
} |
|
|
|
|
|
.prompt-message { |
|
|
background: white; |
|
|
border-radius: 6px; |
|
|
padding: 12px; |
|
|
border-left: 3px solid var(--gray-300); |
|
|
} |
|
|
|
|
|
.prompt-message.system { |
|
|
border-left-color: var(--warning-500); |
|
|
} |
|
|
|
|
|
.prompt-message.user { |
|
|
border-left-color: var(--primary-500); |
|
|
} |
|
|
|
|
|
.prompt-message.assistant { |
|
|
border-left-color: var(--success-500); |
|
|
} |
|
|
|
|
|
.prompt-role { |
|
|
font-size: 11px; |
|
|
font-weight: 600; |
|
|
text-transform: uppercase; |
|
|
color: var(--gray-500); |
|
|
margin-bottom: 6px; |
|
|
letter-spacing: 0.5px; |
|
|
} |
|
|
|
|
|
.prompt-message.system .prompt-role { |
|
|
color: var(--warning-600); |
|
|
} |
|
|
|
|
|
.prompt-message.user .prompt-role { |
|
|
color: var(--primary-600); |
|
|
} |
|
|
|
|
|
.prompt-message.assistant .prompt-role { |
|
|
color: var(--success-600); |
|
|
} |
|
|
|
|
|
.prompt-content { |
|
|
font-size: 13px; |
|
|
line-height: 1.4; |
|
|
color: var(--gray-700); |
|
|
white-space: pre-wrap; |
|
|
word-break: break-word; |
|
|
} |
|
|
|
|
|
.prompt-content pre { |
|
|
background: var(--gray-50); |
|
|
border: 1px solid var(--gray-200); |
|
|
border-radius: 4px; |
|
|
padding: 8px; |
|
|
margin: 8px 0; |
|
|
font-size: 12px; |
|
|
overflow-x: auto; |
|
|
} |
|
|
|
|
|
.prompt-content code { |
|
|
background: var(--gray-100); |
|
|
padding: 2px 4px; |
|
|
border-radius: 3px; |
|
|
font-size: 12px; |
|
|
font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace; |
|
|
} |
|
|
|
|
|
.prompt-content pre code { |
|
|
background: transparent; |
|
|
padding: 0; |
|
|
border-radius: 0; |
|
|
} |
|
|
|
|
|
.prompt-description { |
|
|
font-size: 12px; |
|
|
color: var(--gray-500); |
|
|
margin-bottom: 8px; |
|
|
font-style: italic; |
|
|
} |
|
|
|
|
|
.prompt-image { |
|
|
background: var(--gray-100); |
|
|
border: 1px dashed var(--gray-300); |
|
|
border-radius: 4px; |
|
|
padding: 8px 12px; |
|
|
font-size: 12px; |
|
|
color: var(--gray-600); |
|
|
text-align: center; |
|
|
margin: 4px 0; |
|
|
} |
|
|
|
|
|
|
|
|
.loading-dots::after { |
|
|
content: ''; |
|
|
animation: dots 1.5s steps(5, end) infinite; |
|
|
} |
|
|
|
|
|
@keyframes dots { |
|
|
0%, 20% { color: rgba(0,0,0,0); text-shadow: .25em 0 0 rgba(0,0,0,0), .5em 0 0 rgba(0,0,0,0); } |
|
|
40% { color: var(--gray-500); text-shadow: .25em 0 0 rgba(0,0,0,0), .5em 0 0 rgba(0,0,0,0); } |
|
|
60% { text-shadow: .25em 0 0 var(--gray-500), .5em 0 0 rgba(0,0,0,0); } |
|
|
80%, 100% { text-shadow: .25em 0 0 var(--gray-500), .5em 0 0 var(--gray-500); } |
|
|
} |
|
|
|
|
|
|
|
|
.streaming-indicator { |
|
|
display: inline-flex; |
|
|
align-items: center; |
|
|
gap: 8px; |
|
|
padding: 8px 12px; |
|
|
background: var(--primary-50); |
|
|
border: 1px solid var(--primary-200); |
|
|
border-radius: var(--radius-md); |
|
|
font-size: 13px; |
|
|
color: var(--primary-700); |
|
|
margin: 8px 0; |
|
|
} |
|
|
|
|
|
.execution-spinner { |
|
|
display: inline-flex; |
|
|
align-items: center; |
|
|
gap: 8px; |
|
|
padding: 8px 12px; |
|
|
background: var(--warning-50); |
|
|
border: 1px solid var(--warning-200); |
|
|
border-radius: var(--radius-md); |
|
|
font-size: 13px; |
|
|
color: var(--warning-700); |
|
|
margin: 8px 0; |
|
|
} |
|
|
|
|
|
.spinner { |
|
|
width: 16px; |
|
|
height: 16px; |
|
|
border: 2px solid transparent; |
|
|
border-top: 2px solid currentColor; |
|
|
border-radius: 50%; |
|
|
animation: spin 0.8s linear infinite; |
|
|
} |
|
|
|
|
|
@keyframes spin { |
|
|
0% { transform: rotate(0deg); } |
|
|
100% { transform: rotate(360deg); } |
|
|
} |
|
|
|
|
|
.streaming-text { |
|
|
background: var(--primary-50); |
|
|
padding: 2px 6px; |
|
|
border-radius: var(--radius-sm); |
|
|
border-left: 3px solid var(--primary-500); |
|
|
animation: pulse-blue 1.5s ease-in-out infinite; |
|
|
min-height: 20px; |
|
|
display: block; |
|
|
margin-top: 8px; |
|
|
} |
|
|
|
|
|
@keyframes pulse-blue { |
|
|
0%, 100% { background-color: var(--primary-50); } |
|
|
50% { background-color: var(--primary-100); } |
|
|
} |
|
|
|
|
|
.typing-indicator { |
|
|
display: inline; |
|
|
color: var(--primary-600); |
|
|
font-weight: bold; |
|
|
} |
|
|
|
|
|
.typing-indicator::after { |
|
|
content: '|'; |
|
|
animation: blink 1s infinite; |
|
|
} |
|
|
|
|
|
@keyframes blink { |
|
|
0%, 50% { opacity: 1; } |
|
|
51%, 100% { opacity: 0; } |
|
|
} |