body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;height:100vh}*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 10px 40px #0003;text-align:center;max-width:400px;width:90%}.login-box h1{margin-bottom:1rem;color:#333;font-size:2rem}.login-box p{color:#666;margin-bottom:1.5rem}.username-input{width:100%;padding:.875rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;margin-bottom:1rem;transition:border-color .3s}.username-input:focus{outline:none;border-color:#667eea}.join-button{width:100%;padding:.875rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s}.join-button:hover{transform:translateY(-2px)}.join-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-loading{color:#999;font-size:.875rem;margin:1rem 0}.auth0-login-btn{display:flex;align-items:center;justify-content:center;gap:.5rem}.guest-entry{display:flex;flex-direction:column;gap:.75rem;width:100%}.guest-name-input{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s;box-sizing:border-box}.guest-name-input:focus{border-color:#667eea}.guest-join-btn{background:linear-gradient(135deg,#34d399,#059669)!important}.login-divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0;color:#bbb;font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e0e0e0}.login-promo{text-align:center}.login-promo-text{font-size:.85rem;color:#666;margin-bottom:.75rem}.login-promo-text strong{color:#7c3aed}.server-status{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:20px;font-size:.875rem;font-weight:500;margin-bottom:1.25rem;justify-content:center}.server-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.server-status--checking{background:#f0f0f0;color:#888}.server-status--checking .server-status-dot{background:#aaa;animation:pulse 1.5s infinite}.server-status--online{background:#e8f5e9;color:#2e7d32}.server-status--online .server-status-dot{background:#4caf50}.server-status--offline{background:#fdecea;color:#c62828}.server-status--offline .server-status-dot{background:#e53935}.app-container{display:flex;height:100vh;background:#f5f5f5;position:relative}.reconnecting-banner{position:fixed;top:0;left:0;right:0;background:#ff9800;color:#fff;padding:.75rem;text-align:center;font-weight:600;z-index:1000;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.sidebar{width:320px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column}.sidebar-header{padding:1.25rem 1.5rem 1rem;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.sidebar-header-row1{display:flex;align-items:center;justify-content:space-between}.sidebar-header-row1 h2{font-size:1.2rem;margin:0}.sidebar-header-actions{display:flex;align-items:center;gap:.25rem}.sidebar-header-row2{display:flex;align-items:center;gap:.6rem;margin-top:.6rem}.header-username{flex:1;font-size:.85rem;font-weight:600;opacity:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;border-radius:4px;padding:.1rem .3rem;transition:background .15s}.header-username:hover{background:#ffffff26}.header-username-input{flex:1;font-size:.85rem;font-weight:600;background:#ffffffe6;color:#333;border:none;border-radius:4px;padding:.2rem .4rem;outline:none;min-width:0}.header-avatar-btn{background:none;border:2px solid rgba(255,255,255,.4);border-radius:50%;padding:0;cursor:pointer;flex-shrink:0;transition:border-color .15s,transform .15s}.header-avatar-btn:hover{border-color:#fffc;transform:scale(1.05)}.header-avatar-img{width:36px;height:36px;border-radius:50%;object-fit:cover;display:block}.header-avatar-initials{width:36px;height:36px;border-radius:50%;background:#ffffff40;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#fff}.credits-badge-mini{font-size:.7rem;font-weight:700;color:#ffffffe6;background:#ffffff2e;padding:.15rem .5rem;border-radius:10px;white-space:nowrap}.credits-badge-mini.credits-low{color:#fca5a5;background:#dc262640}.sidebar-header h2{font-size:1.25rem}.sidebar-header-actions{display:flex;gap:.25rem}.icon-button{background:#ffffff26;border:none;border-radius:6px;padding:.3rem .4rem;cursor:pointer;font-size:1rem;line-height:1;transition:background .15s}.icon-button:hover{background:#ffffff4d}.icon-button.active{background:#ffffff59}.icon-button.muted{opacity:.6}.settings-panel{padding:.875rem 1.25rem;background:#f8f8ff;border-bottom:1px solid #e0e0e0;display:flex;flex-direction:column;gap:.6rem}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.settings-label{font-size:.8125rem;color:#555;flex:1}.settings-value{font-size:.8125rem;color:#777;font-variant-numeric:tabular-nums}.settings-input{width:70px;padding:.25rem .5rem;border:1.5px solid #d0d0d0;border-radius:6px;font-size:.8125rem;text-align:right}.toggle-button{padding:.2rem .65rem;border-radius:20px;border:none;font-size:.75rem;font-weight:700;cursor:pointer;transition:all .15s}.toggle-button.on{background:#4caf50;color:#fff}.toggle-button.off{background:#bdbdbd;color:#fff}.danger-button{padding:.4rem .875rem;background:#fdecea;color:#c62828;border:1px solid #f5c6c6;border-radius:6px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .15s;align-self:flex-start}.danger-button:hover{background:#ffcdd2}.user-info-badge{display:flex;flex-direction:row;align-items:center;gap:.75rem;padding:.5rem 0}.anon-signin-area{display:flex;flex-direction:column;gap:.2rem}.user-avatar-img{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.4);flex-shrink:0}.user-avatar-initials{width:40px;height:40px;border-radius:50%;background:#ffffff40;border:2px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:#fff;flex-shrink:0}.profile-card{margin:.75rem 1rem;padding:.875rem;background:#ffffff1f;border-radius:12px;border:1px solid rgba(255,255,255,.18);display:flex;flex-direction:column;gap:.625rem}.profile-card-top{display:flex;align-items:center;gap:.75rem}.profile-avatar-img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.5);flex-shrink:0}.profile-avatar-initials{width:44px;height:44px;border-radius:50%;background:#ffffff40;border:2px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.15rem;color:#fff;flex-shrink:0}.profile-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.profile-name{font-weight:700;font-size:.95rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-email{font-size:.75rem;color:#ffffffb3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-badge{display:inline-block;background:#fff3;padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600}.user-id{display:inline-block;background:#ffffff26;padding:.25rem .75rem;border-radius:4px;font-size:.75rem;font-family:Courier New,monospace;word-break:break-all;opacity:.9}.logout-button{margin-top:.5rem;padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:4px;font-size:.875rem;cursor:pointer;transition:all .2s;width:100%}.logout-button:hover{background:#ffffff4d;border-color:#ffffff80}.sidebar-tabs{display:flex;border-bottom:1px solid #e0e0e0;background:#fff;flex-shrink:0}.sidebar-tab{flex:1;padding:.625rem .25rem;border:none;background:none;font-size:.8rem;font-weight:500;color:#888;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.sidebar-tab:hover{color:#667eea}.sidebar-tab.active{color:#667eea;border-bottom-color:#667eea;font-weight:600}.users-list{flex:1;overflow-y:auto}.users-section-label{padding:.5rem 1rem .25rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#999}.no-users{padding:2rem;text-align:center;color:#999}.user-item{display:flex;align-items:center;padding:.875rem 1.25rem;cursor:pointer;transition:background-color .15s;border-bottom:1px solid #f3f3f3;gap:.875rem}.user-item:hover{background:#f5f5fb}.user-item.selected{background:#eef;border-left:3px solid #667eea;padding-left:calc(1.25rem - 3px)}.user-avatar-wrapper{position:relative;flex-shrink:0}.user-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem;letter-spacing:0}.unread-badge{position:absolute;top:-4px;right:-4px;background:#e53935;color:#fff;border-radius:10px;font-size:.65rem;font-weight:700;padding:1px 5px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:2px solid white;line-height:1;pointer-events:none}.user-info{flex:1;min-width:0}.user-name{font-weight:600;margin-bottom:.2rem;color:#222;font-size:.9375rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-status{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:#777}.online-dot{display:inline-block;width:7px;height:7px;background:#4caf50;border-radius:50%;flex-shrink:0}.ai-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.ai-search-bar{display:flex;gap:.5rem;padding:.625rem .875rem;border-bottom:1px solid #f0f0f0;flex-shrink:0}.ai-search-input{flex:1;padding:.4rem .75rem;border:1.5px solid #e0e0e0;border-radius:20px;font-size:.8125rem;outline:none}.ai-search-input:focus{border-color:#667eea}.show-all-btn{padding:.35rem .75rem;border:1.5px solid #667eea;border-radius:20px;background:none;color:#667eea;font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}.show-all-btn:hover{background:#667eea;color:#fff}.ai-loading{padding:1rem;text-align:center;color:#999;font-size:.875rem}.models-list{flex:1;overflow-y:auto}.model-provider-group{border-bottom:1px solid #f5f5f5}.model-provider-label{padding:.375rem 1rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#aaa;background:#fafafa;position:sticky;top:0}.model-item{display:flex;align-items:center;padding:.625rem 1rem;cursor:pointer;gap:.75rem;transition:background .15s}.model-item:hover{background:#f5f5fb}.model-item.selected{background:#eef;border-left:3px solid #667eea;padding-left:calc(1rem - 3px)}.model-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#43e97b,#38f9d7);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.provider-logo{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-weight:800;font-size:.95rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.model-id{font-size:.7rem;color:#aaa;font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.agents-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.agents-list{flex:1;overflow-y:auto}.agent-avatar{background:linear-gradient(135deg,#f093fb,#f5576c);font-size:1rem}.group-avatar{background:linear-gradient(135deg,#43e97b,#38f9d7);font-size:1.1rem}.group-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#43e97b;margin-right:4px}.group-msg-sender{font-size:.7rem;color:#888;margin-bottom:2px;font-weight:600}.group-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#6c63ff;margin-right:4px}.group-members-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;color:#aaa;font-size:.8rem}.group-members-toggle:hover{color:#fff}.group-member-panel{background:#1e1e2e;border-bottom:1px solid #333;padding:8px 16px;max-height:200px;overflow-y:auto}.group-member-row{display:flex;align-items:center;gap:8px;padding:5px 0}.group-member-avatar{width:28px;height:28px;border-radius:50%;background:#6c63ff;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.group-member-name{flex:1;font-size:.85rem;color:#ddd}.group-owner-badge{font-size:.65rem;background:#6c63ff33;color:#a29bfe;padding:1px 6px;border-radius:8px;margin-left:6px}.group-kick-btn{background:none;border:none;color:#666;cursor:pointer;font-size:1rem;padding:2px 6px;border-radius:4px;line-height:1}.group-kick-btn:hover{color:#ff4757;background:#ff475720}.icon-picker{display:flex;gap:.25rem;flex-wrap:wrap}.icon-option{width:36px;height:36px;border-radius:8px;border:2px solid transparent;background:#f5f5f5;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s}.icon-option:hover{background:#eee}.icon-option.selected{border-color:#667eea;background:#eef}.member-picker{max-height:120px;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem}.member-picker-label{font-size:.75rem;color:#888;font-weight:600;margin-bottom:.125rem}.member-picker-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;cursor:pointer;padding:.125rem 0}.group-form{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;border-top:1px solid #e8e8e8}.new-group-btn{margin:.5rem .75rem;padding:.5rem;background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:transform .2s}.new-group-btn:hover{transform:scale(1.02)}.pending-mentions-bar{display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:#f0f4ff;border-radius:8px 8px 0 0;font-size:.75rem;flex-wrap:wrap}.pending-mentions-label{color:#667eea;font-weight:600;white-space:nowrap}.pending-mention-chip{display:inline-flex;align-items:center;gap:.2rem;background:#667eea;color:#fff;padding:.15rem .5rem;border-radius:12px;font-weight:500}.remove-mention-btn{background:none;border:none;color:#fffc;cursor:pointer;font-size:.85rem;padding:0 .1rem;line-height:1}.remove-mention-btn:hover{color:#fff}.agent-delete-btn{background:none;border:none;color:#bbb;font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;flex-shrink:0}.agent-delete-btn:hover{color:#e53935}.new-agent-btn{margin:.75rem;padding:.625rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s}.new-agent-btn:hover{opacity:.9}.agent-form{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;border-top:1px solid #e8e8e8}.agent-input,.agent-select,.agent-textarea{width:100%;padding:.5rem .75rem;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.875rem;font-family:inherit;outline:none;transition:border-color .2s}.agent-input:focus,.agent-select:focus,.agent-textarea:focus{border-color:#667eea}.agent-textarea{resize:vertical;min-height:70px}.agent-form-buttons{display:flex;gap:.5rem}.agent-save-btn{flex:1;padding:.5rem!important;font-size:.875rem!important}.ai-dot{display:inline-block;width:7px;height:7px;background:#43e97b;border-radius:50%;flex-shrink:0}.ai-typing{display:flex;gap:4px;padding:.625rem .9375rem;align-items:center}.ai-typing span{width:7px;height:7px;background:#aaa;border-radius:50%;animation:ai-bounce 1.2s infinite}.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}@keyframes ai-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.message.error-msg .message-content{background:#fdecea;color:#c62828;border-color:#f5c6c6}.input-area{position:relative;flex-shrink:0}.mention-dropdown{position:absolute;bottom:100%;left:0;right:0;background:#fff;border:1px solid #e0e0e0;border-top-left-radius:10px;border-top-right-radius:10px;box-shadow:0 -4px 16px #0000001a;z-index:100;overflow:hidden;max-height:280px;overflow-y:auto}.mention-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;cursor:pointer;font-size:.875rem;transition:background .1s}.mention-item:hover{background:#f5f5fb}.mention-type-badge{font-size:1rem;flex-shrink:0}.mention-label{color:#333;font-weight:500;flex:1}.mention-sublabel{font-size:.7rem;color:#aaa;font-weight:400}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.profile-modal{background:#fff;border-radius:20px;padding:2rem 1.75rem;width:320px;max-width:92vw;text-align:center;position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}.modal-close-btn{position:absolute;top:1rem;right:1rem;background:#f0f0f0;border:none;border-radius:50%;width:28px;height:28px;font-size:.85rem;cursor:pointer;color:#555;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background:#e0e0e0}.profile-modal-avatar{margin-bottom:.5rem}.profile-modal-avatar img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid #7c3aed}.profile-modal-initials{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#a855f7);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff}.profile-modal-name{font-size:1.2rem;font-weight:700;color:#1a1a1a}.profile-modal-email{font-size:.85rem;color:#666}.profile-modal-badge{display:inline-block;padding:.2rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;background:#ede9fe;color:#7c3aed;margin-top:.25rem}.profile-modal-credits{width:100%;background:#f8f4ff;border-radius:12px;padding:1rem;margin-top:.5rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}.profile-modal-credits-label{font-size:.8rem;color:#888;font-weight:500}.profile-modal-credits-value{font-size:1.75rem;font-weight:800;color:#7c3aed}.profile-modal-credits-value.credits-low{color:#dc2626}.profile-modal-actions{width:100%;margin-top:.5rem}.profile-modal-actions .logout-button{width:100%;margin-top:0;background:#ef4444;color:#fff;border:none;border-radius:10px;font-weight:600;padding:.6rem 1rem}.profile-modal-actions .logout-button:hover{background:#dc2626}.profile-card-top{display:flex;align-items:center;gap:.75rem;width:100%}.profile-avatar-btn{position:relative;background:none;border:none;padding:0;cursor:pointer;flex-shrink:0;border-radius:50%}.profile-avatar-btn:hover .profile-avatar-edit{opacity:1}.profile-avatar-edit{position:absolute;inset:0;border-radius:50%;background:#00000073;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#fff;opacity:0;transition:opacity .15s}.profile-open-btn{margin-left:auto;background:#ffffff26;border:none;border-radius:50%;width:28px;height:28px;color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.profile-open-btn:hover{background:#ffffff4d}.upgrade-modal{background:#fff;border-radius:16px;padding:2rem 2.25rem;max-width:380px;width:90%;text-align:center;box-shadow:0 20px 60px #0003}.upgrade-modal-icon{font-size:2.5rem;margin-bottom:.75rem}.upgrade-modal h3{font-size:1.25rem;font-weight:700;color:#222;margin-bottom:.625rem}.upgrade-modal p{font-size:.9rem;color:#666;line-height:1.55;margin-bottom:1.5rem}.upgrade-modal-actions{display:flex;flex-direction:column;gap:.625rem}.upgrade-btn{padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:opacity .15s}.upgrade-btn:hover{opacity:.9}.dismiss-btn{padding:.625rem;background:none;border:none;color:#999;font-size:.875rem;cursor:pointer;transition:color .15s}.dismiss-btn:hover{color:#555}.secondary-upgrade-btn{padding:.625rem 1.25rem;background:#f0f0f5;color:#555;border:1px solid #ddd;border-radius:8px;font-size:.9rem;cursor:pointer;transition:background .15s}.secondary-upgrade-btn:hover{background:#e5e5ef}.credit-packages{display:flex;gap:.6rem;justify-content:center;margin-bottom:.5rem}.credit-package-btn{flex:1;padding:.7rem 0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.credit-package-btn:hover{opacity:.85}.credits-badge{font-size:.7rem;color:#5a6abf;background:#eef0ff;border-radius:999px;padding:.15rem .5rem;cursor:pointer;transition:background .15s;white-space:nowrap}.credits-badge:hover{background:#dce0ff}.credits-badge.credits-low{color:#c0392b;background:#fdecea}.credits-badge.credits-low:hover{background:#f9d5d3}.upgrade-banner{display:block;width:auto;margin:.4rem .75rem;padding:.45rem .75rem;background:linear-gradient(135deg,#667eea18,#764ba218);border:1px solid #667eea30;border-radius:8px;font-size:.78rem;color:#555;text-align:center;cursor:pointer;transition:background .15s,border-color .15s}.upgrade-banner:hover{background:linear-gradient(135deg,#667eea28,#764ba228);border-color:#667eea50;color:#333}.upgrade-banner strong{color:#7c3aed}.sync-banner{display:flex;align-items:center;gap:.5rem;margin:.4rem .75rem;padding:.4rem .75rem;background:#fef3c7;border:1px solid #f59e0b40;border-radius:8px;font-size:.75rem;color:#92400e}.sync-retry-btn{background:#f59e0b;color:#fff;border:none;border-radius:5px;padding:.2rem .6rem;font-size:.72rem;font-weight:600;cursor:pointer;margin-left:auto}.sync-retry-btn:hover{background:#d97706}.register-google-btn{width:100%;padding:.5rem .75rem;background:#fff;color:#333;border:1px solid #ddd;border-radius:7px;font-size:.8rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,box-shadow .15s}.register-google-btn:hover{background:#f8f8f8;box-shadow:0 1px 3px #0000001a}.register-email-btn{width:100%;padding:.45rem .75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:7px;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .15s}.register-email-btn:hover{opacity:.88}.signin-link-btn{background:none;border:none;color:#667eea;font-size:.73rem;cursor:pointer;text-align:center;padding:.1rem 0;text-decoration:underline}.signin-link-btn:hover{color:#764ba2}.chat-container{flex:1;display:flex;flex-direction:column;background:#fff}.no-chat-selected{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#bbb;gap:.5rem;font-size:.95rem}.no-chat-selected h2{color:#999;font-size:1.25rem;font-weight:600}.chat-header{padding:1rem 1.5rem;border-bottom:1px solid #ebebeb;background:#fff;display:flex;align-items:center}.chat-user-info{display:flex;align-items:center;gap:.875rem}.chat-username{font-weight:600;font-size:1rem;margin-bottom:.15rem;color:#222}.chat-status{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:#777}.messages-container{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;background:#f7f7fb;display:flex;flex-direction:column}.message{margin-bottom:.625rem;display:flex;flex-direction:column;max-width:68%}.message.sent{align-self:flex-end;align-items:flex-end}.message.received{align-self:flex-start;align-items:flex-start}.message-content{padding:.625rem .9375rem;border-radius:16px;word-wrap:break-word;line-height:1.45;font-size:.9375rem}.message.sent .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.message.received .message-content{background:#fff;color:#222;border:1px solid #e8e8e8;border-bottom-left-radius:4px;box-shadow:0 1px 2px #0000000a}.markdown-body>*{margin:0}.markdown-body>*+*{margin-top:.4em}.markdown-body p{line-height:1.5}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4{font-weight:600;line-height:1.3}.markdown-body h1{font-size:1.2em}.markdown-body h2{font-size:1.1em}.markdown-body h3{font-size:1em}.markdown-body ul,.markdown-body ol{padding-left:1.4em}.markdown-body li+li{margin-top:.2em}.markdown-body code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.85em;padding:.15em .35em;border-radius:4px}.message.sent .markdown-body code{background:#fff3}.message.received .markdown-body code{background:#f0f0f5;color:#c7254e}.markdown-body pre{border-radius:6px;padding:.7em .9em;overflow-x:auto;margin-top:.5em}.markdown-body pre code{padding:0;border-radius:0;font-size:.82em}.message.sent .markdown-body pre{background:#00000040}.message.received .markdown-body pre{background:#f6f8fa;border:1px solid #e1e4e8}.markdown-body blockquote{padding-left:.8em;margin-left:0;font-style:italic;opacity:.85}.message.sent .markdown-body blockquote{border-left:3px solid rgba(255,255,255,.5)}.message.received .markdown-body blockquote{border-left:3px solid #ccc;color:#555}.markdown-body a{text-decoration:underline;word-break:break-all}.message.sent .markdown-body a{color:#dde}.message.received .markdown-body a{color:#5a6abf}.markdown-body hr{border:none;border-top:1px solid;margin:.6em 0;opacity:.3}.markdown-body table{border-collapse:collapse;font-size:.87em;width:100%;margin-top:.4em}.markdown-body th,.markdown-body td{padding:.3em .6em;text-align:left}.message.sent .markdown-body th,.message.sent .markdown-body td{border:1px solid rgba(255,255,255,.3)}.message.received .markdown-body th,.message.received .markdown-body td{border:1px solid #ddd}.message.sent .markdown-body th{background:#00000026}.message.received .markdown-body th{background:#f6f8fa}.markdown-body strong{font-weight:600}.markdown-body em{font-style:italic}.markdown-body del{text-decoration:line-through;opacity:.75}.message-time{font-size:.7rem;color:#bbb;margin-top:.2rem;padding:0 .375rem}.message-attachment{margin-top:.375rem}.attachment-image{max-width:240px;max-height:200px;border-radius:10px;display:block;object-fit:cover}.attachment-file{display:inline-flex;align-items:center;gap:.375rem;padding:.4rem .75rem;background:#fff3;border-radius:8px;font-size:.875rem;color:inherit;text-decoration:none;border:1px solid rgba(255,255,255,.35);word-break:break-all}.message.received .attachment-file{background:#f0f0f8;border-color:#ddd;color:#444}.load-older-btn{display:block;margin:.75rem auto;padding:.4rem 1rem;background:#6c5ce71a;color:#6c5ce7;border:1px solid rgba(108,92,231,.3);border-radius:1rem;font-size:.8rem;cursor:pointer;transition:background .2s}.load-older-btn:hover:not(:disabled){background:#6c5ce733}.load-older-btn:disabled{opacity:.5;cursor:default}.attachment-unavailable{font-size:.8rem;color:#888;padding:.3rem .5rem;background:#0000000d;border-radius:.4rem;font-style:italic}.attachment-note{font-size:.75rem;opacity:.7}.pending-attachment-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.25rem;background:#f5f5ff;border-top:1px solid #ebebeb}.pending-attachment-thumb{width:48px;height:48px;object-fit:cover;border-radius:6px;flex-shrink:0}.pending-attachment-name{font-size:.875rem;color:#555;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.remove-attachment-btn{background:#e0e0e0;border:none;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:#555;flex-shrink:0;line-height:1}.remove-attachment-btn:hover{background:#ccc}.extracted-ok{font-size:.7rem;background:#e8f5e9;color:#2e7d32;border-radius:4px;padding:1px 5px;margin-left:4px;font-weight:500}.message-input-container{display:flex;align-items:center;padding:1rem 1.25rem;border-top:1px solid #ebebeb;background:#fff;gap:.75rem}.attach-button{background:none;border:none;cursor:pointer;font-size:1.25rem;padding:.25rem;opacity:.65;transition:opacity .15s;flex-shrink:0;line-height:1}.attach-button:hover{opacity:1}.message-input{flex:1;padding:.75rem 1.125rem;border:1.5px solid #e0e0e0;border-radius:24px;font-size:.9375rem;margin-right:0;transition:border-color .3s}.message-input:focus{outline:none;border-color:#667eea}.send-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:24px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .15s;white-space:nowrap;flex-shrink:0}.send-button:hover{opacity:.9;transform:translateY(-1px)}.send-button:active{transform:translateY(0);opacity:1}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}@media (max-width: 768px){.app-container{flex-direction:column;height:100dvh}.sidebar{width:100%;flex-shrink:0;border-right:none;border-bottom:1px solid #e8e8e8;display:flex;flex-direction:column}.sidebar-header{padding:.5rem .75rem}.sidebar-header-row1{gap:.5rem}.header-title-area h2{font-size:1rem}.sidebar-header h2{font-size:.875rem}.icon-button{padding:.2rem .3rem;font-size:.875rem}.settings-panel{padding:.5rem .75rem;gap:.375rem}.settings-label,.settings-value{font-size:.75rem}.settings-input{width:60px;font-size:.75rem}.toggle-button{font-size:.7rem;padding:.15rem .5rem}.danger-button{font-size:.75rem;padding:.3rem .625rem}.user-info-badge{flex-direction:row;flex-wrap:nowrap;gap:.375rem;align-items:center}.user-badge{font-size:.75rem;padding:.2rem .5rem}.user-id{display:none}.logout-button{width:auto;margin-top:0;padding:.2rem .5rem;font-size:.7rem}.sidebar-tabs{overflow-x:auto}.sidebar-tab{font-size:.7rem;padding:.5rem .25rem}.users-list{display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;padding:.375rem .5rem;gap:.375rem;flex-shrink:0}.users-list::-webkit-scrollbar{height:0}.user-item{flex-direction:column;align-items:center;padding:.375rem .5rem;min-width:60px;gap:.25rem;border-bottom:none;border-radius:8px;text-align:center}.user-item.selected{border-left:none;padding-left:.5rem;border:2px solid #667eea;background:#eef}.ai-panel,.agents-panel{flex-direction:column;max-height:120px}.ai-search-bar{padding:.375rem .5rem;flex-shrink:0}.models-list,.agents-list{display:flex;flex-direction:row;overflow-x:auto;overflow-y:hidden;padding:.375rem .5rem;gap:.375rem}.model-provider-group{display:contents}.model-provider-label{display:none}.model-item,.user-item{flex-direction:column;align-items:center;min-width:60px;padding:.375rem .5rem;text-align:center}.model-id{display:none}.new-agent-btn{margin:.25rem .5rem;padding:.375rem .5rem;font-size:.75rem;flex-shrink:0}.agent-form{padding:.5rem}.user-avatar-wrapper{margin-right:0;margin-bottom:0}.user-avatar{width:36px;height:36px;font-size:.875rem}.user-name{font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56px;margin-bottom:0}.user-status{display:none}.chat-container{flex:1;min-height:0;display:flex;flex-direction:column}.chat-header{padding:.5rem .75rem;flex-shrink:0}.chat-user-info{gap:.5rem}.chat-username{font-size:.9rem}.user-avatar+div .chat-username{font-size:.875rem}.messages-container{flex:1;min-height:0;padding:.5rem;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.message{max-width:82%;margin-bottom:.375rem}.message.sent{align-self:flex-end;margin-right:0}.message-content{padding:.5rem .75rem;font-size:.9rem}.message-time{font-size:.65rem;padding:0 .25rem}.attachment-image{max-width:180px;max-height:150px}.pending-attachment-bar{padding:.375rem .5rem}.pending-attachment-thumb{width:36px;height:36px}.attach-button{font-size:1.1rem}.message-input-container{padding:.5rem;gap:.375rem;flex-shrink:0}.message-input{padding:.5rem .75rem;font-size:16px}.send-button{padding:.5rem .75rem;font-size:.875rem}.login-container{padding:1rem}.login-box{padding:1.5rem 1.25rem;margin:0}.login-box h1{font-size:1.375rem}}.toast-container{position:fixed;top:1rem;right:1rem;z-index:10000;display:flex;flex-direction:column;gap:.5rem;max-width:380px}.toast{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:12px;background:#fff;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;font-size:.85rem;color:#333;animation:toast-slide-in .3s ease-out;border-left:4px solid transparent}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:#22c55e}.toast-error{border-left-color:#ef4444}.toast-warning{border-left-color:#f59e0b}.toast-info{border-left-color:#667eea}.toast-icon{font-size:1rem;flex-shrink:0}.toast-message{flex:1;line-height:1.4}.toast-close{background:none;border:none;font-size:1.1rem;color:#999;cursor:pointer;padding:0 .2rem;flex-shrink:0}.toast-close:hover{color:#555}.credits-modal{background:#fff;border-radius:20px;padding:2rem 2rem 1.5rem;max-width:420px;width:92%;box-shadow:0 24px 64px #0003;position:relative}.credits-balance-section{text-align:center;margin-bottom:1.5rem}.credits-balance-label{font-size:.8rem;color:#888;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem}.credits-balance-amount{font-size:2.5rem;font-weight:800;color:#222;line-height:1.1}.credits-balance-amount.credits-low{color:#f59e0b}.credits-balance-amount.credits-critical{color:#ef4444}.credits-member-tag{display:inline-block;margin-top:.5rem;padding:.25rem .75rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;border-radius:999px;font-size:.75rem;font-weight:700}.credits-warning-tag{display:inline-block;margin-top:.4rem;color:#f59e0b;font-size:.78rem;font-weight:600}.credits-empty-tag{display:inline-block;margin-top:.4rem;color:#ef4444;font-size:.78rem;font-weight:600}.credits-info-row{display:flex;gap:1rem;justify-content:center;margin-bottom:1.25rem;padding:.6rem .75rem;background:#f8f9fa;border-radius:10px}.credits-info-item{display:flex;align-items:center;gap:.35rem;font-size:.78rem;color:#666}.credits-info-icon{font-size:.9rem}.credits-section-title{font-size:.8rem;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.6rem}.credits-packages-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.credits-package-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:.9rem .5rem;background:#f8f9fa;border:2px solid #eee;border-radius:12px;cursor:pointer;transition:all .15s}.credits-package-card:hover{border-color:#667eea;background:#f0f0ff;transform:translateY(-1px)}.credits-package-card.popular{border-color:#667eea;background:linear-gradient(135deg,#667eea08,#764ba208)}.credits-popular-tag{position:absolute;top:-8px;right:-4px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.6rem;font-weight:700;padding:.15rem .4rem;border-radius:6px}.credits-package-price{font-size:1.25rem;font-weight:800;color:#333}.credits-package-desc{font-size:.7rem;color:#888}.credits-membership-section{margin-top:.25rem;margin-bottom:.5rem}.credits-membership-card{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf2440;border-radius:12px;cursor:pointer;transition:all .15s}.credits-membership-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #fbbf2440}.credits-membership-left{display:flex;align-items:center;gap:.6rem}.credits-membership-icon{font-size:1.4rem}.credits-membership-title{font-size:.85rem;font-weight:700;color:#92400e}.credits-membership-desc{font-size:.72rem;color:#a16207;line-height:1.3}.credits-membership-arrow{font-size:1.1rem;color:#a16207;font-weight:700}.credits-member-section{text-align:center;padding:1rem 0}.credits-member-perks{display:flex;flex-direction:column;gap:.5rem;align-items:center}.credits-perk{font-size:.85rem;color:#555}.credits-anon-cta{display:flex;align-items:center;gap:.5rem;padding:.7rem .85rem;background:linear-gradient(135deg,#667eea10,#764ba210);border:1px solid #667eea25;border-radius:10px;margin-top:.75rem;font-size:.8rem;color:#555}.credits-anon-cta strong{color:#7c3aed}.credits-signin-btn{margin-left:auto;padding:.35rem .75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap}.credits-signin-btn:hover{opacity:.88}.profile-modal-badge-row{display:flex;justify-content:center;margin-bottom:.5rem}.profile-modal-badge.badge-member{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.profile-credits-actions{margin-top:.6rem}.profile-credit-packages{display:flex;gap:.4rem;justify-content:center;margin-bottom:.5rem}.profile-credit-pkg-btn{padding:.4rem .9rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:700;cursor:pointer;transition:opacity .15s}.profile-credit-pkg-btn:hover{opacity:.85}.profile-view-all-btn{background:none;border:none;color:#667eea;font-size:.75rem;cursor:pointer;padding:.2rem}.profile-view-all-btn:hover{text-decoration:underline}.profile-membership-btn{display:block;width:100%;margin-top:.6rem;padding:.6rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;border:none;border-radius:10px;font-size:.85rem;font-weight:700;cursor:pointer;transition:opacity .15s}.profile-membership-btn:hover{opacity:.88}.credits-badge-mini.credits-member{background:linear-gradient(135deg,#fbbf244d,#f59e0b4d);color:#fef3c7}.low-credits-banner{display:block;width:auto;margin:.4rem .75rem;padding:.4rem .75rem;background:linear-gradient(135deg,#fef3c718,#fde68a18);border:1px solid #f59e0b35;border-radius:8px;font-size:.75rem;color:#92400e;text-align:center;cursor:pointer;transition:background .15s,border-color .15s}.low-credits-banner:hover{background:linear-gradient(135deg,#fef3c730,#fde68a30);border-color:#f59e0b50}.low-credits-banner strong{color:#d97706}.low-credits-cta{color:#667eea;font-weight:600}
