*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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;transition:background-color .3s ease}.app-layout{display:flex;height:100vh;overflow:hidden}.loading-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-spinner-large{width:48px;height:48px;border:4px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner-small{width:24px;height:24px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 8px}.loading-text{margin-top:16px;font-size:16px;font-weight:500}@keyframes spin{to{transform:rotate(1turn)}}.chat-container{display:flex;flex-direction:column;flex:1;height:100vh;background-color:var(--chat-bg);box-shadow:-4px 0 24px rgba(0,0,0,.1);overflow:hidden;transition:background-color .3s ease}.chat-header{padding:20px 32px;border-bottom:1px solid var(--chat-border);background:var(--chat-header-bg);color:var(--chat-header-text);position:relative;z-index:10;transition:border-color .3s ease}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.header-title-section{display:flex;align-items:center;gap:12px}.header-icon{width:40px;height:40px;background:hsla(0,0%,100%,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px)}.chat-header h1{font-size:22px;font-weight:700;color:#fff;margin:0;line-height:1.2}.header-subtitle{font-size:13px;color:hsla(0,0%,100%,.8);margin:2px 0 0;font-weight:400}.logout-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:hsla(0,0%,100%,.15);color:#fff;border:1px solid hsla(0,0%,100%,.2);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;backdrop-filter:blur(10px)}.logout-btn:hover{background:hsla(0,0%,100%,.25);border-color:hsla(0,0%,100%,.3);transform:translateY(-1px)}.chat-messages{flex:1;overflow-y:auto;padding:32px;gap:20px;background:linear-gradient(to bottom,var(--chat-messages-bg-start) 0,var(--chat-messages-bg-end) 100%);position:relative;transition:background .3s ease}.chat-messages,.empty-chat-state{display:flex;flex-direction:column}.empty-chat-state{flex:1;text-align:center;padding:60px 20px;max-width:600px;margin:0 auto}.empty-chat-icon,.empty-chat-state{align-items:center;justify-content:center}.empty-chat-icon{width:80px;height:80px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;display:flex;color:#fff;margin-bottom:24px;box-shadow:0 8px 24px rgba(102,126,234,.3)}.empty-chat-state h2{font-size:28px;font-weight:700;color:var(--chat-text-primary);margin-bottom:8px;transition:color .3s ease}.empty-chat-state>p{font-size:16px;color:var(--chat-text-secondary);margin-bottom:32px;transition:color .3s ease}.example-questions{margin-top:24px}.example-label{font-size:14px;color:var(--chat-text-muted);margin-bottom:12px;font-weight:500;transition:color .3s ease}.example-chips{display:flex;flex-direction:column;gap:10px;width:100%}.example-chip{padding:14px 20px;background:var(--chat-example-chip-bg);border:2px solid var(--chat-example-chip-border);border-radius:12px;font-size:14px;color:var(--chat-example-chip-text);text-align:left;cursor:pointer;transition:all .2s;box-shadow:0 1px 3px rgba(0,0,0,.05)}.example-chip:hover{border-color:#667eea;background:var(--chat-example-chip-hover-bg);color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.15)}.chat-message{display:flex;width:100%}.user-message{justify-content:flex-end}.assistant-message{justify-content:flex-start}.message-bubble{max-width:75%;padding:16px 20px;border-radius:20px;box-shadow:0 2px 8px rgba(0,0,0,.08);word-wrap:break-word;position:relative}.assistant-message .message-bubble{max-width:95%;width:100%;border-radius:20px 20px 20px 4px}.user-message .message-bubble{border-radius:20px 20px 4px 20px}.chart-container{margin-top:16px;padding:12px;background-color:var(--chat-chart-bg);border-radius:8px;border:1px solid var(--chat-chart-border);transition:background-color .3s ease,border-color .3s ease}.user-message .message-bubble{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px;box-shadow:0 4px 12px rgba(102,126,234,.25)}.assistant-message .message-bubble{background-color:var(--chat-bubble-assistant-bg);color:var(--chat-bubble-assistant-text);border-bottom-left-radius:4px;border:1px solid var(--chat-border);padding:20px 24px;box-shadow:0 2px 8px rgba(0,0,0,.06);transition:background-color .3s ease,color .3s ease,border-color .3s ease}.message-text{font-size:15px;line-height:1.6;white-space:pre-wrap;color:inherit}.message-text strong{font-weight:600;color:inherit}.message-timestamp{font-size:11px;opacity:.6;margin-top:8px;font-weight:400}.chat-input-container{padding:20px 32px;background-color:var(--chat-bg);border-top:1px solid var(--chat-border);position:sticky;bottom:0;box-shadow:0 -4px 12px rgba(0,0,0,.03);transition:background-color .3s ease,border-color .3s ease}.chat-input-wrapper{display:flex;gap:12px;align-items:flex-end}.chat-input{flex:1;padding:14px 20px;border:2px solid var(--chat-input-border);border-radius:16px;font-size:15px;font-family:inherit;resize:none;outline:none;transition:all .2s;min-height:52px;max-height:120px;overflow-y:auto;background:var(--chat-input-bg);color:var(--chat-text-primary)}.chat-input:focus{border-color:#667eea;background:var(--chat-bg);box-shadow:0 0 0 3px rgba(102,126,234,.1)}.chat-input:disabled{background-color:var(--chat-input-bg);cursor:not-allowed;opacity:.6}.send-button{padding:14px 28px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;min-height:52px;white-space:nowrap;box-shadow:0 4px 12px rgba(102,126,234,.3)}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px rgba(102,126,234,.4)}.send-button:active:not(:disabled){transform:translateY(0)}.send-button:disabled{background-color:#ccc;cursor:not-allowed}.typing-indicator{margin-top:8px;padding:8px 16px;font-size:13px;color:var(--chat-text-secondary);text-align:center;font-style:italic;transition:color .3s ease}.loading-spinner{display:inline-block}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:var(--chat-scrollbar-track);-webkit-transition:background .3s ease;transition:background .3s ease}.chat-messages::-webkit-scrollbar-thumb{background:var(--chat-scrollbar-thumb);border-radius:4px;-webkit-transition:background .3s ease;transition:background .3s ease}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--chat-scrollbar-thumb-hover)}.saved-questions-sidebar{width:320px;background:var(--chat-sidebar-bg);border-right:1px solid var(--chat-border);display:flex;flex-direction:column;transition:transform .3s ease,background-color .3s ease,border-color .3s ease;box-shadow:2px 0 12px rgba(0,0,0,.05);z-index:20}.saved-questions-sidebar.closed{width:60px}.saved-questions-header{padding:20px;border-bottom:1px solid var(--chat-border);display:flex;align-items:center;gap:12px;background:var(--chat-header-bg);color:var(--chat-header-text);min-height:80px;transition:border-color .3s ease}.toggle-sidebar-btn{width:36px;height:36px;border:none;background:hsla(0,0%,100%,.2);color:#fff;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.toggle-sidebar-btn:hover{background:hsla(0,0%,100%,.3);transform:scale(1.05)}.saved-questions-header h2{font-size:18px;font-weight:700;margin:0;flex:1;color:#fff}.clear-all-btn{width:32px;height:32px;border:none;background:hsla(0,0%,100%,.15);color:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:.8}.clear-all-btn:hover{background:hsla(0,0%,100%,.25);opacity:1}.saved-questions-content{flex:1;overflow-y:auto;padding:16px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--chat-text-muted);transition:color .3s ease}.empty-icon{opacity:.5;margin-bottom:16px}.empty-state p{font-size:14px;margin:4px 0}.empty-hint{font-size:12px;color:var(--chat-text-muted);margin-top:8px;transition:color .3s ease}.questions-list{display:flex;flex-direction:column;gap:8px}.saved-question-item{display:flex;align-items:flex-start;gap:8px;padding:12px;background:var(--chat-input-bg);border:1px solid var(--chat-input-border);border-radius:10px;transition:all .2s}.saved-question-item:hover{background:var(--chat-example-chip-hover-bg);border-color:var(--chat-border);transform:translateX(2px)}.question-text-btn{flex:1;text-align:left;background:none;border:none;cursor:pointer;padding:0;display:flex;flex-direction:column;gap:4px}.question-text{font-size:13px;color:var(--chat-text-primary);line-height:1.4;font-weight:500;transition:color .3s ease}.question-meta{display:flex;align-items:center;gap:8px;margin-top:4px}.question-usage{font-size:11px;font-weight:600;color:hsla(0,0%,100%,.9);background:hsla(0,0%,100%,.15);padding:2px 6px;border-radius:4px;white-space:nowrap}.question-time{font-size:11px;color:var(--chat-text-muted);font-weight:400;transition:color .3s ease}.delete-question-btn{width:24px;height:24px;border:none;background:transparent;color:var(--chat-text-muted);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;opacity:0}.saved-question-item:hover .delete-question-btn{opacity:1}.delete-question-btn:hover{background:hsla(0,93%,94%,.3);color:#dc2626}@media (max-width:768px){.saved-questions-sidebar{position:fixed;left:0;top:0;height:100vh;z-index:100;transform:translateX(0)}.saved-questions-sidebar.closed{transform:translateX(-100%)}.chat-container{width:100%}}