.game-page { height: 100vh; display: flex; flex-direction: column; background: #0d0d0d; } .game-error { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; gap: 1rem; } .game-header { display: flex; align-items: center; gap: 1rem; padding: 1rem 1.5rem; background: #1a1a1a; border-bottom: 1px solid #333; } .back-btn { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: #2a2a2a; border-radius: 10px; color: #ccc; text-decoration: none; font-size: 1.2rem; transition: background 0.2s; } .back-btn:hover { background: #333; } .header-info { flex: 1; } .header-info h1 { font-size: 1.1rem; margin: 0; color: #fff; } .header-protagonist { font-size: 0.85rem; color: #888; } .header-stats { display: flex; gap: 0.5rem; } .stat-badge { padding: 0.4rem 0.75rem; border-radius: 20px; font-size: 0.8rem; font-weight: 500; } .stat-badge.health { background: rgba(255, 107, 107, 0.15); color: #ff8a8a; } .stat-badge.location { background: rgba(102, 126, 234, 0.15); color: #a0b4ff; } .game-content { flex: 1; display: flex; flex-direction: column; overflow: hidden; } .messages-container { flex: 1; overflow-y: auto; padding: 1.5rem; display: flex; flex-direction: column; gap: 1rem; } .message { max-width: 85%; animation: fadeIn 0.3s ease; } @keyframes fadeIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } } .message.user { align-self: flex-end; } .message.assistant { align-self: flex-start; } .message-content { padding: 1rem 1.25rem; border-radius: 16px; line-height: 1.6; } .message.user .message-content { background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); color: white; border-bottom-right-radius: 4px; } .message.assistant .message-content { background: #1f1f1f; color: #ddd; border: 1px solid #333; border-bottom-left-radius: 4px; } .message-content p { margin: 0; } .message-content p + p { margin-top: 0.75rem; } /* Markdown стили */ .message-content strong { font-weight: 700; color: #fff; } .message-content em { font-style: italic; color: #bbb; } .message-content ul, .message-content ol { margin: 0.5rem 0; padding-left: 1.5rem; } .message-content li { margin: 0.25rem 0; } .message-content blockquote { border-left: 3px solid #667eea; padding-left: 1rem; margin: 0.75rem 0; color: #aaa; font-style: italic; } .message-content code { background: #2a2a2a; padding: 0.15rem 0.4rem; border-radius: 4px; font-family: monospace; font-size: 0.9em; } .message-content hr { border: none; border-top: 1px solid #444; margin: 1rem 0; } .message-time { display: block; font-size: 0.7rem; color: #666; margin-top: 0.35rem; padding: 0 0.5rem; } .message.user .message-time { text-align: right; } .message.loading .message-content { padding: 1.25rem 1.5rem; } .typing-indicator { display: flex; gap: 4px; } .typing-indicator span { width: 8px; height: 8px; background: #667eea; border-radius: 50%; animation: typing 1.4s infinite ease-in-out; } .typing-indicator span:nth-child(1) { animation-delay: 0s; } .typing-indicator span:nth-child(2) { animation-delay: 0.2s; } .typing-indicator span:nth-child(3) { animation-delay: 0.4s; } @keyframes typing { 0%, 60%, 100% { transform: translateY(0); opacity: 0.4; } 30% { transform: translateY(-8px); opacity: 1; } } .error-message { display: flex; align-items: center; justify-content: space-between; padding: 0.75rem 1rem; background: rgba(255, 107, 107, 0.1); border: 1px solid rgba(255, 107, 107, 0.3); border-radius: 10px; color: #ff8a8a; font-size: 0.9rem; } .error-message button { background: none; border: none; color: #ff8a8a; cursor: pointer; padding: 0.25rem; } .quick-actions { display: flex; gap: 0.5rem; padding: 0.75rem 1.5rem; overflow-x: auto; background: #131313; } .quick-actions button { padding: 0.5rem 1rem; background: #222; border: 1px solid #333; border-radius: 20px; color: #aaa; font-size: 0.85rem; cursor: pointer; white-space: nowrap; transition: all 0.2s; } .quick-actions button:hover { background: #2a2a2a; color: #fff; border-color: #667eea; } .input-container { display: flex; align-items: center; gap: 0.75rem; padding: 1rem 1.5rem 1.5rem; background: #131313; border-top: 1px solid #222; } .input-container textarea { flex: 1; min-height: 50px; max-height: 120px; padding: 0.875rem 1rem; background: #1a1a1a; border: 2px solid #333; border-radius: 12px; color: white; font-size: 1rem; font-family: inherit; resize: none; transition: border-color 0.2s; } .input-container textarea:focus { outline: none; border-color: #667eea; } .input-container textarea::placeholder { color: #666; } .send-btn { width: 50px; min-width: 50px; height: 50px; background: linear-gradient(135deg, #667eea 0%, #764ba2 100%); border: none; border-radius: 12px; color: white; font-size: 1.25rem; cursor: pointer; transition: transform 0.2s, opacity 0.2s; flex-shrink: 0; } .send-btn:hover:not(:disabled) { transform: scale(1.05); } .send-btn:disabled { opacity: 0.5; cursor: not-allowed; } /* Скроллбар */ .messages-container::-webkit-scrollbar { width: 6px; } .messages-container::-webkit-scrollbar-track { background: transparent; } .messages-container::-webkit-scrollbar-thumb { background: #333; border-radius: 3px; } .messages-container::-webkit-scrollbar-thumb:hover { background: #444; } @media (max-width: 600px) { .game-header { padding: 0.75rem 1rem; } .header-stats { display: none; } .messages-container { padding: 1rem; } .message { max-width: 95%; } .quick-actions { padding: 0.5rem 1rem; } .input-container { padding: 0.75rem 1rem 1rem; } }