.safety-indicator{display:flex;align-items:center;gap:6px;padding:.375rem .75rem;background:linear-gradient(135deg,#10b981,#059669);border-radius:6px;color:#fff;font-size:13px;font-weight:500;box-shadow:0 2px 4px #10b98133;transition:all .2s ease}.safety-indicator:hover{box-shadow:0 4px 8px #10b9814d;transform:translateY(-1px)}.safety-indicator-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:#fff}.safety-indicator-icon svg{width:16px;height:16px}.safety-indicator-content{display:flex;align-items:center;gap:6px}.safety-indicator-status{font-weight:600;letter-spacing:.3px}.safety-indicator-level{padding:2px 6px;background:#fff3;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.safety-indicator{font-size:12px;padding:.25rem .5rem;gap:4px}.safety-indicator-icon{width:16px;height:16px}.safety-indicator-icon svg{width:12px;height:12px}.safety-indicator-level{font-size:10px;padding:1px 4px}.safety-indicator-status,.safety-indicator-level{display:none}}@media (prefers-contrast: high){.safety-indicator{border:2px solid white;background:#059669}}@media (prefers-reduced-motion: reduce){.safety-indicator{transition:none}.safety-indicator:hover{transform:none}}@media (prefers-color-scheme: dark){.safety-indicator{background:linear-gradient(135deg,#059669,#047857)}}.mode-selector{display:flex;justify-content:center;margin-bottom:16px}.mode-toggle-container{position:relative;display:flex;background:#f1f5f9;border-radius:8px;padding:4px;box-shadow:inset 0 1px 3px #0000001a}.mode-toggle-option{position:relative;display:flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;font-family:inherit;font-size:13px;font-weight:500;color:#64748b;z-index:2;min-width:90px;justify-content:center}.mode-toggle-option:hover{color:#334155}.mode-toggle-option.active{color:#1e293b;font-weight:600}.mode-toggle-option:focus{outline:2px solid #4a90e2;outline-offset:2px}.mode-icon{font-size:16px;line-height:1;flex-shrink:0}.mode-label{font-size:inherit;font-weight:inherit;color:inherit;white-space:nowrap}.mode-toggle-slider{position:absolute;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px);background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a,0 1px 2px #0000000f;transition:transform .2s ease;z-index:1}@media (max-width: 640px){.mode-toggle-container{padding:3px}.mode-toggle-option{padding:6px 12px;font-size:12px;min-width:80px;gap:4px}.mode-icon{font-size:14px}.mode-toggle-slider{top:3px;left:3px;width:calc(50% - 3px);height:calc(100% - 6px)}}@media (prefers-reduced-motion: reduce){.mode-toggle-option,.mode-toggle-slider{transition:none}}@media (prefers-contrast: high){.mode-toggle-container{background:#fff;border:2px solid #000000}.mode-toggle-option{color:#000}.mode-toggle-option.active{color:#000;font-weight:700}.mode-toggle-slider{background:#e5e7eb;border:1px solid #000000}}.conversation-flow-indicator{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:1rem;margin-bottom:1rem;box-shadow:0 4px 12px #667eea33;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.flow-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.flow-info{display:flex;flex-direction:column;gap:.25rem}.flow-step-count{font-size:14px;font-weight:600;color:#fff;opacity:.95}.flow-strategy{font-size:12px;color:#fff;opacity:.8;font-weight:500}.flow-progress-text{font-size:18px;font-weight:700;color:#fff;opacity:.95}.flow-progress-bar{height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-bottom:.75rem}.flow-progress-fill{height:100%;background:#fff;border-radius:4px;transition:width .5s ease;box-shadow:0 0 8px #ffffff80}.flow-step-dots{display:flex;gap:.5rem;justify-content:center;margin-bottom:.75rem;flex-wrap:wrap}.flow-step-dot{width:12px;height:12px;border-radius:50%;background:#ffffff4d;transition:all .3s ease;cursor:pointer;position:relative}.flow-step-dot.completed{background:#fff;box-shadow:0 0 8px #fff9}.flow-step-dot.active{background:#fff;box-shadow:0 0 12px #fffc;transform:scale(1.3);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 12px #fffc}50%{box-shadow:0 0 20px #fff}}.flow-step-dot.upcoming{background:#fff3}.flow-step-dot:hover{transform:scale(1.2)}.flow-current-step{display:flex;align-items:center;gap:.5rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.2)}.flow-step-label{font-size:12px;font-weight:600;color:#fff;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.flow-step-description{font-size:13px;color:#fff;opacity:.95;font-weight:500;flex:1;line-height:1.4}@media (max-width: 768px){.conversation-flow-indicator{padding:.875rem;margin-bottom:.875rem}.flow-header{margin-bottom:.625rem}.flow-step-count{font-size:13px}.flow-strategy{font-size:11px}.flow-progress-text{font-size:16px}.flow-progress-bar{height:6px;margin-bottom:.625rem}.flow-step-dots{gap:.375rem;margin-bottom:.625rem}.flow-step-dot{width:10px;height:10px}.flow-step-dot.active{transform:scale(1.2)}.flow-current-step{padding-top:.625rem}.flow-step-label{font-size:11px}.flow-step-description{font-size:12px}}@media (prefers-reduced-motion: reduce){.conversation-flow-indicator,.flow-progress-fill,.flow-step-dot{animation:none;transition:none}.flow-step-dot.active{animation:none}}@media (prefers-contrast: high){.conversation-flow-indicator{border:2px solid white}.flow-progress-bar,.flow-step-dot{border:1px solid white}}.safety-warning{position:fixed;top:20px;right:20px;z-index:1000;max-width:320px;animation:slideInRight .3s ease-out}.safety-warning--closing{animation:slideOutRight .3s ease-in}.safety-warning__content{display:flex;align-items:center;gap:8px;background:#fff3cd;color:#856404;padding:12px 16px;border-radius:8px;border:1px solid #ffeaa7;box-shadow:0 4px 12px #00000026;font-size:14px;line-height:1.4}.safety-warning__icon{font-size:16px;flex-shrink:0}.safety-warning__message{flex:1;font-weight:500}.safety-warning__close{background:none;border:none;color:#856404;font-size:18px;font-weight:700;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease;flex-shrink:0}.safety-warning__close:hover{background-color:#8564041a}.safety-warning__close:focus{outline:2px solid #856404;outline-offset:2px}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@media (max-width: 768px){.safety-warning{top:10px;right:10px;left:10px;max-width:none}.safety-warning__content{padding:10px 12px;font-size:13px}.safety-warning__icon{font-size:14px}.safety-warning__close{font-size:16px;width:18px;height:18px}}@media (prefers-contrast: high){.safety-warning__content{border-width:2px;border-color:#856404}}@media (prefers-reduced-motion: reduce){.safety-warning{animation:none}.safety-warning--closing{animation:none;opacity:0}.safety-warning__close{transition:none}}.chat-interface{display:flex;flex-direction:column;height:100vh;background:#f7fafc}.chat-layout{display:flex;flex:1;overflow:hidden}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-container{flex:1;display:flex;flex-direction:column;max-width:900px;margin:0 auto;width:100%;padding:2rem 1rem;overflow:hidden}.chat-error{background:#fed7d7;color:#c53030;padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid #c53030}.message-list,.message-list-virtual{flex:1;overflow-y:auto;padding:1rem 0;scroll-behavior:smooth}.message-list-empty{flex:1;display:flex;align-items:center;justify-content:center}.empty-state{text-align:center;color:#718096}.empty-state svg{margin-bottom:1rem}.empty-state h3{font-size:20px;font-weight:600;color:#2d3748;margin-bottom:.5rem}.empty-state p{font-size:14px}.chat-message{display:flex;gap:1rem;margin-bottom:1.5rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-avatar{flex-shrink:0}.message-content{flex:1;min-width:0}.message-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.message-role{font-size:14px;font-weight:600;color:#2d3748}.message-time{font-size:12px;color:#a0aec0}.message-text{background:#fff;padding:1rem;border-radius:12px;box-shadow:0 1px 3px #0000001a;line-height:1.6;color:#2d3748}.chat-message.assistant .message-text{background:#f7fafc}.message-text p{margin:0 0 1rem}.message-text p:last-child{margin-bottom:0}.message-text code{background:#edf2f7;padding:.2rem .4rem;border-radius:4px;font-size:.9em;font-family:Courier New,monospace}.message-text pre{margin:1rem 0;border-radius:8px;overflow-x:auto}.message-text pre code{background:none;padding:0}.message-text ul,.message-text ol{margin:.5rem 0;padding-left:1.5rem}.message-text li{margin:.25rem 0}.typing-indicator{display:flex;gap:1rem;margin-bottom:1.5rem;animation:fadeIn .3s ease}.typing-avatar{flex-shrink:0}.typing-content{background:#f7fafc;padding:1rem;border-radius:12px;box-shadow:0 1px 3px #0000001a}.typing-dots{display:flex;gap:.5rem}.dot{width:8px;height:8px;background:#a0aec0;border-radius:50%;animation:bounce 1.4s infinite ease-in-out}.dot:nth-child(1){animation-delay:-.32s}.dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chat-input-form{margin-top:1rem}.chat-input-container{display:flex;gap:.75rem;background:#fff;border-radius:12px;padding:.75rem;box-shadow:0 2px 8px #0000001a;border:2px solid transparent;transition:border-color .3s ease}.chat-input-container:focus-within{border-color:#667eea}.chat-input-textarea{flex:1;border:none;outline:none;resize:none;font-size:14px;line-height:1.5;max-height:200px;overflow-y:auto;font-family:inherit}.chat-input-textarea::placeholder{color:#a0aec0}.chat-input-button{flex-shrink:0;width:40px;height:40px;border-radius:8px;border:none;background:#667eea;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.chat-input-button:hover:not(:disabled){background:#5568d3;transform:scale(1.05)}.chat-input-button:disabled{background:#cbd5e0;cursor:not-allowed;transform:none}.chat-input-hint{font-size:12px;color:#a0aec0;margin-top:.5rem;text-align:center}.sidebar-overlay{position:fixed;inset:0;background:#00000080;z-index:999;animation:fadeIn .3s ease}.chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:2rem}.empty-state-icon{font-size:64px;margin-bottom:1.5rem;opacity:.5}.chat-empty-state h2{font-size:24px;font-weight:600;color:#2d3748;margin:0 0 .75rem}.chat-empty-state p{font-size:16px;color:#718096;margin:0 0 2rem;max-width:400px}.empty-state-button{padding:12px 24px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease}.empty-state-button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.empty-state-button:disabled{background:#cbd5e0;color:#a0aec0;cursor:not-allowed;transform:none;box-shadow:none}.empty-state-button[aria-busy=true]{position:relative;color:transparent}.empty-state-button[aria-busy=true]:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid #ffffff;border-radius:50%;border-top-color:transparent;animation:spinner .6s linear infinite}.chat-loading-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;animation:fadeIn .3s ease}.chat-loading-placeholder .loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;animation:spinner .8s linear infinite;margin-bottom:1rem}.chat-loading-placeholder p{font-size:16px;color:#718096;margin:0}@keyframes spinner{to{transform:rotate(360deg)}}.chat-error{display:flex;align-items:center;gap:12px;background:#fed7d7;color:#c53030;padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid #c53030}.error-icon{font-size:20px;flex-shrink:0}.error-message{flex:1;font-size:14px}@media (max-width: 768px){.chat-container{padding:1rem .5rem}.chat-message{gap:.75rem}.message-avatar svg{width:28px;height:28px}.message-text{padding:.75rem;font-size:14px}.chat-empty-state{padding:1rem}.empty-state-icon{font-size:48px}.chat-empty-state h2{font-size:20px}.chat-empty-state p{font-size:14px}}.chat-voice-status{display:flex;justify-content:center;margin-bottom:12px;animation:fadeIn .3s ease}.chat-voice-error{display:flex;align-items:center;gap:8px;background:#fff5f5;color:#c53030;padding:8px 12px;border-radius:8px;margin-bottom:12px;border-left:3px solid #c53030;font-size:13px;animation:fadeIn .3s ease}.chat-voice-error .error-icon{font-size:16px;flex-shrink:0}.chat-voice-error .error-message{flex:1}.chat-input-actions{display:flex;align-items:center;gap:8px}.chat-input-container{align-items:flex-end}.chat-input-container .voice-input-button{width:40px;height:40px}@media (max-width: 768px){.chat-input-actions{gap:6px}.chat-input-container .voice-input-button,.chat-input-button{width:36px;height:36px}}.chat-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:#718096}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.6}.chat-empty-state h2{font-size:1.75rem;font-weight:600;color:#2d3748;margin-bottom:.75rem}.chat-empty-state p{font-size:1rem;margin-bottom:1.5rem;max-width:400px}.empty-state-button{background:#4299e1;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.empty-state-button:hover:not(:disabled){background:#3182ce;transform:translateY(-1px);box-shadow:0 4px 12px #4299e14d}.empty-state-button:disabled{background:#cbd5e0;cursor:not-allowed;opacity:.6}.chat-ready-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:#718096}.ready-state-icon{font-size:3rem;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.chat-ready-state h3{font-size:1.5rem;font-weight:600;color:#2d3748;margin-bottom:.5rem}.chat-ready-state p{font-size:1rem;color:#718096;max-width:400px}.chat-loading-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;color:#718096}.loading-spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#4299e1;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.chat-loading-placeholder p{font-size:1rem;color:#718096}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
