:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:#f0f2f5}h1{font-size:3.2em;line-height:1.1;color:#333}@media (prefers-color-scheme: dark){:root{color:#ffffffde;background-color:#242424}a:hover{color:#747bff}button{background-color:#f9f9f9}}.App{width:100%;display:flex;justify-content:center;align-items:center;flex-direction:column}.persona-setup-form{max-width:600px;margin:40px auto;padding:30px;border:none;border-radius:12px;box-shadow:0 10px 25px #0000001a;background-color:#fff;text-align:left;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.persona-setup-form h1{text-align:center;color:#1c2e4a;margin-bottom:30px;font-size:2.2em;font-weight:700}.persona-setup-form .form-group{margin-bottom:25px}.persona-setup-form label{display:block;margin-bottom:10px;font-weight:600;color:#334e68;font-size:1.1em}.persona-setup-form input[type=text],.persona-setup-form input[type=file]{width:calc(100% - 24px);padding:12px;border:1px solid #cdd5df;border-radius:8px;font-size:16px;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}.persona-setup-form input[type=text]:focus,.persona-setup-form input[type=file]:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff40;outline:none}.persona-setup-form input[type=file]{padding:10px}.persona-setup-form button{width:100%;padding:14px;background-color:#007bff;color:#fff;border:none;border-radius:8px;font-size:1.1em;font-weight:600;cursor:pointer;transition:background-color .3s ease,transform .2s ease}.persona-setup-form button:hover{background-color:#0056b3;transform:translateY(-2px)}.image-preview-container{margin-top:20px;text-align:center;background-color:#f8f9fa;padding:15px;border-radius:8px;border:1px dashed #ced4da}.image-preview{max-width:180px;max-height:180px;border:3px solid #007bff;border-radius:50%;object-fit:cover;box-shadow:0 4px 10px #0000001a}.chat-interface{display:flex;flex-direction:column;width:100%;max-width:800px;height:80vh;background-color:#fff;border-radius:12px;box-shadow:0 10px 25px #0000001a;overflow:hidden}.chat-header{display:flex;align-items:center;padding:15px 20px;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0;color:#1c2e4a}.chat-header h2{font-size:1.5em;font-weight:600;margin:0 0 0 15px}.chat-header p{font-size:.9em;color:#6c757d;margin:0 0 0 10px}.chat-persona-image{width:50px;height:50px;border-radius:50%;object-fit:cover;border:2px solid #007bff}.chat-messages{flex-grow:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column}.chat-message{display:flex;align-items:flex-start;margin-bottom:15px;max-width:80%}.chat-message.user{align-self:flex-end;justify-content:flex-end}.chat-message.assistant{align-self:flex-start;justify-content:flex-start}.chat-message p{padding:10px 15px;border-radius:18px;margin:0;line-height:1.4;word-wrap:break-word}.chat-message.user p{background-color:#007bff;color:#fff;border-bottom-right-radius:2px}.chat-message.assistant p{background-color:#e9ecef;color:#343a40;border-bottom-left-radius:2px;margin-left:10px}.chat-message-avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;border:1px solid #ced4da;flex-shrink:0}.chat-input-form{display:flex;padding:15px 20px;border-top:1px solid #e0e0e0;background-color:#f8f9fa}.chat-input-form input{flex-grow:1;padding:10px 15px;border:1px solid #cdd5df;border-radius:20px;font-size:1em;margin-right:10px;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}.chat-input-form input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff40;outline:none}.chat-input-form button{padding:10px 20px;background-color:#28a745;color:#fff;border:none;border-radius:20px;font-size:1em;cursor:pointer;transition:background-color .3s ease}.chat-input-form button:hover:not(:disabled){background-color:#218838}.chat-input-form button:disabled{background-color:#94d3a2;cursor:not-allowed}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;justify-content:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
