:root { --bg-dark: #0a0a0a; --bg-panel: rgba(255, 115, 0, 0.1); --accent: #ff6600; --accent-glow: 0 0 12px #ff6600cc; --text-main: #e6e6e6; --text-fade: #999; --font-console: "IBM Plex Mono", monospace; } /* Light mode variables */ body { --bg-dark: #f5f5f5; --bg-panel: rgba(255, 115, 0, 0.05); --accent: #ff6600; --accent-glow: 0 0 12px #ff6600cc; --text-main: #1a1a1a; --text-fade: #666; } /* Dark mode variables */ body.dark { --bg-dark: #0a0a0a; --bg-panel: rgba(255, 115, 0, 0.1); --accent: #ff6600; --accent-glow: 0 0 12px #ff6600cc; --text-main: #e6e6e6; --text-fade: #999; } body { margin: 0; background: var(--bg-dark); color: var(--text-main); font-family: var(--font-console); height: 100vh; display: flex; justify-content: center; align-items: center; } #chat { width: 95%; max-width: 900px; height: 95vh; display: flex; flex-direction: column; border: 1px solid var(--accent); border-radius: 10px; box-shadow: var(--accent-glow); background: var(--bg-dark); overflow: hidden; } /* Header sections */ #model-select, #session-select, #status { display: flex; align-items: center; gap: 8px; padding: 8px 12px; border-bottom: 1px solid var(--accent); background-color: rgba(255, 102, 0, 0.05); } #status { justify-content: flex-start; border-top: 1px solid var(--accent); } label, select, button { font-family: var(--font-console); font-size: 0.9rem; color: var(--text-main); background: transparent; border: 1px solid var(--accent); border-radius: 4px; padding: 4px 8px; } button:hover, select:hover { box-shadow: 0 0 8px var(--accent); cursor: pointer; } #thinkingStreamBtn { background: rgba(138, 43, 226, 0.2); border-color: #8a2be2; } #thinkingStreamBtn:hover { box-shadow: 0 0 8px #8a2be2; background: rgba(138, 43, 226, 0.3); } /* Chat area */ #messages { flex: 1; padding: 16px; overflow-y: auto; display: flex; flex-direction: column; gap: 8px; scroll-behavior: smooth; } /* Messages */ .msg { max-width: 80%; padding: 10px 14px; border-radius: 8px; line-height: 1.4; word-wrap: break-word; box-shadow: 0 0 8px rgba(255,102,0,0.2); } .msg.user { align-self: flex-end; background: rgba(255,102,0,0.15); border: 1px solid var(--accent); } .msg.assistant { align-self: flex-start; background: rgba(255,102,0,0.08); border: 1px solid rgba(255,102,0,0.5); } .msg.system { align-self: center; font-size: 0.8rem; color: var(--text-fade); } /* Input bar */ #input { display: flex; border-top: 1px solid var(--accent); background: rgba(255, 102, 0, 0.05); padding: 10px; } #userInput { flex: 1; background: transparent; color: var(--text-main); border: 1px solid var(--accent); border-radius: 4px; padding: 8px; } #sendBtn { margin-left: 8px; } /* Relay status dot */ #status { display: flex; align-items: center; margin: 10px 0; gap: 8px; font-family: monospace; color: #f5f5f5; } #status-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; } @keyframes pulseGreen { 0% { box-shadow: 0 0 5px #00ff66; opacity: 0.9; } 50% { box-shadow: 0 0 20px #00ff99; opacity: 1; } 100% { box-shadow: 0 0 5px #00ff66; opacity: 0.9; } } .dot.ok { background: #00ff66; animation: pulseGreen 2s infinite ease-in-out; } /* Offline state stays solid red */ .dot.fail { background: #ff3333; box-shadow: 0 0 10px #ff3333; } /* Dropdown (session selector) styling */ select { background-color: var(--bg-dark); color: var(--text-main); border: 1px solid #b84a12; border-radius: 6px; padding: 4px 6px; font-size: 14px; } select option { background-color: var(--bg-dark); color: var(--text-main); } /* Hover/focus for better visibility */ select:focus, select:hover { outline: none; border-color: #ff7a33; background-color: var(--bg-panel); } /* Settings Modal */ .modal { display: none !important; position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 1000; } .modal.show { display: block !important; } .modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.8); backdrop-filter: blur(4px); z-index: 999; } .modal-content { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background: linear-gradient(180deg, rgba(255,102,0,0.1) 0%, rgba(10,10,10,0.95) 100%); border: 2px solid var(--accent); border-radius: 12px; box-shadow: var(--accent-glow), 0 0 40px rgba(255,102,0,0.3); min-width: 400px; max-width: 600px; max-height: 80vh; overflow-y: auto; z-index: 1001; } .modal-header { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px; border-bottom: 1px solid var(--accent); background: rgba(255,102,0,0.1); } .modal-header h3 { margin: 0; font-size: 1.2rem; color: var(--accent); } .close-btn { background: transparent; border: none; color: var(--accent); font-size: 1.5rem; cursor: pointer; padding: 0; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center; border-radius: 4px; } .close-btn:hover { background: rgba(255,102,0,0.2); box-shadow: 0 0 8px var(--accent); } .modal-body { padding: 20px; } .settings-section h4 { margin: 0 0 8px 0; color: var(--accent); font-size: 1rem; } .settings-desc { margin: 0 0 16px 0; color: var(--text-fade); font-size: 0.85rem; } .radio-group { display: flex; flex-direction: column; gap: 12px; } .radio-label { display: flex; flex-direction: column; padding: 12px; border: 1px solid rgba(255,102,0,0.3); border-radius: 6px; background: rgba(255,102,0,0.05); cursor: pointer; transition: all 0.2s; } .radio-label:hover { border-color: var(--accent); background: rgba(255,102,0,0.1); box-shadow: 0 0 8px rgba(255,102,0,0.3); } .radio-label input[type="radio"] { margin-right: 8px; accent-color: var(--accent); } .radio-label span { font-weight: 500; margin-bottom: 4px; } .radio-label small { color: var(--text-fade); font-size: 0.8rem; margin-left: 24px; } .radio-label input[type="text"] { margin-top: 8px; margin-left: 24px; padding: 6px; background: rgba(0,0,0,0.3); border: 1px solid rgba(255,102,0,0.5); border-radius: 4px; color: var(--text-main); font-family: var(--font-console); } .radio-label input[type="text"]:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 8px rgba(255,102,0,0.3); } .modal-footer { display: flex; justify-content: flex-end; gap: 10px; padding: 16px 20px; border-top: 1px solid var(--accent); background: rgba(255,102,0,0.05); } .primary-btn { background: var(--accent); color: #000; font-weight: bold; } .primary-btn:hover { background: #ff7a33; box-shadow: var(--accent-glow); } /* Session List */ .session-list { display: flex; flex-direction: column; gap: 8px; max-height: 300px; overflow-y: auto; } .session-item { display: flex; justify-content: space-between; align-items: center; padding: 12px; border: 1px solid rgba(255,102,0,0.3); border-radius: 6px; background: rgba(255,102,0,0.05); transition: all 0.2s; } .session-item:hover { border-color: var(--accent); background: rgba(255,102,0,0.1); } .session-info { display: flex; flex-direction: column; gap: 4px; flex: 1; } .session-info strong { color: var(--text-main); font-size: 0.95rem; } .session-info small { color: var(--text-fade); font-size: 0.75rem; } .session-delete-btn { background: transparent; border: 1px solid rgba(255,102,0,0.5); color: var(--accent); padding: 6px 10px; border-radius: 4px; cursor: pointer; font-size: 1rem; transition: all 0.2s; } .session-delete-btn:hover { background: rgba(255,0,0,0.2); border-color: #ff3333; color: #ff3333; box-shadow: 0 0 8px rgba(255,0,0,0.3); }