.sentiment-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:12px;font-size:.75rem;font-weight:500;transition:all .2s ease}.sentiment-icon{font-size:1rem;line-height:1}.sentiment-label{text-transform:capitalize}.sentiment-badge-positive{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.sentiment-badge-negative{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.sentiment-badge-neutral{background-color:#e2e3e5;color:#383d41;border:1px solid #d6d8db}@medi a (max-width: 768px){.sentiment-badge {padding: 3px 6px; font-size: .7rem;} .sentiment-icon {font-size: .9rem;}}@media (max-width: 480px){.sentiment-badge{padding:2px 5px;font-size:.65rem}.sentiment-icon{font-size:.85rem}}.message-actions-container{position:absolute;top:-12px;right:10px;z-index:10}.message-user .message-actions-container{right:auto;left:10px}.message-actions{display:flex;gap:6px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:4px;border-radius:12px;box-shadow:0 4px 12px #00000026;animation:fadeInActions .2s ease}@keyframes fadeInActions{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.action-btn{width:28px;height:28px;border:none;background:transparent;border-radius:8px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.action-btn:hover{background:#667eea1a;transform:scale(1.1)}.copy-btn.copied{color:#28a745}.delete-btn:hover{background:#dc35451a}@med ia (max-width: 768px){.message-actions-container {top: -10px;} .message-actions {padding: 3px; gap: 4px;} .action-btn {width: 26px; height: 26px; font-size: .85rem;}}@media (max-width: 480px){.message-actions-container{top:-8px}.message-actions{padding:2px;gap:3px}.action-btn{width:24px;height:24px;font-size:.8rem}}.emoji-reactions-container{position:absolute;bottom:-16px;left:10px;z-index:10}.selected-reaction{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50%;font-size:1.2rem;box-shadow:0 2px 8px #00000026;animation:reactionPop .3s cubic-bezier(.68,-.55,.265,1.55)}@keyframes reactionPop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.emoji-reactions-picker{display:flex;gap:6px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:6px;border-radius:20px;box-shadow:0 4px 16px #00000026;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.reaction-btn{width:36px;height:36px;border:none;background:transparent;border-radius:50%;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.reaction-btn:hover{background:#667eea1a;transform:scale(1.2)}.reaction-btn.selected{background:#667eea33;transform:scale(1.1)}@media (max-width: 768px){.emoji-reactions-container{bottom:-14px}.selected-reaction{width:28px;height:28px;font-size:1.1rem}.emoji-reactions-picker{gap:4px;padding:4px}.reaction-btn{width:32px;height:32px;font-size:1.2rem}}@media (max-width: 480px){.emoji-reactions-container{bottom:-12px}.selected-reaction{width:26px;height:26px;font-size:1rem}.emoji-reactions-picker{gap:3px;padding:3px}.reaction-btn{width:30px;height:30px;font-size:1.1rem}}.message{display:flex;margin-bottom:16px;position:relative;z-index:3}.message-user{animation:slideInRight .4s cubic-bezier(.4,0,.2,1)}.message-bot{animation:slideInLeft .4s cubic-bezier(.4,0,.2,1)}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.message-user{justify-content:flex-end}.message-bot{justify-content:flex-start}.message-content{max-width:70%;padding:16px 20px;border-radius:24px;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:0 8px 32px #0000001a,inset 0 1px 1px #ffffff80,inset 0 -1px 1px #0000000d;border:1px solid rgba(255,255,255,.3);position:relative}.message-content:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,#ffffff4d,#fff0);border-radius:24px 24px 0 0;pointer-events:none}.message-user .message-content{background:linear-gradient(135deg,#667eeab3,#764ba2b3);color:#fff;border:1px solid rgba(255,255,255,.4)}.message-bot .message-content{background:#ffffff40;color:#1a1a1a;border:1px solid rgba(255,255,255,.5)}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:.75rem;opacity:.8}.message-sender{font-weight:600}.message-timestamp{font-size:.7rem}.message-text{line-height:1.6;word-wrap:break-word;position:relative;z-index:1}.message-bot .message-text{text-shadow:0 1px 2px rgba(255,255,255,.8);font-weight:500}.message-sentiment{margin-top:8px;display:flex;align-items:center;gap:8px;justify-content:flex-start}.message-user .message-sentiment{justify-content:flex-end}.sentiment-emoji{font-size:1.3rem;animation:emojiPop .5s cubic-bezier(.68,-.55,.265,1.55)}@keyframes emojiPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.message-content{max-width:85%;padding:12px 16px;font-size:.95rem}.message-header{font-size:.7rem}.message-timestamp{font-size:.65rem}.sentiment-emoji{font-size:1.1rem}}@media (max-width: 480px){.message-content{max-width:90%;padding:10px 14px;font-size:.9rem}.message-header{font-size:.65rem;margin-bottom:4px}.message-text{line-height:1.5}.sentiment-emoji{font-size:1rem}}.conversation-summary{background:#ffffff40;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:20px;padding:20px;margin:20px 0;border:1px solid rgba(255,255,255,.4);position:relative;z-index:4;box-shadow:0 8px 32px #0000001a,inset 0 1px 1px #ffffff80}.conversation-summary:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,#fff3,#fff0);border-radius:20px 20px 0 0;pointer-events:none}.summary-title{font-size:1.25rem;font-weight:700;margin:0 0 16px;color:#1a1a1a;text-shadow:0 1px 2px rgba(255,255,255,.8);position:relative;z-index:1}.summary-overall{display:flex;align-items:center;gap:12px;margin-bottom:12px}.summary-label{font-weight:600;color:#2a2a2a;text-shadow:0 1px 2px rgba(255,255,255,.8);position:relative;z-index:1}.summary-explanation{color:#3a3a3a;font-size:.9rem;margin:12px 0;line-height:1.5;text-shadow:0 1px 2px rgba(255,255,255,.8);position:relative;z-index:1}.summary-distribution{margin-top:20px}.distribution-title{font-size:1rem;font-weight:600;margin:0 0 12px;color:#495057}.distribution-item{margin-bottom:16px}.distribution-label{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:.9rem;color:#495057}.distribution-icon{font-size:1.2rem}.distribution-count{margin-left:auto;font-weight:500;color:#212529}.distribution-bar{height:8px;background-color:#e9ecef;border-radius:4px;overflow:hidden}.distribution-fill{height:100%;transition:width .3s ease;border-radius:4px}.distribution-fill-positive{background-color:#28a745}.distribution-fill-neutral{background-color:#6c757d}.distribution-fill-negative{background-color:#dc3545}@media (max-width: 768px){.conversation-summary{padding:16px;margin:16px 0}.summary-title{font-size:1.1rem}.summary-explanation,.distribution-label{font-size:.85rem}.distribution-icon{font-size:1.1rem}}@media (max-width: 480px){.conversation-summary{padding:12px;margin:12px 0;border-radius:16px}.summary-title{font-size:1rem}.summary-explanation{font-size:.8rem}.distribution-title{font-size:.9rem}.distribution-label{font-size:.8rem}}.conversation-stats{background:#ffffff40;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-radius:20px;padding:20px;margin:20px 0;border:1px solid rgba(255,255,255,.4);box-shadow:0 8px 32px #0000001a}.stats-title{font-size:1.3rem;font-weight:700;color:#1a1a1a;margin:0 0 20px;text-shadow:0 1px 2px rgba(255,255,255,.8)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:24px}.stat-card{background:#fff6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:16px;text-align:center;border:1px solid rgba(255,255,255,.5)}.stat-value{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px}.stat-label{font-size:.85rem;color:#4a4a4a;font-weight:500;text-shadow:0 1px 2px rgba(255,255,255,.8)}.sentiment-stats h4{font-size:1.1rem;font-weight:600;color:#2a2a2a;margin:0 0 16px;text-shadow:0 1px 2px rgba(255,255,255,.8)}.sentiment-bars{display:flex;flex-direction:column;gap:12px}.sentiment-bar-item{display:grid;grid-template-columns:100px 1fr 40px;align-items:center;gap:12px}.sentiment-bar-label{font-size:.9rem;font-weight:500;color:#2a2a2a;text-shadow:0 1px 2px rgba(255,255,255,.8)}.sentiment-bar-track{height:8px;background:#fff6;border-radius:4px;overflow:hidden}.sentiment-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.sentiment-bar-fill.positive{background:linear-gradient(90deg,#28a745,#20c997)}.sentiment-bar-fill.neutral{background:linear-gradient(90deg,#6c757d,#adb5bd)}.sentiment-bar-fill.negative{background:linear-gradient(90deg,#dc3545,#fd7e14)}.sentiment-bar-count{font-size:.9rem;font-weight:600;color:#2a2a2a;text-align:right;text-shadow:0 1px 2px rgba(255,255,255,.8)}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.sentiment-bar-item{grid-template-columns:80px 1fr 30px;gap:8px}}@med ia (max-width: 480px){.conversation-stats {padding: 16px; margin: 16px 0; border-radius: 16px;} .stats-title {font-size: 1.1rem; margin-bottom: 16px;} .stats-grid {grid-template-columns: repeat(2,1fr); gap: 10px;} .stat-card {padding: 12px;} .stat-value {font-size: 1.6rem;} .stat-label {font-size: .75rem;} .sentiment-stats h4 {font-size: 1rem; margin-bottom: 12px;} .sentiment-bar-item {grid-template-columns: 70px 1fr 28px; gap: 6px;} .sentiment-bar-label {font-size: .8rem;} .sentiment-bar-count {font-size: .8rem;}}.typing-indicator{display:flex;align-items:center;gap:12px;padding:12px 18px!important;min-width:120px}.typing-dots{display:flex;gap:6px;align-items:center}.typing-dots .dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);animation:typingBounce 1.4s infinite ease-in-out;box-shadow:0 2px 4px #667eea4d}.typing-dots .dot:nth-child(1){animation-delay:0s}.typing-dots .dot:nth-child(2){animation-delay:.2s}.typing-dots .dot:nth-child(3){animation-delay:.4s}.typing-text{font-size:.85rem;color:#6c757d;font-style:italic}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-10px)}}@me dia (max-width: 768px){.typing-indicator {padding: 10px 14px !important; min-width: 100px;} .typing-dots .dot {width: 7px; height: 7px;} .typing-text {font-size: .8rem;}}@media (max-width: 480px){.typing-indicator{padding:8px 12px!important;min-width:90px}.typing-dots .dot{width:6px;height:6px;gap:4px}.typing-text{font-size:.75rem}}.theme-toggle{width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.theme-toggle:hover{background:#ffffff4d;transform:rotate(180deg) scale(1.1)}@media (max-width: 768px){.theme-toggle{width:32px;height:32px;font-size:1rem}}@media (max-width: 480px){.theme-toggle{width:28px;height:28px;font-size:.9rem}}.sound-toggle{width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.sound-toggle:hover{background:#ffffff4d;transform:scale(1.1)}@media (max-width: 768px){.sound-toggle{width:32px;height:32px;font-size:1rem}}@media (max-width: 480px){.sound-toggle{width:28px;height:28px;font-size:.9rem}}.tts-toggle{width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.tts-toggle:hover{background:#ffffff4d;transform:scale(1.1)}.tts-toggle.active{background:linear-gradient(135deg,#28a745,#20c997);border-color:#fff;animation:speakPulse 2s infinite}@keyframes speakPulse{0%,to{box-shadow:0 0 #28a745b3}50%{box-shadow:0 0 0 8px #28a74500}}@media (max-width: 768px){.tts-toggle{width:32px;height:32px;font-size:1rem}}@media (max-width: 480px){.tts-toggle{width:28px;height:28px;font-size:.9rem}}.voice-input-btn{width:44px;height:44px;border-radius:50%;border:2px solid rgba(102,126,234,.5);background:#ffffff4d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;padding:8px}.mic-icon{width:100%;height:100%;object-fit:contain;filter:brightness(0) saturate(100%) invert(45%) sepia(93%) saturate(1352%) hue-rotate(224deg) brightness(98%) contrast(92%);transition:all .3s ease}.voice-input-btn:hover{background:#fff6;transform:scale(1.05);box-shadow:0 4px 12px #667eea4d}.voice-input-btn:hover .mic-icon{filter:brightness(0) saturate(100%) invert(35%) sepia(93%) saturate(1352%) hue-rotate(224deg) brightness(108%) contrast(92%)}.voice-input-btn.listening{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#fff;animation:pulse 1.5s infinite}.voice-input-btn.listening .mic-icon{filter:brightness(0) saturate(100%) invert(100%)}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #667eeab3}50%{transform:scale(1.05);box-shadow:0 0 0 10px #667eea00}}@media (max-width: 768px){.voice-input-btn{width:44px;height:44px}}@media (max-width: 480px){.voice-input-btn{width:44px;height:44px}}.language-selector{position:relative}.language-btn{width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.language-btn:hover{background:#ffffff4d;transform:scale(1.05)}.lang-flag{font-size:1.3rem}.language-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:998}.language-dropdown{position:absolute;top:50px;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:12px;padding:8px;min-width:180px;box-shadow:0 8px 32px #0003;z-index:999;animation:dropdownSlide .2s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.language-option{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left}.language-option:hover{background:#667eea1a}.language-option.active{background:#667eea26}.lang-name{flex:1;font-size:.9rem;font-weight:500;color:#2a2a2a}.check-mark{color:#667eea;font-weight:700}@m edia (max-width: 768px){.language-btn {width: 32px; height: 32px;} .lang-flag {font-size: 1.1rem;} .language-dropdown {top: 42px; min-width: 160px;} .language-option {padding: 8px 10px;} .lang-name {font-size: .85rem;}}@media (max-width: 480px){.language-btn{width:28px;height:28px}.lang-flag{font-size:1rem}.language-dropdown{top:38px;min-width:140px;right:-10px}.language-option{padding:6px 8px;gap:8px}.lang-name{font-size:.8rem}}.image-upload-btn{width:44px;height:44px;border-radius:50%;border:2px solid rgba(102,126,234,.5);background:#ffffff4d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#667eea;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px #0000001a}.image-upload-btn:hover{background:#fff6;transform:scale(1.05);box-shadow:0 4px 12px #667eea4d}.image-preview-container{position:relative;display:inline-block;margin:8px 0}.image-preview{max-width:300px;max-height:300px;border-radius:12px;box-shadow:0 4px 12px #00000026}.image-remove-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;border:none;background:#dc3545;color:#fff;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;transition:all .2s ease}@media (max-width: 768px){.image-upload-btn{width:44px;height:44px;font-size:1.2rem}.image-preview{max-width:200px;max-height:200px}}@media (max-width: 480px){.image-upload-btn{width:44px;height:44px;font-size:1.1rem}.image-preview{max-width:150px;max-height:150px}}.chat-interface{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;background:transparent;position:relative;overflow:hidden}.header-toggle-btn{position:fixed;top:10px;right:10px;width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.5);background:#ffffff40;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;z-index:1000;box-shadow:0 4px 12px #0003}.header-toggle-btn:hover{background:#ffffff59;transform:scale(1.1);box-shadow:0 6px 16px #0000004d}.header-toggle-btn:active{transform:scale(.95)}.dark-mode .header-toggle-btn{background:#0006;border-color:#ffffff4d}.dark-mode .header-toggle-btn:hover{background:#00000080}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;box-shadow:0 2px 8px #0000001a;position:relative;z-index:10;gap:20px}.header-left,.header-right{display:flex;align-items:center;gap:16px}.sidebar-toggle{width:40px;height:40px;border-radius:8px;border:2px solid rgba(255,255,255,.5);background:#fff3;color:#fff;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.sidebar-toggle:hover{background:#ffffff4d;transform:scale(1.05)}.chat-header h2{margin:0;font-size:1.5rem;font-weight:600}.user-info{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#fff3;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.5);background:#fff;padding:2px}.user-info span{color:#fff;font-weight:500;font-size:.9rem}.logout-button{padding:8px 16px;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:16px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 10px #f5576c4d}.logout-button:hover{transform:translateY(-2px);box-shadow:0 4px 15px #f5576c80}.summary-button{padding:10px 20px;background:#ffffffe6;color:#667eea;border:2px solid rgba(255,255,255,.5);border-radius:20px;font-weight:600;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.summary-button:hover:not(:disabled){background:#fff;transform:translateY(-2px);box-shadow:0 4px 15px #ffffff4d}.summary-button:disabled{opacity:.5;cursor:not-allowed}.chat-error{display:flex;align-items:center;gap:12px;padding:12px 20px;background-color:#f8d7da;color:#721c24;border-bottom:1px solid #f5c6cb}.error-icon{font-size:1.2rem}.error-close{margin-left:auto;background:none;border:none;font-size:1.5rem;color:#721c24;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.error-close:hover{opacity:.7}.chat-messages{flex:1;overflow-y:auto;padding:20px;position:relative}.chat-messages.empty{padding-top:0}.floating-alien{position:fixed;width:120px;height:120px;z-index:1;pointer-events:none;transition:all 3s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 10px 20px rgba(102,126,234,.3));animation:gentleFloat 4s ease-in-out infinite}.floating-alien img{width:100%;height:100%;object-fit:contain}.chat-messages.empty .floating-alien{width:200px;height:200px;left:50%!important;top:30%!important;transform:translate(-50%,-50%)}@keyframes gentleFloat{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-10px) rotate(2deg)}50%{transform:translateY(-5px) rotate(-2deg)}75%{transform:translateY(-15px) rotate(1deg)}}.chat-empty,.chat-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#495057;gap:20px;text-align:center;position:relative;z-index:2;padding-top:280px}.chat-empty h2{font-size:2rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;text-shadow:0 2px 10px rgba(102,126,234,.2)}.chat-empty p{font-size:1.1rem;color:#6c757d;margin:0}.message{position:relative;z-index:3}@keyframes floatCenter{0%,to{transform:translate(-50%,-50%) translateY(0)}50%{transform:translate(-50%,-50%) translateY(-20px)}}@keyframes floatTopRight{0%,to{transform:translate(0) translateY(0)}50%{transform:translate(0) translateY(-15px)}}.chat-input-form{display:flex;gap:12px;padding:20px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.3);position:relative;z-index:10;flex-shrink:0}.input-wrapper{flex:1;display:flex;flex-direction:column;gap:8px}.image-preview-container{position:relative;display:inline-block;align-self:flex-start}.image-preview{max-width:150px;max-height:150px;border-radius:12px;box-shadow:0 4px 12px #00000026}.image-remove-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;border:none;background:#dc3545;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;transition:all .2s ease;line-height:1}.image-remove-btn:hover{background:#c82333;transform:scale(1.1)}.chat-input{flex:1;padding:14px 20px;border:1px solid rgba(255,255,255,.4);border-radius:30px;font-size:1rem;outline:none;transition:all .3s ease;background:#ffffff4d;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#1a1a1a!important;-webkit-text-fill-color:#1a1a1a!important;box-shadow:0 4px 16px #0000001a,inset 0 1px 1px #fff9}.chat-input::placeholder{color:#00000080}.chat-input:focus{border-color:#fff9;box-shadow:0 4px 20px #667eea4d,inset 0 1px 1px #fff9;background:#fff6}.chat-input:disabled{background-color:#e9ecef;cursor:not-allowed}.chat-send-button{padding:14px 28px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:30px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66}.chat-send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.chat-send-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6;box-shadow:none}.loading-spinner{display:inline-block;animation:spin 1s linear infinite}@media (max-width: 768px){.chat-interface{height:100vh;height:100dvh}.chat-header{padding:10px 12px;flex-wrap:wrap;gap:8px;flex-shrink:0}.header-left{gap:8px;flex:0 0 auto;order:1}.header-right{gap:4px;flex:1;justify-content:flex-end;order:2;flex-wrap:wrap}.chat-header h2{font-size:.9rem;white-space:nowrap}.sidebar-toggle{width:32px;height:32px;font-size:1rem}.summary-button{padding:5px 8px;font-size:.7rem;white-space:nowrap;min-width:auto}.export-dropdown button{padding:5px 8px;font-size:1rem;min-width:32px}.user-info{padding:4px 8px;order:3;flex:1 1 100%;justify-content:center;margin-top:4px}.user-avatar{width:24px;height:24px}.user-info span{font-size:.75rem}.logout-button{padding:4px 8px;font-size:.7rem}.chat-messages{padding:12px 12px 20px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.chat-empty,.chat-loading{padding-top:180px;padding-bottom:120px}.chat-empty h2{font-size:1.3rem}.chat-empty p{font-size:.9rem;padding:0 20px}.floating-alien{width:100px;height:100px}.chat-messages.empty .floating-alien{width:140px;height:140px;top:25%!important}.chat-input-form{padding:12px;flex-wrap:nowrap;gap:8px;flex-shrink:0;position:sticky;bottom:0;background:#ffffff40;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-top:2px solid rgba(255,255,255,.4);box-shadow:0 -4px 12px #0000001a;align-items:flex-end}.input-wrapper{flex:1;min-width:0;display:flex;flex-direction:column}.chat-input{font-size:16px!important;padding:12px 16px;width:100%;min-height:48px;border-radius:24px;background:#ffffffe6;border:2px solid rgba(255,255,255,.5);color:#1a1a1a!important}.chat-input::placeholder{color:#00000080}.chat-send-button{padding:12px 20px;font-size:.9rem;min-width:75px;height:48px;flex-shrink:0;border-radius:24px}.image-preview{max-width:60px;max-height:60px}.image-preview-container{margin-bottom:4px}}@media (max-width: 480px){.chat-header{padding:8px 10px}.header-left{gap:6px}.header-right{gap:3px}.chat-header h2{font-size:.85rem}.sidebar-toggle{width:30px;height:30px;font-size:.95rem}.summary-button{padding:4px 6px;font-size:.65rem}.export-dropdown button{padding:4px 6px;font-size:.9rem;min-width:28px}.user-info{padding:3px 6px}.user-info span{font-size:.7rem}.logout-button{padding:3px 6px;font-size:.65rem}.chat-messages{padding:10px}.chat-empty,.chat-loading{padding-top:140px;padding-bottom:100px}.chat-empty h2{font-size:1.1rem}.chat-empty p{font-size:.85rem}.chat-input-form{padding:10px;gap:6px;position:sticky;bottom:0;align-items:flex-end;background:#ffffff4d;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px)}.input-wrapper{flex:1;min-width:0}.chat-input{font-size:16px!important;padding:12px 14px;min-height:44px;border-radius:22px;width:100%;background:#fffffff2;color:#1a1a1a!important}.chat-send-button{padding:12px 16px;font-size:.85rem;min-width:65px;height:44px;border-radius:22px;flex-shrink:0}.image-preview-container{margin-bottom:4px}}.image-preview-container{position:relative;display:inline-block;margin-right:10px;margin-bottom:8px}.image-preview{max-width:80px;max-height:80px;border-radius:8px;object-fit:cover;border:2px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #0003}.image-remove-btn{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:#f44;color:#fff;border:2px solid white;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding:0;transition:all .2s ease}.image-remove-btn:hover{background:#c00;transform:scale(1.1)}.input-wrapper{display:flex;flex-direction:column;flex:1}.chat-input-form{display:flex;align-items:flex-end;gap:10px;padding:16px 20px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2)}.chat-send-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d;white-space:nowrap;min-width:80px;height:48px}.chat-send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea80}.chat-send-button:disabled{opacity:.6;cursor:not-allowed}.chat-input{flex:1;padding:12px 16px;border:2px solid rgba(255,255,255,.3);border-radius:12px;background:#fff3;color:#fff;font-size:1rem;transition:all .3s ease}.chat-input::placeholder{color:#fff9}.chat-input:focus{outline:none;border-color:#ffffff80;background:#ffffff40}.dark-mode .chat-input{background:#0000004d;border-color:#fff3;color:#fff}.dark-mode .chat-input::placeholder{color:#ffffff80}.conversation-list{width:280px;height:100vh;background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-right:1px solid rgba(102,126,234,.2);display:flex;flex-direction:column;overflow:hidden}.conversation-list-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid rgba(102,126,234,.2);color:#fff}.conversation-list-header h3{margin:0;font-size:1.1rem;color:#fff;font-weight:600}.conversation-search{padding:12px;background:linear-gradient(180deg,#a8c0ff0d,#c5a3ff0d)}.search-input{width:100%;padding:10px 14px;border:1px solid rgba(255,255,255,.3);border-radius:20px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#2a2a2a;font-size:.9rem;outline:none;transition:all .3s ease}.search-input::placeholder{color:#00000080}.search-input:focus{background:#ffffff4d;border-color:#667eea80;box-shadow:0 2px 8px #667eea33}.new-conversation-btn{width:36px;height:36px;border-radius:50%;border:2px solid white;background-color:#fff3;color:#fff;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.new-conversation-btn:hover{background-color:#ffffff4d;transform:scale(1.1)}.conversation-list-loading,.conversation-list-error,.conversation-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:#6c757d}.conversation-list-loading .loading-spinner{font-size:2rem;animation:spin 1s linear infinite}.conversation-list-error button{margin-top:12px;padding:8px 16px;background-color:#007bff;color:#fff;border:none;border-radius:6px;cursor:pointer}.empty-hint{font-size:.85rem;margin-top:8px}.conversation-items{flex:1;overflow-y:auto;padding:12px;background:linear-gradient(180deg,#a8c0ff0d,#c5a3ff0d)}.conversation-item{background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:12px;margin-bottom:10px;cursor:pointer;transition:all .3s ease;border:2px solid transparent;display:flex;justify-content:space-between;align-items:center;gap:8px}.conversation-item:hover{background:#fffffff2;transform:translate(4px);box-shadow:0 4px 12px #667eea33}.conversation-item.active{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 4px 12px #667eea4d}.conversation-item.deleting{opacity:.5;pointer-events:none}.conversation-item-content{flex:1;min-width:0}.conversation-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.conversation-emoji{font-size:1.5rem}.conversation-date{font-size:.75rem;color:#6c757d}.conversation-title{font-size:.9rem;font-weight:600;color:#2a2a2a;margin:6px 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 2px rgba(255,255,255,.8)}.conversation-item-info{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.message-count{color:#495057}.sentiment-label{padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize}.sentiment-label.sentiment-positive{background-color:#d4edda;color:#155724}.sentiment-label.sentiment-negative{background-color:#f8d7da;color:#721c24}.sentiment-label.sentiment-neutral{background-color:#e2e3e5;color:#383d41}.delete-conversation-btn{width:32px;height:32px;border-radius:50%;border:none;background-color:#dc3545;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;opacity:0}.conversation-item:hover .delete-conversation-btn{opacity:1}.delete-conversation-btn:hover:not(:disabled){background-color:#c82333;transform:scale(1.1)}.delete-conversation-btn:disabled{cursor:not-allowed;opacity:.6}@media (max-width: 768px){.conversation-list{position:fixed;top:0;left:0;width:280px;height:100vh;height:100dvh;z-index:1000;box-shadow:4px 0 12px #0003;overflow:hidden}.conversation-list-header{padding:14px}.conversation-list-header h3{font-size:1rem}.new-conversation-btn{width:32px;height:32px;font-size:1.1rem}.conversation-item{padding:10px}.conversation-title{font-size:.85rem}.delete-conversation-btn{opacity:1;width:28px;height:28px;font-size:.9rem}}@media (max-width: 480px){.conversation-list{width:260px}.conversation-list-header{padding:12px}.conversation-item{padding:8px}.conversation-emoji{font-size:1.3rem}.conversation-title{font-size:.8rem}.conversation-date{font-size:.7rem}}.login-container{display:flex;height:100vh;width:100vw;overflow:hidden;position:fixed;top:0;left:0;background:#f5f5f5;z-index:9999}.login-container *{scrollbar-width:none;-ms-overflow-style:none}.login-container *::-webkit-scrollbar{display:none}.login-left{flex:1;display:flex;align-items:center;justify-content:center;padding:60px 40px;background:#fff;overflow:hidden}.login-content{width:100%;max-width:420px;overflow:hidden}.login-brand{display:flex;align-items:center;gap:8px;margin-bottom:60px}.brand-dot{width:10px;height:10px;background:#7c3aed;border-radius:50%}.brand-name{font-size:1rem;font-weight:600;color:#1a1a1a}.login-header{margin-bottom:40px}.login-header h1{font-size:2.5rem;font-weight:700;color:#1a1a1a;margin:0 0 12px;line-height:1.2}.login-header p{color:#6b7280;font-size:1rem;margin:0;line-height:1.5}.alert{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;font-size:.9rem;font-weight:500;margin-bottom:20px}.alert-error{background-color:#fee;color:#c00;border:1px solid #fcc}.alert-success{background-color:#efe;color:#0a0;border:1px solid #cfc}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column}.form-input{padding:14px 16px;border:1px solid #e5e7eb;border-radius:8px;font-size:.95rem;transition:all .2s ease;background:#fff;color:#1a1a1a}.form-input::placeholder{color:#9ca3af}.form-input:focus{outline:none;border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}.form-input:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.form-options{display:flex;justify-content:space-between;align-items:center;margin-top:-8px}.remember-me{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#6b7280;cursor:pointer}.remember-me input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#7c3aed}.forgot-password{font-size:.9rem;color:#6b7280;text-decoration:none}.forgot-password:hover{color:#7c3aed}.btn-signin{padding:14px 24px;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #7c3aed4d;margin-top:8px}.btn-signin:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #7c3aed66}.btn-signin:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{text-align:center;margin-top:24px}.login-footer p{color:#6b7280;font-size:.9rem;margin:0}.link-text{color:#7c3aed;font-weight:600;cursor:pointer;text-decoration:none}.link-text:hover{text-decoration:underline}.otp-hint{color:#6b7280;font-size:.9rem;margin-bottom:12px;text-align:center}.otp-input{text-align:center;font-size:1.3rem!important;letter-spacing:4px;font-weight:600}.back-link{background:none;border:none;color:#7c3aed;font-weight:600;cursor:pointer;font-size:.9rem;padding:0;margin-bottom:8px}.back-link:hover{text-decoration:underline}.resend-hint{color:#9ca3af;font-size:.85rem;margin:8px 0 0}.login-right{flex:1;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8b5cf6,#a78bfa,#c4b5fd);position:relative;overflow:hidden;height:100vh}.login-image{width:100%;height:100%;object-fit:cover;-webkit-user-select:none;user-select:none}@media (max-width: 1024px){.login-left{padding:40px 30px}}@media (max-width: 768px){.login-container{flex-direction:column}.login-left{padding:30px 20px;flex:none;min-height:60vh}.login-right{flex:none;min-height:40vh;height:40vh}.login-header h1{font-size:2rem}.login-content{max-width:100%}}@media (max-width: 480px){.login-left{padding:20px 16px;min-height:65vh}.login-right{min-height:35vh;height:35vh}.login-header{margin-bottom:30px}.login-header h1{font-size:1.6rem}.login-header p{font-size:.9rem}.form-input{padding:12px 14px;font-size:.9rem}.btn-signin{padding:12px 20px;font-size:.95rem}.login-brand{margin-bottom:30px}.alert{padding:10px 14px;font-size:.85rem}}*{box-sizing:border-box;margin:0;padding:0}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,#f093fb);min-height:100vh;transition:background .3s ease}body.dark-mode{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.app{display:flex;width:100%;height:100vh;height:100dvh;background:linear-gradient(135deg,#a8c0ff,#c5a3ff,#fbc2eb);position:relative;transition:background .3s ease;overflow:hidden}.app.dark-mode{background:linear-gradient(135deg,#0f0f1e,#1a1a2e,#16213e)}.app-loading,.app-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb);color:#fff;padding:20px;text-align:center}.loading-spinner-large{font-size:3rem;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-loading p{font-size:1.2rem;color:#fff;margin:10px 0;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.2)}.app-loading .loading-hint{font-size:.95rem;color:#ffffffd9;font-style:italic;margin-top:5px}.loading-animation{border-radius:20px;box-shadow:0 10px 40px #0000004d;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.error-icon-large{font-size:4rem;margin-bottom:20px}.app-error h2{font-size:1.5rem;margin-bottom:12px;color:#212529}.app-error p{font-size:1rem;color:#6c757d;margin-bottom:24px;text-align:center;max-width:400px}.retry-button{padding:12px 24px;background-color:#007bff;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.retry-button:hover{background-color:#0056b3;transform:translateY(-1px)}@media (max-width: 768px){.app{overflow-x:hidden}.app-loading p{font-size:1rem}.loading-spinner-large{font-size:2.5rem}.app-error h2{font-size:1.25rem}.app-error p{font-size:.9rem;padding:0 20px}.error-icon-large{font-size:3.5rem}.retry-button{padding:10px 20px;font-size:.95rem}}@media (max-width: 480px){.loading-spinner-large{font-size:2rem}.app-loading p{font-size:.9rem}.error-icon-large{font-size:3rem}.app-error h2{font-size:1.1rem}.app-error p{font-size:.85rem}.retry-button{padding:8px 16px;font-size:.9rem}}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html{font-size:16px;-webkit-text-size-adjust:100%}body{margin:0;padding:0;overflow:hidden;position:fixed;width:100%;height:100vh;height:100dvh;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}#root{width:100%;height:100%;overflow:hidden}@media (max-width: 768px){input,textarea,select{font-size:16px!important}}html{scroll-behavior:smooth}button,a,input[type=button],input[type=submit]{min-height:44px;min-width:44px}@media (max-width: 480px){button,a,input[type=button],input[type=submit]{min-height:40px;min-width:40px}}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.sidebar-overlay.active{display:block}}
