.layout-root{display:flex;flex-direction:column;height:100vh;overflow:hidden}.layout-header{height:64px;padding:0 24px;background-color:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.header-logo{width:40px;height:40px}.header-title{font-size:20px;font-weight:700;color:#111827;font-family:sans-serif}.header-actions{display:flex;align-items:center;gap:16px;border:solid,2px,#f9fafb;border-radius:9999px;padding:5px 15px}.layout-body{display:flex;flex:1;overflow:hidden}.layout-sidebar{width:320px;height:100%;background-color:#fff;display:flex;flex-direction:column;padding:0;overflow:hidden}.layout-chat{flex:1;overflow-y:auto;background-color:#f9fafb;padding:0}.avatar-dropdown{position:absolute;top:56px;right:0;width:260px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 8px 24px #00000014;padding:12px;z-index:50}.dropdown-header{display:flex;align-items:center;gap:12px;padding:8px 4px 12px}.avatar-initials.large{width:40px;height:40px;font-size:14px;background-color:#f3f4f6;border:1px solid #e5e7eb;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:600;color:#374151}.greeting{font-size:13px;color:#111827;font-weight:500}.role{font-size:12px;color:#6b7280}.header-actions{display:flex;align-items:center;gap:16px}.notification-button{background:#f9fafb;border:none;padding:8px;border-radius:999px;position:relative;cursor:pointer}.notification-icon{width:20px;height:20px;color:#6b7280}.notification-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background-color:#ef4444;border-radius:50%}.avatar-button{width:36px;height:36px;border-radius:999px;background-color:#f9fafb;border:1px solid #e5e7eb;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:#374151;cursor:pointer}.avatar-initials{-webkit-user-select:none;user-select:none}.dropdown-divider{height:1px;background-color:#e5e7eb;margin:8px 0}.dropdown-item{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:#111827;padding:8px 6px;border-radius:8px;cursor:pointer;transition:background-color .15s ease}.dropdown-item .icon{margin-right:8px;font-size:16px}.dropdown-item kbd{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;padding:2px 6px;font-size:12px;color:#6b7280}.dropdown-item:hover{background-color:#f9fafb}.dropdown-item.signout{color:#b91c1c}.avatar-dropdown a.dropdown-item{display:flex;align-items:center;justify-content:space-between;font-size:14px;color:#111827;padding:8px 6px;border-radius:8px;cursor:pointer;text-decoration:none;transition:background-color .15s ease}.avatar-dropdown a.dropdown-item .icon{margin-right:8px;font-size:16px}.avatar-dropdown a.dropdown-item:hover{background-color:#f9fafb}.avatar-dropdown a.dropdown-item kbd{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;padding:2px 6px;font-size:12px;color:#6b7280}.sidebar{max-width:100%;height:100vh;background-color:#fff;border-right:1px solid #e5e7eb;display:flex;flex-direction:column;font-family:sans-serif;font-size:14px;overflow:hidden;padding:16px 16px 0;gap:16px;position:relative}.sidebar-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;margin-top:16px}.sidebar-logo{width:32px;height:32px}.sidebar-title{font-size:20px;font-weight:700;color:#111827}.sidebar-user{display:flex;align-items:center;background-color:#f6f4f233;padding:12px;border:1px solid #dfe1e7;border-radius:12px;margin-bottom:16px;gap:12px}.sidebar-avatar{width:40px;height:40px;border-radius:50%}.sidebar-user-info{flex-grow:1}.sidebar-user-name{font-weight:500}.sidebar-user-org{font-size:12px;background-color:#dbeafe;color:#1d4ed8;padding:2px 8px;border-radius:6px;display:inline-block;margin-top:4px}.sidebar-arrow{font-size:18px;color:#9ca3af}.sidebar-search-wrapper{display:flex;align-items:center;gap:8px;margin-bottom:20px}.sidebar-search{flex:1;padding:8px 12px;border:1px solid #d1d5db;border-radius:8px}.sidebar-search-shortcut{font-size:12px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;padding:2px 6px;color:#6b7280}.sidebar-newchat{display:flex;align-items:center;justify-content:space-between;border:1px solid #e5e7eb;border-radius:8px;padding:10px 12px;margin-bottom:16px;cursor:pointer;background-color:#f9fafb;transition:background-color .2s ease}.sidebar-newchat:hover{background-color:#f3f4f6}.sidebar-newchat .icon{width:16px;height:16px;margin-right:8px}.sidebar-newchat .label{flex-grow:1;font-weight:500;color:#111827}.sidebar-newchat .shortcut{background:#f3f4f6;border-radius:6px;padding:2px 6px;font-size:12px;color:#6b7280}.sidebar-chatlist{list-style:none;padding:0;margin:0;flex-grow:1;overflow-y:auto;min-height:0}.sidebar-chatitem{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background-color .2s ease}.sidebar-chatitem.active{background-color:#f3f4f6;font-weight:600}.sidebar-chat-meta{display:flex;flex-direction:column;overflow:hidden}.sidebar-chat-title{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-chat-time{font-size:12px;color:#9ca3af}.sidebar-chat-icon{width:16px;height:16px;margin-left:8px}.sidebar-icon{width:16px;height:16px;margin-right:8px}.sidebar-section-title{font-size:12px;text-transform:uppercase;color:#9ca3af;margin:16px 0 4px}.sidebar-settings{position:absolute;bottom:0;left:0;right:0;padding:12px 20px;border-top:1px solid #e5e7eb;background-color:#fff;box-sizing:border-box}.settings-item{display:flex;align-items:center;cursor:pointer;color:#374151;font-size:14px;text-decoration:none;padding:10px 12px;border-radius:8px;transition:background-color .2s ease}.settings-item:hover{background-color:#f9fafb}.settings-item.active{background-color:#f3f4f6;font-weight:600}.settings-icon{width:18px;height:18px;margin-right:10px;flex-shrink:0}.input-bar-container{padding:16px;border-top:1px solid #e5e7eb;background-color:#fff}.input-wrapper{position:relative;background-color:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:12px 48px 12px 16px}.chat-input{width:100%;border:none;resize:none;font-size:14px;line-height:1.5;outline:none;background:transparent}.send-button{position:absolute;top:12px;right:12px;background-color:#111827;color:#fff;border:none;border-radius:8px;width:32px;height:32px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}.send-button:hover{background-color:#1f2937}.input-meta{display:flex;justify-content:space-between;margin-top:8px;padding:0 4px;font-size:13px;color:#6b7280}.model-select{display:flex;align-items:center;gap:6px;cursor:pointer}.dropdown-icon{font-size:10px}.add-content{display:flex;align-items:center;gap:4px;cursor:pointer}.messages{flex:1 1 auto;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;height:100%;min-height:0;scroll-behavior:smooth}.message-row{display:flex;align-items:flex-start;gap:12px;margin:24px 0}.message-avatar img{width:32px;height:32px;border-radius:50%}.message-block{display:flex;flex-direction:column;flex:1}.message-user{display:flex;flex-direction:column;background-color:#fdfdfc;border:1px solid #dfe1e7;border-radius:16px;padding:16px;max-width:600px;box-shadow:0 1px 2px #0d0d120f;text-align:left}.message-user-header{display:flex;justify-content:space-between;font-size:13px;color:#6b7280;margin-bottom:8px}.message-user-sender{font-weight:600;color:#111827}.message-user-timestamp{color:#9ca3af}.message-ai{display:flex;flex-direction:column;max-width:600px}.message-ai-header{display:flex;justify-content:space-between;font-size:13px;color:#6b7280;margin-bottom:6px}.message-ai-sender{font-weight:600;color:#111827}.message-text{font-size:14px;line-height:1.6;color:#111827;text-align:left;margin:0}.message-actions{display:flex;gap:12px;margin-top:12px;font-size:16px;color:#6b7280}.message-actions button{background:none;border:none;cursor:pointer;color:inherit;transition:color .2s ease}.message-actions button:hover{color:#111827}.chart-container{height:300px;margin-top:16px;border:1px solid #e5e7eb;border-radius:12px;background-color:#fff;padding:16px;box-shadow:0 1px 4px #0000000d}.chart-error{padding:1rem;color:#dc2626;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-top:16px}html,body,#root{height:100%;margin:0;padding:0}.app{display:flex;height:100vh}.chat-section{flex:1;display:flex;flex-direction:column;height:100vh}.login-page{display:flex;flex-direction:row;font-family:sans-serif;background-color:#fff;min-height:100vh}.login-form-section{width:50%;padding:80px;display:flex;flex-direction:column;justify-content:center}.brand{display:flex;align-items:center;gap:12px;margin-bottom:32px}.logo{width:32px;height:32px}.brand-name{font-size:24px;font-weight:700}.welcome-title{font-size:28px;font-weight:600;margin-bottom:8px}.subtitle{font-size:14px;color:#6b7280;margin-bottom:32px;max-width:360px}.login-form{display:flex;flex-direction:column;gap:20px}.login-form label{display:flex;flex-direction:column;font-size:14px;color:#374151}.login-form input[type=email],.login-form input[type=password]{padding:12px;border-radius:8px;border:1px solid #d1d5db;margin-top:6px;font-size:14px}.login-options{display:flex;justify-content:space-between;font-size:13px;align-items:center}.remember-me{display:flex;align-items:center;gap:6px}.forgot-password{color:#2563eb;text-decoration:none;font-size:13px}.sign-in-btn{padding:12px;border:none;border-radius:8px;background-color:#2563eb;color:#fff;font-weight:500;font-size:14px;cursor:pointer}.oauth-container{margin-top:16px}.google-signin-btn{width:100%;border:1px solid #e5e7eb;background-color:#fff;color:#111827;font-size:14px;font-weight:500;padding:12px;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:background-color .2s ease}.google-signin-btn img{width:20px;height:20px}.google-signin-btn:hover{background-color:#f9fafb}.signup-link{font-size:13px;margin-top:16px}.signup-link a{color:#2563eb;text-decoration:none}.footer{font-size:12px;color:#9ca3af;margin-top:auto}.testimonial-section{width:50%;padding:80px;display:flex;flex-direction:column;justify-content:center}.testimonial-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:16px}.testimonial-section blockquote{font-size:20px;line-height:1.6;font-weight:500;color:#111827;max-width:600px;margin:0}.stars{display:flex;gap:4px;margin-top:4px}.star-icon{width:20px;height:20px;display:block}.testimonial-author{font-size:14px;color:#6b7280;display:block;margin-top:12px}.mockup{width:100%;border-radius:12px;border:1px solid #e5e7eb;margin-top:32px}@media (max-width: 768px){.login-page{flex-direction:column;align-items:center}.login-form-section,.testimonial-section{width:90%;padding:40px 24px}.testimonial-section{align-items:center;text-align:center}.testimonial-header{flex-direction:column;align-items:center}.testimonial-section blockquote{font-size:18px;max-width:100%}.mockup{margin-top:24px;max-width:100%;height:auto}}.settings-nav{display:flex;flex-direction:column;gap:8px}.settings-link{font-size:14px;padding:8px 12px;border-radius:6px;color:#374151;text-decoration:none;transition:background .2s}.settings-link:hover{background-color:#f3f4f6}.settings-link.active{background-color:#e0f2fe;color:#0284c7;font-weight:500}.users-container{max-width:640px;padding:24px}.users-title{font-size:20px;font-weight:700;color:#111827;margin-bottom:24px}.users-form{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.users-form input,.users-form select{padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#111827}.users-form .btn{align-self:flex-start;padding:10px 16px;background-color:#111827;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.users-form .btn:hover{background-color:#1f2937}.users-message{font-size:13px;color:#374151}.users-subtitle{font-size:16px;font-weight:600;margin-bottom:8px;color:#111827}.users-list{display:flex;flex-direction:column;gap:12px}.users-item{border:1px solid #e5e7eb;padding:16px;border-radius:12px;background-color:#fff}.users-item .name{font-weight:500;font-size:15px;color:#111827}.users-item .role{font-size:13px;color:#6b7280}.users-item img{margin-top:12px;width:48px;height:48px;border-radius:50%;object-fit:cover}.users-table-wrapper{overflow-x:auto;background:#fff;border:1px solid #e5e7eb;border-radius:12px}.users-table{width:100%;border-collapse:collapse;font-size:14px;color:#111827}.users-table thead{background-color:#f9fafb;border-bottom:1px solid #e5e7eb}.users-table th{text-align:left;padding:12px 16px;font-weight:600;font-size:13px;color:#6b7280}.users-table td{padding:12px 16px;border-top:1px solid #f3f4f6}.avatar-thumb{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid #e5e7eb}.role-select{padding:6px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background-color:#fff;color:#111827}.container{padding:2rem;max-width:1000px;margin:0 auto;font-family:sans-serif}h1,h2{margin-bottom:1rem;font-size:1.5rem;color:#111827}.form{margin-bottom:2rem;padding:1rem;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb}.form label{font-size:.95rem;font-weight:500;display:block;margin-bottom:.25rem}.form input,.form select{display:block;margin-bottom:.75rem;padding:.5rem;width:100%;font-size:1rem;border:1px solid #d1d5db;border-radius:6px;background-color:#fff}.form button{padding:.5rem 1.2rem;font-weight:600;background-color:#2563eb;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease}.form button:hover{background-color:#1d4ed8}.table-wrapper{overflow-x:auto;margin-top:2rem;border:1px solid #e5e7eb;border-radius:8px;background:#fff}table{width:100%;border-collapse:collapse;font-size:.95rem}table th,table td{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;text-align:left}table th{background-color:#f3f4f6;font-weight:600;color:#374151}table tr:last-child td{border-bottom:none}select{padding:.4rem;font-size:.95rem;border-radius:4px;border:1px solid #d1d5db}button.danger{background:#ef4444;color:#fff;border:none;padding:.4rem .8rem;border-radius:6px;font-weight:500;cursor:pointer;transition:background-color .2s ease}button.danger:hover{background:#b91c1c}.avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.message{margin-top:1rem;font-size:.95rem;color:#374151}.profile-container{max-width:600px;padding:24px}.profile-heading{font-size:24px;font-weight:700;margin-bottom:24px}.profile-card{display:flex;gap:24px;background:#fff;border:1px solid #e5e7eb;padding:24px;border-radius:12px;align-items:center}.profile-avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;border:1px solid #e5e7eb}.profile-avatar.initials{display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;font-weight:600;font-size:24px;color:#374151}.profile-info{display:flex;flex-direction:column;gap:8px}.profile-label{font-size:12px;color:#6b7280;text-transform:uppercase}.profile-value{font-size:16px;color:#111827;font-weight:500}
