*{box-sizing:border-box;margin:0;padding:0}:root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}body{background:#f5f5f5;margin:0;font-family:inherit}#root{width:100%;height:100vh}.auth-container{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:40px;box-shadow:0 20px 60px #0000004d}.auth-card h1{color:#1a1a1a;margin:0 0 8px;font-size:28px;font-weight:600}.auth-subtitle{color:#666;margin:0 0 32px;font-size:14px}.auth-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#333;font-size:14px;font-weight:500}.form-group input{border:2px solid #e0e0e0;border-radius:8px;padding:12px 16px;font-size:15px;transition:all .2s}.form-group input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.form-hint{color:#999;font-size:12px}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;padding:14px 24px;font-size:16px;font-weight:600;transition:transform .2s,box-shadow .2s}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#c33;background:#fee;border-left:4px solid #c33;border-radius:8px;padding:12px 16px;font-size:14px}.auth-footer{text-align:center;color:#666;margin-top:24px;font-size:14px}.auth-footer a{color:#667eea;font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.chat-container{background:#f5f5f5;height:100vh;display:flex}.sidebar{color:#fff;background:#2c2c2c;border-right:1px solid #444;flex-direction:column;width:280px;display:flex}.sidebar-header{border-bottom:1px solid #444;padding:20px}.sidebar-header h2{margin:0 0 16px;font-size:20px;font-weight:600}.btn-new-chat{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;width:100%;padding:12px;font-size:14px;font-weight:600;transition:background .2s}.btn-new-chat:hover{background:#5568d3}.conversations-list{flex:1;padding:8px;overflow-y:auto}.empty-state{text-align:center;color:#999;padding:20px;font-size:14px}.conversation-item{cursor:pointer;border-radius:8px;margin-bottom:4px;padding:12px;transition:background .2s}.conversation-item:hover{background:#3c3c3c}.conversation-item.active{background:#667eea}.conversation-preview{text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-size:14px;overflow:hidden}.conversation-date{color:#999;font-size:12px}.conversation-item.active .conversation-date{color:#ffffffb3}.sidebar-footer{border-top:1px solid #444;align-items:center;gap:12px;padding:16px;display:flex}.user-info{flex:1;overflow:hidden}.user-name{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;display:block;overflow:hidden}.btn-logout{color:#ff6b6b;cursor:pointer;background:0 0;border:1px solid #ff6b6b;border-radius:6px;padding:8px 16px;font-size:13px;transition:all .2s}.btn-logout:hover{color:#fff;background:#ff6b6b}.chat-main{background:#fff;flex-direction:column;flex:1;display:flex}.error-banner{color:#c33;background:#fee;border-bottom:1px solid #fcc;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.error-banner button{color:#c33;cursor:pointer;background:0 0;border:none;padding:0 8px;font-size:18px}.usage-banner{background:#f9fafb;border-bottom:1px solid #ececec;flex-direction:column;gap:8px;padding:14px 20px;display:flex}.usage-banner-header{color:#4a5568;justify-content:space-between;align-items:center;font-size:13px;display:flex}.usage-label{color:#2d3748;font-weight:600}.usage-remaining{color:#667eea;font-size:12px}.usage-progress{background:#e5e7eb;border-radius:999px;width:100%;height:8px;overflow:hidden}.usage-progress-bar{background:linear-gradient(90deg,#667eea 0%,#764ba2 100%);height:100%;transition:width .3s}.usage-count{color:#4a5568;justify-content:space-between;align-items:baseline;font-size:12px;display:flex}.usage-count strong{color:#2d3748;font-size:16px}.messages-container{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.empty-chat{color:#999;flex-direction:column;flex:1;justify-content:center;align-items:center;display:flex}.empty-chat h2{margin:0 0 8px;font-size:32px}.empty-chat p{margin:0;font-size:16px}.message{margin-bottom:8px;display:flex}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.message-content{background:#f5f5f5;border-radius:12px;max-width:70%;padding:12px 16px}.message.user .message-content{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.message-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;display:flex}.message-role{align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.message-icon{background:#e0e0e0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.message.user .message-icon{background:#fff3}.message.user .message-role{color:#ffffffe6}.message-time{color:#999;font-size:11px}.message.user .message-time{color:#ffffffb3}.message-text{white-space:pre-wrap;word-wrap:break-word;font-size:15px;line-height:1.6}.typing-indicator{gap:4px;padding:8px 0;display:flex}.typing-indicator span{background:#999;border-radius:50%;width:8px;height:8px;animation:1.4s infinite typing}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-8px)}}.spinner{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.input-form{background:#fff;border-top:1px solid #e0e0e0;padding:20px}.input-controls{align-items:center;gap:12px;display:flex}.model-select-wrapper{min-width:160px;position:relative}.model-select{cursor:pointer;color:#333;appearance:none;background:#fff;border:2px solid #e0e0e0;border-radius:24px;width:100%;padding:12px 40px 12px 16px;font-family:inherit;font-size:14px;transition:all .2s}.select-icon{pointer-events:none;color:#667eea;transition:all .2s;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.model-select:hover:not(:disabled){border-color:#667eea}.model-select:hover:not(:disabled)~.select-icon{color:#5568d3}.model-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.model-select:disabled{cursor:not-allowed;opacity:.6;background:#f5f5f5}.model-select:disabled~.select-icon{opacity:.4}.message-input{border:2px solid #e0e0e0;border-radius:24px;flex:1;padding:14px 18px;font-family:inherit;font-size:15px;transition:all .2s}.message-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.message-input:disabled{cursor:not-allowed;background:#f5f5f5}.btn-send{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;transition:all .2s;display:flex}.btn-send:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.btn-send:disabled{opacity:.5;cursor:not-allowed}.conversations-list::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar{width:6px}.conversations-list::-webkit-scrollbar-track{background:0 0}.conversations-list::-webkit-scrollbar-thumb{background:#555;border-radius:3px}.messages-container::-webkit-scrollbar-track{background:#f5f5f5}.messages-container::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.btn-close-sidebar{display:none}@media (max-width:768px){.message-content{max-width:85%}.btn-menu-mobile{z-index:1002;color:#fff;background:#2c2c2c;border:none;border-radius:8px;padding:10px 12px;position:fixed;top:18px;left:18px;box-shadow:0 2px 8px #00000014;display:block!important}.menu-icon{flex-direction:column;gap:5px;display:flex}.menu-icon span{background:#fff;border-radius:2px;width:28px;height:4px;display:block}.sidebar{display:none}.sidebar.sidebar-mobile-visible{z-index:1001;width:80vw;max-width:340px;height:100vh;animation:.2s slideInSidebar;position:fixed;top:0;left:0;box-shadow:2px 0 16px #0000001f;display:flex!important}.btn-close-sidebar{color:#fff;z-index:1003;cursor:pointer;background:0 0;border:none;font-size:28px;display:block;position:absolute;top:18px;right:18px}.input-controls{flex-wrap:wrap}.model-select-wrapper{flex:0 0 100%;order:-1;min-width:100%;margin-bottom:8px}}@keyframes slideInSidebar{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}#root{width:100%;height:100vh;overflow:hidden}
