:root{--primary: #2A3447;--primary-dark: #1A2332;--primary-light: #3D4A5C;--secondary: #667eea;--secondary-dark: #764ba2;--success: #4CAF50;--error: #FF3B30;--warning: #FF9800;--info: #2196F3;--background: #f0f2f5;--surface: #FFFFFF;--text-primary: #1A1A1A;--text-secondary: #6B7280;--text-light: #9CA3AF;--border: #E8E9EA;--border-light: #F0F0F0;--white: #FFFFFF;--black: #000000;--incoming-msg: #FFFFFF;--outgoing-msg: #d9fdd3;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--font-family: "Segoe UI", "Helvetica Neue", Helvetica, Arial, sans-serif}@media(prefers-color-scheme:dark){:root{--primary: #202c33;--primary-dark: #111b21;--primary-light: #2a3942;--background: #111b21;--surface: #202c33;--text-primary: #e9edef;--text-secondary: #8696a0;--text-light: #667781;--border: #2a3942;--border-light: #222e35;--incoming-msg: #202c33;--outgoing-msg: #005c4b;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4)}}*{box-sizing:border-box}body{margin:0;font-family:var(--font-family);background-color:var(--background);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100vh;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#0000004d}@media(prefers-color-scheme:dark){::-webkit-scrollbar-thumb{background:#ffffff1a}::-webkit-scrollbar-thumb:hover{background:#ffffff26}}.app-container{display:flex;height:100vh;width:100vw;overflow:hidden;position:relative}@media(min-width:1600px){.app-container{max-width:1600px;margin:19px auto 0;box-shadow:0 0 20px #0000001a;height:calc(100vh - 38px);border-radius:4px;overflow:hidden}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flex-center{display:flex;align-items:center;justify-content:center}@keyframes highlight-blink{0%{background-color:transparent}50%{background-color:#06cf9c4d}to{background-color:transparent}}.highlight-message{animation:highlight-blink 1s ease-in-out}.call-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center}.call-screen{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;position:relative}.call-avatar-container{margin-bottom:30px}.call-avatar{width:120px;height:120px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:600;overflow:hidden;box-shadow:0 8px 32px #0003}.call-avatar.large{width:160px;height:160px;font-size:64px}.call-avatar img{width:100%;height:100%;object-fit:cover}.call-avatar.pulse{animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #ffffffb3}70%{box-shadow:0 0 0 20px #fff0}to{box-shadow:0 0 #fff0}}.call-info{text-align:center;margin-bottom:60px}.caller-name{font-size:32px;font-weight:600;margin:0 0 10px}.call-type{font-size:18px;opacity:.9;margin:0}.call-duration{font-size:20px;opacity:.9;margin:10px 0 0}.group-call-text{font-size:16px;opacity:.8;margin:10px 0 0}.call-controls{display:flex;gap:60px;align-items:center;justify-content:center}.control-item{display:flex;flex-direction:column;align-items:center;gap:12px}.control-item span{font-size:14px;font-weight:500}.control-button{width:64px;height:64px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #0003}.control-button:hover{transform:scale(1.05)}.control-button:active{transform:scale(.95)}.decline-button{background:#ef5350;color:#fff}.answer-button{background:#4caf50;color:#fff}.active-call-controls{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;gap:20px;padding:20px;background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50px}.active-call-controls .control-button{width:56px;height:56px;background:#fff3;color:#fff;position:relative}.active-call-controls .control-button.active{background:#ef5350}.active-call-controls .end-call-button{background:#ef5350;width:64px;height:64px}.audio-indicator{position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.audio-wave{width:100%;background:#4caf50;border-radius:2px;transition:height .1s ease,opacity .1s ease;animation:pulse-wave .3s ease-in-out infinite alternate}@keyframes pulse-wave{0%{transform:scaleY(.8)}to{transform:scaleY(1)}}.video-container{width:100%;height:100%;position:relative;background:#000}.main-video{width:100%;height:100%;position:relative}.remote-video,.local-video-main{width:100%;height:100%;object-fit:contain;background:#000}.video-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.video-disabled-overlay{position:absolute;inset:0;z-index:10}.placeholder-name{font-size:24px;font-weight:600;margin:20px 0 10px}.placeholder-status{font-size:16px;opacity:.9}.pip-video{position:absolute;top:20px;right:20px;width:160px;height:200px;border-radius:12px;overflow:hidden;box-shadow:0 4px 16px #0006;cursor:pointer;transition:transform .2s ease;background:#000}.pip-video:hover{transform:scale(1.05)}.local-video-pip,.remote-video-pip{width:100%;height:100%;object-fit:cover}.pip-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.pip-placeholder .call-avatar.small{width:60px;height:60px;font-size:24px}.call-info-overlay{position:absolute;top:20px;left:20px;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 20px;border-radius:12px}.call-info-overlay h3{margin:0 0 4px;font-size:18px;font-weight:600}.call-info-overlay p{margin:0;font-size:14px;opacity:.9}.connecting-overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.connecting-overlay p{font-size:20px;font-weight:500}.voice-call-view{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}@media(max-width:768px){.call-avatar{width:100px;height:100px;font-size:40px}.call-avatar.large{width:140px;height:140px;font-size:56px}.caller-name{font-size:28px}.call-type{font-size:16px}.control-button{width:56px;height:56px}.pip-video{width:120px;height:160px;top:15px;right:15px}.call-info-overlay{top:15px;left:15px;padding:10px 16px}.call-info-overlay h3{font-size:16px}.call-info-overlay p{font-size:12px}.active-call-controls{bottom:30px;gap:15px;padding:15px}.active-call-controls .control-button{width:48px;height:48px}.active-call-controls .end-call-button{width:56px;height:56px}}.call-type-switch-prompt{position:absolute;inset:0;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.prompt-content{background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:40px;text-align:center;max-width:400px;box-shadow:0 8px 32px #0006;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.prompt-icon{margin-bottom:20px;animation:scaleIn .4s ease}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.prompt-title{font-size:24px;font-weight:600;margin:0 0 12px;color:#fff}.prompt-message{font-size:16px;opacity:.9;margin:0 0 30px;color:#fff}.prompt-buttons{display:flex;gap:16px;justify-content:center}.prompt-button{padding:12px 32px;border-radius:24px;border:none;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:120px}.prompt-button:hover{transform:scale(1.05)}.prompt-button:active{transform:scale(.95)}.prompt-button.decline{background:#ef5350e6;color:#fff}.prompt-button.decline:hover{background:#ef5350}.prompt-button.accept{background:#00a884e6;color:#fff}.prompt-button.accept:hover{background:#00a884}@media(max-width:768px){.prompt-content{padding:30px 20px;max-width:90%}.prompt-title{font-size:20px}.prompt-message{font-size:14px}.prompt-buttons{flex-direction:column;gap:12px}.prompt-button{width:100%}}.chatbot-fab{position:fixed;width:60px;height:60px;border-radius:50%;border:none;cursor:grab;z-index:9999;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 6px 20px #667eea73,0 2px 8px #00000026;transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s ease;user-select:none;-webkit-user-select:none}.chatbot-fab:hover{transform:scale(1.08);box-shadow:0 8px 28px #667eea8c,0 4px 12px #0003}.chatbot-fab:active{cursor:grabbing;transform:scale(.96)}.chatbot-fab svg{width:28px;height:28px;color:#fff;transition:transform .3s ease}.chatbot-fab.chatbot-open svg{transform:rotate(90deg)}.chatbot-fab-badge{position:absolute;top:-2px;right:-2px;width:18px;height:18px;background:#ff3b30;border-radius:50%;border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;animation:chatbot-pulse 2s infinite}@keyframes chatbot-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.chatbot-panel{position:fixed;width:380px;height:520px;max-height:80vh;border-radius:20px;z-index:9998;display:flex;flex-direction:column;overflow:hidden;background:#ffffffeb;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid rgba(255,255,255,.35);box-shadow:0 20px 60px #00000026,0 8px 20px #00000014,inset 0 1px #fff9;transform-origin:bottom right;animation:chatbot-panel-in .35s cubic-bezier(.34,1.56,.64,1) forwards}.chatbot-panel.chatbot-panel-closing{animation:chatbot-panel-out .25s ease-in forwards}@keyframes chatbot-panel-in{0%{opacity:0;transform:scale(.6) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes chatbot-panel-out{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.6) translateY(20px)}}.chatbot-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:16px 18px;display:flex;align-items:center;gap:12px;cursor:grab;user-select:none;-webkit-user-select:none;flex-shrink:0}.chatbot-header:active{cursor:grabbing}.chatbot-header-avatar{width:38px;height:38px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chatbot-header-avatar svg{width:20px;height:20px;color:#fff}.chatbot-header-info{flex:1;min-width:0}.chatbot-header-title{color:#fff;font-size:15px;font-weight:600;letter-spacing:.2px}.chatbot-header-status{color:#ffffffbf;font-size:12px;margin-top:1px;display:flex;align-items:center;gap:5px}.chatbot-header-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;display:inline-block;animation:chatbot-dot-glow 2s ease-in-out infinite}@keyframes chatbot-dot-glow{0%,to{box-shadow:0 0 4px #4ade8066}50%{box-shadow:0 0 10px #4ade80cc}}.chatbot-header-actions{display:flex;gap:4px}.chatbot-header-btn{width:32px;height:32px;border:none;border-radius:50%;background:#ffffff26;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.chatbot-header-btn:hover{background:#ffffff47}.chatbot-header-btn svg{width:16px;height:16px}.chatbot-messages{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:10px;background:linear-gradient(180deg,#f5f5fa80,#f0f2f5cc)}.chatbot-messages::-webkit-scrollbar{width:5px}.chatbot-messages::-webkit-scrollbar-track{background:transparent}.chatbot-messages::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}.chatbot-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:20px;gap:14px}.chatbot-welcome-icon{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#667eea22,#764ba222);display:flex;align-items:center;justify-content:center;animation:chatbot-float 3s ease-in-out infinite}@keyframes chatbot-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.chatbot-welcome-icon svg{width:36px;height:36px;color:#667eea}.chatbot-welcome h3{margin:0;font-size:18px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.chatbot-welcome p{margin:0;font-size:13px;color:#6b7280;line-height:1.5;max-width:260px}.chatbot-suggestions{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:6px}.chatbot-suggestion-btn{padding:6px 14px;border:1px solid rgba(102,126,234,.25);border-radius:20px;background:#667eea0f;color:#667eea;font-size:12px;cursor:pointer;transition:all .2s;font-weight:500}.chatbot-suggestion-btn:hover{background:#667eea24;border-color:#667eea66;transform:translateY(-1px)}.chatbot-msg{max-width:85%;padding:10px 14px;border-radius:16px;font-size:13.5px;line-height:1.55;animation:chatbot-msg-in .3s ease-out forwards;word-wrap:break-word;overflow-wrap:break-word}@keyframes chatbot-msg-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chatbot-msg-user{align-self:flex-end;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px;box-shadow:0 2px 8px #667eea40}.chatbot-msg-bot{align-self:flex-start;background:#fff;color:#1a1a1a;border-bottom-left-radius:4px;box-shadow:0 1px 4px #0000000f;border:1px solid rgba(0,0,0,.04)}.chatbot-msg-bot p{margin:0 0 6px}.chatbot-msg-bot p:last-child{margin-bottom:0}.chatbot-msg-bot ul,.chatbot-msg-bot ol{margin:4px 0;padding-left:18px}.chatbot-msg-bot li{margin-bottom:2px}.chatbot-msg-bot code{background:#667eea14;padding:1px 5px;border-radius:4px;font-size:12.5px;font-family:Fira Code,Consolas,monospace}.chatbot-msg-bot pre{background:#1e1e2e;color:#cdd6f4;padding:10px 12px;border-radius:10px;overflow-x:auto;font-size:12px;margin:6px 0}.chatbot-msg-bot pre code{background:none;padding:0;color:inherit}.chatbot-msg-bot strong{font-weight:600;color:#374151}.chatbot-msg-time{font-size:10px;opacity:.55;margin-top:4px;display:block}.chatbot-msg-user .chatbot-msg-time{text-align:right;color:#ffffffb3}.chatbot-sources{margin-top:8px;padding-top:6px;border-top:1px solid rgba(0,0,0,.06)}.chatbot-sources-label{font-size:10px;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.chatbot-source-item{font-size:11px;color:#6b7280;padding:2px 0;display:flex;align-items:center;gap:4px}.chatbot-source-item:before{content:"📄";font-size:10px}.chatbot-typing{align-self:flex-start;background:#fff;padding:12px 18px;border-radius:16px 16px 16px 4px;display:flex;gap:5px;align-items:center;box-shadow:0 1px 4px #0000000f;border:1px solid rgba(0,0,0,.04);animation:chatbot-msg-in .3s ease-out forwards}.chatbot-typing-dot{width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);animation:chatbot-typing-bounce 1.4s ease-in-out infinite}.chatbot-typing-dot:nth-child(2){animation-delay:.16s}.chatbot-typing-dot:nth-child(3){animation-delay:.32s}@keyframes chatbot-typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-8px);opacity:1}}.chatbot-error{align-self:center;background:#ff3b3014;color:#dc2626;padding:8px 16px;border-radius:12px;font-size:12px;text-align:center;border:1px solid rgba(255,59,48,.15);display:flex;align-items:center;gap:6px}.chatbot-input-area{padding:12px 14px;border-top:1px solid rgba(0,0,0,.06);display:flex;align-items:flex-end;gap:8px;background:#fffc;flex-shrink:0}.chatbot-input-wrapper{flex:1;position:relative}.chatbot-input{width:100%;padding:10px 14px;border:1.5px solid rgba(0,0,0,.08);border-radius:22px;font-size:13.5px;font-family:inherit;outline:none;background:#f5f5facc;color:#1a1a1a;resize:none;min-height:40px;max-height:100px;line-height:1.4;transition:border-color .2s,box-shadow .2s}.chatbot-input::placeholder{color:#9ca3af}.chatbot-input:focus{border-color:#667eea66;box-shadow:0 0 0 3px #667eea14}.chatbot-send-btn{width:40px;height:40px;border:none;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s,box-shadow .2s,opacity .2s;box-shadow:0 3px 12px #667eea59}.chatbot-send-btn:hover:not(:disabled){transform:scale(1.06);box-shadow:0 4px 16px #667eea73}.chatbot-send-btn:active:not(:disabled){transform:scale(.95)}.chatbot-send-btn:disabled{opacity:.4;cursor:not-allowed}.chatbot-send-btn svg{width:18px;height:18px}@media(prefers-color-scheme:dark){.chatbot-panel{background:#202c33eb;border-color:#ffffff14;box-shadow:0 20px 60px #0006,0 8px 20px #00000040,inset 0 1px #ffffff0d}.chatbot-messages{background:linear-gradient(180deg,#111b2180,#111b21cc)}.chatbot-messages::-webkit-scrollbar-thumb{background:#ffffff1a}.chatbot-msg-bot{background:#202c33;color:#e9edef;border-color:#ffffff0d;box-shadow:0 1px 4px #0003}.chatbot-msg-bot strong{color:#e2e8f0}.chatbot-msg-bot code{background:#667eea26}.chatbot-typing{background:#202c33;border-color:#ffffff0d;box-shadow:0 1px 4px #0003}.chatbot-welcome p{color:#8696a0}.chatbot-welcome-icon{background:linear-gradient(135deg,#667eea18,#764ba218)}.chatbot-suggestion-btn{background:#667eea1a;border-color:#667eea33}.chatbot-suggestion-btn:hover{background:#667eea33}.chatbot-input-area{background:#202c33e6;border-top-color:#ffffff0f}.chatbot-input{background:#2a3942cc;border-color:#ffffff14;color:#e9edef}.chatbot-input::placeholder{color:#667781}.chatbot-input:focus{border-color:#667eea80;box-shadow:0 0 0 3px #667eea1f}.chatbot-error{background:#dc26261f;border-color:#dc262633}.chatbot-sources{border-top-color:#ffffff0f}.chatbot-source-item{color:#8696a0}.chatbot-fab-badge{border-color:#111b21}}@media(max-width:480px){.chatbot-panel{width:calc(100vw - 24px);height:calc(100vh - 120px);max-height:none;border-radius:16px}}
