| | .App { |
| | display: flex; |
| | justify-content: center; |
| | align-items: center; |
| | min-height: 100vh; |
| | padding: 20px; |
| | direction: rtl; |
| | font-family: 'Segoe UI', 'Arial', 'Tahoma', 'Cairo', 'Noto Sans Arabic', sans-serif; |
| | } |
| |
|
| | .chat-container { |
| | width: 100%; |
| | max-width: 900px; |
| | height: 90vh; |
| | background: white; |
| | border-radius: 20px; |
| | box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3); |
| | display: flex; |
| | flex-direction: column; |
| | overflow: hidden; |
| | } |
| |
|
| | .chat-header { |
| | background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); |
| | color: white; |
| | padding: 25px; |
| | text-align: center; |
| | box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); |
| | } |
| |
|
| | .chat-header h1 { |
| | margin: 0 0 10px 0; |
| | font-size: 28px; |
| | font-weight: 600; |
| | } |
| |
|
| | .chat-header p { |
| | margin: 0 0 15px 0; |
| | opacity: 0.9; |
| | font-size: 14px; |
| | } |
| |
|
| | .messages-container { |
| | flex: 1; |
| | overflow-y: auto; |
| | padding: 20px; |
| | background: #f8f9fa; |
| | } |
| |
|
| | .welcome-message { |
| | text-align: center; |
| | padding: 60px 20px; |
| | color: #666; |
| | } |
| |
|
| | .welcome-message h2 { |
| | color: #333; |
| | margin-bottom: 15px; |
| | font-size: 24px; |
| | } |
| |
|
| | .welcome-message p { |
| | margin: 10px 0; |
| | font-size: 16px; |
| | } |
| |
|
| | .welcome-message .hint { |
| | font-size: 14px; |
| | color: #999; |
| | font-style: italic; |
| | } |
| |
|
| | .message { |
| | margin-bottom: 20px; |
| | display: flex; |
| | animation: fadeIn 0.3s ease; |
| | } |
| |
|
| | @keyframes fadeIn { |
| | from { |
| | opacity: 0; |
| | transform: translateY(10px); |
| | } |
| | to { |
| | opacity: 1; |
| | transform: translateY(0); |
| | } |
| | } |
| |
|
| | .message.user { |
| | justify-content: flex-start; |
| | } |
| |
|
| | .message.assistant { |
| | justify-content: flex-start; |
| | } |
| |
|
| | .message-content { |
| | max-width: 70%; |
| | padding: 15px 20px; |
| | border-radius: 18px; |
| | box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); |
| | } |
| |
|
| | .message.user .message-content { |
| | background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); |
| | color: white; |
| | border-bottom-left-radius: 4px; |
| | } |
| |
|
| | .message.assistant .message-content { |
| | background: white; |
| | color: #333; |
| | border-bottom-right-radius: 4px; |
| | } |
| |
|
| | .message-header { |
| | font-size: 12px; |
| | font-weight: 600; |
| | margin-bottom: 8px; |
| | opacity: 0.8; |
| | } |
| |
|
| | .message-text { |
| | font-size: 15px; |
| | line-height: 1.8; |
| | word-wrap: break-word; |
| | text-align: right; |
| | direction: rtl; |
| | } |
| |
|
| | .message-text.error { |
| | color: #d32f2f; |
| | } |
| |
|
| | .message-text p { |
| | margin: 0 0 10px 0; |
| | } |
| |
|
| | .message-text strong { |
| | font-weight: 700; |
| | } |
| |
|
| | .message-text ul, |
| | .message-text ol { |
| | padding-right: 20px; |
| | margin: 10px 0; |
| | } |
| |
|
| | .message-text li { |
| | margin-bottom: 6px; |
| | } |
| |
|
| | .typing-indicator { |
| | display: inline-block; |
| | } |
| |
|
| | .typing-indicator::after { |
| | content: '...'; |
| | animation: dots 1.5s steps(4, end) infinite; |
| | } |
| |
|
| | @keyframes dots { |
| | 0%, 20% { |
| | content: '.'; |
| | } |
| | 40% { |
| | content: '..'; |
| | } |
| | 60%, 100% { |
| | content: '...'; |
| | } |
| | } |
| |
|
| | .sources { |
| | margin-top: 12px; |
| | padding-top: 12px; |
| | border-top: 1px solid rgba(0, 0, 0, 0.1); |
| | font-size: 12px; |
| | } |
| |
|
| | .message.user .sources { |
| | border-top-color: rgba(255, 255, 255, 0.3); |
| | } |
| |
|
| | .sources strong { |
| | display: block; |
| | margin-bottom: 6px; |
| | opacity: 0.8; |
| | } |
| |
|
| | .sources ul { |
| | list-style: none; |
| | padding: 0; |
| | margin: 0; |
| | } |
| |
|
| | .sources li { |
| | padding: 4px 0; |
| | opacity: 0.9; |
| | display: flex; |
| | flex-direction: column; |
| | gap: 6px; |
| | } |
| |
|
| | .source-name { |
| | font-weight: 600; |
| | color: #333; |
| | } |
| |
|
| | .source-actions { |
| | display: flex; |
| | gap: 10px; |
| | } |
| |
|
| | .source-link { |
| | background: none; |
| | border: none; |
| | color: #4c6ef5; |
| | cursor: pointer; |
| | text-decoration: underline; |
| | font-size: 14px; |
| | font-weight: 600; |
| | padding: 0; |
| | direction: rtl; |
| | text-align: right; |
| | } |
| |
|
| | .source-link:hover { |
| | color: #2a48c5; |
| | } |
| |
|
| | .source-link.download { |
| | color: #2f9e44; |
| | } |
| |
|
| | .source-link.download:hover { |
| | color: #1b6d2f; |
| | } |
| |
|
| | .preview-panel { |
| | margin: 20px; |
| | padding: 15px; |
| | border: 1px solid #e0e0e0; |
| | border-radius: 12px; |
| | background: #fdfdfd; |
| | max-height: 300px; |
| | overflow: auto; |
| | direction: rtl; |
| | } |
| |
|
| | .preview-header { |
| | display: flex; |
| | justify-content: space-between; |
| | align-items: center; |
| | margin-bottom: 10px; |
| | } |
| |
|
| | .preview-header h3 { |
| | margin: 0; |
| | } |
| |
|
| | .preview-filename { |
| | font-size: 14px; |
| | color: #555; |
| | } |
| |
|
| | .close-preview { |
| | background: none; |
| | border: none; |
| | font-size: 22px; |
| | cursor: pointer; |
| | color: #ff4d4f; |
| | font-weight: bold; |
| | } |
| |
|
| | .close-preview:hover { |
| | color: #d9363e; |
| | } |
| |
|
| | .preview-content pre { |
| | white-space: pre-wrap; |
| | direction: rtl; |
| | text-align: right; |
| | margin: 0; |
| | font-size: 14px; |
| | background: #f8f9fa; |
| | padding: 10px; |
| | border-radius: 8px; |
| | } |
| |
|
| | .preview-content { |
| | min-height: 200px; |
| | display: flex; |
| | justify-content: center; |
| | align-items: center; |
| | } |
| |
|
| | .pdf-frame { |
| | width: 100%; |
| | height: 400px; |
| | border: none; |
| | border-radius: 8px; |
| | background: #fff; |
| | box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.05); |
| | } |
| |
|
| | .input-container { |
| | display: flex; |
| | padding: 20px; |
| | background: white; |
| | border-top: 1px solid #e0e0e0; |
| | gap: 10px; |
| | } |
| |
|
| | .message-input { |
| | flex: 1; |
| | padding: 15px 20px; |
| | border: 2px solid #e0e0e0; |
| | border-radius: 25px; |
| | font-size: 15px; |
| | outline: none; |
| | transition: border-color 0.3s ease; |
| | text-align: right; |
| | direction: rtl; |
| | } |
| |
|
| | .message-input:focus { |
| | border-color: #667eea; |
| | } |
| |
|
| | .message-input:disabled { |
| | background: #f5f5f5; |
| | cursor: not-allowed; |
| | } |
| |
|
| | .send-button { |
| | padding: 15px 30px; |
| | background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); |
| | color: white; |
| | border: none; |
| | border-radius: 25px; |
| | font-size: 15px; |
| | font-weight: 600; |
| | cursor: pointer; |
| | transition: transform 0.2s ease, box-shadow 0.2s ease; |
| | } |
| |
|
| | .send-button:hover:not(:disabled) { |
| | transform: translateY(-2px); |
| | box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4); |
| | } |
| |
|
| | .send-button:disabled { |
| | opacity: 0.6; |
| | cursor: not-allowed; |
| | transform: none; |
| | } |
| |
|
| | |
| | .messages-container::-webkit-scrollbar { |
| | width: 8px; |
| | } |
| |
|
| | .messages-container::-webkit-scrollbar-track { |
| | background: #f1f1f1; |
| | border-radius: 10px; |
| | } |
| |
|
| | .messages-container::-webkit-scrollbar-thumb { |
| | background: #888; |
| | border-radius: 10px; |
| | } |
| |
|
| | .messages-container::-webkit-scrollbar-thumb:hover { |
| | background: #555; |
| | } |
| |
|
| | |
| | @media (max-width: 768px) { |
| | .chat-container { |
| | height: 100vh; |
| | border-radius: 0; |
| | } |
| |
|
| | .message-content { |
| | max-width: 85%; |
| | } |
| |
|
| | .chat-header h1 { |
| | font-size: 24px; |
| | } |
| | } |
| |
|
| |
|
| |
|