.chat{display:flex;flex-direction:column;height:100%;background:#fff}.chat-header{padding:1.5rem 2rem;border-bottom:1px solid #e9ecef;background:#f8f9fa;display:flex;justify-content:space-between;align-items:center}.chat-header h2{font-size:1.2rem;color:#333;margin:0}.chat-meta{display:flex;gap:1rem;font-size:.85rem;color:#666}.messages-container{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;background:#fafafa}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-style:italic}.message{display:flex;flex-direction:column;max-width:70%;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-user{align-self:flex-end}.message-assistant{align-self:flex-start}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:1rem}.message-role{font-weight:600;font-size:.9rem;color:#667eea}.message-time{font-size:.75rem;color:#999}.message-content{padding:1rem 1.5rem;border-radius:12px;line-height:1.6;word-wrap:break-word;white-space:pre-wrap}.message-assistant .message-content{white-space:normal}.message-assistant .message-content h1,.message-assistant .message-content h2,.message-assistant .message-content h3,.message-assistant .message-content h4,.message-assistant .message-content h5,.message-assistant .message-content h6{margin-top:1.5rem;margin-bottom:.75rem;font-weight:600;line-height:1.25;color:#333}.message-assistant .message-content h1{font-size:1.5rem;border-bottom:1px solid #e9ecef;padding-bottom:.5rem}.message-assistant .message-content h2{font-size:1.3rem;border-bottom:1px solid #e9ecef;padding-bottom:.4rem}.message-assistant .message-content h3{font-size:1.1rem}.message-assistant .message-content h4{font-size:1rem}.message-assistant .message-content h5{font-size:.9rem}.message-assistant .message-content h6{font-size:.85rem;color:#666}.message-assistant .message-content p{margin-top:.75rem;margin-bottom:.75rem}.message-assistant .message-content p:first-child{margin-top:0}.message-assistant .message-content p:last-child{margin-bottom:0}.message-assistant .message-content ul,.message-assistant .message-content ol{margin:.75rem 0;padding-left:1.5rem}.message-assistant .message-content li{margin:.25rem 0}.message-assistant .message-content ul{list-style-type:disc}.message-assistant .message-content ol{list-style-type:decimal}.message-assistant .message-content code{background:#f4f4f4;border:1px solid #e0e0e0;border-radius:4px;padding:.2rem .4rem;font-family:Courier New,Courier,monospace;font-size:.9em;color:#d63384}.message-assistant .message-content pre{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1rem;overflow-x:auto;margin:1rem 0}.message-assistant .message-content pre code{background:transparent;border:none;padding:0;color:#333;font-size:.9em}.message-assistant .message-content blockquote{border-left:4px solid #667eea;padding-left:1rem;margin:1rem 0;color:#666;font-style:italic}.message-assistant .message-content a{color:#667eea;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}.message-assistant .message-content a:hover{border-bottom-color:#667eea}.message-assistant .message-content table{border-collapse:collapse;margin:1rem 0;width:100%}.message-assistant .message-content table th,.message-assistant .message-content table td{border:1px solid #e9ecef;padding:.5rem .75rem;text-align:left}.message-assistant .message-content table th{background:#f8f9fa;font-weight:600}.message-assistant .message-content table tr:nth-child(2n){background:#f8f9fa}.message-assistant .message-content hr{border:none;border-top:1px solid #e9ecef;margin:1.5rem 0}.message-assistant .message-content strong{font-weight:600;color:#333}.message-assistant .message-content em{font-style:italic}.message-user .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.message-assistant .message-content{background:#fff;color:#333;border:1px solid #e9ecef;border-bottom-left-radius:4px;box-shadow:0 2px 4px #0000000d}.typing-indicator{display:inline-block;animation:pulse 1.5s ease-in-out infinite;color:#667eea;font-size:1.2rem}@keyframes pulse{0%,to{opacity:.4}50%{opacity:1}}.chat-input-container{padding:1.5rem 2rem;border-top:1px solid #e9ecef;background:#fff;display:flex;gap:1rem;align-items:flex-end}.chat-input{flex:1;padding:.75rem 1rem;border:2px solid #e9ecef;border-radius:12px;font-size:1rem;font-family:inherit;resize:none;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#667eea}.chat-input:disabled{background:#f8f9fa;cursor:not-allowed}.send-button{padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;outline:none;white-space:nowrap}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.message{max-width:85%}.chat-header{padding:1rem;flex-direction:column;align-items:flex-start;gap:.5rem}.messages-container,.chat-input-container{padding:1rem}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;padding:3rem;width:100%;max-width:450px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;color:#333;margin-bottom:.5rem;font-weight:600}.login-header p{color:#666;font-size:.95rem}.login-error{background:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem;margin-bottom:1.5rem;color:#c33;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#333;font-size:.9rem}.form-group input{padding:.75rem 1rem;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .2s;outline:none}.form-group input:focus{border-color:#667eea}.form-group input:disabled{background:#f8f9fa;cursor:not-allowed}.login-button{padding:.875rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;outline:none;margin-top:.5rem}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{margin-top:2rem;text-align:center}.login-hint{color:#999;font-size:.85rem;margin:0}@media (max-width: 480px){.login-card{padding:2rem 1.5rem}.login-header h1{font-size:1.5rem}}.app{display:flex;flex-direction:column;height:100vh;max-width:1400px;margin:0 auto;background:#fff;box-shadow:0 0 20px #0000001a}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.app-header h1{font-size:1.5rem;font-weight:600}.session-controls{display:flex;gap:1rem;align-items:center}.session-select{padding:.5rem 1rem;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;font-size:.9rem;cursor:pointer;outline:none}.session-select:hover{background:#fff3}.session-select option{background:#667eea;color:#fff}.btn{padding:.5rem 1.5rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;outline:none}.btn-primary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-primary:hover{background:#ffffff4d}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.app-content{display:flex;flex:1;overflow:hidden}.sidebar{width:300px;background:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;overflow-y:auto}.sidebar-header{padding:1.5rem;border-bottom:1px solid #e9ecef;background:#fff}.sidebar-header h2{font-size:1.1rem;color:#333;margin-bottom:.5rem}.sidebar-header p{font-size:.85rem;color:#666}.sessions-list{flex:1;padding:1rem;overflow-y:auto}.session-item{padding:1rem;margin-bottom:.5rem;background:#fff;border-radius:8px;cursor:pointer;transition:all .2s;border:2px solid transparent}.session-item:hover{background:#f0f0f0;transform:translate(4px)}.session-item.active{border-color:#667eea;background:#f0f4ff}.session-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.session-item-id{font-size:.75rem;color:#666;font-family:monospace;word-break:break-all;flex:1}.session-delete-btn{background:transparent;border:none;color:#999;font-size:1.5rem;font-weight:700;cursor:pointer;padding:0 .5rem;line-height:1;transition:all .2s;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.session-delete-btn:hover{background:#fee;color:#c33}.session-delete-btn:disabled{opacity:.5;cursor:not-allowed}.session-item-date{font-size:.75rem;color:#999}.session-item-meta{font-size:.85rem;color:#666}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.loading{padding:2rem;text-align:center;color:#666}.error{padding:1rem;margin:1rem;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33}@media (max-width: 768px){.app-content{flex-direction:column}.sidebar{width:100%;max-height:200px}.session-controls{flex-direction:column;gap:.5rem}}*{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;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
