:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:40px;width:100%;max-width:450px;box-shadow:0 20px 60px #0000004d}.auth-card h1{margin:0 0 10px;color:#333;font-size:32px;font-weight:700}.auth-subtitle{color:#666;margin:0 0 30px;font-size:16px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:10px;font-size:16px;transition:all .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.auth-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.auth-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:30px;color:#666;font-size:14px}.auth-footer a{color:#667eea;text-decoration:none;font-weight:600}.auth-footer a:hover{text-decoration:underline}.home-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.home-header{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.home-header h1{margin:0;color:#fff;font-size:28px;font-weight:700}.user-info{display:flex;align-items:center;gap:20px;color:#fff}.logout-button{padding:10px 20px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease}.logout-button:hover{background:#ffffff4d;border-color:#ffffff80}.home-main{padding:40px;display:flex;justify-content:center;align-items:flex-start}.welcome-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:40px;max-width:600px;width:100%;box-shadow:0 20px 60px #0000004d}.welcome-card h2{margin:0 0 10px;color:#333;font-size:28px}.welcome-card>p{color:#666;margin:0 0 30px;font-size:16px}.user-details{background:#f5f5f5;padding:20px;border-radius:10px;margin-top:20px}.user-details p{margin:10px 0;color:#333;font-size:14px}.user-details strong{color:#667eea}.go-to-chats-button{margin-top:30px;padding:14px 28px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.go-to-chats-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.chats-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.chats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px 30px;border-radius:15px}.chats-header h1{margin:0;color:#fff;font-size:32px;font-weight:700}.new-chat-button{padding:12px 24px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:10px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s ease}.new-chat-button:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80}.new-chat-button:disabled{opacity:.6;cursor:not-allowed}.chats-list{display:flex;flex-direction:column;gap:15px}.chat-item{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:15px;padding:20px;cursor:pointer;transition:all .3s ease;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 15px #0000001a}.chat-item:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.chat-info{flex:1}.chat-info h3{margin:0 0 8px;color:#333;font-size:18px;font-weight:600}.chat-meta{margin:0;color:#666;font-size:14px}.delete-button{background:transparent;border:none;color:#999;font-size:28px;cursor:pointer;padding:0 10px;transition:color .2s ease;line-height:1}.delete-button:hover{color:#e33}.empty-state{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:15px;padding:60px 40px;text-align:center;color:#666;font-size:18px}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:30px;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-content h2{margin:0 0 20px;color:#333;font-size:24px;font-weight:700}.modal-content .form-group{margin-bottom:20px}.modal-content .form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:14px}.modal-input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:10px;font-size:16px;transition:all .3s ease;box-sizing:border-box}.modal-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-buttons{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal-button{padding:12px 24px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.modal-button.cancel{background:#f5f5f5;color:#666}.modal-button.cancel:hover{background:#e0e0e0}.modal-button.submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-button.submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.modal-button:disabled{opacity:.6;cursor:not-allowed}.modal-input textarea{resize:vertical;min-height:80px;font-family:inherit}.form-hint{display:block;margin-top:4px;font-size:12px;color:#999}.chat-context{margin:4px 0 8px;color:#667eea;font-size:13px;font-style:italic}.chat-actions{display:flex;gap:8px;align-items:center}.edit-button-icon{background:transparent;border:none;color:#667eea;font-size:20px;cursor:pointer;padding:4px 8px;transition:all .2s ease;line-height:1}.edit-button-icon:hover{color:#764ba2;transform:scale(1.1)}.chat-item.edit-mode{cursor:default;flex-direction:column;align-items:stretch}.chat-item.edit-mode form{width:100%}.edit-buttons{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.edit-button{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.edit-button.cancel{background:#f5f5f5;color:#666}.edit-button.cancel:hover{background:#e0e0e0}.edit-button.save{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.edit-button.save:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 15px #667eea4d}.edit-button:disabled{opacity:.6;cursor:not-allowed}.chat-view-container{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#333}.chat-header{background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:18px 24px;display:flex;align-items:center;gap:18px;box-shadow:0 4px 20px #00000026;border-bottom:1px solid rgba(255,255,255,.2)}.back-button{background:#ffffff40;color:#fff;border:2px solid rgba(255,255,255,.4);border-radius:12px;padding:10px 18px;cursor:pointer;font-size:15px;font-weight:600;transition:all .3s ease;box-shadow:0 2px 8px #0000001a}.back-button:hover{background:#ffffff59;border-color:#fff9;transform:translate(-2px)}.chat-header h2{margin:0;color:#fff;font-size:22px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.2);letter-spacing:-.3px}.messages-container{flex:1;overflow-y:auto;padding:24px 20px;display:flex;flex-direction:column;gap:18px;scroll-behavior:smooth}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}.messages-container::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:10px}.messages-container::-webkit-scrollbar-thumb:hover{background:#ffffff80}.message{display:flex;margin-bottom:10px}.user-message{justify-content:flex-end}.assistant-message{justify-content:flex-start}.message-content{max-width:75%;padding:14px 18px;border-radius:20px;box-shadow:0 4px 12px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-message .message-content{background:linear-gradient(135deg,#fff,#f8f9fa);color:#1a1a1a;border-bottom-right-radius:6px;border:1px solid rgba(255,255,255,.8)}.assistant-message .message-content{background:linear-gradient(135deg,#f0f4ff,#e8edff);color:#1a1a1a;border-bottom-left-radius:6px;border:1px solid rgba(102,126,234,.2)}.message-text{margin-bottom:6px;line-height:1.6;word-wrap:break-word;font-size:15px;font-weight:400;color:#1a1a1a;white-space:pre-wrap;min-height:1.2em}.message-time{font-size:11px;color:#666;text-align:right;margin-top:4px;opacity:.7;font-weight:500}.assistant-message .message-time{text-align:left}.empty-messages{text-align:center;color:#fffffff2;padding:60px 40px;font-size:18px;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.2)}.message-input-form{display:flex;gap:12px;padding:20px;background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.2);box-shadow:0 -4px 20px #0000001a}.message-input{flex:1;padding:14px 20px;border:2px solid rgba(255,255,255,.4);border-radius:30px;background:#fffffffa;font-size:16px;color:#1a1a1a;outline:none;transition:all .3s ease;font-weight:400;box-shadow:0 2px 10px #0000001a}.message-input::placeholder{color:#999;font-weight:400}.message-input:focus{border-color:#fffc;box-shadow:0 4px 20px #667eea4d;background:#fff;transform:translateY(-1px)}.send-button{padding:14px 32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:30px;cursor:pointer;font-size:16px;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #667eea66;min-width:100px}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80;background:linear-gradient(135deg,#7a8ef0,#8655b8)}.send-button:active:not(:disabled){transform:translateY(0)}.send-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.streaming-indicator{display:flex;justify-content:flex-start;padding:10px 0}.typing-dots{display:inline-flex;gap:5px;padding:14px 18px;background:linear-gradient(135deg,#f0f4ff,#e8edff);border-radius:20px 20px 20px 6px;border:1px solid rgba(102,126,234,.2);box-shadow:0 4px 12px #00000026}.typing-dots span{width:9px;height:9px;border-radius:50%;background:#667eea;animation:typing 1.4s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.loading{text-align:center;color:#fff;font-size:18px;padding:40px}.error-message{background:#fee;color:#c33;padding:12px;margin:10px 20px;border-radius:8px;font-size:14px;border:1px solid #fcc}.image-upload-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#ffffff40;border:2px solid rgba(255,255,255,.4);border-radius:12px;cursor:pointer;font-size:20px;transition:all .3s ease;flex-shrink:0}.image-upload-button:hover{background:#ffffff59;border-color:#fff9;transform:scale(1.05)}.image-upload-button:active{transform:scale(.95)}.selected-images-preview{padding:12px 20px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2)}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.preview-count{color:#ffffffe6;font-size:13px;font-weight:500}.clear-all-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:4px 12px;font-size:12px;cursor:pointer;transition:all .2s ease}.clear-all-button:hover{background:#ffffff4d;border-color:#ffffff80}.preview-images-grid{display:flex;gap:10px;overflow-x:auto;max-width:100%;padding-bottom:4px}.image-preview-item{position:relative;flex-shrink:0;width:80px;height:80px;border-radius:10px;overflow:hidden;border:2px solid rgba(255,255,255,.3)}.preview-image{width:100%;height:100%;object-fit:cover}.remove-image-button{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#0009;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.remove-image-button:hover{background:#f00c;transform:scale(1.1)}.message-attachments{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.message-image{max-width:100%;max-height:400px;border-radius:12px;object-fit:contain;cursor:pointer;transition:transform .2s ease}.message-image:hover{transform:scale(1.02)}.message-input-form{display:flex;gap:12px;padding:20px;background:#ffffff26;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.2);box-shadow:0 -4px 20px #0000001a;align-items:center}*{margin:0;padding:0;box-sizing:border-box}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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
