.references-popover-wrapper{display:inline-flex;position:relative;margin-top:.5rem}.references-trigger{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:#4a5568;color:#fff;border:none;border-radius:9999px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .2s}.references-trigger:hover{background:#5a6578}.references-trigger:focus{outline:2px solid #667eea;outline-offset:2px}.references-popover{position:fixed;z-index:1000;min-width:440px;max-width:560px;display:flex;flex-direction:column;background:#2d3748;border-radius:8px;box-shadow:0 4px 20px #0000004d;overflow:hidden;animation:referencesPopoverIn .15s ease-out}.references-popover-above{animation:referencesPopoverInAbove .15s ease-out}@keyframes referencesPopoverIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes referencesPopoverInAbove{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.references-popover-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.2rem 1rem;border-bottom:1px solid #4a5568;width:100%;flex-shrink:0}.references-popover-title{flex:1;margin:0;font-size:.85rem;font-weight:600;color:#fff}.references-popover-close{background:none;border:none;color:#ffffffe6;font-size:.9rem;cursor:pointer;padding:.125rem;line-height:1;flex-shrink:0;transition:color .2s}.references-popover-close:hover{color:#fff}.references-popover-list{padding:.5rem;flex:1;min-height:0;overflow-y:auto}.references-popover-item{display:flex;gap:.75rem;padding:.75rem;border-radius:6px;text-decoration:none;color:inherit;transition:background .15s}.references-popover-item:hover{background:#4a5568}.references-popover-item-icon{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#4a5568;border-radius:6px;color:#a0aec0}.references-popover-item-content{display:flex;flex-direction:column;gap:.2rem;min-width:0}.references-popover-item-source{font-weight:600;color:#fff;font-size:.9rem}.references-popover-item-domain{font-size:.75rem;color:#a0aec0}.references-popover-item-title{font-size:.8rem;color:#cbd5e0;line-height:1.4;display:-webkit-box;line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.intention-popover-wrapper{display:inline-flex;position:relative;margin-top:.5rem;margin-left:.5rem}.intention-trigger{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:#4a5568;color:#fff;border:none;border-radius:9999px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .2s}.intention-trigger:hover{background:#5a6578}.intention-trigger:focus{outline:2px solid #667eea;outline-offset:2px}.intention-popover{position:fixed;z-index:1000;min-width:320px;max-width:560px;display:flex;flex-direction:column;background:#2d3748;border-radius:8px;box-shadow:0 4px 20px #0000004d;overflow:hidden;animation:intentionPopoverIn .15s ease-out}.intention-popover-above{animation:intentionPopoverInAbove .15s ease-out}@keyframes intentionPopoverIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes intentionPopoverInAbove{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.intention-popover-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.2rem 1rem;border-bottom:1px solid #4a5568;width:100%;flex-shrink:0}.intention-popover-title{flex:1;margin:0;font-size:.85rem;font-weight:600;color:#fff}.intention-popover-close{background:none;border:none;color:#ffffffe6;font-size:.9rem;cursor:pointer;padding:.125rem;line-height:1;flex-shrink:0;transition:color .2s}.intention-popover-close:hover{color:#fff}.intention-popover .intention-popover-json{margin:0;padding:1rem;font-size:.8rem;font-family:ui-monospace,monospace;background:#1a202c!important;color:#e2e8f0!important;white-space:pre-wrap;word-break:break-word;overflow:auto;border:none;flex:1;min-height:0}.usage-popover-wrapper{display:inline-flex;position:relative;margin-top:.5rem;margin-left:.5rem}.usage-trigger{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:#4a5568;color:#fff;border:none;border-radius:9999px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .2s}.usage-trigger:hover{background:#5a6578}.usage-trigger:focus{outline:2px solid #667eea;outline-offset:2px}.usage-popover{position:fixed;z-index:1000;min-width:360px;max-width:560px;display:flex;flex-direction:column;background:#2d3748;border-radius:8px;box-shadow:0 4px 20px #0000004d;overflow:hidden;animation:usagePopoverIn .15s ease-out}.usage-popover-above{animation:usagePopoverInAbove .15s ease-out}@keyframes usagePopoverIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes usagePopoverInAbove{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.usage-popover-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.2rem 1rem;border-bottom:1px solid #4a5568;width:100%;flex-shrink:0}.usage-popover-title{flex:1;margin:0;font-size:.85rem;font-weight:600;color:#fff}.usage-popover-close{background:none;border:none;color:#ffffffe6;font-size:.9rem;cursor:pointer;padding:.125rem;line-height:1;flex-shrink:0;transition:color .2s}.usage-popover-close:hover{color:#fff}.usage-popover .usage-popover-json{margin:0;padding:1rem;font-size:.8rem;font-family:ui-monospace,monospace;background:#1a202c!important;color:#e2e8f0!important;white-space:pre-wrap;word-break:break-word;overflow:auto;border:none;flex:1;min-height:0}.session-info-popover-wrapper{display:inline-flex;position:relative}.session-info-trigger{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:#4a5568;color:#fff;border:none;border-radius:9999px;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .2s}.session-info-trigger:hover{background:#5a6578}.session-info-trigger:focus{outline:2px solid #667eea;outline-offset:2px}.session-info-popover{position:fixed;z-index:1000;min-width:320px;max-width:560px;display:flex;flex-direction:column;background:#2d3748;border-radius:8px;box-shadow:0 4px 20px #0000004d;overflow:hidden;animation:sessionInfoPopoverIn .15s ease-out}.session-info-popover-above{animation:sessionInfoPopoverInAbove .15s ease-out}@keyframes sessionInfoPopoverIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes sessionInfoPopoverInAbove{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.session-info-popover-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.2rem 1rem;border-bottom:1px solid #4a5568;width:100%;flex-shrink:0}.session-info-popover-title{flex:1;margin:0;font-size:.85rem;font-weight:600;color:#fff}.session-info-popover-close{background:none;border:none;color:#ffffffe6;font-size:.9rem;cursor:pointer;padding:.125rem;line-height:1;flex-shrink:0;transition:color .2s}.session-info-popover-close:hover{color:#fff}.session-info-popover .session-info-popover-json{margin:0;padding:1rem;font-size:.8rem;font-family:ui-monospace,monospace;background:#1a202c!important;color:#e2e8f0!important;white-space:pre-wrap;word-break:break-word;overflow:auto;border:none;flex:1;min-height:0}.chat{display:flex;flex-direction:column;width:100%;min-width:0;height:100%;min-height:400px;background:#fff}.chat-header{padding:1.5rem 2rem;border-bottom:1px solid #e9ecef;background:#f8f9fa;display:flex;justify-content:space-between;align-items:center}.chat-header-left{display:flex;align-items:center;gap:.75rem}.chat-header h2{font-size:1.2rem;color:#333;margin:0}.chat-header-title{font-size:1rem;font-weight:500;color:#333}.chat-meta{display:flex;gap:1rem;align-items:center;font-size:.85rem;color:#666}.chat-session-id{font-family:ui-monospace,Cascadia Code,Source Code Pro,monospace;font-size:.75rem;color:#666;word-break:break-all}.messages-container{flex:1;min-width:0;min-height:50vh;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;background:#fafafa}.empty-state{display:flex;flex:1;width:100%;align-items:center;justify-content:center;min-height:45vh;color:#999;font-style:italic}.message{display:flex;flex-direction:column;max-width:70%;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-user{align-self:flex-end}.message-assistant{align-self:flex-start}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:1rem}.message-role{font-weight:600;font-size:.9rem;color:#667eea}.message-time{font-size:.75rem;color:#999}.message-metadata-buttons{display:flex;flex-wrap:wrap;align-items:center;gap:0}.message-content{padding:1rem 1.5rem;border-radius:12px;line-height:1.6;word-wrap:break-word;white-space:pre-wrap}.message-assistant .message-content{white-space:normal}.message-assistant .message-content h1,.message-assistant .message-content h2,.message-assistant .message-content h3,.message-assistant .message-content h4,.message-assistant .message-content h5,.message-assistant .message-content h6{margin-top:1.5rem;margin-bottom:.75rem;font-weight:600;line-height:1.25;color:#333}.message-assistant .message-content h1{font-size:1.5rem;border-bottom:1px solid #e9ecef;padding-bottom:.5rem}.message-assistant .message-content h2{font-size:1.3rem;border-bottom:1px solid #e9ecef;padding-bottom:.4rem}.message-assistant .message-content h3{font-size:1.1rem}.message-assistant .message-content h4{font-size:1rem}.message-assistant .message-content h5{font-size:.9rem}.message-assistant .message-content h6{font-size:.85rem;color:#666}.message-assistant .message-content p{margin-top:.75rem;margin-bottom:.75rem}.message-assistant .message-content p:first-child{margin-top:0}.message-assistant .message-content p:last-child{margin-bottom:0}.message-assistant .message-content ul,.message-assistant .message-content ol{margin:.75rem 0;padding-left:1.5rem}.message-assistant .message-content li{margin:.25rem 0}.message-assistant .message-content ul{list-style-type:disc}.message-assistant .message-content ol{list-style-type:decimal}.message-assistant .message-content code{background:#f4f4f4;border:1px solid #e0e0e0;border-radius:4px;padding:.2rem .4rem;font-family:Courier New,Courier,monospace;font-size:.9em;color:#d63384}.message-assistant .message-content pre{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1rem;overflow-x:auto;max-width:100%;margin:1rem 0}.message-assistant .message-content pre code{background:transparent;border:none;padding:0;color:#333;font-size:.9em;white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.message-assistant .message-content blockquote{border-left:4px solid #667eea;padding-left:1rem;margin:1rem 0;color:#666;font-style:italic}.message-assistant .message-content a{color:#667eea;text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}.message-assistant .message-content a:hover{border-bottom-color:#667eea}.message-assistant .message-content table{border-collapse:collapse;margin:1rem 0;width:100%}.message-assistant .message-content table th,.message-assistant .message-content table td{border:1px solid #e9ecef;padding:.5rem .75rem;text-align:left}.message-assistant .message-content table th{background:#f8f9fa;font-weight:600}.message-assistant .message-content table tr:nth-child(2n){background:#f8f9fa}.message-assistant .message-content hr{border:none;border-top:1px solid #e9ecef;margin:1.5rem 0}.message-assistant .message-content strong{font-weight:600;color:#333}.message-assistant .message-content em{font-style:italic}.message-user .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.message-assistant .message-content{background:#fff;color:#333;border:1px solid #e9ecef;border-bottom-left-radius:4px;box-shadow:0 2px 4px #0000000d}.message.message-assistant.message-emergency .message-content{background:linear-gradient(135deg,#fff5f5,#ffebee)!important;border:2px solid #dc3545!important;box-shadow:0 2px 8px #dc354540!important}.message.message-assistant.message-emergency .message-header .message-role:after{content:" 🚨 Emergency";color:#dc3545;font-size:.8em;font-weight:600;margin-left:.25em}.emergency-banner{display:block;background:#dc3545;color:#fff;font-size:.85rem;font-weight:600;padding:.5rem 1rem;margin:-1rem -1.5rem 1rem;border-radius:12px 12px 0 0;text-align:center}.typing-indicator{display:inline-flex;align-items:center;gap:.28rem;padding:.15rem 0}.typing-indicator-dot{width:.4rem;height:.4rem;border-radius:50%;background:#667eea;animation:typing-dot 1.2s ease-in-out infinite}.typing-indicator-dot:nth-child(1){animation-delay:0ms}.typing-indicator-dot:nth-child(2){animation-delay:.2s}.typing-indicator-dot:nth-child(3){animation-delay:.4s}@keyframes typing-dot{0%,60%,to{opacity:.35;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}.chat-input-container{padding:1.5rem 2rem;border-top:1px solid #e9ecef;background:#fff;display:flex;flex-direction:column;gap:1rem;align-items:stretch}.common-questions-wrap{display:flex;flex-direction:column;gap:.5rem}.common-questions-toggle{align-self:flex-start;display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .35rem;margin:0;font:inherit;font-size:.8125rem;font-weight:500;color:#5a67d8;background:transparent;border:none;border-radius:6px;cursor:pointer;transition:color .15s ease,background .15s ease}.common-questions-toggle:hover{color:#4c51bf;background:#667eea14}.common-questions-toggle:focus-visible{outline:2px solid rgba(102,126,234,.45);outline-offset:2px}.common-questions-toggle-icon{display:flex;flex-shrink:0;align-items:center;justify-content:center;transition:transform .38s cubic-bezier(.4,0,.2,1)}.common-questions-toggle-icon svg{display:block}.common-questions-toggle[aria-expanded=false] .common-questions-toggle-icon{transform:rotate(-90deg)}.common-questions-toggle[aria-expanded=true] .common-questions-toggle-icon{transform:rotate(0)}.common-questions-toggle-label{line-height:1.3}.common-questions-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s cubic-bezier(.4,0,.2,1)}.common-questions-panel.is-open{grid-template-rows:1fr}.common-questions-panel-inner{overflow:hidden;min-height:0;opacity:0;transform:translateY(-6px);transition:opacity .32s ease,transform .4s cubic-bezier(.4,0,.2,1)}.common-questions-panel.is-open .common-questions-panel-inner{opacity:1;transform:translateY(0)}.common-questions-panel:not(.is-open) .common-questions-panel-inner{pointer-events:none}@media (prefers-reduced-motion: reduce){.common-questions-panel{transition:grid-template-rows .01ms}.common-questions-panel-inner{transition:opacity .01ms,transform .01ms}.common-questions-toggle-icon{transition:transform .01ms}}.common-questions-section{margin-bottom:.25rem}.common-questions-scroll{overflow-x:auto;overflow-y:hidden;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.common-questions-scroll::-webkit-scrollbar{height:12px}.common-questions-scroll::-webkit-scrollbar-track{background:#f1f1f1;border-radius:6px}.common-questions-scroll::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:6px}.common-questions-row{display:flex;gap:.5rem;flex-wrap:nowrap;width:max-content;min-width:100%;min-height:40px;align-items:center}.common-question-btn{flex-shrink:0;padding:.5rem 1rem;background:linear-gradient(135deg,#5a67d8,#6a4190);color:#fff;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;white-space:nowrap;transition:box-shadow .2s,transform .15s}.common-question-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.common-question-btn:disabled{opacity:.5;cursor:not-allowed}.chat-input-row{display:flex;gap:1rem;align-items:flex-end}.chat-input{flex:1;padding:.75rem 1rem;border:2px solid #e9ecef;border-radius:12px;font-size:1rem;font-family:inherit;resize:none;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#667eea}.chat-input:disabled{background:#f8f9fa;cursor:not-allowed}.send-button{padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;outline:none;white-space:nowrap}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.message{max-width:85%}.chat-header{padding:1rem;flex-direction:column;align-items:flex-start;gap:.5rem}.messages-container{padding:1rem;min-height:55vh}.empty-state{min-height:50vh}.chat-input-container{padding:1rem}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;padding:3rem;width:100%;max-width:450px;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;color:#333;margin-bottom:.5rem;font-weight:600}.login-header p{color:#666;font-size:.95rem}.login-error{background:#fee;border:1px solid #fcc;border-radius:8px;padding:1rem;margin-bottom:1.5rem;color:#c33;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#333;font-size:.9rem}.form-group input{padding:.75rem 1rem;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;font-family:inherit;transition:border-color .2s;outline:none}.form-group input:focus{border-color:#667eea}.form-group input:disabled{background:#f8f9fa;cursor:not-allowed}.login-button{padding:.875rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;outline:none;margin-top:.5rem}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer{margin-top:2rem;text-align:center}.login-hint{color:#999;font-size:.85rem;margin:0}@media (max-width: 480px){.login-card{padding:2rem 1.5rem}.login-header h1{font-size:1.5rem}}.app{display:flex;flex-direction:column;width:100%;min-width:0;height:100vh;max-width:1400px;margin:0 auto;background:#fff;box-shadow:0 0 20px #0000001a}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.header-title h1{font-size:1.5rem;font-weight:600;margin:0 0 .25rem}.header-title .user-display{font-size:.85rem;font-weight:400;opacity:.9;margin:0}.session-controls{display:flex;gap:1rem;align-items:center}.session-select{padding:.5rem 1rem;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;font-size:.9rem;cursor:pointer;outline:none}.session-select:hover{background:#fff3}.session-select option{background:#667eea;color:#fff}.btn{padding:.5rem 1.5rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;outline:none}.btn-primary{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.btn-primary:hover{background:#ffffff4d}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#e9ecef;color:#333;border:1px solid #dee2e6}.btn-secondary:hover{background:#dee2e6}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:1.5rem 2rem 2rem;border-radius:12px;box-shadow:0 4px 20px #0003;min-width:360px}.modal-content h3{margin:0 0 1rem;font-size:1.25rem;color:#333}.modal-content label{display:block;font-size:.9rem;font-weight:500;color:#555;margin-bottom:.5rem}.modal-topic-dropdown{position:relative;margin-bottom:1.25rem}.modal-topic-select{width:100%;padding:.6rem 1rem;border:1px solid #dee2e6;border-radius:8px;font-size:1rem;box-sizing:border-box;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:space-between;text-align:left;font-family:inherit}.modal-topic-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.modal-topic-chevron{font-size:.7rem;color:#6c757d}.modal-topic-options{position:absolute;top:100%;left:0;right:0;margin:4px 0 0;padding:4px 0;list-style:none;background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:240px;overflow-y:auto;z-index:10}.modal-topic-options li{padding:.5rem 1rem;cursor:pointer;transition:background .15s}.modal-topic-options li:hover,.modal-topic-options li.selected{background:#e7e9fc;color:#4338ca}.modal-topics-loading{margin:0 0 1rem;font-size:.85rem;color:#666}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;flex-wrap:wrap;margin-top:1.5rem}.modal-content .btn{padding:.65rem 1.5rem;font-weight:600;font-size:.95rem;box-shadow:0 2px 8px #0000001f;transition:all .2s ease}.modal-content .btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0000002e}.modal-content .btn-modal-cancel{background:transparent;color:#6c757d;border:2px solid #dee2e6;box-shadow:none}.modal-content .btn-modal-cancel:hover:not(:disabled){background:#f8f9fa;color:#495057;border-color:#adb5bd}.modal-content .btn-modal-continue{background:#5558a8;color:#fff;border:none;box-shadow:0 3px 10px #5558a866}.modal-content .btn-modal-continue:hover:not(:disabled){background:#5a5fb0;box-shadow:0 4px 14px #6b70c380}.modal-content .btn-modal-create{background:#5558a8;color:#fff;border:none;box-shadow:0 3px 10px #5558a866}.modal-content .btn-modal-create:hover:not(:disabled){background:#5a5fb0;box-shadow:0 4px 14px #6b70c380}.modal-content .btn-modal-create:disabled{opacity:.5;cursor:not-allowed}.app-content{display:flex;flex:1;min-width:0;overflow:hidden}.sidebar{flex-shrink:0;width:300px;background:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;overflow-y:auto}.sidebar-header{padding:1.5rem;border-bottom:1px solid #e9ecef;background:#fff}.sidebar-header h2{font-size:1.1rem;color:#333;margin:0}.sessions-list{flex:1;padding:1rem;overflow-y:auto}.session-item{padding:1rem;margin-bottom:.5rem;background:#fff;border-radius:8px;cursor:pointer;transition:all .2s;border:2px solid transparent}.session-item:hover{background:#f0f0f0;transform:translate(4px)}.session-item.active{border-color:#667eea;background:#f0f4ff}.session-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.session-item-id{font-size:.75rem;color:#666;font-family:monospace;word-break:break-all;flex:1}.session-item-id.session-item-title{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:.95rem}.session-delete-btn{background:transparent;border:none;color:#999;font-size:1.5rem;font-weight:700;cursor:pointer;padding:0 .5rem;line-height:1;transition:all .2s;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.session-delete-btn:hover{background:#fee;color:#c33}.session-delete-btn:disabled{opacity:.5;cursor:not-allowed}.session-item-date{font-size:.75rem;color:#999}.session-item-meta{font-size:.85rem;color:#666}.chat-container{flex:1 1 0%;min-width:0;min-height:400px;display:flex;flex-direction:column;overflow:hidden}.loading{padding:2rem;text-align:center;color:#666}.error{padding:1rem;margin:1rem;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33}@media (max-width: 768px){.app-content{flex-direction:column}.sidebar{width:100%;max-height:200px}.chat-container{min-height:55vh}.session-controls{flex-direction:column;gap:.5rem}}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%}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);min-height:100vh}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
