:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#333;background-color:beige;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh}#root{width:100vw;height:100vh}.app{display:flex;width:100%;height:100%}.sidebar{width:280px;background-color:#e8e8d0;border-right:1px solid #d0d0b0;padding:20px;transition:width .3s ease;display:flex;flex-direction:column}.sidebar.collapsed{width:60px}.sidebar-header{display:flex;align-items:center;justify-content:flex-end;margin-bottom:20px}.sidebar-toggle{background:none;border:none;color:#374151;cursor:pointer;font-size:20px;padding:8px;transition:color .2s}.sidebar-toggle:hover{color:#1f2937}.sidebar-content{flex:1;display:flex;flex-direction:column}.auth-section{margin-bottom:30px}.section-title{font-size:12px;font-weight:600;margin-bottom:12px;white-space:nowrap;color:#4b5563;text-transform:uppercase;letter-spacing:.5px}.auth-buttons{display:flex;flex-direction:column;gap:8px}.auth-button{padding:12px 16px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.login-button{background-color:#3b82f6;color:#fff}.login-button:hover{background-color:#2563eb}.register-button{background-color:#d0d0b0;color:#374151;border:1px solid #b0b090}.register-button:hover{background-color:#c0c0a0}.user-info{display:flex;flex-direction:column;gap:10px}.user-email{font-size:14px;color:#374151;word-break:break-all}.logout-button{padding:10px 14px;background-color:#d0d0b0;color:#dc2626;border:none;border-radius:6px;cursor:pointer;font-size:13px;transition:background-color .2s}.logout-button:hover{background-color:#c0c0a0}.auth-form{display:flex;flex-direction:column;gap:10px;margin-top:15px;padding:15px;background-color:#e0e0c0;border-radius:8px}.auth-input{padding:10px 14px;background-color:beige;border:1px solid #c0c0a0;border-radius:6px;color:#374151;font-size:14px;outline:none;transition:border-color .2s}.auth-input:focus{border-color:#3b82f6}.submit-button{padding:10px 14px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.submit-button:hover{background-color:#2563eb}.model-section{margin-top:auto}.model-list{display:flex;flex-direction:column;gap:8px}.model-item{display:flex;align-items:center;padding:10px 12px;background-color:#d0d0b0;border-radius:6px;border-left:3px solid #3b82f6;transition:all .2s;cursor:pointer;gap:10px}.model-item:hover{background-color:#c0c0a0}.model-item.selected{background-color:#c0d4e8}.model-item.selected .model-name{color:#1e40af;font-weight:600}.model-checkbox{width:18px;height:18px;border:2px solid #9ca3af;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.model-item:hover .model-checkbox{border-color:#6b7280}.model-item.selected .model-checkbox{border-color:transparent}.check-icon{color:#374151;font-size:12px;font-weight:700}.model-name{font-size:14px;color:#374151;transition:color .2s}.model-hint{display:flex;align-items:center;gap:6px;padding:10px 12px;margin-top:10px;font-size:12px;color:#374151;background-color:#6366f11a;border-radius:6px}.hint-icon{font-size:14px}.home-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.home-container{max-width:600px;width:100%;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;overflow:hidden;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.home-header{text-align:center;padding:50px 30px 30px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.home-logo{display:flex;align-items:center;justify-content:center;gap:15px;margin-bottom:15px}.home-logo-icon{font-size:50px}.home-title{font-size:42px;font-weight:700;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.home-subtitle{font-size:16px;opacity:.9;margin:10px 0 0}.home-features{display:flex;justify-content:center;gap:20px;padding:30px;background:#f8f9fa;flex-wrap:wrap}.feature-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:15px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000d;min-width:80px}.feature-icon{font-size:28px}.feature-name{font-size:13px;color:#666;font-weight:500}.home-actions{padding:30px;display:flex;flex-direction:column;gap:15px}.home-enter-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:16px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease}.home-enter-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.home-enter-icon{font-size:20px}.home-about-btn{padding:12px 24px;background:transparent;color:#667eea;border:2px solid #667eea;border-radius:12px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease}.home-about-btn:hover{background:#667eea;color:#fff}.home-footer{padding:30px;text-align:center;background:#f8f9fa;border-top:1px solid #eee}.footer-links{margin-bottom:15px}.footer-links a{color:#667eea;text-decoration:none;font-size:14px;transition:color .3s}.footer-links a:hover{color:#764ba2;text-decoration:underline}.footer-divider{margin:0 15px;color:#ccc}.filing-info{font-size:12px;color:#999}.filing-info p{margin:5px 0}.about-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);padding:20px}.about-container{max-width:800px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;overflow:hidden}.about-header{display:flex;justify-content:space-between;padding:20px 30px;background:linear-gradient(135deg,#667eea,#764ba2)}.about-back-btn,.about-home-btn{padding:10px 20px;background:#fff3;color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:all .3s}.about-back-btn:hover,.about-home-btn:hover{background:#ffffff4d}.about-content{padding:40px 30px}.about-section{margin-bottom:40px}.about-section:last-child{margin-bottom:0}.about-section .section-title{font-size:22px;color:#333;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #667eea}.about-intro p{font-size:15px;line-height:1.8;color:#555;margin-bottom:15px}.about-intro p:last-child{margin-bottom:0}.team-list{display:flex;gap:20px;flex-wrap:wrap}.team-member{display:flex;align-items:center;gap:15px;padding:20px;background:#f8f9fa;border-radius:12px;flex:1;min-width:200px}.member-avatar{font-size:40px}.member-info{display:flex;flex-direction:column}.member-name{font-size:16px;font-weight:600;color:#333}.member-role{font-size:13px;color:#888;margin-top:4px}.feedback-form{background:#f8f9fa;padding:25px;border-radius:12px}.feedback-types{display:flex;gap:10px;margin-bottom:20px}.feedback-type-btn{flex:1;padding:12px 16px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;cursor:pointer;transition:all .3s}.feedback-type-btn:hover{border-color:#667eea}.feedback-type-btn.active{background:#667eea;color:#fff;border-color:#667eea}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:10px}.feedback-textarea{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;transition:border-color .3s;box-sizing:border-box}.feedback-textarea:focus{outline:none;border-color:#667eea}.feedback-input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:border-color .3s;box-sizing:border-box}.feedback-input:focus{outline:none;border-color:#667eea}.feedback-submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.feedback-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.feedback-submit-btn:disabled{opacity:.6;cursor:not-allowed}.feedback-success{margin-top:15px;padding:12px;background:#d4edda;color:#155724;border-radius:8px;text-align:center;font-size:14px}.contact-list{display:flex;flex-direction:column;gap:15px}.contact-item{display:flex;align-items:center;gap:12px;padding:15px;background:#f8f9fa;border-radius:8px}.contact-icon{font-size:24px}.contact-info{font-size:14px;color:#555}.about-footer{padding:25px 30px;text-align:center;background:#f8f9fa;border-top:1px solid #eee}.about-footer p{margin:5px 0;font-size:12px;color:#999}.sidebar-home-section{padding:10px 15px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-home-link{display:block;width:100%;padding:10px;background:transparent;color:#ffffffb3;border:none;border-radius:6px;font-size:13px;text-align:left;cursor:pointer;transition:all .2s}.sidebar-home-link:hover{background:#ffffff1a;color:#fff}.sidebar-home-btn{display:block;width:100%;padding:12px;background:transparent;border:none;font-size:18px;cursor:pointer;transition:background .2s}.sidebar-home-btn:hover{background:#ffffff1a}.main-content{flex:1;display:flex;flex-direction:column;background-color:beige;padding:12px;overflow:hidden}.app-container{width:100%;max-width:none;margin:0;height:100%;display:flex;flex-direction:column}.app-header{padding:20px 0;border-bottom:1px solid #2a2a2a;margin-bottom:20px}.logo-section{text-align:center;margin-bottom:20px}.logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.logo-icon{font-size:32px}.app-title{font-size:32px;font-weight:700;color:#fff;background:linear-gradient(135deg,#3b82f6,#8b5cf6,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{font-size:14px;color:#4b5563}.input-form{display:flex;gap:12px;max-width:800px;margin:0 auto}.input-wrapper{flex:1}.chat-input{width:100%;padding:14px 20px;border:1px solid #c0c0a0;border-radius:12px;background-color:#fff;color:#374151;font-size:15px;resize:none;outline:none;transition:border-color .2s,box-shadow .2s;line-height:1.5}.chat-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.chat-input::placeholder{color:#9ca3af}.send-button{display:flex;align-items:center;gap:8px;padding:0 24px;border:none;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;cursor:pointer;font-size:15px;font-weight:500;transition:all .2s}.send-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.send-button:disabled{background-color:#4b5563;cursor:not-allowed}.send-icon{font-size:18px;font-weight:700}.loading-circle{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.cancel-button{background:linear-gradient(135deg,#ef4444,#dc2626)!important}.cancel-button:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)!important;transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.cancel-icon{font-size:18px;font-weight:700;color:#fff}.responses-container{flex:1;overflow-y:auto;padding-right:10px}.responses-container::-webkit-scrollbar{width:6px}.responses-container::-webkit-scrollbar-track{background:#e8e8d0}.responses-container::-webkit-scrollbar-thumb{background:#b0b090;border-radius:3px}.responses-container::-webkit-scrollbar-thumb:hover{background:#909070}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;text-align:center}.empty-icon{font-size:64px;margin-bottom:20px}.empty-state h3{font-size:20px;color:#1f2937;margin-bottom:8px}.empty-state p{font-size:14px;color:#4b5563;margin-bottom:24px}.feature-list{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.feature-list span{padding:8px 16px;background-color:#d0d0b0;border:1px solid #b0b090;border-radius:20px;font-size:13px;color:#374151}.responses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;width:100%}.response-card{background-color:#fff;border-radius:8px;overflow:hidden;border-left:3px solid var(--accent-color, #3b82f6);transition:transform .2s,box-shadow .2s;box-shadow:0 1px 3px #0000001a}.response-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.response-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background-color:#3b82f614;border-bottom:1px solid rgba(0,0,0,.05)}.model-badge{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:8px}.model-color{width:8px;height:8px;border-radius:50%}.model-label{font-size:14px;font-weight:600;color:#fff}.loading-status{display:flex;gap:6px}.loading-dot{width:6px;height:6px;background-color:#64748b;border-radius:50%;animation:loading-pulse 1.5s infinite ease-in-out}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}@keyframes loading-pulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}.conversation-card{max-height:600px;overflow-y:auto}.conversation-body{padding:12px}.conversation-turn{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #f3f4f6}.conversation-turn:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.user-message{margin-bottom:12px;padding:10px 14px;background-color:#eff6ff;border-radius:12px;border-left:3px solid #3b82f6}.assistant-message{padding:10px 14px;background-color:#f9fafb;border-radius:12px;border-left:3px solid var(--accent-color, #3b82f6)}.message-role{font-weight:600;color:#6b7280;font-size:13px;margin-right:8px}.message-content{font-size:14px;color:#374151;line-height:1.6}.answer-content h1,.answer-content h2,.answer-content h3,.answer-content h4,.answer-content h5,.answer-content h6{font-weight:600;margin-top:16px;margin-bottom:8px;color:#1f2937}.answer-content h1{font-size:24px}.answer-content h2{font-size:20px}.answer-content h3{font-size:18px}.answer-content h4{font-size:16px}.answer-content h5{font-size:14px}.answer-content h6{font-size:13px}.answer-content p{margin-bottom:12px;line-height:1.7}.answer-content ul,.answer-content ol{margin-bottom:12px;padding-left:24px}.answer-content li{margin-bottom:6px}.answer-content blockquote{border-left:4px solid #3b82f6;padding-left:12px;margin:12px 0;color:#6b7280;font-style:italic}.answer-content code{background-color:#f3f4f6;padding:2px 6px;border-radius:4px;font-family:Fira Code,Monaco,Consolas,monospace;font-size:13px;color:#dc2626}.answer-content pre{background-color:#1e293b;padding:16px;border-radius:8px;overflow-x:auto;margin:12px 0}.answer-content pre code{background-color:transparent;color:#e2e8f0;padding:0;font-size:13px}.answer-content table{width:100%;border-collapse:collapse;margin:12px 0}.answer-content th,.answer-content td{border:1px solid #e5e7eb;padding:8px 12px;text-align:left}.answer-content th{background-color:#f9fafb;font-weight:600}.answer-content a{color:#3b82f6;text-decoration:underline}.answer-content a:hover{color:#2563eb}.answer-content hr{border:none;border-top:1px solid #e5e7eb;margin:16px 0}.structure-analysis{padding:15px 20px;background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border-top:1px solid rgba(99,102,241,.2);border-bottom:1px solid rgba(99,102,241,.2)}.structure-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:#a5b4fc;margin-bottom:10px}.structure-icon{font-size:14px}.structure-tags{display:flex;flex-wrap:wrap;gap:8px}.response-body{padding:14px 16px;min-height:120px}.loading-content{display:flex;align-items:center;justify-content:center;height:100px}.typing-indicator{display:flex;align-items:center;gap:8px;color:#94a3b8;font-size:14px}.typing-dot{width:8px;height:8px;background-color:#3b82f6;border-radius:50%;animation:typing-pulse 1.4s infinite ease-in-out}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing-pulse{0%,80%,to{opacity:.4;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.error-content{color:#ef4444;font-size:14px}.answer-content{font-size:14px;line-height:1.7;color:#374151;white-space:pre-wrap;word-break:break-word}.highlight{background:linear-gradient(135deg,#fbbf244d,#f59e0b4d);color:#92400e;padding:3px 6px;border-radius:4px;font-weight:600;border:1px solid rgba(251,191,36,.4);box-shadow:0 2px 4px #fbbf2426;transition:all .2s ease}.highlight:hover{background:linear-gradient(135deg,#fbbf2480,#f59e0b80);box-shadow:0 2px 8px #fbbf244d}.structure-tag{display:inline-block;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;margin-right:6px;margin-bottom:4px}@media (max-width: 768px){.sidebar{position:absolute;left:0;top:0;height:100%;z-index:100;background-color:#1a1a1a}.sidebar.collapsed{transform:translate(-100%)}.main-content{width:100%}.input-form{flex-direction:column}.send-button{justify-content:center;padding:14px}.responses-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background-color:#fff;border-radius:20px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 25px 50px -12px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:#6b7280;font-size:24px;cursor:pointer;padding:4px;border-radius:8px;transition:all .2s;z-index:10}.modal-close:hover{color:#374151;background-color:#f3f4f6}.modal-header{text-align:center;padding:32px 24px 24px}.modal-icon{font-size:48px;margin-bottom:12px}.modal-title{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:8px}.modal-subtitle{font-size:14px;color:#6b7280}.modal-body{padding:0 24px 24px}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background-color:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:10px;margin-bottom:16px;color:#fca5a5;font-size:14px}.error-icon{font-size:16px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:8px}.form-input{width:100%;padding:14px 16px;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;color:#374151;font-size:14px;outline:none;transition:all .2s}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:#9ca3af}.input-wrapper{position:relative}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:16px}.toggle-password-btn{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:16px;cursor:pointer;padding:4px;border-radius:4px;transition:background-color .2s}.toggle-password-btn:hover{background-color:#0000000d}.form-input{padding-left:44px;padding-right:44px}.input-hint{display:block;font-size:12px;color:#64748b;margin-top:6px}.input-error{display:block;font-size:12px;color:#dc2626;margin-top:6px}.input-success{display:block;font-size:12px;color:#16a34a;margin-top:6px}.form-input.error{border-color:#dc2626}.form-options{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#94a3b8;cursor:pointer}.form-checkbox{width:16px;height:16px;border-radius:4px;background-color:#2a2a2a;border:1px solid #3a3a3a;cursor:pointer}.forgot-link{font-size:14px;color:#3b82f6;text-decoration:none;transition:color .2s}.forgot-link:hover{color:#60a5fa}.modal-footer{padding:16px 24px 24px;display:flex;gap:12px}.modal-button{flex:1;padding:14px 20px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.modal-button.primary{background-color:#3b82f6;color:#fff}.modal-button.primary:hover{background-color:#2563eb}.modal-button.secondary{background-color:#e8e8d0;color:#374151;border:1px solid #b0b090}.modal-button.secondary:hover{background-color:#d0d0b0;color:#1f2937}.user-info{display:flex;align-items:center;gap:12px;padding:12px;background-color:#d0d0b0;border-radius:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center}.avatar-icon{font-size:20px}.user-details{flex:1;display:flex;flex-direction:column;gap:2px}.user-name{font-size:14px;font-weight:600;color:#1f2937}.credits-section{margin-top:12px}.credits-button{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.credits-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.credits-icon{font-size:18px}.auth-button{display:flex;align-items:center;justify-content:center;gap:8px}.button-icon{font-size:16px}.history-section{margin-bottom:24px;flex:1;display:flex;flex-direction:column;overflow:hidden}.history-header{display:flex;flex-direction:column;align-items:stretch;margin-bottom:12px}.new-session-btn{width:100%;height:32px;background-color:#3b82f6;border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0 12px;margin-top:8px}.new-session-btn:hover{background-color:#2563eb}.session-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.session-list::-webkit-scrollbar{width:4px}.session-list::-webkit-scrollbar-track{background:transparent}.session-list::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:2px}.session-item{display:flex;flex-direction:column;padding:10px 12px;background-color:#d0d0b0;border-radius:8px;cursor:pointer;transition:all .2s;position:relative}.session-item:hover{background-color:#c0c0a0}.session-item.active{background-color:#c0d4e8;border-left:3px solid #3b82f6}.session-item.pinned{border-left:3px solid #f59e0b}.session-title{font-size:13px;color:#374151;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-time{font-size:11px;color:#6b7280}.delete-session-btn{position:absolute;top:8px;right:8px;width:20px;height:20px;background-color:#ef444433;border:none;border-radius:4px;color:#dc2626;font-size:14px;cursor:pointer;opacity:0;transition:all .2s;display:flex;align-items:center;justify-content:center}.edit-session-btn{position:absolute;top:8px;right:32px;width:20px;height:20px;background-color:#3b82f633;border:none;border-radius:4px;color:#3b82f6;font-size:12px;cursor:pointer;opacity:0;transition:all .2s;display:flex;align-items:center;justify-content:center}.pin-session-btn{position:absolute;top:8px;right:56px;width:20px;height:20px;background-color:#f59e0b33;border:none;border-radius:4px;color:#f59e0b;font-size:12px;cursor:pointer;opacity:0;transition:all .2s;display:flex;align-items:center;justify-content:center}.session-item:hover .delete-session-btn,.session-item:hover .edit-session-btn,.session-item:hover .pin-session-btn{opacity:1}.delete-session-btn:hover{background-color:#ef444466}.edit-session-btn:hover{background-color:#3b82f666}.pin-session-btn:hover{background-color:#f59e0b66}.empty-history{padding:20px;text-align:center;color:#64748b;font-size:13px}.history-messages{display:flex;flex-direction:column;gap:16px;max-width:800px;margin:0 auto}.message-item{display:flex;flex-direction:column;gap:8px}.message-item.user{align-items:flex-end}.message-item.assistant{align-items:flex-start}.message-role{font-size:12px;font-weight:600;padding:4px 10px;border-radius:10px}.message-item.user .message-role{background-color:#3b82f6;color:#fff}.message-item.assistant .message-role{background-color:#d0d0b0;color:#374151}.message-content{padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.6;max-width:80%}.message-item.user .message-content{background-color:#3b82f6;color:#fff;border-bottom-right-radius:4px}.message-item.assistant .message-content{background-color:#fff;color:#374151;border:1px solid #e5e7eb;border-bottom-left-radius:4px}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px;text-align:center}.error-icon{font-size:80px;margin-bottom:24px;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-boundary h2{font-size:24px;color:#fff;margin-bottom:12px}.error-boundary p{font-size:14px;color:#94a3b8;margin-bottom:24px}.retry-btn{padding:12px 32px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a1a2e)}.loading-spinner{width:50px;height:50px;border:3px solid #2a2a2a;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:14px;color:#94a3b8;font-weight:500}.send-button:disabled{opacity:.5;cursor:not-allowed}.send-button:disabled:hover{transform:none;box-shadow:none}.guest-login-section{padding:0 24px 24px}.guest-divider{display:flex;align-items:center;text-align:center;margin-bottom:16px}.guest-divider:before,.guest-divider:after{content:"";flex:1;border-bottom:1px solid #e5e7eb}.guest-divider:before{margin-right:12px}.guest-divider:after{margin-left:12px}.divider-text{font-size:12px;color:#9ca3af}.modal-button.guest{display:flex;align-items:center;justify-content:center;gap:8px;background-color:#fbbf24;color:#78350f;font-weight:600}.modal-button.guest:hover{background-color:#f59e0b}.guest-icon{font-size:16px}.guest-hint{font-size:12px;font-weight:400;opacity:.8}.user-status{font-size:12px;color:#059669}.user-status.guest{color:#d97706}.social-login-buttons{display:flex;flex-direction:column;gap:10px}.modal-button.wechat{background-color:#07c160;color:#fff;display:flex;align-items:center;justify-content:center;gap:10px}.modal-button.wechat:hover{background-color:#06ad56}.wechat-icon{font-size:20px}.wechat-modal{max-width:400px}.wechat-qrcode-container{display:flex;flex-direction:column;align-items:center;padding:20px 0}.qrcode-wrapper{position:relative;display:flex;flex-direction:column;align-items:center}.qrcode-image{width:200px;height:200px;border-radius:12px;border:2px solid #e5e7eb;box-shadow:0 4px 20px #0000001a}.qrcode-status{margin-top:16px;display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:20px;background-color:#f3f4f6;font-size:14px;color:#374151}.qrcode-status.waiting{background-color:#dbeafe;color:#1d4ed8}.qrcode-status.scanned{background-color:#dcfce7;color:#16a34a}.qrcode-status.confirmed{background-color:#dcfce7;color:#16a34a;animation:pulse 1s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.status-icon{font-size:18px}.wechat-tips{text-align:center;padding:16px;background-color:#f9fafb;border-radius:12px;margin-bottom:16px}.wechat-tips p{margin:4px 0;font-size:13px;color:#6b7280}.dev-tools{border-top:1px solid #e5e7eb;padding-top:16px}.dev-tools-title{font-size:12px;color:#9ca3af;margin-bottom:12px;text-align:center}.dev-buttons{display:flex;gap:10px}.dev-button{flex:1;padding:10px 16px;background-color:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;font-size:13px;color:#374151;cursor:pointer;transition:all .2s}.dev-button:hover{background-color:#e5e7eb;border-color:#9ca3af}.credits-modal{max-width:700px}.credits-balance{color:#3b82f6;font-weight:700;font-size:18px}.vip-badge{display:inline-block;margin-left:8px;padding:2px 8px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-radius:10px;font-size:12px;font-weight:600}.packages-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.package-card{position:relative;padding:16px;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s}.package-card:hover{border-color:#d1d5db;background:#f3f4f6}.package-card.selected{border-color:#3b82f6;background:#eff6ff}.discount-tag{position:absolute;top:-8px;right:8px;padding:2px 8px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-radius:8px;font-size:11px;font-weight:600}.package-name{font-size:14px;font-weight:600;color:#1f2937;margin-bottom:8px}.package-credits{font-size:20px;font-weight:700;color:#3b82f6;margin-bottom:4px}.vip-unlimited{color:#f59e0b}.package-price{display:flex;align-items:baseline;margin-bottom:4px}.price-symbol{font-size:14px;color:#ef4444}.price-value{font-size:24px;font-weight:700;color:#ef4444}.package-original-price{font-size:12px;color:#9ca3af;text-decoration:line-through}.package-description{font-size:12px;color:#6b7280;margin-top:8px}.payment-method-section{margin-bottom:20px}.section-title{font-size:14px;font-weight:600;color:#374151;margin-bottom:12px}.payment-methods{display:flex;gap:12px}.payment-method{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:#374151}.payment-method:hover{border-color:#d1d5db}.payment-method.selected{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8}.payment-icon{font-size:20px}.credits-actions{display:flex;gap:12px;margin-top:20px}.credits-actions .modal-button{flex:1}.qrcode-section{display:flex;flex-direction:column;align-items:center;gap:16px}.qrcode-info{text-align:center;padding:12px 20px;background:#f3f4f6;border-radius:10px}.qrcode-info p{margin:4px 0;font-size:14px;color:#374151}.qrcode-info p:first-child{font-family:monospace;font-size:12px;color:#6b7280}.dev-button.full-width{width:100%}.web-search-section{margin-top:20px;padding-top:20px;border-top:1px solid #d0d0b0}.web-search-toggle{display:flex;align-items:center;padding:12px;background-color:beige;border:2px solid #d0d0b0;border-radius:12px;cursor:pointer;transition:all .3s ease;margin-top:10px}.web-search-toggle:hover{border-color:#4a90e2;box-shadow:0 2px 8px #4a90e226}.web-search-toggle.enabled{background-color:#e8f4fd;border-color:#4a90e2}.web-search-icon{font-size:24px;margin-right:12px;transition:transform .3s ease}.web-search-toggle.enabled .web-search-icon{transform:scale(1.1)}.web-search-info{flex:1;display:flex;flex-direction:column}.web-search-status{font-size:14px;font-weight:600;color:#333}.web-search-toggle.enabled .web-search-status{color:#4a90e2}.web-search-desc{font-size:12px;color:#666;margin-top:2px}.web-search-toggle.enabled .web-search-desc{color:#6b9dc7}.web-search-switch{width:44px;height:24px;background-color:#ccc;border-radius:12px;position:relative;transition:background-color .3s ease}.web-search-switch.on{background-color:#4a90e2}.switch-thumb{width:20px;height:20px;background-color:#fff;border-radius:50%;position:absolute;top:2px;left:2px;transition:transform .3s ease;box-shadow:0 2px 4px #0003}.web-search-switch.on .switch-thumb{transform:translate(20px)}.web-search-hint{display:flex;align-items:center;gap:6px;margin-top:8px;padding:8px 12px;background-color:#4a90e21a;border-radius:8px;font-size:12px;color:#5a7a9a}.web-search-hint .hint-icon{font-size:14px}
