:root{--bg-primary: #F5F5F4;--bg-secondary: #ffffff;--bg-tertiary: #E7E5E4;--bg-quaternary: #f0efee;--text-primary: #3F3F46;--text-secondary: #78716C;--text-tertiary: #7C6F64;--text-quaternary: #B6A186;--border-primary: #E7E5E4;--border-secondary: #d6d3d1;--accent-primary: #7C6F64;--accent-secondary: #6b5f54;--accent-success: #059669;--accent-error: #dc2626;--shadow: rgba(124, 111, 100, .08);--shadow-lg: rgba(124, 111, 100, .12);--streaming-bg: #F5F5F4;--chart-bg: #ffffff;--gradient-primary: linear-gradient(135deg, #B6A186 0%, #7C6F64 100%);--gradient-accent: linear-gradient(135deg, #7C6F64 0%, #6b5f54 100%);--blur: blur(8px)}.dark-mode{--bg-primary: #2a2520;--bg-secondary: #3a342e;--bg-tertiary: #4a433c;--bg-quaternary: #5a524a;--text-primary: #F5F5F4;--text-secondary: #E7E5E4;--text-tertiary: #B6A186;--text-quaternary: #9c8f7e;--border-primary: #4a433c;--border-secondary: #5a524a;--accent-primary: #B6A186;--accent-secondary: #9c8f7e;--accent-success: #10b981;--accent-error: #f87171;--shadow: rgba(0, 0, 0, .3);--shadow-lg: rgba(0, 0, 0, .5);--streaming-bg: #3a342e;--chart-bg: #3a342e;--gradient-primary: linear-gradient(135deg, #B6A186 0%, #7C6F64 100%);--gradient-accent: linear-gradient(135deg, #7C6F64 0%, #6b5f54 100%);--blur: blur(8px)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;line-height:1.6;letter-spacing:-.01em}.app{display:flex;height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden;background:var(--bg-primary);position:relative}@media (max-width: 1024px){.sidebar{width:260px}}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:1000;box-shadow:0 20px 25px -5px var(--shadow-lg);width:280px}.sidebar.hidden{transform:translate(-100%)}.main-content{width:100%;margin-left:0}}.sidebar{width:280px;background:var(--bg-secondary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;z-index:10;flex-shrink:0;box-shadow:0 4px 6px -1px var(--shadow);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur)}.sidebar.hidden{width:0;min-width:0;transform:translate(-100%);border-right:none;overflow:hidden;opacity:0;visibility:hidden}.sidebar-header{padding:1rem 1.25rem;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);height:72px;box-sizing:border-box}.sidebar-header h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.02em}.new-thread-btn{padding:.75rem;background:var(--gradient-accent);color:#fff;border:none;border-radius:.75rem;cursor:pointer;font-size:1rem;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px var(--shadow);font-weight:500}.new-thread-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)}.threads-list{flex:1;overflow-y:auto;padding:1rem}.thread-item{padding:.875rem;margin-bottom:.375rem;border-radius:.75rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid transparent;background:var(--bg-tertiary)}.thread-item:hover{background:var(--bg-quaternary);transform:translateY(-1px);box-shadow:0 2px 8px var(--shadow)}.thread-item.active{background:var(--gradient-accent);color:#fff;box-shadow:0 4px 12px var(--shadow-lg);transform:translateY(-1px)}.thread-item.active .thread-title,.thread-item.active .thread-date{color:#fff}.thread-content{flex:1;min-width:0}.thread-title{font-size:.9rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.thread-date{font-size:.75rem;color:var(--text-tertiary);font-weight:400}.delete-thread-btn{padding:.5rem;background:transparent;border:none;cursor:pointer;font-size:.9rem;color:var(--text-tertiary);transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0;margin-left:.75rem;border-radius:.5rem}.delete-thread-btn:hover{color:var(--accent-error);background:var(--bg-quaternary)}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;transition:all .3s cubic-bezier(.4,0,.2,1);background:var(--bg-primary);width:100%;margin-left:0}.main-content.sidebar-hidden{margin-left:0;width:100%}@media (min-width: 1024px){.sidebar.hidden{width:280px;min-width:280px;transform:translate(0);border-right:1px solid var(--border-primary);overflow:visible;opacity:1;visibility:visible}.main-content.sidebar-hidden{margin-left:280px;width:calc(100% - 280px)}}.app-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary);position:sticky;top:0;z-index:10;transition:all .3s ease;-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);box-shadow:0 1px 3px var(--shadow);height:72px;box-sizing:border-box}.header-left{display:flex;align-items:center;gap:1.5rem}.header-right{display:flex;align-items:center;gap:1rem}.desktop-header{display:flex}.mobile-header{display:none}.desktop-only{display:block}.profile-menu{position:relative}.profile-btn{padding:.75rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.75rem;cursor:pointer;font-size:1.1rem;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px var(--shadow);display:flex;align-items:center;justify-content:center;min-width:44px;height:44px;color:var(--text-primary)}.profile-btn:hover{background:var(--accent-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)}.profile-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:.75rem;box-shadow:0 8px 25px var(--shadow-lg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);min-width:200px;z-index:1000;overflow:hidden;animation:dropdownFadeIn .2s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{width:100%;padding:.75rem 1rem;background:transparent;border:none;text-align:left;cursor:pointer;transition:all .2s ease;font-size:.875rem;font-weight:500;color:var(--text-primary);display:flex;align-items:center;justify-content:space-between;gap:.75rem}.dropdown-item:hover{background:var(--bg-quaternary)}.dropdown-item:first-child{border-top-left-radius:.75rem;border-top-right-radius:.75rem}.dropdown-item:last-child{border-bottom-left-radius:.75rem;border-bottom-right-radius:.75rem}.logout-item:hover{background:var(--accent-error);color:#fff}.toggle-switch{width:40px;height:20px;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:10px;position:relative;cursor:pointer;transition:all .2s ease}.toggle-switch.active{background:var(--accent-primary);border-color:var(--accent-primary)}.toggle-slider{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:1px;left:1px;transition:all .2s ease;box-shadow:0 2px 4px var(--shadow)}.toggle-switch.active .toggle-slider{transform:translate(20px)}.connection-status{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;margin-left:16px}.connection-status.connected,.dark-mode .connection-status.connected{background-color:var(--accent-success);color:#fff}.connection-status.disconnected,.dark-mode .connection-status.disconnected{background-color:var(--accent-error);color:#fff}.connection-status .status-dot{width:6px;height:6px;border-radius:50%;background-color:currentColor;animation:pulse 2s infinite}.connection-status .status-text{font-size:11px;font-weight:600}.logout-btn{padding:.75rem 1rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.75rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-primary);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px var(--shadow);display:flex;align-items:center;gap:.5rem}.logout-btn:hover{background:var(--accent-error);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)}.dark-mode-toggle{padding:.75rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.75rem;cursor:pointer;font-size:1.1rem;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px var(--shadow)}.dark-mode-toggle:hover{background:var(--accent-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)}.sidebar-toggle{width:2.5rem;height:2.5rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.75rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:1rem;color:var(--text-primary);box-shadow:0 2px 4px var(--shadow);display:flex;align-items:center;justify-content:center}@media (min-width: 1024px){.sidebar-toggle{display:none}}.app-header h1{font-size:1.75rem;font-weight:700;background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.02em}.status-indicator{display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:var(--accent-success);font-weight:500;padding:.5rem 1rem;background:var(--bg-quaternary);border-radius:.5rem;border:1px solid var(--border-primary)}.status-dot{width:8px;height:8px;background:var(--accent-success);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary);margin:0;padding:0}.messages{flex:1;overflow-y:auto;padding:1rem .5rem;display:flex;flex-direction:column;gap:0;background:var(--bg-primary)}.message-group{display:flex;flex-direction:column;gap:.25rem;max-width:100%;animation:fadeInUp .3s ease-out;width:100%;margin-bottom:1.5rem;position:relative}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-group.user{align-items:flex-end}.message-group.assistant{align-items:flex-start}.message{display:flex;flex-direction:column;gap:.25rem;max-width:100%;width:100%;position:relative}.message.user{align-items:flex-end}.message.assistant{align-items:flex-start}.message-content{word-wrap:break-word;overflow-wrap:break-word;display:flex;flex-direction:column;gap:.25rem}.message-group.user .message-content{max-width:65%;margin-left:auto;align-items:flex-end}.message-group.assistant .message-content{width:100%;max-width:100%;margin-right:auto;align-items:flex-start}.message-item{padding:.75rem 1rem;line-height:1.6;white-space:pre-line;word-wrap:break-word;overflow-wrap:break-word;width:100%;box-sizing:border-box;font-weight:400;letter-spacing:-.01em;margin-bottom:.25rem;position:relative}.message-group.user .message-item{background:var(--gradient-accent);color:#fff;border-radius:1.25rem 1.25rem .375rem}.message-group.assistant .message-item{background:transparent;color:var(--text-primary);border-radius:1.25rem 1.25rem 1.25rem .375rem}.message-sender-label{font-size:.75rem;font-weight:600;margin-bottom:.5rem;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.message-group.user .message-sender-label{color:#ffffffe6;text-align:right}.message-group.assistant .message-sender-label{color:var(--text-tertiary);text-align:left}.message-item:first-child{border-top-left-radius:1.25rem;border-top-right-radius:1.25rem}.message-item:last-child{border-bottom-left-radius:1.25rem;border-bottom-right-radius:1.25rem;margin-bottom:0}.message-group.user .message-item:first-child{border-top-right-radius:.5rem}.message-group.user .message-item:last-child{border-bottom-right-radius:.5rem}.message-group.assistant .message-item:first-child{border-top-left-radius:.5rem}.message-group.assistant .message-item:last-child{border-bottom-left-radius:.5rem}.message-group .message-item:only-child{border-radius:1.25rem}.message-group.user .message-item:only-child{border-bottom-right-radius:.5rem}.message-group.assistant .message-item:only-child{border-bottom-left-radius:.5rem}.message-text{background:inherit;padding:0;border:none;border-radius:0;box-shadow:none;margin:0;line-height:inherit;color:inherit}.message-timestamp{font-size:.75rem;color:var(--text-quaternary);margin-top:.5rem;text-align:right;font-weight:400}.message.user .message-timestamp{text-align:left}.typing-indicator{display:flex;gap:.375rem;padding:1rem 1.25rem;background:var(--bg-secondary);border-radius:1.25rem 1.25rem 1.25rem .5rem;border:1px solid var(--border-primary);box-shadow:0 2px 8px var(--shadow)}.typing-indicator span{width:8px;height:8px;background:var(--accent-primary);border-radius:50%;animation:typing 1.4s infinite ease-in-out}.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:.4}30%{transform:translateY(-8px);opacity:1}}.input-form{padding:1rem .75rem;background:transparent;transition:all .3s ease}.input-container{display:flex;gap:1rem;align-items:end;max-width:800px;margin:0 auto;background:var(--bg-secondary);padding:1rem;border-radius:1.5rem;border:1px solid var(--border-primary);box-shadow:0 4px 12px var(--shadow)}.input-container input,.input-container textarea{flex:1;padding:1rem 1.25rem;border:2px solid var(--border-primary);border-radius:1rem;font-size:1rem;resize:none;outline:none;transition:all .2s cubic-bezier(.4,0,.2,1);background:var(--bg-tertiary);color:var(--text-primary);box-shadow:0 2px 4px var(--shadow);font-weight:400;letter-spacing:-.01em;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.input-container textarea{line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.input-container input:focus,.input-container textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a;background:var(--bg-secondary)}.input-container input:disabled,.input-container textarea:disabled{opacity:.6;cursor:not-allowed}.input-container button{padding:1rem;background:var(--gradient-accent);color:#fff;border:none;border-radius:1rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px var(--shadow);min-width:48px}.input-container button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)}.input-container button:disabled{opacity:.6;cursor:not-allowed}.input-actions{display:flex;gap:.5rem;align-items:flex-end}.help-btn{padding:.75rem!important;background:var(--bg-quaternary)!important;border:1px solid var(--border-primary)!important;border-radius:.75rem!important;cursor:pointer;font-size:1rem;color:var(--text-secondary)!important;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:44px!important;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px var(--shadow)!important}.help-btn:hover{background:var(--bg-tertiary)!important;color:var(--accent-primary)!important;border-color:var(--accent-primary)!important;transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)!important}.header-help-btn{padding:.75rem!important;background:var(--bg-quaternary)!important;border:1px solid var(--border-primary)!important;border-radius:.75rem!important;cursor:pointer;font-size:1rem;color:var(--text-secondary)!important;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:44px!important;height:44px!important;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px var(--shadow)!important}.header-help-btn:hover{background:var(--accent-primary)!important;color:#fff!important;border-color:var(--accent-primary)!important;transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)!important}.help-tooltip{position:absolute;bottom:100%;left:0;right:0;margin-bottom:.5rem;z-index:100}.header-help-tooltip{position:fixed;top:80px;right:1rem;left:auto;bottom:auto;margin:0;z-index:1000}.mobile-help-tooltip{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);margin:0;z-index:1001;max-width:calc(100vw - 2rem);max-height:calc(100vh - 4rem);overflow-y:auto}.help-backdrop{display:none}.help-tooltip-responsive{position:fixed;top:80px;right:1rem;left:auto;bottom:auto;margin:0;z-index:1000}.help-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-primary)}.help-header h4{margin:0;color:var(--text-primary);font-size:1.125rem;font-weight:600}.help-close-btn{padding:.5rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.5rem;cursor:pointer;font-size:1rem;font-weight:700;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.help-close-btn:hover{background:var(--accent-error);color:#fff;border-color:var(--accent-error)}.help-content{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:1rem;padding:1.5rem;box-shadow:0 8px 25px var(--shadow-lg);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur);max-width:500px;margin:0 auto}.help-section{margin-bottom:1.25rem}.help-section:last-of-type{margin-bottom:1rem}.help-section strong{display:block;color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.help-section ul{margin:0;padding-left:1rem;list-style:none}.help-section li{color:var(--text-secondary);font-size:.875rem;margin-bottom:.25rem;position:relative;line-height:1.4}.help-section li:before{content:"•";color:var(--accent-primary);position:absolute;left:-.75rem}.help-section kbd{background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.25rem;padding:.125rem .375rem;font-size:.75rem;font-weight:500;color:var(--text-primary);font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace}.help-note{background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.5rem;padding:.75rem;text-align:center;color:var(--text-tertiary);font-size:.8125rem;font-weight:500;margin-top:.5rem}.load-older-messages{display:flex;justify-content:center;padding:1rem 0;margin-bottom:1rem}.load-older-btn{padding:.75rem 1.5rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.75rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-primary);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px var(--shadow)}.load-older-btn:hover:not(:disabled){background:var(--gradient-accent);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)}.load-older-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 1px 2px var(--shadow)}.loading-older-messages{display:flex;align-items:center;justify-content:center;padding:1.5rem;color:var(--text-tertiary);font-size:.875rem;gap:.75rem;font-weight:500}.loading-older-messages .typing-indicator{display:flex;gap:.25rem;background:transparent;border:none;padding:0;box-shadow:none}.loading-older-messages .typing-indicator span{width:4px;height:4px;border-radius:50%;background:var(--text-tertiary);animation:typing 1.4s infinite ease-in-out}.sidebar-footer{padding:1rem;border-top:1px solid var(--border-primary);background:var(--bg-tertiary);transition:all .3s ease}.memory-stats{text-align:center;color:var(--text-tertiary);font-size:.75rem;line-height:1.4;font-weight:400}.load-more-conversations{padding:.75rem 0;margin-top:.5rem;border-top:1px solid var(--border-primary)}.load-more-btn{width:100%;padding:.75rem 1rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.75rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-primary);transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px var(--shadow)}.load-more-btn:hover:not(:disabled){background:var(--gradient-accent);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:0 1px 2px var(--shadow)}@media (max-width: 768px){.app{height:100vh;max-width:100%}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:20;box-shadow:0 10px 25px var(--shadow-lg)}.main-content{width:100%}.app-header{padding:1rem}.messages{padding:.75rem .25rem}.message-group{max-width:100%;width:100%;gap:.2rem;margin-bottom:.75rem}.message-group.user .message-content{max-width:85%}.message-group.assistant .message-content{max-width:100%}.message-item{width:100%;padding:.75rem;margin-bottom:.2rem}.input-form{padding:.75rem}.help-content{max-width:calc(100vw - 2rem);padding:1rem}.help-content h4{font-size:1rem}.help-section{margin-bottom:1rem}.help-section strong,.help-section li{font-size:.8125rem}.header-help-tooltip{top:70px;right:.5rem;left:.5rem;max-width:none}}.chart-container{margin:1rem 0;padding:0;background:transparent;border-radius:0;border:none;transition:all .3s ease;box-shadow:none}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.chart-container h3{margin:0;font-size:1rem;font-weight:500;color:var(--text-secondary);letter-spacing:-.01em}.fullscreen-btn{padding:.75rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.75rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:1rem;color:var(--text-primary);box-shadow:0 2px 4px var(--shadow)}.fullscreen-btn:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)}.fullscreen-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur)}.fullscreen-content{background:var(--bg-secondary);border-radius:1.5rem;padding:2rem;width:90vw;height:85vh;max-width:1200px;max-height:800px;overflow:auto;position:relative;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px var(--shadow-lg);border:1px solid var(--border-primary)}.fullscreen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-primary)}.fullscreen-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.close-btn{padding:.75rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.75rem;cursor:pointer;font-size:1.25rem;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1);color:var(--text-primary);box-shadow:0 2px 4px var(--shadow)}.close-btn:hover{background:var(--accent-error);color:#fff;border-color:var(--accent-error);transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow-lg)}.chart-container.fullscreen{margin:0;padding:0;background:transparent;border:none;flex:1;display:flex;flex-direction:column;box-shadow:none}.chart-container.fullscreen .chart-header{display:none}.fullscreen-content>.chart-container{height:100%}.chart-scroll-container{overflow-x:auto;overflow-y:hidden;border-radius:.75rem;position:relative;flex:1;min-height:320px;width:100%;padding:0 1rem;margin:0 -1rem}.table-container{overflow-x:auto;border-radius:.5rem;border:none;box-shadow:none;flex:1;min-height:320px}.data-table{width:100%;border-collapse:collapse;font-size:.875rem;background:var(--bg-secondary)}.data-table th{background:var(--bg-quaternary);padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-primary);letter-spacing:-.01em}.data-table td{padding:1rem;border-bottom:1px solid var(--border-primary);color:var(--text-secondary);font-weight:400}.data-table tr:hover{background:var(--bg-tertiary)}.data-table tr:last-child td{border-bottom:none}.chart-wrapper{margin:.75rem 0;padding:0;background:transparent;border-radius:0;border:none;width:100%;box-sizing:border-box;overflow:visible;box-shadow:none}.chart-controls{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-top:1px solid var(--border-primary);border-radius:0 0 .75rem .75rem}.chart-view-controls,.comparison-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.chart-view-controls span,.comparison-controls span{font-size:.875rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.chart-buttons{display:flex;gap:.375rem}.chart-buttons button{padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:.75rem;font-size:1rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:44px;height:44px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px var(--shadow)}.chart-buttons button:hover{background:var(--bg-quaternary);border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 4px 8px var(--shadow)}.chart-buttons button.active{background:var(--gradient-accent);color:#fff;border-color:transparent;box-shadow:0 4px 12px var(--shadow-lg)}.comparison-selector{padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:.5rem;font-size:.875rem;color:var(--text-primary);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:140px;font-weight:500}.comparison-selector:hover{background:var(--bg-quaternary);border-color:var(--accent-primary)}.comparison-selector:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #7c6f641a}.dark-mode .comparison-selector{background:var(--bg-tertiary);border-color:var(--border-primary);color:var(--text-primary)}.dark-mode .comparison-selector:hover{background:var(--bg-quaternary);border-color:var(--accent-primary)}.dark-mode .comparison-selector:focus{box-shadow:0 0 0 3px #b6a18633}.current-chart{margin:1.5rem 0;padding:2rem;background:var(--bg-secondary);border-radius:1rem;border:2px solid var(--accent-primary);box-shadow:0 8px 20px var(--shadow-lg)}.current-chart h3{margin:0 0 1rem;font-size:1.3rem;font-weight:600;color:var(--accent-primary);letter-spacing:-.02em}.streaming-status{border:none;border-radius:.5rem;overflow:hidden;width:100%;margin:.5rem 0;background:transparent}.streaming-status .streaming-toggle-btn{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-quaternary);border:none;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all .2s ease;gap:.75rem;border:1px solid var(--border-primary)}.streaming-status .streaming-toggle-btn:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.streaming-status .streaming-title{font-weight:500;color:var(--text-secondary);font-size:.875rem}.streaming-content{position:relative;padding:1rem;background:var(--streaming-bg);border-radius:0 0 .5rem .5rem;border:1px solid var(--border-primary);border-top:none}.stream-step{margin-bottom:.75rem}.stream-step:last-child{margin-bottom:0}.step-message{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem;word-wrap:break-word;overflow-wrap:break-word;max-width:100%;font-weight:400}.progress-bar{width:100%;height:4px;background:var(--bg-secondary);border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:var(--gradient-accent);border-radius:2px;transition:width .3s ease}.completed-streaming-status{margin:.5rem 0;border:none;border-radius:.5rem;overflow:hidden;width:100%;background:transparent}.streaming-toggle-btn{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-secondary);transition:all .2s ease;gap:.75rem}.streaming-toggle-btn:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.toggle-icon{transition:transform .2s ease;font-size:.875rem;color:var(--text-secondary);font-weight:600;flex-shrink:0}.toggle-icon.expanded{transform:rotate(180deg)}.streaming-steps-content{padding:1rem;background:var(--streaming-bg);border-radius:0 0 .5rem .5rem;border:1px solid var(--border-primary);border-top:none}.completed-stream-step{margin-bottom:.75rem}.completed-stream-step:last-child{margin-bottom:0}.completed-stream-step .step-message{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem;word-wrap:break-word;overflow-wrap:break-word;max-width:100%;font-weight:400}.progress-fill.completed{background:linear-gradient(90deg,var(--accent-success),var(--accent-primary))}.messages::-webkit-scrollbar{width:8px}.messages::-webkit-scrollbar-track{background:var(--bg-quaternary);border-radius:4px}.messages::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:4px}.messages::-webkit-scrollbar-thumb:hover{background:var(--accent-secondary)}.recharts-default-tooltip{background:var(--bg-secondary)!important;border:1px solid var(--border-primary)!important;border-radius:.75rem!important;box-shadow:0 8px 20px var(--shadow-lg)!important;-webkit-backdrop-filter:var(--blur)!important;backdrop-filter:var(--blur)!important}.demo-suggestions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.5rem}.demo-suggestion{padding:.75rem 1.25rem;background:var(--bg-quaternary);border:1px solid var(--border-primary);border-radius:1.5rem;font-size:.875rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500;box-shadow:0 2px 4px var(--shadow)}.demo-suggestion:hover{background:var(--gradient-accent);color:#fff;border-color:transparent;transform:translateY(-1px);box-shadow:0 4px 8px var(--shadow)}.chart-loading{display:flex;align-items:center;justify-content:center;height:300px;background:var(--bg-tertiary);border-radius:.75rem;color:var(--text-tertiary);font-weight:500}@media (max-width: 768px){.messages{padding:.75rem}.message{max-width:100%}.chart-container,.chart-wrapper{padding:.5rem 0;margin:.5rem -.25rem;border-radius:.5rem;width:calc(100% + .5rem)}.chart-scroll-container{margin:0 -1rem;padding:0 1rem;min-height:240px}.chart-controls{flex-direction:column;align-items:flex-start;gap:.75rem;margin-top:.75rem;padding-top:.75rem}.comparison-controls{width:100%;flex-direction:column;align-items:flex-start;gap:.5rem}.comparison-controls span{font-size:.8125rem;font-weight:600}.chart-buttons{flex-wrap:wrap;gap:.5rem}.chart-controls button{min-width:36px;height:36px;font-size:.875rem;padding:.5rem}.fullscreen-modal{padding:.5rem}.fullscreen-content{padding:1rem;width:98vw;height:95vh;max-width:none;border-radius:.75rem}.fullscreen-header h2{font-size:1.125rem}.table-container{font-size:.8rem;margin:0 -.75rem}.data-table th,.data-table td{padding:.5rem}.input-form{padding:.75rem}.app-header{padding:.75rem 1rem}.app-header h1{font-size:1.5rem}.logout-btn{padding:.5rem .75rem;font-size:.8rem}.header-right{gap:.5rem}.desktop-header{display:none}.mobile-header{display:flex}.desktop-only{display:none}.app-header h1{font-size:1.25rem}.connection-status{font-size:.75rem}.connection-status .status-text{display:none}.profile-dropdown{right:-.5rem;min-width:180px}.help-tooltip-responsive{position:fixed;top:10%;left:5%;right:5%;bottom:10%;transform:none;margin:0;z-index:1001;max-width:none;width:auto;height:auto;max-height:none;overflow-y:auto}.help-content{padding:1.5rem;max-width:none;height:100%;display:flex;flex-direction:column}.help-header h4{font-size:1.25rem}.help-section{margin-bottom:1.5rem}.help-section strong{font-size:1rem;margin-bottom:.75rem}.help-section li{font-size:1rem;margin-bottom:.5rem;line-height:1.5}.help-note{font-size:1rem;padding:1rem;margin-top:1rem}.help-backdrop{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.header-help-tooltip{display:none}.comparison-selector{min-width:120px;max-width:calc(100vw - 4rem);font-size:.8125rem;padding:.5rem}.comparison-selector option{padding:.5rem;font-size:.8125rem}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}.login-background{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0}.bg-gradient{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb,#f5576c,#4facfe);background-size:400% 400%;animation:gradientShift 15s ease infinite}.bg-pattern{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 20% 80%,rgba(120,119,198,.3) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,119,198,.3) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(120,219,255,.3) 0%,transparent 50%);animation:patternFloat 20s ease-in-out infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes patternFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.login-content{position:relative;z-index:1;max-width:480px;width:90%;display:flex;flex-direction:column;align-items:center;gap:2rem;animation:fadeInUp .8s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:1rem}.brand-icon{margin-bottom:1.5rem;animation:iconBounce 2s ease-in-out infinite}@keyframes iconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.icon-circle{width:80px;height:80px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto;box-shadow:0 10px 30px #667eea66;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2)}.icon-text{font-size:2rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.brand-title{margin:0 0 1rem;display:flex;flex-direction:column;gap:.25rem}.brand-name{font-size:3rem;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.05em;text-shadow:0 4px 20px rgba(102,126,234,.3)}.brand-subtitle{font-size:1.125rem;font-weight:500;color:#ffffffe6;letter-spacing:.05em;text-transform:uppercase}.brand-description{font-size:1.125rem;color:#fffc;font-weight:400;line-height:1.6;margin:0}.error-message{display:flex;align-items:center;justify-content:center;gap:.75rem;background:#fee2e2f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#dc2626;padding:1rem 1.25rem;border-radius:16px;margin-bottom:2rem;border:1px solid rgba(252,165,165,.6);font-weight:500;animation:errorSlide .3s ease-out;box-shadow:0 10px 25px #dc26261a;max-width:420px;width:100%}@keyframes errorSlide{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.error-icon{font-size:1.25rem;flex-shrink:0}.meesho-signin-btn{width:100%;max-width:420px;background:linear-gradient(135deg,#667eea,#764ba2,#667eea,#764ba2,#667eea);background-size:200% 200%;background-position:0% 0%;border:none;border-radius:24px;padding:0;font-size:1.125rem;font-weight:600;cursor:pointer;transform:translateY(0) scale(1);transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 20px 40px #667eea40,0 8px 16px #764ba226,inset 0 1px #ffffff1a,0 0 0 1px #ffffff0d;position:relative;overflow:hidden;animation:buttonSlideIn .8s ease-out .4s both}.meesho-signin-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);transition:left .6s ease}.meesho-signin-btn:hover:before{left:100%}@keyframes buttonSlideIn{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.meesho-signin-btn:hover:not(.loading){transform:translateY(-2px) scale(1.01);background-position:100% 0;box-shadow:0 20px 35px #667eea4d,0 10px 20px #764ba233,inset 0 1px #ffffff26,0 0 0 1px #ffffff1a,0 0 20px #667eea26}.meesho-signin-btn:active:not(.loading){transform:translateY(-1px) scale(1.005);transition:all .1s ease}.meesho-signin-btn.loading{cursor:not-allowed;opacity:.85}.meesho-signin-btn.loading .btn-content{opacity:.9}.btn-content{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.375rem 2.5rem;background:linear-gradient(135deg,#fffffffa,#ffffffeb);margin:4px;border-radius:20px;color:#1f2937;position:relative;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);box-shadow:inset 0 1px #ffffff4d}.btn-content:before{content:"🚀";font-size:1.25rem;margin-right:.25rem;filter:drop-shadow(0 1px 2px rgba(102,126,234,.3))}.btn-text{font-weight:700;font-size:1.125rem;letter-spacing:-.02em;background:linear-gradient(135deg,#1f2937,#374151);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.loading-spinner{position:absolute;right:2rem}.spinner{width:24px;height:24px;border:3px solid rgba(102,126,234,.2);border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;box-shadow:0 0 10px #667eea4d}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 640px){.login-content{width:95%;gap:1.5rem}.brand-name{font-size:2.5rem}.brand-subtitle,.brand-description{font-size:1rem}.meesho-signin-btn{max-width:none;width:100%}.btn-content{padding:1.25rem 2rem}.btn-content:before{font-size:1.125rem}.btn-text{font-size:1rem}.loading-spinner{right:1.75rem}}@media (max-width: 480px){.brand-name{font-size:2rem}.icon-circle{width:60px;height:60px}.icon-text{font-size:1.5rem}.btn-content{padding:1.125rem 1.75rem}.btn-content:before{font-size:1rem;margin-right:.125rem}.btn-text{font-size:.9rem}.loading-spinner{right:1.5rem}.spinner{width:20px;height:20px;border-width:2px}.error-message{padding:.875rem 1rem;margin-bottom:1.5rem}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-color-scheme: dark){.error-message{background:#7f1d1df2;color:#fca5a5;border-color:#7f1d1d99}}
