body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin:0;background-color:#f0f2f5;color:#1c1e21;display:flex;justify-content:center;align-items:center;min-height:100vh;padding:10px;box-sizing:border-box;overflow:hidden}#root{width:100%;height:100%;display:flex;justify-content:center;align-items:center}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:15px;font-size:1.1em;color:#495057}.login-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:20px;box-sizing:border-box}.login-form{background:#fff;padding:40px 30px;border-radius:12px;box-shadow:0 6px 18px #0000001a;width:100%;max-width:400px;text-align:center;display:flex;flex-direction:column;gap:20px}.login-form h1{margin-top:0;margin-bottom:5px;font-size:1.8em;color:#232f3e}.login-form p{margin-top:0;margin-bottom:20px;color:#6c757d;font-size:1em}.login-form .input-group{display:flex;flex-direction:column;text-align:left}.login-form label{margin-bottom:8px;font-weight:500;color:#495057}.login-form input[type=password]{padding:12px 15px;border-radius:8px;border:1px solid #ced4da;font-size:1rem;transition:border-color .2s,box-shadow .2s}.login-form input[type=password]:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.login-form button{padding:12px 20px;background-color:#f90;color:#1a2433;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}.login-form button:hover:not(:disabled){background-color:#e68a00}.login-form button:disabled{background-color:#fcc277;cursor:not-allowed}.bypass-login-button{background:none;border:none;color:#007bff;cursor:pointer;text-decoration:underline;padding:8px;margin-top:-10px;font-size:.9em;font-weight:500}.bypass-login-button:hover:not(:disabled){color:#0056b3}.login-error-message{color:#a94442;background-color:#fdecea;padding:10px;border-radius:6px;font-size:.9em;text-align:center}.chat-container{width:100%;height:calc(100vh - 40px);max-height:900px;background-color:#fff;border-radius:12px;box-shadow:0 6px 18px #0000001a;display:flex;flex-direction:column;overflow:hidden}.app-header{padding:15px 20px;background-color:#232f3e;color:#fff;border-bottom:1px solid #1a2433;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;gap:10px}.header-left-content{display:flex;align-items:center;gap:15px;flex-grow:1;min-width:0}.title-container{display:flex;align-items:center;gap:8px;flex-shrink:0}.app-header h1{margin:0;font-size:1.4em;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.model-info-icon-container{display:flex;align-items:center;cursor:help;flex-shrink:0}.model-info-icon-container svg{width:20px;height:20px}.provider-selector-container{display:flex;align-items:center;gap:6px;flex-shrink:1;min-width:150px}.provider-selector-container label{font-size:.9em;font-weight:500;white-space:nowrap}.provider-selector-container select{padding:6px 10px;border-radius:6px;border:1px solid #4a5c6d;background-color:#37475a;color:#fff;font-size:.9em;font-weight:500;cursor:pointer;transition:background-color .2s,border-color .2s;max-width:200px}.provider-selector-container select:hover{background-color:#4a5c6d}.provider-selector-container select:focus{outline:none;border-color:#f90;box-shadow:0 0 0 2px #ff99004d}.header-right-content{display:flex;align-items:center;gap:10px;flex-shrink:0}.help-button{background-color:#6c757d;color:#fff;border:none;border-radius:50%;width:34px;height:34px;font-size:1.2em;font-weight:700;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;padding:0}.help-button:hover:not(:disabled){background-color:#5a6268}.help-button:disabled{opacity:.7;cursor:not-allowed}.new-conversation-button{background-color:#4a5c6d;color:#fff;border:none;border-radius:6px;padding:8px 14px;font-size:.9em;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap;display:flex;align-items:center;gap:6px}.new-conversation-button:hover:not(:disabled){background-color:#6c757d}.new-conversation-button:disabled{background-color:#37475a;color:#adb5bd;cursor:not-allowed;opacity:.7}.new-conversation-button svg{width:1em;height:1em}.show-example-button{background-color:#f90;color:#1a2433;border:none;border-radius:6px;padding:8px 14px;font-size:.9em;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s,visibility .2s,width .2s,padding .2s;white-space:nowrap}.show-example-button.hidden{opacity:0;visibility:hidden;width:0;padding:8px 0;margin-right:0;overflow:hidden}.show-example-button:hover:not(:disabled){background-color:#e68a00}.show-example-button:disabled{background-color:#fcc277;color:#6c757d;cursor:not-allowed;opacity:.7}.error-message{background-color:#fdecea;color:#a94442;padding:12px 15px;text-align:center;border-bottom:1px solid #f5c6cb;font-size:.9em;flex-shrink:0}.message-list{flex-grow:1;padding:20px;overflow-y:auto;overflow-x:auto;display:flex;flex-direction:column;gap:12px}.message{padding:12px 18px;border-radius:20px;max-width:90%;line-height:1.55;box-shadow:0 2px 3px #0000000f;box-sizing:border-box;min-width:0}.message p{margin-top:0;margin-bottom:0;overflow-wrap:break-word;word-break:break-word}.message p:first-child{margin-top:0}.message p:last-child{margin-bottom:0}.message.user{background-color:#007bff;color:#fff;align-self:flex-end;border-bottom-right-radius:8px;position:relative;padding-right:45px}.message.model{background-color:#e9ecef;color:#1c1e21;align-self:flex-start;border-bottom-left-radius:8px;position:relative;padding-right:45px}.user-message-content-wrapper{transition:max-height .3s ease-in-out;overflow-wrap:break-word;word-break:break-word}.user-message-content-wrapper.collapsed{max-height:100px;overflow:hidden;position:relative}.user-message-content-wrapper.collapsed:after{content:"";position:absolute;bottom:0;left:0;right:0;height:20px;background:linear-gradient(to bottom,transparent,#007bff);pointer-events:none}.user-message-content-wrapper.expanded{max-height:1000px;overflow-y:auto}.expand-collapse-button{position:absolute;top:8px;right:8px;background:#fff3;border:none;border-radius:4px;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:background-color .2s}.expand-collapse-button:hover{background:#ffffff4d}.expand-collapse-button svg{width:16px;height:16px;display:block}.message.model pre:not(.mermaid-code-block){background-color:#282c34;color:#abb2bf;padding:12px 15px;border-radius:6px;overflow-x:auto;white-space:pre-wrap;word-wrap:normal;word-break:normal;margin:10px 0;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace;font-size:.9em}.message.model code:not(pre code){background-color:#f0f0f0;padding:.2em .4em;margin:0 .1em;font-size:85%;border-radius:4px;border:1px solid #ddd;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace;color:#c7254e;word-wrap:break-word;overflow-wrap:break-word}.message.model pre code{font-family:inherit;font-size:inherit;background-color:transparent;padding:0;border:none;color:inherit;word-break:normal}.input-container{flex-shrink:0;background-color:#f8f9fa;border-top:1px solid #dee2e6}.input-area{display:flex;align-items:flex-start;padding:10px 20px 15px}.input-area textarea{flex-grow:1;padding:10px 18px;border:1px solid #ced4da;border-radius:22px;margin-right:10px;font-size:1rem;line-height:1.4;outline:none;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;resize:none;overflow-y:auto;min-height:24px;max-height:150px;box-sizing:border-box;font-family:inherit}.input-area textarea:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40}.input-area textarea:disabled{background-color:#e9ecef;cursor:not-allowed}.input-area button{padding:12px 20px;background-color:#f90;color:#1a2433;border:none;border-radius:22px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s;white-space:nowrap;align-self:flex-end;height:46px}.input-area button:hover:not(:disabled){background-color:#e68a00}.input-area button:disabled{background-color:#fcc277;color:#6c757d;cursor:not-allowed}.input-area button.stop-button{background-color:#dc3545;color:#fff}.input-area button.stop-button:hover:not(:disabled){background-color:#c82333}.loading-dots span{display:inline-block;width:8px;height:8px;margin:0 3px;background-color:#f90;border-radius:50%;animation:loading-animation 1.4s infinite ease-in-out both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}.loading-dots span:nth-child(3){animation-delay:0s}@keyframes loading-animation{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.gemini-key-container{padding:10px 20px 5px;background-color:#e8f0fe;border-bottom:1px solid #d2e3fc;display:flex;align-items:center;gap:12px}.gemini-key-container label{font-weight:500;font-size:.9em;color:#1967d2;white-space:nowrap}.gemini-key-container input[type=password]{flex-grow:1;padding:6px 10px;border:1px solid #d2e3fc;border-radius:6px;font-size:.9rem}.gemini-key-container input[type=password]:focus{outline:none;border-color:#8ab4f8;box-shadow:0 0 0 .2rem #4285f440}.gemini-key-container input[type=password]:disabled{background-color:#f1f5fe;cursor:not-allowed}.gemini-key-container button{padding:6px 12px;background-color:#4285f4;color:#fff;border:1px solid #4285f4;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.gemini-key-container button:hover:not(:disabled){background-color:#3367d6}.gemini-key-container button:disabled{background-color:#a0c3ff;border-color:#a0c3ff;cursor:not-allowed;color:#f1f5fe}.gemini-key-status{display:flex;align-items:center;gap:5px;font-size:.85em;font-weight:500}.gemini-key-status.set{color:#155724}.gemini-key-status.not-set{color:#721c24}.openai-key-container{padding:10px 20px 5px;background-color:#fff3cd;border-bottom:1px solid #ffeeba;display:flex;align-items:center;gap:12px}.openai-key-container label{font-weight:500;font-size:.9em;color:#856404;white-space:nowrap}.openai-key-container input[type=password]{flex-grow:1;padding:6px 10px;border:1px solid #ffeeba;border-radius:6px;font-size:.9rem}.openai-key-container input[type=password]:focus{outline:none;border-color:#ffc107;box-shadow:0 0 0 .2rem #ffc10780}.openai-key-container input[type=password]:disabled{background-color:#fff9e6;cursor:not-allowed}.openai-key-container button{padding:6px 12px;background-color:#ffc107;color:#212529;border:1px solid #ffc107;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.openai-key-container button:hover:not(:disabled){background-color:#e0a800}.openai-key-container button:disabled{background-color:#ffeeba;border-color:#ffeeba;cursor:not-allowed;color:#6c757d}.openai-key-status{display:flex;align-items:center;gap:5px;font-size:.85em;font-weight:500}.openai-key-status.set{color:#155724}.openai-key-status.not-set{color:#721c24}.inline-input-error{background-color:#fdecea;color:#a94442;padding:10px 20px;text-align:center;font-size:.9em;border-bottom:1px solid #f5c6cb}.response-options-container{padding:10px 20px 5px;background-color:#f8f9fa;display:flex;flex-wrap:wrap;gap:15px;align-items:center;border-bottom:1px solid #e9ecef}.response-options-container fieldset{border:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:15px;align-items:center}.response-options-container legend{font-weight:500;font-size:.9em;margin-right:10px;color:#495057;padding:0}.response-options-container .option-item{display:flex;align-items:center;gap:5px}.response-options-container label{font-size:.85em;color:#495057;cursor:pointer}.response-options-container input[type=checkbox]{cursor:pointer;accent-color:#007bff;width:15px;height:15px}.response-options-container input[type=checkbox]:disabled{cursor:not-allowed;accent-color:#adb5bd}.response-options-container label:has(input:disabled){cursor:not-allowed;color:#6c757d}.mermaid-section{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.mermaid-action-button{background-color:#6c757d;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.8em;transition:background-color .2s}.mermaid-action-button:hover:not(:disabled){background-color:#5a6268}.mermaid-action-button:disabled{opacity:.6;cursor:not-allowed}.mermaid-code-block{background-color:#282c34;color:#abb2bf;padding:12px 15px;border-radius:6px;overflow-x:auto;white-space:pre-wrap;word-wrap:normal;word-break:normal;border:1px solid #212529;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace;font-size:.9em;max-height:500px;overflow-y:auto;width:100%;box-sizing:border-box;margin-top:8px}.mermaid-editor-container{width:100%;margin-top:8px;display:flex;flex-direction:column;gap:8px;background-color:#282c34;padding:12px 15px;border-radius:6px;border:1px solid #212529;box-sizing:border-box;transition:border-color .2s}.mermaid-editor-container:has(.mermaid-editor-textarea:focus){border-color:#007bff}.mermaid-editor-textarea{width:100%;min-height:150px;max-height:500px;resize:vertical;background-color:transparent;color:#abb2bf;border:none;border-radius:0;padding:0;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace;font-size:.9em;box-sizing:border-box;outline:none;white-space:pre;word-wrap:normal;word-break:normal;overflow-x:auto;min-width:900px}.mermaid-editor-controls{display:flex;gap:8px;justify-content:flex-end}.mermaid-editor-controls .mermaid-action-button.save{background-color:#28a745}.mermaid-editor-controls .mermaid-action-button.save:hover{background-color:#218838}.mermaid-editor-controls .mermaid-action-button.cancel{background-color:#dc3545}.mermaid-editor-controls .mermaid-action-button.cancel:hover{background-color:#c82333}.inline-mermaid-error{padding:8px 12px;margin-top:8px;background-color:#fff3cd;border:1px solid #ffeeba;color:#856404;border-radius:4px;font-size:.85em;width:100%;box-sizing:border-box}.mermaid-diagram{background-color:#f9f9f9;padding:15px;border-radius:8px;border:1px solid #e0e0e0;box-sizing:border-box;width:100%;max-width:100%}.mermaid-diagram svg{max-width:none!important;height:auto;display:block;margin-left:auto;margin-right:auto}.mermaid-diagram-loading,.mermaid-error{padding:12px;margin-top:8px;background-color:#f0f0f0;border-radius:6px;text-align:center;color:#555;font-style:italic}.mermaid-error{color:#a94442;background-color:#fdecea;border:1px solid #f5c6cb}.copy-message-button{position:absolute;top:8px;right:8px;background:#0000001a;border:none;border-radius:4px;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#333;transition:background-color .2s,color .2s;font-size:.8em;line-height:1}.copy-message-button:hover{background:#0003}.copy-message-button svg{width:16px;height:16px;display:block}.copy-message-button:disabled{cursor:default;opacity:.7}.diagram-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1050;padding:20px;box-sizing:border-box}.diagram-modal-content{background-color:#fff;padding:20px 25px 25px;border-radius:12px;box-shadow:0 8px 25px #0003;max-width:1200px;width:90vw;max-height:90vh;position:relative;display:flex;flex-direction:column}.diagram-modal-close-button{position:absolute;top:12px;right:15px;background:transparent;border:none;font-size:2.2rem;font-weight:300;color:#777;cursor:pointer;line-height:1;padding:0;z-index:10}.diagram-modal-close-button:hover{color:#000}.diagram-modal-controls{position:absolute;top:15px;right:55px;display:flex;gap:6px;z-index:20}.diagram-modal-controls button{background-color:#f0f0f0;border:1px solid #ccc;border-radius:50%;width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s,box-shadow .2s;color:#333}.diagram-modal-controls button:hover:not(:disabled){background-color:#e0e0e0;border-color:#bbb}.diagram-modal-controls button:active:not(:disabled){box-shadow:inset 0 1px 3px #00000026}.diagram-modal-controls button:disabled{opacity:.5;cursor:not-allowed}.diagram-modal-controls button svg{width:16px;height:16px}.diagram-modal-body{flex-grow:1;overflow:auto;margin-top:10px;display:grid;place-items:center}.diagram-modal-body .mermaid-diagram{min-height:300px}.diagram-modal-body .mermaid-diagram:not(.is-zoomed) svg{max-width:100%!important;height:auto;max-height:calc(90vh - 120px);object-fit:contain}.diagram-modal-body .mermaid-diagram-loading,.diagram-modal-body .mermaid-error{min-height:100px;display:flex;align-items:center;justify-content:center}.help-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1050;padding:20px;box-sizing:border-box}.help-modal-content{background-color:#fff;padding:25px 30px 30px;border-radius:12px;box-shadow:0 8px 25px #0003;max-width:700px;width:90vw;max-height:90vh;position:relative;display:flex;flex-direction:column;text-align:left;line-height:1.6}.help-modal-content h2{margin-top:0;margin-bottom:15px;color:#232f3e;border-bottom:2px solid #ff9900;padding-bottom:8px}.help-modal-content h3{margin-top:20px;margin-bottom:10px;color:#1a2433}.help-modal-content p,.help-modal-content li{color:#495057;font-size:.95em}.help-modal-content ul{padding-left:20px;margin-top:5px}.help-modal-content strong{color:#1a2433}.help-modal-close-button{position:absolute;top:12px;right:15px;background:transparent;border:none;font-size:2.2rem;font-weight:300;color:#777;cursor:pointer;line-height:1;padding:0;z-index:10}.help-modal-close-button:hover{color:#000}.help-modal-body{overflow-y:auto;padding-right:15px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}#mermaidTooltip,div.mermaid-main-error,div.mermaidErrorMessage{display:none!important;visibility:hidden!important;pointer-events:none!important;width:0!important;height:0!important;overflow:hidden!important;position:absolute!important;left:-9999px!important;top:-9999px!important}svg[aria-roledescription=error]{display:none!important;visibility:hidden!important}@media (max-width: 900px){.diagram-modal-content{width:90vw}}@media (max-width: 800px){.app-header{flex-wrap:wrap;padding:12px 15px}.header-left-content{width:100%;order:1;margin-bottom:10px;justify-content:space-between}.title-container{flex-grow:1}.provider-selector-container{min-width:auto;flex-basis:180px;flex-grow:0}.provider-selector-container select{max-width:none;width:100%}.header-right-content{width:100%;order:2;justify-content:flex-end}.app-header h1{font-size:1.2em}.new-conversation-button,.show-example-button{font-size:.8em;padding:6px 10px}.show-example-button.hidden{padding:6px 0}.input-area textarea{max-height:100px}}@media (max-width: 600px){body{padding:0}.chat-container{height:100vh;max-height:none;border-radius:0;box-shadow:none}.app-header{padding:10px 12px}.header-left-content{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:8px}.title-container{width:100%}.app-header h1{font-size:1.1em}.provider-selector-container{width:100%;flex-basis:auto}.provider-selector-container label{font-size:.85em}.provider-selector-container select{font-size:.85em;padding:5px 8px}.new-conversation-button,.show-example-button{font-size:.75em;padding:5px 8px;width:auto}.show-example-button.hidden{padding:5px 0}.new-conversation-button span{display:none}.new-conversation-button{padding:6px;gap:0}.help-button{width:30px;height:30px;font-size:1em}.message-list{padding:15px 10px}.message{max-width:95%}.input-area{padding:10px 15px}.response-options-container{padding:8px 15px 4px;gap:10px}.response-options-container legend{font-size:.8em;width:100%;margin-bottom:4px}.response-options-container .option-item{gap:4px}.response-options-container label{font-size:.8em}.input-area textarea{font-size:.95rem;padding:8px 15px;min-height:22px}.input-area button{font-size:.95rem;padding:10px 15px;height:42px}.diagram-modal-content,.help-modal-content{padding:15px;width:calc(100vw - 20px);max-width:calc(100vw - 20px);height:calc(100vh - 20px);max-height:calc(100vh - 20px);border-radius:0}.diagram-modal-close-button,.help-modal-close-button{top:5px;right:10px;font-size:1.8rem}.diagram-modal-controls{top:8px;right:45px}.diagram-modal-controls button{width:26px;height:26px}.diagram-modal-controls button svg{width:14px;height:14px}}@media (max-width: 400px){.app-header h1{font-size:1em}.provider-selector-container label,.provider-selector-container select{font-size:.8em}.new-conversation-button,.show-example-button{font-size:.7em}.response-options-container,.response-options-container fieldset{flex-direction:column;align-items:flex-start;gap:5px}.response-options-container legend{margin-bottom:5px;width:auto}}
