:root{font-family: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh;width:100%;overflow:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{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,#0a0a0a,#1a1a1a);color:#fafafa;min-height:100vh;overflow:hidden}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0f0f0f}::-webkit-scrollbar-thumb{background:#333;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#444}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a1a1a)}.loading-spinner-large{width:50px;height:50px;border:4px solid rgba(37,99,235,.1);border-top-color:#2563eb;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;padding:20px;background:linear-gradient(135deg,#0a0a0a,#1a1a1a)}.auth-card{width:100%;max-width:440px;background:#141414f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:40px;box-shadow:0 20px 60px #00000080;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{text-align:center;margin-bottom:32px}.auth-header h1{font-size:28px;font-weight:600;margin-bottom:8px;background:linear-gradient(135deg,#fff,#999);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header p{color:#999;font-size:14px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:#e5e5e5}.form-group input{padding:12px 16px;background:#26262699;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fafafa;font-size:15px;transition:all .3s ease}.form-group input:focus{outline:none;border-color:#2563eb80;box-shadow:0 0 0 3px #2563eb1a;background:#262626cc}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-group input::placeholder{color:#666}.error-message{padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:14px}.auth-submit-btn{padding:14px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;margin-top:8px}.auth-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-2px);box-shadow:0 8px 20px #2563eb66}.auth-submit-btn:active:not(:disabled){transform:translateY(0)}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.loading-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.auth-footer{margin-top:24px;text-align:center}.auth-footer p{color:#999;font-size:14px}.link-btn{background:none;border:none;color:#60a5fa;cursor:pointer;font-size:14px;text-decoration:underline;padding:0;transition:color .2s}.link-btn:hover{color:#93c5fd}#root{width:100%;height:100vh;display:flex;flex-direction:column}.app-layout{display:flex;height:100vh;width:100%;overflow:hidden}.sidebar{width:280px;min-width:280px;flex-shrink:0;background:#0f0f0ff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;transition:transform .3s ease;z-index:1000;height:100vh;overflow:hidden}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}.sidebar-logo svg{color:#2563eb}.sidebar-logo h2{font-size:18px;font-weight:600;color:#fafafa}.new-chat-sidebar-btn{width:100%;padding:10px 16px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s ease}.new-chat-sidebar-btn:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb66}.sidebar-sessions{flex:1;overflow-y:auto;padding:16px}.sessions-title{font-size:12px;font-weight:600;text-transform:uppercase;color:#666;margin-bottom:12px;padding:0 8px}.empty-sessions{text-align:center;padding:40px 20px;color:#666}.sessions-list{display:flex;flex-direction:column;gap:4px}.session-item{padding:12px;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;gap:8px;border:1px solid transparent}.session-item:hover{background:#26262699;border-color:#ffffff0d}.session-item.active{background:#2563eb1a;border-color:#2563eb4d}.session-content{display:flex;align-items:flex-start;gap:10px;flex:1;min-width:0}.session-icon{flex-shrink:0;color:#999;margin-top:2px}.session-item.active .session-icon{color:#2563eb}.session-info{flex:1;min-width:0}.session-preview{font-size:14px;color:#e5e5e5;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-meta{font-size:12px;color:#666}.delete-session-btn{padding:6px;background:none;border:none;color:#666;cursor:pointer;border-radius:4px;transition:all .2s ease;opacity:0;flex-shrink:0}.session-item:hover .delete-session-btn{opacity:1}.delete-session-btn:hover{background:#ef44441a;color:#ef4444}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between;gap:12px}.user-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#1d4ed8);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.user-details{flex:1;min-width:0}.user-name{font-size:14px;font-weight:500;color:#fafafa;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{font-size:12px;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{padding:8px;background:#26262699;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#999;cursor:pointer;transition:all .2s ease;flex-shrink:0}.logout-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:999}.chat-container{flex:1;min-width:0;height:100vh;max-height:100vh;display:flex;flex-direction:column;background:#0f0f0f99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;position:relative}.chat-header{background:#141414f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);padding:16px 24px;flex-shrink:0;z-index:100;display:flex;align-items:center;gap:16px}.header-content{display:flex;justify-content:space-between;align-items:center;gap:16px;width:100%}.sidebar-toggle-btn{display:none;padding:8px;background:#26262699;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fafafa;cursor:pointer;transition:all .2s ease;flex-shrink:0}.sidebar-toggle-btn:hover{background:#262626cc;border-color:#fff3}.chat-title{font-size:20px!important;font-weight:600;background:linear-gradient(135deg,#fff,#999);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex:1;line-height:1.2;margin:0}.new-chat-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#262626,#1a1a1a);color:#fafafa;border:1px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;flex-shrink:0}.new-chat-btn:hover{background:linear-gradient(135deg,#333,#222);border-color:#fff3;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.new-chat-btn:active{transform:translateY(0)}.chat-messages{flex:1;min-height:0;padding:32px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.message{display:flex;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.message-wrapper{display:flex;gap:12px;max-width:80%;align-items:flex-start}.message.user .message-wrapper{flex-direction:row-reverse}.avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:linear-gradient(135deg,#262626,#1a1a1a);border:1px solid rgba(255,255,255,.1)}.message.user .avatar{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.bubble{padding:14px 18px;border-radius:16px;line-height:1.6;font-size:15px;position:relative;word-wrap:break-word;word-break:break-word}.message.user .bubble{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border-bottom-right-radius:4px}.message.assistant .bubble{background:#262626cc;color:#e5e5e5;border:1px solid rgba(255,255,255,.05);border-bottom-left-radius:4px}.bubble code{background:#0000004d;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:14px}.bubble strong{font-weight:600;color:#fff}.bubble em{font-style:italic}.bubble a{color:#60a5fa;text-decoration:underline}.bubble a:hover{color:#93c5fd}.bubble br{display:block;content:"";margin:.5em 0}.typing-indicator{display:flex;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#666;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.6}30%{transform:translateY(-10px);opacity:1}}.cursor{display:inline-block;width:2px;height:1em;background:currentColor;margin-left:2px;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.input-container{padding:20px 24px 24px;background:#0f0f0ff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.input-box{display:flex;gap:12px;align-items:flex-end;background:#26262699;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px;transition:all .3s ease}.input-box:focus-within{border-color:#2563eb80;box-shadow:0 0 0 3px #2563eb1a}textarea{flex:1;resize:none;padding:8px;background:transparent;border:none;color:#fafafa;font-size:15px;font-family:inherit;outline:none;max-height:200px;overflow-y:auto;line-height:1.5;min-width:0}textarea::placeholder{color:#666}textarea:disabled{opacity:.5;cursor:not-allowed}.send-btn{padding:10px 12px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.send-btn:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);transform:translateY(-2px);box-shadow:0 4px 12px #2563eb66}.send-btn:active:not(:disabled){transform:translateY(0)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.input-hint{margin-top:8px;font-size:12px;color:#666;text-align:center}.input-hint kbd{background:#262626cc;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:2px 6px;font-family:inherit;font-size:11px}.bubble.loading{background:#262626cc;border:1px solid rgba(255,255,255,.05)}@media(max-width:1024px)and (min-width:769px){.sidebar{width:240px;min-width:240px}}@media(max-width:768px){.sidebar-overlay{display:block}.sidebar{position:fixed;left:0;top:0;height:100vh;width:280px;min-width:280px;transform:translate(-100%);z-index:1000}.sidebar.open{transform:translate(0)}.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center}.chat-container{width:100%}.chat-header{padding:12px 16px}.chat-title{font-size:18px}.new-chat-btn span{display:none}.new-chat-btn{padding:10px}.chat-messages{padding:16px;gap:16px}.message-wrapper{max-width:90%}.input-container{padding:12px 16px 16px}.avatar{width:32px;height:32px}.bubble{font-size:14px;padding:12px 16px}.auth-card{padding:32px 24px}}@media(max-width:480px){.chat-title{font-size:16px}.message-wrapper{max-width:95%}.bubble{font-size:13px;padding:10px 14px}.input-hint{display:none}.auth-card{padding:24px 16px}}
