body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@media (max-width:768px){.clickable,button{-webkit-tap-highlight-color:transparent;min-height:44px;min-width:44px;touch-action:manipulation;transition:all .2s ease}.clickable:active,button:active{opacity:.8;transform:scale(.98)}input,textarea{-webkit-appearance:none;background:#fff;border:1px solid #e9ecef;border-radius:8px;font-size:16px;padding:12px 16px}input:focus,textarea:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.message-bubble{word-wrap:break-word;border-radius:18px;margin-bottom:8px;max-width:85%;padding:12px 16px;position:relative;word-break:break-word}.message.own .message-bubble{align-self:flex-end;background:#667eea;border-bottom-right-radius:4px;color:#fff}.message.other .message-bubble{align-self:flex-start;background:#667eea;border-bottom-left-radius:4px;color:#fff}.message{display:flex;flex-direction:column;margin-bottom:12px}.chat-header{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;display:flex;flex-direction:row;justify-content:space-between;padding:12px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-left{flex:1 1}.header-right{align-items:center;display:flex;flex-direction:row;gap:12px}.chat-sidebar{background:#fff;border-bottom:2px solid #e9ecef;max-height:180px;overflow-y:auto;padding:8px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:99}.user-item{align-items:center;background:#fff;border:1px solid #0000;border-radius:8px;display:flex;flex-direction:row;gap:12px;margin-bottom:4px;padding:12px 16px;transition:all .2s ease}.user-item:active{background-color:#f0f4ff;border-color:#667eea;transform:scale(.98)}.user-item.current{background:#e3f2fd;border-color:#2196f3}.conversation-item{background:#fff;border:1px solid #0000;border-radius:8px;margin-bottom:4px;padding:12px 16px;transition:all .2s ease}.conversation-item:active{background-color:#f0f4ff;border-color:#667eea;transform:scale(.98)}.conversation-item.selected{background:#e3f2fd;border-color:#2196f3}.input-group{align-items:center;border-top:1px solid #e9ecef;bottom:0;display:flex;flex-direction:row;gap:12px;position:-webkit-sticky;position:sticky;z-index:100}.input-group,.message-input{background:#fff;padding:12px 16px}.message-input{border:1px solid #e9ecef;border-radius:25px;flex:1 1;font-size:16px;min-height:44px}.send-button{align-items:center;background:#667eea;border:none;border-radius:50%;color:#fff;display:flex;font-size:16px;height:44px;justify-content:center;width:44px}.send-button:active{background:#5a6fd8;transform:scale(.95)}.send-button:disabled{background:#ccc;opacity:.5}.auth-container{align-items:center;background:radial-gradient(circle at center,#667eea 0,#764ba2 100%);display:flex;flex-direction:column;justify-content:center;margin:0;min-height:100vh;padding:0;position:relative}.auth-container:after{bottom:20px;color:#fff;content:"✦";font-size:24px;opacity:.3;position:absolute;right:20px}.auth-form{background:#fff;border-radius:20px;box-shadow:0 8px 32px #00000026;margin:20px;max-width:400px;padding:32px 24px;width:90%}.auth-header{margin-bottom:24px;text-align:center}.logo-section{align-items:center;display:flex;flex-direction:column;gap:8px}.robot-logo{color:#667eea;font-size:2.5rem;margin-bottom:8px}.title-section h1{color:#333;font-size:1.5rem;font-weight:700;margin:0 0 4px}.title-section p{color:#666;font-size:.9rem;line-height:1.4;margin:0}.auth-tabs{background:#f8f9fa;border-radius:12px;display:flex;flex-direction:row;gap:0;margin-bottom:24px;padding:4px}.auth-tabs button{background:#0000;border:none;border-radius:8px;color:#666;flex:1 1;font-size:16px;font-weight:600;min-height:48px;padding:14px 20px;transition:all .3s ease}.auth-tabs button.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d;color:#fff}.auth-tabs button:active{transform:scale(.98)}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-group input{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-sizing:border-box;font-size:16px;padding:16px 20px;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.auth-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 16px #667eea4d;color:#fff;font-size:16px;font-weight:600;margin-top:8px;min-height:52px;padding:16px 20px;transition:all .3s ease;width:100%}.auth-button:active{box-shadow:0 2px 8px #667eea66;transform:scale(.98)}.auth-button:disabled{opacity:.6;transform:none}.demo-users{margin-top:32px;text-align:center}.demo-users h3{color:#667eea;font-size:16px;font-weight:600;margin:0 0 16px}.demo-user-list{display:flex;flex-direction:column;gap:12px}.demo-user{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:12px;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:500;justify-content:center;min-height:52px;padding:16px 20px;transition:all .3s ease}.demo-user:active{background:#f8f9fa;border-color:#667eea;transform:scale(.98)}.error-message{margin:16px 0;text-align:center}.message-list::-webkit-scrollbar{width:4px}.message-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.message-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.chat-sidebar::-webkit-scrollbar{width:4px}.chat-sidebar::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.chat-sidebar::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.message-list{flex:1 1;overflow-y:auto;padding:16px 16px 80px}.message-header{font-size:13px;justify-content:space-between;margin-bottom:6px}.message-header,.message-username{align-items:center;display:flex;flex-direction:row}.message-username{font-weight:600;gap:6px}.message-time{font-size:11px;opacity:.8}.sentiment-badge{align-self:flex-start;border-radius:12px;font-size:12px;margin-top:6px;padding:4px 8px}.message-sentiment,.user-sentiment{border-radius:8px;color:#fff;font-size:10px;font-weight:600;padding:2px 6px}.welcome-message{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000001a;margin:16px;padding:20px 16px;text-align:center}.welcome-message h2{color:#333;font-size:1.4rem;line-height:1.3;margin-bottom:12px}.welcome-message p{color:#666;font-size:14px;line-height:1.4;margin-bottom:20px}.features{flex-direction:column;margin-left:auto;margin-right:auto;margin-top:20px;max-width:300px}.feature,.features{display:flex;gap:12px}.feature{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;flex-direction:row;min-height:44px;padding:14px 16px;transition:all .2s ease}.feature:active{background:#e9ecef;transform:scale(.98)}.feature-icon{flex-shrink:0;font-size:1.5rem}.feature span:last-child{color:#333;font-size:14px;font-weight:500}.view-mode-buttons{display:flex;flex-direction:row;gap:8px}.view-mode-buttons button{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#667eea;font-size:14px;min-height:44px;min-width:44px;padding:8px 16px}.view-mode-buttons button.active{background:#667eea;color:#fff}.view-mode-buttons button:active{transform:scale(.98)}.logout-button{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#667eea;font-size:14px;min-height:44px;min-width:44px;padding:8px 16px}.logout-button:active{background:#e9ecef;transform:scale(.98)}.search-section{display:flex;flex-direction:row;gap:8px;margin-bottom:15px}.search-input{border:1px solid #e9ecef;border-radius:6px;flex:1 1}.search-button,.search-input{font-size:14px;min-height:44px;padding:8px 12px}.search-button{background:#667eea;border:none;border-radius:6px;color:#fff;min-width:44px}.search-button:active{background:#5a6fd8;transform:scale(.98)}.section-title{color:#333;font-size:16px;font-weight:600;margin-bottom:12px}.user-avatar{flex-shrink:0;font-size:20px}.user-name{color:#333;flex:1 1;font-weight:500}.you-badge{color:#2196f3;font-size:12px;font-weight:600}.conversation-header{align-items:center;display:flex;flex-direction:row;justify-content:space-between;margin-bottom:5px}.conversation-user{color:#333;font-weight:600}.conversation-preview{margin-bottom:5px}.last-message{color:#666;font-size:12px;font-style:italic}.unread-badge{align-items:center;background:#2196f3;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:600;height:20px;justify-content:center;width:20px}.conversation-time{color:#666;font-size:12px}.no-messages{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.no-messages-text{color:#666;font-size:16px;line-height:1.4}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;font-size:14px;margin:12px 16px;padding:12px 16px}.loading{align-items:center;display:flex;flex-direction:row;justify-content:center;padding:20px}.loading-text{color:#666;font-size:14px;margin-left:8px}}@media (min-width:769px) and (max-width:1024px){.chat-container{max-width:900px;width:95%}.chat-sidebar{width:300px}.message-bubble{max-width:75%}}@media (max-width:480px){.app{padding:0}.chat-container{border-radius:0;height:100vh;margin:0}.chat-header{padding:12px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.title-section h1{font-size:1.1rem}.title-section p{font-size:.8rem}.view-mode-buttons button{font-size:13px;padding:6px 10px}.chat-sidebar{max-height:160px;padding:8px 16px}.conversations-list,.users-list{max-height:120px}.conversation-item,.user-item{font-size:14px;padding:10px 12px}.message-list{padding:12px 12px 70px}.message-bubble{font-size:14px;max-width:90%;padding:10px 14px}.message-content{font-size:14px;line-height:1.4}.message-time{font-size:10px}.message-header{font-size:12px}.input-group{padding:10px 12px}.message-input{font-size:16px;padding:10px 14px}.send-button{height:40px;width:40px}.auth-container{padding:0}.auth-form{margin:10px;padding:24px 20px;width:95%}.auth-header{margin-bottom:20px}.robot-logo{font-size:2.2rem}.title-section h1{font-size:1.3rem}.title-section p{font-size:.85rem}.auth-tabs button{font-size:15px;min-height:44px;padding:12px 16px}.auth-button,.form-group input{font-size:16px;padding:14px 16px}.auth-button,.demo-user{min-height:48px}.demo-user{font-size:13px;padding:14px 16px}.demo-users h3{font-size:15px}.sentiment-badge{font-size:11px;padding:3px 6px}.message-sentiment,.user-sentiment{font-size:9px;padding:2px 4px}.welcome-message{padding:16px 12px}.welcome-message h2{font-size:1.2rem;margin-bottom:10px}.welcome-message p{font-size:13px;margin-bottom:16px}.features{gap:10px;margin-top:16px;max-width:280px}.feature{border-radius:10px;padding:12px 14px}.feature-icon{font-size:1.3rem}.feature span:last-child{font-size:13px}}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}input,textarea{-webkit-user-select:text;user-select:text}html{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.clickable:focus,button:focus,input:focus{outline:2px solid #667eea;outline-offset:2px}.clickable,button{-webkit-user-select:none;user-select:none}@media (hover:none) and (pointer:coarse){.conversation-item:hover,.user-item:hover{background-color:initial}.conversation-item:active,.user-item:active{background-color:#f0f4ff}.demo-user:hover{background-color:#f8f9fa}.demo-user:active{background-color:#e9ecef;transform:scale(.98)}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app,body{min-height:100vh}.app{align-items:center;display:flex;justify-content:center;padding:20px}.auth-container{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:40px;text-align:center;width:100%}.auth-header{margin-bottom:30px}.logo-section{align-items:center;display:flex;gap:15px;justify-content:center;margin-bottom:20px}.robot-logo{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:48px}.title-section h1{color:#333;font-size:28px;font-weight:600;margin:0}.title-section p{color:#666;font-size:16px;margin:5px 0 0}.auth-tabs{border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;margin-bottom:30px;overflow:hidden}.auth-tabs button{background:#f8f9fa;border:none;color:#666;cursor:pointer;flex:1 1;font-size:16px;font-weight:500;padding:15px;transition:all .3s ease}.auth-tabs button.active{background:#667eea;color:#fff}.auth-tabs button:hover{background:#5a6fd8;color:#fff}.auth-form{text-align:left}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:8px}.form-group input{border:2px solid #e9ecef;border-radius:10px;font-size:16px;padding:15px;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.auth-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:15px;transition:transform .2s ease;width:100%}.auth-button:hover{transform:translateY(-2px)}.auth-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:10px;color:#721c24;margin-bottom:20px;padding:15px}.demo-users{background:#f8f9fa;border-radius:15px;margin-top:30px;padding:20px}.demo-users h3{color:#667eea;font-size:18px;margin-bottom:15px}.demo-user-list{display:flex;flex-direction:column;gap:10px}.demo-user{background:#fff;border:2px solid #0000;border-radius:8px;cursor:pointer;padding:12px;transition:all .3s ease}.demo-user:hover{background:#e9ecef;border-color:#667eea;transform:translateY(-2px)}.demo-user strong{color:#667eea}.chat-container{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;display:flex;flex-direction:column;height:85vh;max-width:1200px;overflow:hidden;width:100%}.chat-header{background:#fff;border-bottom:1px solid #e9ecef;justify-content:space-between;padding:20px}.chat-header,.header-left,.header-right{align-items:center;display:flex}.header-right{gap:15px}.chat-header .logo-section{margin-bottom:0}.chat-header .robot-logo{font-size:32px}.chat-header .title-section h1{color:#333;font-size:20px;margin:0}.chat-header .title-section p{color:#666;font-size:14px;margin:2px 0 0}.logout-button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .3s ease}.logout-button:hover{background:#5a6fd8}.chat-main{display:flex;flex:1 1;overflow:hidden}.chat-sidebar{background:#f8f9fa;border-right:1px solid #e9ecef;overflow-y:auto;padding:20px;scroll-behavior:smooth;width:300px}.chat-sidebar::-webkit-scrollbar{width:6px}.chat-sidebar::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.chat-sidebar::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.chat-sidebar::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.welcome-section{margin-bottom:20px}.welcome-section h3{color:#333;font-size:16px;font-weight:500;margin:0}.chat-sidebar h3{color:#667eea;font-size:16px;font-weight:600;margin-bottom:15px}.conversations-section{margin-bottom:20px}.search-section{display:flex;gap:8px;margin-bottom:15px}.search-input{border:1px solid #e9ecef;border-radius:6px;flex:1 1}.search-button,.search-input{font-size:14px;padding:8px 12px}.search-button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer}.search-button:hover{background:#5a6fd8}.users-section{margin-top:30px}.users-list{display:flex;flex-direction:column;gap:10px}.user-item{align-items:center;background:#fff;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:12px;transition:all .3s ease}.user-item:hover{background:#e9ecef;border-color:#667eea}.user-item.current{background:#e3f2fd;border-color:#2196f3}.user-item.clickable{cursor:pointer}.user-avatar{font-size:20px}.user-name{color:#333;font-weight:500}.you-badge{color:#2196f3;font-size:12px;font-weight:600}.chat-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.general-chat,.private-chat{display:flex;flex-direction:column;height:100%}.no-selection{align-items:center;display:flex;height:100%;justify-content:center;padding:20px;text-align:center}.welcome-message h2{color:#667eea;font-size:28px;margin-bottom:20px}.welcome-message p{color:#666;font-size:16px;margin-bottom:30px}.features{display:flex;flex-direction:column;gap:15px;margin-top:30px}.feature{align-items:center;background:#f8f9fa;border-radius:10px;display:flex;gap:10px;padding:15px}.feature-icon{font-size:24px}.chat-header-private{background:#f8f9fa;border-bottom:1px solid #e9ecef;padding:15px 20px}.chat-header-private h3{color:#667eea;font-size:18px;margin:0}.message-list{display:flex;flex:1 1;flex-direction:column;gap:15px;min-height:0;overflow-y:auto;padding:20px;scroll-behavior:smooth}.message-list::-webkit-scrollbar{width:6px}.message-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.message-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.message-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.no-messages{color:#666;font-style:italic;margin-top:50px;text-align:center}.message{display:flex;margin-bottom:15px}.message.own{justify-content:flex-end}.message.other{justify-content:flex-start}.message-bubble{border-radius:18px;max-width:70%;padding:8px 12px;position:relative}.message.own .message-bubble{background:#667eea;border-bottom-right-radius:4px;color:#fff}.message.other .message-bubble{background:#667eea;border-bottom-left-radius:4px;color:#fff}.message-header{align-items:center;display:flex;font-size:12px;justify-content:space-between;margin-bottom:8px;opacity:.9;padding:0 4px}.message-username{align-items:center;display:flex;font-weight:600;gap:5px}.message-sentiment{border-radius:4px;color:#fff;font-size:10px;font-weight:600;padding:2px 4px}.message-time{font-size:11px;margin-top:4px;text-align:right}.message-content{line-height:1.4;margin:0}.message-status{margin-top:5px;text-align:right}.status-icon{font-size:12px}.input-group{background:#fff;border-top:1px solid #e9ecef;display:flex;flex-shrink:0;gap:10px;padding:15px 20px}.message-input{border:2px solid #e9ecef;border-radius:25px;flex:1 1;font-size:16px;outline:none;padding:12px 16px;transition:border-color .3s ease}.message-input:focus{border-color:#667eea}.send-button{background:#667eea;border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:16px;padding:12px 20px;transition:background .3s ease}.send-button:hover:not(:disabled){background:#5a6fd8}.send-button:disabled{cursor:not-allowed;opacity:.5}.conversations-list{margin-bottom:20px;max-height:300px;overflow-y:auto;scroll-behavior:smooth}.conversations-list::-webkit-scrollbar{width:4px}.conversations-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.conversations-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.conversations-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.conversation-item{background:#fff;border:2px solid #0000;border-radius:8px;cursor:pointer;margin-bottom:8px;padding:12px;transition:all .3s ease}.conversation-item:hover{background:#e9ecef;border-color:#667eea}.conversation-item.selected{background:#e3f2fd;border-color:#2196f3}.conversation-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.conversation-user{color:#333;font-weight:600}.conversation-preview{margin-bottom:5px}.last-message{color:#666;font-size:12px;font-style:italic}.unread-badge{align-items:center;background:#2196f3;border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:600;height:20px;justify-content:center;width:20px}.conversation-time{color:#666;font-size:12px}.header-actions{align-items:center;display:flex;gap:15px}.view-mode-buttons{display:flex;gap:5px}.view-mode-buttons button{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#667eea;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .3s ease}.view-mode-buttons button.active{background:#667eea;color:#fff}.view-mode-buttons button:hover{background:#5a6fd8;color:#fff}.sentiment-legend{background:#fff;border:1px solid #e9ecef;border-radius:8px;bottom:20px;box-shadow:0 2px 8px #0000001a;left:20px;max-width:150px;padding:12px;position:fixed;z-index:1000}.sentiment-legend h4{color:#333;font-size:12px;font-weight:600;margin:0 0 8px}.legend-items{display:flex;flex-direction:column;gap:6px}.legend-item{align-items:center;color:#666;display:flex;font-size:11px;gap:6px}.legend-color{border-radius:50%;display:inline-block;height:10px;width:10px}.sentiment-badge{border-radius:12px;box-shadow:0 2px 4px #0000001a;color:#fff;display:inline-block;font-size:12px;font-weight:600;margin-top:8px;padding:4px 8px}.message-bubble.has-sentiment{padding-bottom:8px}.user-item{position:relative}.user-sentiment{border-radius:4px;color:#fff;font-size:10px;font-weight:600;padding:2px 4px;position:absolute;right:5px;top:5px}@media (max-width:768px){.chat-container{border-radius:0;height:100vh}.chat-sidebar{width:250px}.auth-container{margin:10px;padding:30px}.chat-header{flex-direction:column;gap:15px;text-align:center}.user-info{flex-direction:column;gap:10px}.message-bubble{max-width:85%}}
/*# sourceMappingURL=main.30af0bc9.css.map*/