{
    "title": "Chatbot UI Design Improvement",
    "turns": [{
        "turn": 1,
        "user": "It's set up like this, but I want to make it more readable and visually appealing. I want to add a small box next to 'Please start the chatbot' where users can enter their name. How do I implement that in code?",
        "assistant": "Sure, I understand. I'll show you an example of how to improve the existing design to make it more stylish and readable, and, as you requested, place a name input box next to the sentence \"Please start the chatbot.\"\n\nInstead of a wide input field, I've created a small input box that blends naturally with the sentence, guiding the user's attention and enhancing the overall design.\n\n* * *\n\n### Design Suggestion & Code Implementation\n\nFor a better user experience, instead of directly asking \"Who are you?\", I used a softer guide like \"If you tell me your name, we can start a more friendly conversation.\"\n\n**✨ Improved Design Example**\n\n👋 Hello! Try starting a conversation with the chatbot.\n\nIf you tell me your name, we can start a more friendly conversation.\n\n* * *\n\n### Code\n\nCopy and use the HTML and CSS code below to implement the screen as shown above.\n\n#### HTML (`index.html`)\n\n```\n<!DOCTYPE html>\n<html lang=\"ko\">\n<head>\n    <meta charset=\"UTF-8\">\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n    <title>Chatbot Start</title>\n    <link rel=\"stylesheet\" href=\"style.css\">\n</head><body>\n\n    <div class=\"chat-start-container\">\n        <div class=\"welcome-message\">\n            👋 Hello! Try starting a conversation with the chatbot.\n        </div>\n\n        <div class=\"input-wrapper\">\n            <label for=\"username\">My name is</label>\n            <input type=\"text\" id=\"username\" class=\"name-input\" placeholder=\"Enter here\">\n            <span>.</span>\n        </div>\n\n        <button class=\"start-button\">Start Chatbot</button>\n\n        <div class=\"sub-text\">\n            If you tell me your name, we can start a more friendly conversation.\n        </div>\n    </div>\n\n</body>\n</html>\n```\n\n#### CSS (`style.css`)\n\n```\n@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700&display=swap');\n\nbody {\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    height: 100vh;\n    margin: 0;\n    background-color: #f0f4f8;\n    font-family: 'Noto Sans KR', sans-serif;\n}\n\n.chat-start-container {\n    background-color: white;\n    padding: 40px 50px;\n    border-radius: 16px;\n    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);\n    text-align: center;\n    width: 100%;\n    max-width: 480px;\n}\n\n.welcome-message {\n    font-size: 1.25em;\n    font-weight: 500;\n    color: #333;\n    margin-bottom: 25px;\n}\n\n.input-wrapper {\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    gap: 10px; /* Space between elements */\n    margin-bottom: 30px;\n    font-size: 1.1em;\n    color: #444;\n}\n\n.name-input {\n    border: 2px solid #dcdfe6;\n    border-radius: 8px;\n    padding: 10px 15px;\n    text-align: center;\n    font-size: 1em;\n    width: 140px;\n    transition: all 0.2s ease-in-out;\n}\n\n.name-input::placeholder {\n    color: #a8a8a8;\n}\n\n/* Change design when input is focused */\n.name-input:focus {\n    outline: none;\n    border-color: #5a9cff;\n    box-shadow: 0 0 0 3px rgba(90, 156, 255, 0.2);\n}\n\n.start-button {\n    width: 100%;\n    background-color: #5a9cff;\n    color: white;\n    border: none;\n    padding: 15px 0;\n    border-radius: 10px;\n    font-size: 1.1em;\n    font-weight: 700;\n    cursor: pointer;\n    transition: background-color 0.2s;\n}\n\n/* Change color when hovering over button */\n.start-button:hover {\n    background-color: #4a8ae6;\n}\n\n.sub-text {\n    margin-top: 20px;\n    font-size: 0.9em;\n    color: #888;\n}\n```"
    }, {
        "turn": 2,
        "user": "Right now, the boxes are stacked vertically, but what do you think about placing them side by side, with the name on the left and the start button on the right?",
        "assistant": "That's a great idea! Arranging the input box and the start button horizontally makes better use of the screen and helps focus the user's actions in one place.\n\nI'll modify the code so that the name input is on the left and the start button is on the right.\n\n* * *\n\n### ✨ Side-by-Side Layout Example\n\nThis gives a much cleaner and more dynamic feel.\n\n👋 Hello! Try starting a conversation with the chatbot.\n\nIf you tell me your name, we can start a more friendly conversation.\n\n* * *\n\n### Code\n\nApply the code below to implement the side-by-side layout as shown above.\n\n#### HTML (`index.html`)\n\nUse the same HTML structure as before, but wrap the input and button in a new `div` to apply horizontal alignment.\n\n```\n<!DOCTYPE html>\n<html lang=\"ko\">\n<head>\n    <meta charset=\"UTF-8\">\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n    <title>Chatbot Start</title>\n    <link rel=\"stylesheet\" href=\"style.css\">\n</head>\n<body>\n\n    <div class=\"chat-start-container\">\n        <div class=\"welcome-message\">\n            👋 Hello! Try starting a conversation with the chatbot.\n        </div>\n\n        <div class=\"action-row\">\n            <div class=\"input-wrapper\">\n                <label for=\"username\">Name:</label>\n                <input type=\"text\" id=\"username\" class=\"name-input\" placeholder=\"Enter here\">\n            </div>\n            \n            <button class=\"start-button\">Start</button>\n        </div>\n\n        <div class=\"sub-text\">\n            If you tell me your name, we can start a more friendly conversation.\n        </div>\n    </div>\n\n</body>\n</html>\n```\n\n#### CSS (`style.css`)\n\nThe key is to use **`display: flex`** in the CSS.\n\n```\n@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700&display=swap');\n\nbody {\n    display: flex;\n    justify-content: center;\n    align-items: center;\n    height: 100vh;\n    margin: 0;\n    background-color: #f0f4f8;\n    font-family: 'Noto Sans KR', sans-serif;\n}\n\n.chat-start-container {\n    background-color: white;\n    padding: 40px 50px;\n    border-radius: 16px;\n    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);\n    text-align: center;\n    width: 100%;\n    max-width: 550px; /* Slightly wider for better balance */\n}\n\n.welcome-message {\n    font-size: 1.25em;\n    font-weight: 500;\n    color: #333;\n    margin-bottom: 25px;\n}\n\n/* --- ▼ Key Changes ▼ --- */\n\n/* Container for horizontal alignment of input and button */\n.action-row {\n    display: flex; /* Arrange children horizontally */\n    align-items: stretch; /* Make children the same height */\n    gap: 15px; /* Space between input and button */\n    margin-bottom: 20px;\n}\n\n/* Left: Wrapper for the entire name input area */\n.input-wrapper {\n    flex-grow: 1; /* Take up all available space */\n    display: flex;\n    align-items: center;\n    gap: 10px;\n    border: 2px solid #dcdfe6;\n    border-radius: 10px;\n    padding: 0 20px;\n    transition: all 0.2s ease-in-out;\n}\n\n/* When input-wrapper is focused (when input inside is active) */\n.input-wrapper:focus-within {\n    border-color: #5a9cff;\n    box-shadow: 0 0 0 3px rgba(90, 156, 255, 0.2);\n}\n\n.input-wrapper label {\n    font-size: 1.1em;\n    color: #444;\n    white-space: nowrap; /* Prevent 'Name:' from wrapping */\n}\n\n/* Actual name input box */\n.name-input {\n    flex-grow: 1; /* Take up all available space inside wrapper */\n    border: none;\n    outline: none;\n    padding: 15px 0;\n    font-size: 1em;\n    width: 100%;\n    background-color: transparent; /* Transparent background */\n}\n\n/* Right: Start button */\n.start-button {\n    background-color: #5a9cff;\n    color: white;\n    border: none;\n    padding: 0 30px; /* Adjust size with padding instead of width */\n    border-radius: 10px;\n    font-size: 1.1em;\n    font-weight: 700;\n    cursor: pointer;\n    transition: background-color 0.2s;\n    white-space: nowrap; /* Prevent 'Start' from wrapping */\n}\n\n.start-button:hover {\n    background-color: #4a8ae6;\n}\n\n/* --- ▲ Key Changes ▲ --- */\n\n.sub-text {\n    margin-top: 20px;\n    font-size: 0.9em;\n    color: #888;\n}\n```"
    }, {
        "turn": 3,
        "user": "Right now, the two boxes have different heights. Can you make the heights the same? And can you change the design of the input box on the left to match the one on the right?\n\n# --- Page Settings ---\n\nst.set_page_config(\n\n    page_title=\"Thank You Pediatric Anesthesia Chatbot\",\n\n    page_icon=\"🩺\",\n\n    layout=\"wide\"\n\n)\n\n# --- 1. Global Style and Font Settings ---\n\nst.markdown(\"\"\"\n\n<link href=\"https://fonts.googleapis.com/css2?family=Nanum+Gothic:wght@400;700&display=swap\" rel=\"stylesheet\">\n\n<style>\n\n    * {\n\n        font-family: 'Nanum Gothic', sans-serif !important;\n\n    }\n\n    body, .stApp {\n\n        background-color: #eaf4fb !important;\n\n    }\n\n    /* Apply font to everything */\n\n    html, body, [class*=\"st-\"], button, input, textarea {\n\n        font-family: 'Nanum Gothic', sans-serif;\n\n    }\n\n    /* Main page title */\n\n    .main-title {\n\n        text-align: center;\n\n        color: #4F8BF9;\n\n        font-weight: 1000;\n\n    }\n\n    /* Main page subtitle */\n\n    .main-subtitle {\n\n        text-align: center;\n\n        color: #555555;\n\n        margin-bottom: 2rem;\n\n    }\n\n    /* Feature card style */\n\n    .feature-card {\n\n        background: #f7faff;\n\n        border-radius: 15px;\n\n        padding: 24px 20px;\n\n        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);\n\n        transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;\n\n        height: 100%;\n\n        display: flex;\n\n        flex-direction: column;\n\n        align-items: center;\n\n        text-align: center;\n\n    }\n\n    .feature-card:hover {\n\n        transform: translateY(-5px);\n\n        box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);\n\n    }\n\n    .feature-card h3 {\n\n        color: #4F8BF9;\n\n        margin-bottom: 12px;\n\n        font-size: 1.3em;\n\n    }\n\n    .feature-card p {\n\n        font-size: 1em;\n\n        color: #333;\n\n        line-height: 1.6;\n\n    }\n\n    .feature-icon {\n\n        font-size: 3em;\n\n        margin-bottom: 1rem;\n\n    }\n\n    /* Default button style */\n\n    .stButton>button {\n\n        background-color: #4F8BF9;\n\n        color: white;\n\n        font-size: 2rem;\n\n        font-weight: 900;\n\n        border-radius: 8px;\n\n        height: 3em;\n\n        width: 100%;\n\n        transition: all 0.2s ease-in-out;\n\n        border: none;\n\n        box-shadow: 0 4px 10px rgba(79, 139, 249, 0.3);\n\n    }\n\n    .stButton>button:hover {\n\n        background-color: #3c7de0;\n\n        transform: translateY(-2px);\n\n        box-shadow: 0 6px 14px rgba(79, 139, 249, 0.4);\n\n    }\n\n    .stButton>button:active {\n\n        background-color: #cccccc !important;\n\n        color: #222 !important;\n\n        transform: translateY(0);\n\n        box-shadow: none !important;\n\n    }\n\n    /* Footer style */\n\n    .footer {\n\n        text-align: center;\n\n        color: #aaa;\n\n        font-size: 0.9em;\n\n        margin-top: 3rem;\n\n    }\n\n    .start-chat-title {\n\n        text-align: center;\n\n        color: #222;\n\n        font-size: 1.1rem !important;\n\n        font-weight: 700;\n\n    }\n\n    .stButton>button {\n\n        background-color: #4F8BF9;\n\n        color: white;\n\n        font-size: 1.5rem;\n\n        font-weight: 900;\n\n        border-radius: 8px;\n\n        height: 3em;\n\n        width: 100%;\n\n        transition: all 0.2s ease-in-out;\n\n        border: none;\n\n        box-shadow: 0 4px 10px rgba(79, 139, 249, 0.3);\n\n    }\n\n    /* Reduce sidebar button width */\n\n    div[data-testid=\"stSidebar\"] .stButton > button {\n\n        width: 80% !important;\n\n        min-width: 0 !important;\n\n        max-width: 200px !important;\n\n        margin-left: auto;\n\n        margin-right: auto;\n\n        display: block;\n\n        height: 1.1em !important;\n\n        padding-top: 0.1em !important;\n\n        padding-bottom: 0.1em !important;\n\n        line-height: 0.6 !important;\n\n    }\n\n    /* Force sidebar button height/padding */\n\n    section[data-testid=\"stSidebar\"] button {\n\n        height: 2.2em !important;\n\n        padding-top: 0.4em !important;\n\n        padding-bottom: 0.4em !important;\n\n        line-height: 2.4 !important;\n\n        font-size: 1.1rem !important;\n\n        min-height: unset !important;\n\n        max-height: 2.6em !important;\n\n    }\n\n    /* Force sidebar session button text to one line, ellipsis if overflow */\n\n    div[data-testid=\"stSidebar\"] .stButton > button {\n\n        white-space: nowrap !important;\n\n        overflow: hidden !important;\n\n        text-overflow: ellipsis !important;\n\n        max-width: 220px !important;\n\n        min-width: 0 !important;\n\n        padding: 0.5em 1em !important;\n\n        height: auto !important;\n\n        line-height: 1.3 !important;\n\n    }\n\n    /* Center text input label */\n\n    div[data-testid=\"stTextInput\"] label {\n\n        width: 100%;\n\n        text-align: center !important;\n\n        display: block !important;\n\n        justify-content: center !important;\n\n        align-items: center !important;\n\n    }\n\n</style>\n\n\"\"\", unsafe_allow_html=True)\n\n# --- 2. Screen State Management ---\n\nif \"page\" not in st.session_state:\n\n    st.session_state[\"page\"] = \"main\"\ndef go_to_chatbot():\n\n    st.session_state[\"page\"] = \"chatbot\"\ndef go_to_main():\n\n    st.session_state[\"page\"] = \"main\"\n\n# --- 3. Page Rendering ---\n\nif st.session_state[\"page\"] == \"main\":\n\n    # --- Main Page ---\n\n    st.markdown(\"<h1 class='main-title'>🩺 Thank You Pediatric Anesthesia Chatbot</h1>\", unsafe_allow_html=True)\n\n    st.markdown(\"<p class='main-subtitle'>From clinical questions to patient data management, we help you with everything in pediatric anesthesia.</p>\", unsafe_allow_html=True)\n\n    st.write(\"\")\n\n    st.write(\"\")\n\n    st.subheader(\"✨ Main Features\")\n\n    st.write(\"\")\n\n    col1, col2 = st.columns(2, gap=\"medium\")\n\n    with col1:\n\n        st.markdown(\"\"\"\n\n        <div class=\"feature-card\">\n\n            <div class=\"feature-icon\">🤖</div>\n\n            <h3>RAG-based Clinical Questions</h3>\n\n            <p>Get fast and accurate answers to all your clinical questions about pediatric anesthesia, referencing the latest documents.</p>\n\n        </div>\n\n        \"\"\", unsafe_allow_html=True)\n\n    with col2:\n\n        st.markdown(\"\"\"\n\n        <div class=\"feature-card\">\n\n            <div class=\"feature-icon\">🗂️</div>\n\n            <h3>Patient Data Management</h3>\n\n            <p>Look up <strong>surgical information and clinical charts</strong> in real time by patient ID, and get customized answers for efficient <strong>patient management</strong>.</p>\n\n        </div>\n\n        \"\"\", unsafe_allow_html=True)\n\n    st.write(\"\")\n\n    col3, col4 = st.columns(2, gap=\"medium\")\n\n    with col3:\n\n        st.markdown(\"\"\"\n\n        <div class=\"feature-card\">\n\n            <div class=\"feature-icon\">💬</div>\n\n            <h3>Slack Message Integration</h3>\n\n            <p>Send important or shareable search results to colleagues instantly via Slack messages for efficient collaboration.</p>\n\n        </div>\n\n        \"\"\", unsafe_allow_html=True)\n\n    with col4:\n\n        st.markdown(\"\"\"\n\n        <div class=\"feature-card\">\n\n            <div class=\"feature-icon\">💾</div>\n\n            <h3>Save Conversation History</h3>\n\n            <p>You can download important conversations with the chatbot as a text file anytime for record-keeping and management.</p>\n\n        </div>\n\n        \"\"\", unsafe_allow_html=True)\n\n    st.divider()\n\n    st.markdown(\"\"\"\n\n    <div style='text-align:center;'>\n\n        <h3 class='start-chat-title'>👇 Enter your name and start the chatbot </h3>\n\n    </div>\n\n    \"\"\", unsafe_allow_html=True)\n\n    st.markdown(\"\"\"\n\n    <div style='display:flex; justify-content:center;'><div style='width:300px;'>\n\n    \"\"\", unsafe_allow_html=True)\n\n    col1, col2 = st.columns([1, 1])\n\n    with col1:\n\n        user_name = st.text_input(\"\", value=st.session_state.get(\"user_name\", \"\"), key=\"user_name_inline\", placeholder=\"Enter your name\")\n\n        st.session_state[\"user_name\"] = user_name\n\n    with col2:\n\n        st.write(\"\")  # Space to push the button down\n\n        st.button(\"Start Chatbot\", on_click=go_to_chatbot, disabled=not bool(user_name.strip()), use_container_width=True)\n\n    st.image(\"image.png\", use_container_width=True)\n\n    st.markdown(\"<div class='footer'>© 2025 Thank You Pediatric Anesthesia. All Rights Reserved.</div>\", unsafe_allow_html=True)\n\nelse: # \"chatbot\" page\n\n    # --- Chatbot Page ---\n\n    st.markdown(\"<h2 style='color: #222;'>🩺 Thank You Pediatric Anesthesia Chatbot</h2>\", unsafe_allow_html=True)\n\n    col1, col2, col3 = st.columns(3)\n\n    box_style = \"background:{bg}; border-radius:12px; padding:14px; text-align:center; box-shadow:0 2px 8px #0001; height:120px; display:flex; flex-direction:column; justify-content:center; align-items:center; font-size:0.9rem;\"\n\n    icon_box_style = \"width:100%; display:flex; justify-content:center; align-items:center; height:36px; margin-bottom:0.5em;\"\n\n    with col1:\n\n        st.markdown(f\"\"\"<div style='{box_style.format(bg=\"#fef9e7\")}'><div style='{icon_box_style}'><span style='font-size:1.5rem;'>🆔</span></div><div><b>Try asking a question including the patient's name or a specific surgery history.</b></div></div>\"\"\", unsafe_allow_html=True)\n\n    with col2:\n\n        st.markdown(f\"\"\"<div style='{box_style.format(bg=\"#eafaf1\")}'><div style='{icon_box_style}'><span style='font-size:1.5rem;'>📋</span></div><div>Answers are generated in real time by looking up the patient's <b>clinical chart and surgical information</b>.</div></div>\"\"\", unsafe_allow_html=True)\n\n    with col3:\n\n        st.markdown(f\"\"\"<div style='{box_style.format(bg=\"#fef9e7\")}'><div style='{icon_box_style}'><img src=\"https://a.slack-edge.com/80588/marketing/img/icons/icon_slack_hash_colored.png\" alt=\"Slack\" style=\"height:1.5rem;\"></div><div>Automatically send answers to your desired colleague via <b>Slack</b>.</div></div>\"\"\", unsafe_allow_html=True)\n\n    st.divider()\n\n    if \"sessions\" not in st.session_state:\n\n        st.session_state.sessions = [[]]\n\n    if \"current_session_index\" not in st.session_state:\n\n        st.session_state.current_session_index = 0\n\n    def switch_session(session_index):\n\n        st.session_state.current_session_index = session_index\n\n    with st.sidebar:\n\n        st.markdown('<div style=\"text-align:center; font-size:2.5rem; margin-bottom:0.5em;\">🐘</div>', unsafe_allow_html=True)\n\n        if st.button(\"⬅️ Back to Main\"):\n\n            go_to_main()\n\n        st.markdown(\"---\")\n\n        if st.button(\"🆕 Start New Chat\"):\n\n            st.session_state.sessions.append([])\n\n            switch_session(len(st.session_state.sessions) - 1)\n\n        st.markdown(\"---\")\n\n        st.markdown(\"#### 💬 Chat Session History\")\n\n        if not any(st.session_state.sessions):\n\n            st.markdown(\"_No saved sessions yet._\")\n\n        else:\n\n            for i, session in enumerate(st.session_state.sessions):\n\n                if session:\n\n                    first_q = next((msg['content'] for msg in session if msg['role'] == 'user'), \"Session\")\n\n                    display_text = first_q[:10] + (\"...\" if len(first_q) > 10 else \"\")\n\n                    st.button(f\"📜 {display_text}\", key=f\"session_{i}\", on_click=switch_session, args=(i,))\n\n                else:\n\n                    st.button(f\"🆕 New Chat {i+1}\", key=f\"session_{i}\", on_click=switch_session, args=(i,))\n\n        st.markdown(\n\n            '''\n\n            <a href=\"https://app.slack.com/client/T093ELJBE2Z\" target=\"_blank\"\n\n                style=\"display:inline-block; background:#611f69; color:#fff; font-weight:700; padding:0.7em 2em; border-radius:8px; text-decoration:none; font-size:1.1rem; box-shadow:0 2px 8px #0002; margin-top:2em;\">\n\n                <img src=\"https://a.slack-edge.com/80588/marketing/img/icons/icon_slack_hash_colored.png\" alt=\"Slack\" style=\"height:1.3em; vertical-align:middle; margin-right:0.5em;\">\n\n                Go to Slack\n\n            </a>\n\n            ''', unsafe_allow_html=True\n\n        )\n\n    current_messages = st.session_state.sessions[st.session_state.current_session_index]\n\n    for message in current_messages:\n\n        if message[\"role\"] == \"user\":\n\n            st.markdown(f\"\"\"<div style='display:flex; justify-content:flex-end; margin-bottom:8px;'><div style='background:#fff; color:#222; border-radius:16px 16px 4px 16px; padding:12px 18px; max-width:70%; box-shadow:0 2px 8px #0001;'>{message[\"content\"]}</div></div>\"\"\", unsafe_allow_html=True)\n\n        else:\n\n            st.markdown(f\"\"\"<div style='display:flex; justify-content:flex-start; margin-bottom:8px;'><div style='background:#b3d8f6; color:#222; border-radius:16px 16px 16px 4px; padding:12px 18px; max-width:70%; box-shadow:0 2px 8px #0001;'>{message[\"content\"]}</div></div>\"\"\", unsafe_allow_html=True)\n\n    input_and_loading = st.empty()\n\n    if len(current_messages) > 0:\n\n        st.divider()\n\n        buffer = StringIO()\n\n        for m in current_messages:\n\n            role = \"User\" if m['role'] == 'user' else \"Chatbot\"\n\n            buffer.write(f\"{role}: {m['content']}\\n\\n\")\n\n        st.download_button(\n\n            label=\"📄 Download Current Conversation\",\n\n            data=buffer.getvalue(),\n\n            file_name=f\"chat_history_session_{st.session_state.current_session_index + 1}.txt\",\n\n            mime=\"text/plain\"\n\n        )\n\n    # 1. Define summary function (example: reuse single_question)\n\n    def summarize_history(history_text):\n\n        summary_prompt = f\"Summarize the following conversation in one or two sentences:\\n{history_text}\"\n\n        return asyncio.run(single_question(summary_prompt))\n\n    prompt = st.chat_input(\"Enter patient ID or your question...\")\n\n    if prompt:\n\n        st.session_state.sessions[st.session_state.current_session_index].append({\"role\": \"user\", \"content\": prompt})\n\n        with input_and_loading.container():\n\n            st.markdown(f\"\"\"\n\n            <div style='display:flex; justify-content:flex-end; margin-bottom:8px;'>\n\n                <div style='background:#fff; color:#222; border-radius:16px 16px 4px 16px; padding:12px 18px; max-width:70%; box-shadow:0 2px 8px #0001;'>\n\n                    {prompt}\n\n                </div>\n\n            </div>\n\n            \"\"\", unsafe_allow_html=True)\n\n            st.markdown(f\"\"\"\n\n            <div style='display:flex; justify-content:flex-start; margin-bottom:8px;'>\n\n                <div style='background:#b3d8f6; color:#222; border-radius:16px 16px 16px 4px; padding:12px 18px; max-width:70%; box-shadow:0 2px 8px #0001; font-style:italic;'>\n\n                    Generating answer...\n\n                </div>\n\n            </div>\n\n            \"\"\", unsafe_allow_html=True)\n\n        # 2. Separate and summarize conversation\n\n        all_messages = current_messages + [{\"role\": \"user\", \"content\": prompt}]\n\n        if len(all_messages) > 3:\n\n            # Summarize part\n\n            history_to_summarize = \"\\n\".join([\n\n                f\"{'User' if m['role']=='user' else 'Chatbot'}: {m['content']}\" for m in all_messages[:-3]\n\n            ])\n\n            summary = summarize_history(history_to_summarize)\n\n            recent_history = \"\\n\".join([\n\n                f\"{'User' if m['role']=='user' else 'Chatbot'}: {m['content']}\" for m in all_messages[-3:]\n\n            ])\n\n        else:\n\n            summary = \"\"\n\n            recent_history = \"\\n\".join([\n\n                f\"{'User' if m['role']=='user' else 'Chatbot'}: {m['content']}\" for m in all_messages\n\n            ])\n\n        user_question = prompt\n\n        # 3. Compose prompt and call LLM\n\n        multi_turn_prompt = f\"\"\"\\n### Previous Conversation Summary\\n{summary}\\n\\n### Recent Conversation\\n{recent_history}\\n\\nPlease generate a natural answer to the following question, referring to the previous and recent conversation.\\n### User Question\\n{user_question}\\n\"\"\"\n\n        result = asyncio.run(single_question(multi_turn_prompt))\n\n        st.session_state.sessions[st.session_state.current_session_index].append({\"role\": \"assistant\", \"content\": result})\n\n        st.rerun()"
    }, {
        "turn": 4,
        "user": "Just change that part and give me the full code.",
        "assistant": "Sure! I'll provide the complete Streamlit code with the modified part included. You can copy and use this code as is.\n\n* * *\n\n```\nimport streamlit as st\nfrom io import StringIO\nimport asyncio"
    }]
}