.sidebar{width:260px;background-color:#fff;display:flex;flex-direction:column;border-right:1px solid #e5e7eb;flex-shrink:0}.sidebar-header{padding:16px;border-bottom:1px solid #e5e7eb}.new-chat-btn{width:100%;padding:12px;background-color:#fff;border:1px solid #d1d5db;color:#374151;border-radius:8px;cursor:pointer;font-size:14px;transition:all .2s;font-weight:500}.new-chat-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.sidebar-section-header{padding:12px 16px 4px;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center}.new-project-btn{background:none;border:1px solid #d1d5db;color:#6b7280;cursor:pointer;border-radius:50%;width:24px;height:24px;font-size:16px;line-height:22px;text-align:center;transition:all .2s}.new-project-btn:hover{background-color:#f9fafb;border-color:#9ca3af}.project-item{padding:10px 16px;cursor:pointer;border-radius:6px;margin:2px 8px;display:flex;align-items:center;justify-content:space-between;transition:background-color .2s;position:relative;font-size:14px}.project-item:hover{background-color:#f9fafb}.project-item.active{background-color:#f3f4f6;font-weight:500}.project-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#374151}.project-actions{display:flex;align-items:center;gap:4px;opacity:0;transition:opacity .2s}.project-item:hover .project-actions{opacity:1}.project-action-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;font-size:14px;color:#6b7280;display:flex;align-items:center;justify-content:center}.project-action-btn:hover{background-color:#f9fafb;color:#111827}.project-action-btn:hover:last-child{color:#ef4444}.conversations-list{flex:1;overflow-y:auto}.conversation-item{padding:12px;cursor:pointer;border-radius:6px;margin:4px 8px;display:flex;align-items:center;justify-content:space-between;transition:background-color .2s;position:relative}.conversation-item:hover{background-color:#f9fafb}.conversation-item.active{background-color:#f3f4f6}.conversation-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;color:#374151}.delete-btn{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;border-radius:4px;opacity:0;transition:opacity .2s;font-size:16px;line-height:1}.conversation-item:hover .delete-btn{opacity:1}.delete-btn:hover{background-color:#f9fafb;color:#ef4444}.sidebar-footer{padding:16px;border-top:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.user-info{font-size:14px;font-weight:500;color:#374151}.settings-button{background:none;border:1px solid #d1d5db;padding:8px 12px;border-radius:6px;cursor:pointer;color:#374151;font-size:14px;transition:background-color .2s}.settings-button:hover{background-color:#f9fafb}.loading-indicator{padding:16px;display:flex;justify-content:center;align-items:center}.loading-indicator .spinner{width:20px;height:20px;border:2px solid #e5e7eb;border-top-color:#6b7280;border-radius:50%;animation:spinner-rotate .8s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.context-menu{background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 4px 12px #00000026;padding:4px 0;min-width:160px;z-index:1000}.context-menu-item{display:flex;align-items:center;padding:8px 16px;cursor:pointer;font-size:14px;color:#333;border:none;background:none;width:100%;text-align:left;transition:background-color .15s ease}.context-menu-item:hover{background-color:#f5f5f5}.context-menu-item:active{background-color:#e0e0e0}.context-menu-item.danger{color:#d32f2f}.context-menu-item.danger:hover{background-color:#ffebee}.context-menu-item.danger:active{background-color:#ffcdd2}.context-menu-item svg{margin-right:8px;width:16px;height:16px}.message-list{flex:1;overflow-y:auto;padding:80px 20px 160px;width:70%;margin:0 auto}.message{margin-bottom:12px}.message-content{display:flex;flex-direction:column;align-items:flex-start;gap:14px;max-width:600px;padding:8px 16px;border-radius:8px}.message-text{flex:1;line-height:1.7;font-size:15px;word-wrap:break-word}.user-message{display:flex;justify-content:flex-end}.user-message .message-content{justify-content:flex-end}.assistant-message{display:flex;justify-content:flex-start}.user-message .message-content{background-color:#f3f4f6;margin-left:120px;margin-right:0}.user-message .message-text{color:#111827}.assistant-message .message-content{background-color:#fff;margin-left:0;margin-right:120px}.assistant-message .message-text{color:#374151}.typing{display:inline-flex;align-items:center;gap:6px}.typing .dot{width:6px;height:6px;border-radius:50%;background-color:#9ca3af;opacity:.4;animation:typing-bounce 1.2s infinite ease-in-out}.typing .dot:nth-child(1){animation-delay:0s}.typing .dot:nth-child(2){animation-delay:.15s}.typing .dot:nth-child(3){animation-delay:.3s}@keyframes typing-bounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-4px);opacity:1}}.message-actions{align-self:flex-end;margin-top:8px;position:relative;display:flex;gap:4px}.copy-button{background:none;border:none;color:#999;cursor:pointer;font-size:16px;padding:4px}.copy-button:hover{color:#fff}.regenerate-button{background:none;border:none;color:#999;cursor:pointer;font-size:15px;padding:4px}.regenerate-button:hover{color:#fff}.regenerate-menu{position:absolute;bottom:calc(100% + 8px);right:0;background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;width:140px;padding:8px;z-index:10}.regenerate-menu-button{background:none;border:none;color:#374151;cursor:pointer;padding:8px 12px;text-align:left;border-radius:4px;font-size:14px}.regenerate-menu-button:hover{background-color:#f3f4f6}.message-text>*+*{margin-top:1em}.message-text p{margin:0}.message-text table{width:100%;border-collapse:collapse;margin-top:0;margin-bottom:16px}.message-text th,.message-text td{border:1px solid #ddd;padding:8px;text-align:left}.message-text th{background-color:#f2f2f2;color:#333}.message-text ul,.message-text ol{margin:.5em 0;padding-left:1.5em}.message-text li{margin:.25em 0;line-height:1.6}.message-text ul ul,.message-text ol ol,.message-text ul ol,.message-text ol ul{margin:.25em 0;padding-left:1.5em}.message-text h1,.message-text h2,.message-text h3,.message-text h4,.message-text h5,.message-text h6{margin-top:1.5em;margin-bottom:.5em}.message-text h1+ul,.message-text h1+ol,.message-text h2+ul,.message-text h2+ol,.message-text h3+ul,.message-text h3+ol,.message-text h4+ul,.message-text h4+ol,.message-text h5+ul,.message-text h5+ol,.message-text h6+ul,.message-text h6+ol{margin-top:.5em}.message-input-container{position:sticky;bottom:0;padding:16px 16px 20px;background:linear-gradient(0deg,#fff,#ffffffe6,#fff0)}.message-input-form{max-width:800px;margin:0 auto;padding:0}.attachments-list{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 8px}.attachment-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid #e5e7eb;color:#111827;border-radius:9999px;padding:6px 10px;font-size:12px}.remove-attachment{background:none;border:none;color:#9ca3af;cursor:pointer;border-radius:9999px;width:18px;height:18px;line-height:18px;text-align:center}.remove-attachment:hover{background:#fff;color:#ef4444}.input-wrapper{position:relative;background-color:#fff;border-radius:20px;border:1px solid #d1d5db;display:flex;align-items:center;padding:10px 48px 10px 42px;transition:border-color .2s,box-shadow .2s}.input-wrapper:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.message-textarea{flex:1;background:none;border:none;outline:none;color:#1f2937;font-size:15px;line-height:1.5;resize:none;max-height:220px;overflow-y:auto}.message-textarea::placeholder{color:#9ca3af}.send-button{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:32px;height:32px;border:none;border-radius:8px;background-color:#3b82f6;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.send-button:hover:not(:disabled){background-color:#2563eb}.send-button:disabled{background-color:#fff;cursor:not-allowed}.input-hint{max-width:800px;margin:8px auto 0;color:#9ca3af;font-size:12px;text-align:center}.left-actions{position:absolute;left:8px;top:50%;transform:translateY(-50%);display:flex;align-items:center}.attach-button{width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:#6b7280;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.attach-button:hover{background:#fff}.hidden-file-input{display:none}.dropzone-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#fffc;border:2px dashed #3b82f6;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#3b82f6;z-index:10;margin:16px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:16px;height:16px;border:2px solid rgba(59,130,246,.3);border-radius:50%;border-top-color:#3b82f6;animation:spin 1s linear infinite}.attachment-spinner{width:14px;height:14px;border:2px solid rgba(59,130,246,.3);border-radius:50%;border-top-color:#3b82f6;animation:spin 1s linear infinite}.top-bar{position:sticky;top:0;z-index:10;background:linear-gradient(180deg,#fff,#ffffffe6 80%,#fff0);border-bottom:1px solid rgba(229,231,235,.6);padding:10px 16px}.top-bar-inner{max-width:1000px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}.top-bar-left{display:flex;align-items:center;gap:10px}.top-bar-title{font-size:14px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.model-pill{border:1px solid #e5e7eb;background:#fff;color:#6b7280;border-radius:9999px;padding:4px 8px;font-size:12px}.top-bar-right{display:flex;align-items:center;gap:10px}.header-icon-btn{width:32px;height:32px;border:none;background:transparent;border-radius:8px;color:#6b7280;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.header-icon-btn:hover{background:#fff}.user-chip{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:9999px;padding:4px 8px 4px 4px}.avatar-circle{width:24px;height:24px;border-radius:9999px;background:#3b82f6;color:#fff;font-size:12px;display:inline-flex;align-items:center;justify-content:center}.user-meta{display:flex;flex-direction:column;line-height:1.1}.user-name{font-size:12px;color:#111827}.user-status{font-size:11px;color:#6b7280;display:inline-flex;align-items:center;gap:4px}.online-dot{width:8px;height:8px;border-radius:9999px;background:#10b981}.chat-area{flex:1;min-width:0;display:flex;flex-direction:column;background-color:#fff}.welcome-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.welcome-content{text-align:center;max-width:100%;width:100%;padding:0 16px}.welcome-content h1{font-size:32px;margin-bottom:16px;color:#111827;font-weight:600}.welcome-content p{font-size:16px;color:#6b7280;margin-bottom:32px}.suggestions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;max-width:800px;margin:0 auto 16px}.suggestion-card{background-color:#fff;border:1px solid #e5e7eb;color:#111827;text-align:left;border-radius:12px;padding:14px 16px;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .05s}.suggestion-card:hover{border-color:#d1d5db}.suggestion-card:active{transform:translateY(1px)}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:modal-fade-in .2s ease-out}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;width:90%;max-height:90vh;overflow:hidden;animation:modal-slide-in .2s ease-out}.modal-header{padding:24px 24px 0}.modal-title{margin:0;font-size:18px;font-weight:600;color:#1f2937}.modal-body{padding:16px 24px}.modal-message{margin:0;font-size:14px;line-height:1.5;color:#6b7280}.modal-footer{padding:0 24px 24px;display:flex;justify-content:flex-end;gap:12px}.modal-btn{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:all .2s ease}.modal-btn-cancel{background-color:#fff;color:#6b7280;border:1px solid #d1d5db}.modal-btn-cancel:hover{background-color:#fff;border-color:#9ca3af}.modal-btn-confirm{background-color:#ef4444;color:#fff}.modal-btn-confirm:hover{background-color:#dc2626}.modal-btn:focus{outline:2px solid #3b82f6;outline-offset:2px}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-slide-in{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width: 480px){.modal-content{margin:20px;width:calc(100% - 40px)}.modal-header,.modal-body,.modal-footer{padding-left:20px;padding-right:20px}.modal-footer{flex-direction:column-reverse}.modal-btn{width:100%}}.modal-content{background-color:#fff;border-radius:8px;width:700px;max-width:95%;box-shadow:0 5px 15px #0000004d;display:flex;flex-direction:column}.modal-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:20px;font-weight:600}.close-button{background:none;border:none;font-size:28px;cursor:pointer;color:#888}.modal-body{padding:20px;max-height:70vh;overflow-y:auto}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input[type=text],.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box;font-size:14px}.form-group textarea{min-height:120px;resize:vertical}.traits-container{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.trait-button{background-color:#fff;border:1px solid #ddd;border-radius:16px;padding:6px 12px;cursor:pointer;font-size:12px;transition:all .2s}.trait-button.active{background-color:#007bff;color:#fff;border-color:#007bff}.code-block{background-color:#fff;border:1px solid #ddd;padding:15px;border-radius:4px;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word}.code-block code{font-family:Courier New,Courier,monospace;font-size:13px}.modal-footer{padding:20px;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;gap:10px}.cancel-button,.save-button,.delete-all-button{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-weight:600}.cancel-button{background-color:#f0f0f0;color:#333;border:1px solid #ddd}.save-button{background-color:#007bff;color:#fff}.delete-all-button{background-color:#dc3545;color:#fff}.modal-footer>div{display:flex;gap:10px}.switch{position:relative;display:inline-block;width:50px;height:28px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#fff;transition:.4s;border:1px solid #ccc}.slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.4s}input:checked+.slider{background-color:#2196f3}input:checked+.slider:before{transform:translate(22px)}.slider.round{border-radius:34px}.slider.round:before{border-radius:50%}.app{display:flex;flex-direction:column;height:100vh;width:100vw;background-color:#fff;color:#111827}.app-main{display:flex;flex-grow:1;overflow:hidden}.app-unauthenticated{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background-color:#fff;color:#111827;text-align:center;padding:2rem}.app-unauthenticated h1{font-size:4rem;font-weight:700;margin:0;color:#111827;letter-spacing:-.05em}.app-unauthenticated p{font-size:1.25rem;margin:.5rem 0 2rem;color:#6b7280}.app-unauthenticated button{background-color:#4f46e5;color:#fff;border:none;padding:12px 24px;font-size:1.1rem;font-weight:600;cursor:pointer;border-radius:8px;transition:background-color .2s ease-in-out,transform .1s ease-in-out}.app-unauthenticated button:hover{background-color:#4338ca}.app-unauthenticated button:active{transform:scale(.98)}.auth-error-message{background-color:#d13438;color:#fff;padding:12px 16px;border-radius:6px;margin-bottom:1rem;text-align:center;font-size:.95rem;border:1px solid #e81123}.auth-error-banner{background-color:#d13438;color:#fff;padding:8px 16px;display:flex;align-items:center;justify-content:space-between;font-size:.9rem;border-bottom:1px solid #e81123;position:sticky;top:0;z-index:1000}.auth-error-banner p{margin:0;flex-grow:1}.re-auth-button{background-color:#fff;color:#d13438;border:1px solid #ffffff;padding:6px 12px;font-size:.85rem;font-weight:600;cursor:pointer;border-radius:4px;margin-left:12px;transition:background-color .2s ease-in-out}.re-auth-button:hover{background-color:#fff}.app-main.project-view-active{grid-template-columns:260px 1fr auto}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:24px;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.modal-content h2{margin-top:0;margin-bottom:16px;font-size:20px;color:#333}.modal-content input{width:100%;padding:10px;border:1px solid #ccc;border-radius:4px;font-size:16px;margin-bottom:16px}.modal-actions{display:flex;justify-content:flex-end;gap:12px}.modal-actions button{padding:10px 16px;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500}.modal-actions button[type=submit]{background-color:#4f46e5;color:#fff}.modal-actions button[type=button]{background-color:#fff;color:#374151}.project-view{display:flex;flex-direction:column;flex-grow:1;width:0;padding:2rem;height:100%;overflow-y:auto;background-color:#fff}.project-view-header{margin-bottom:2rem}.project-view-header h1{font-size:2rem;font-weight:700;color:#111827;margin:0}.project-view-content{display:grid;grid-template-columns:1fr;gap:2rem}.project-files-section,.project-conversations-section{background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem;position:relative}.project-view h2{font-size:1.125rem;font-weight:600;color:#374151;margin-top:0;margin-bottom:0}.project-files-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.upload-btn{background-color:#f3f4f6;color:#374151;border:none;border-radius:50%;width:28px;height:28px;font-size:20px;line-height:28px;text-align:center;cursor:pointer;transition:background-color .2s}.upload-btn:hover{background-color:#e5e7eb}.upload-indicator{padding:1rem;text-align:center;color:#6b7280;font-size:14px;background-color:#f9fafb;border-radius:8px;margin-bottom:1rem}.dropzone-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#f9fafbe6;border:2px dashed #d1d5db;border-radius:12px;display:flex;align-items:center;justify-content:center;z-index:10;color:#374151;font-weight:500}.empty-files{text-align:center;padding:2rem;color:#6b7280;font-size:14px}.empty-files p{margin:.25rem 0}.file-list,.conversation-list{list-style:none;padding:0;margin:0;max-height:400px;overflow-y:auto}.file-list li,.conversation-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px;font-size:14px;color:#4b5563;border-bottom:1px solid #f3f4f6}.file-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px;font-size:14px;color:#4b5563;border-bottom:1px solid #f3f4f6;transition:background-color .2s}.file-list-item:hover{background-color:#f9fafb}.file-name{flex:1;margin-right:8px}.file-list-item .delete-btn{opacity:0;background:none;border:none;color:#9ca3af;cursor:pointer;font-size:16px;transition:opacity .2s;padding:4px;border-radius:4px}.file-list-item:hover .delete-btn{opacity:1}.file-list-item .delete-btn:hover{color:#ef4444;background-color:#fef2f2}.conversation-list-item{cursor:pointer;transition:background-color .2s;border-radius:6px}.conversation-list-item:hover{background-color:#f9fafb}.conversation-list-item .delete-btn{opacity:0;background:none;border:none;color:#9ca3af;cursor:pointer;font-size:16px;transition:opacity .2s}.conversation-list-item:hover .delete-btn{opacity:1}.file-list p,.conversation-list p{font-size:14px;color:#6b7280;margin-top:8px;text-align:center;padding:2rem}.project-view-footer{margin-top:auto;padding-top:1rem;border-top:1px solid #e5e7eb}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#fff;color:#374151;height:100vh;overflow:hidden}#root{height:100vh;width:100vw;display:flex}
