body{margin:0;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-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}#root{min-height:100vh}.header-fleet-selector{padding:.4rem 1.8rem .4rem .6rem;border:1px solid #dee2e6;border-radius:6px;background-color:#fff;color:#333;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease-in-out;flex:1 1 auto;max-width:300px;min-width:120px;align-self:center;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .4rem center;background-size:1rem;margin-left:auto}html,body{margin:0;padding:0;height:100%}#root{height:100%}.App{min-height:100vh;display:flex;flex-direction:column;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}body.chat-active .App{height:100vh;height:100dvh;min-height:auto}.App-header{background-color:#06c;color:#fff;padding:1rem;box-shadow:0 2px 4px #0000001a}.App-header h1{margin:0;font-size:1.8rem;font-weight:600}.App-header p{margin:.5rem 0 0;font-size:1rem;opacity:.9}.App-main{flex:1;padding:2rem;display:flex;justify-content:center;align-items:flex-start;max-width:800px;margin:0 auto;width:100%;box-sizing:border-box}.chat-interface{width:100%;max-width:700px;box-shadow:0 4px 6px #0000001a;border-radius:8px;overflow:hidden;background:#fff}@media (max-width: 768px){.App-main{padding:1rem}.App-header h1{font-size:1.5rem}.chat-interface{height:500px}}.loading{opacity:.6;pointer-events:none}.error{border-color:#dc3545;background-color:#f8d7da}.markdown-message{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.4;color:#202124;word-wrap:break-word;max-width:100%;overflow-wrap:break-word;min-width:0}.markdown-message strong{font-weight:600}.bot-message-container,.copilot-response{white-space:normal}.markdown-message .metric-list-item ul .metric-list-item,.markdown-message .metric-list-item ol .metric-list-item,.markdown-message li ul li,.markdown-message li ol li{margin:0!important;padding:0!important;line-height:1.4}.bot-message-container .markdown-message .metric-list,.bot-message-container .markdown-message ol,.bot-message-container .markdown-message ul{margin:4px 0;padding-left:20px}.bot-message-container .markdown-message .metric-list-item,.bot-message-container .markdown-message li{margin:0;padding:0;line-height:1.5}.bot-message-container{max-width:100%;padding:0}.copilot-response{margin-bottom:12px}.message-citations{margin-top:16px;border-top:1px solid #e8eaed;padding-top:12px}.message-citations summary{font-size:12px;color:#5f6368;cursor:pointer;font-weight:500;margin-bottom:8px;list-style:none;display:flex;align-items:center}.message-citations summary::-webkit-details-marker{display:none}.message-citations summary:before{content:"▶";font-size:10px;margin-right:6px;transition:transform .2s ease}.message-citations[open] summary:before{transform:rotate(90deg)}.citations-list{margin:0;padding:0;list-style:none}.citation-item{margin:6px 0;padding:8px;background:#f8f9fa;border-radius:4px;font-size:12px;border-left:3px solid #dadce0}.citation-content{color:#5f6368;font-size:inherit}.markdown-h1,.markdown-h2,.markdown-h3,.markdown-h4{margin:8px 0 2px;font-weight:600;color:#1a73e8;border-bottom:1px solid #e8eaed;padding-bottom:2px}.markdown-message h1,.markdown-message h2,.markdown-message h3,.markdown-message h4,.markdown-message h5,.markdown-message h6{margin:4px 0 2px!important;font-weight:600;color:#1a73e8;border-bottom:1px solid #e8eaed;padding-bottom:2px}.markdown-h1,.markdown-message h1{font-size:1.25em;color:#1a73e8;margin:6px 0 2px!important}.markdown-h2,.markdown-message h2{font-size:1.15em;color:#1a73e8;margin:4px 0 2px!important}.markdown-h3,.markdown-message h3{font-size:1.05em;color:#1a73e8;margin:4px 0 2px!important}.markdown-h4,.markdown-message h4{font-size:1em;color:#1a73e8;margin:4px 0 2px!important}.markdown-paragraph{margin:0 0 8px;line-height:1.5;white-space:normal}.markdown-paragraph:last-child{margin-bottom:0}.code-block{margin:8px 0;border-radius:6px;overflow:hidden;border:1px solid #dadce0;background:#f8f9fa;box-shadow:0 1px 2px #0000001a}.code-header{background:#e8eaed;padding:6px 12px;font-size:11px;font-weight:500;color:#5f6368;text-transform:uppercase;border-bottom:1px solid #dadce0;letter-spacing:.5px}.language-label{font-family:Roboto Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.code-block pre{margin:0;padding:12px;background:#fff;font-family:Roboto Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1;overflow-x:auto;color:#202124}.inline-code{background:#f1f3f4;padding:2px 4px;border-radius:3px;font-family:Roboto Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:85%;color:#202124;border:none}pre code.inline-code{display:block;background:#f8f9fa;border:1px solid #dadce0;border-radius:6px;padding:12px;font-size:13px;line-height:1.4;overflow-x:auto;white-space:pre;margin:8px 0;color:#202124;min-width:0;max-width:100%;box-sizing:border-box}pre code.inline-code:has-text("┤"),pre code.inline-code:has-text("┼"),pre code.inline-code:has-text("🔵"){font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Source Code Pro,monospace;letter-spacing:0}pre{background:#f8f9fa;border:1px solid #dadce0;border-radius:6px;padding:12px;margin:8px 0;overflow-x:auto;font-family:Roboto Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.4;color:#202124;min-width:0;max-width:100%;box-sizing:border-box}pre code{background:transparent!important;border:none!important;padding:0!important;margin:0!important;border-radius:0!important;font-size:inherit!important;color:inherit!important}.table-container{overflow-x:auto;margin:8px 0;border:1px solid #dadce0;border-radius:8px;box-shadow:0 1px 3px #0000001a}.fleet-table{width:100%;border-collapse:collapse;font-size:13px;background:#fff;color:#202124}.fleet-table th,.fleet-table td{padding:12px;text-align:left;border-bottom:1px solid #e8eaed;vertical-align:top;color:inherit}.fleet-table th{background:#f8f9fa;font-weight:600;color:#3c4043;border-bottom:2px solid #dadce0;position:sticky;top:0;z-index:1}.fleet-table tbody tr:hover{background:#f8f9fa;transition:background-color .2s ease}.fleet-table tbody tr:last-child td{border-bottom:none}.fleet-table td:last-child,.fleet-table td:nth-last-child(2),.fleet-table td:nth-last-child(3){font-family:Roboto Mono,monospace;font-weight:500;text-align:right}.safety-alert{margin:8px 0;padding:10px 12px;background:#fef7e0;border-left:4px solid #f9ab00;border-radius:0 6px 6px 0;color:#b8860b;box-shadow:0 1px 3px #f9ab0033}.safety-alert p:last-child{margin-bottom:0}.safety-alert strong{color:#e37400}.safety-alert.critical{background:#fce8e6;border-left-color:#ea4335;color:#d93025}.safety-alert.critical strong{color:#b52d20}.safety-alert.success{background:#e6f4ea;border-left-color:#34a853;color:#137333}.safety-alert.success strong{color:#0d652d}.metric-list,.task-list{margin:2px 0;padding-left:20px}.metric-list li{margin:0;position:relative}.metric-list li::marker{color:#1a73e8;font-weight:700}.task-list{list-style:none;padding-left:0}.task-list li{position:relative;padding-left:24px;margin:0}.task-list li:before{content:"□";position:absolute;left:0;color:#5f6368;font-weight:700}.task-list li.checked:before{content:"☑";color:#34a853}.markdown-link{color:#1a73e8;text-decoration:none;border-bottom:1px solid transparent;transition:all .2s ease}.markdown-link:hover{border-bottom-color:#1a73e8;background-color:#1a73e80d}.markdown-link:visited{color:#8e24aa}.markdown-link[target=_blank]{color:#1a73e8}.markdown-link[target=_blank]:after{font-size:.8em;opacity:.7;margin-left:2px}@media (max-width: 768px){.markdown-message{font-size:14px}.markdown-h1{font-size:1.2em}.markdown-h2{font-size:1.1em}.markdown-h3{font-size:1.05em}.markdown-h4{font-size:1em}.fleet-table{font-size:12px}.fleet-table th,.fleet-table td{padding:8px 6px}.code-block pre{padding:8px;font-size:12px}.code-header{padding:4px 8px;font-size:10px}.table-container{margin:8px 0}.safety-alert{padding:8px 12px;margin:8px 0}}@media (max-width: 480px){.fleet-table th,.fleet-table td{padding:6px 4px;font-size:11px}.code-block pre{font-size:11px}.inline-code{font-size:11px;word-break:break-all;overflow-wrap:break-word;white-space:pre-wrap}pre code.inline-code{font-size:11px;padding:8px;white-space:pre-wrap;word-break:break-all;overflow-wrap:break-word;overflow-x:visible;max-width:100%}}@media (max-width: 425px){.markdown-message{font-size:13px;min-width:0;overflow:hidden}.inline-code{font-size:10px;line-height:1.3;letter-spacing:-.02em;min-width:0;max-width:100%}pre code.inline-code{font-size:10px;padding:6px;line-height:1.3;letter-spacing:-.02em;white-space:pre-wrap;word-break:break-all;overflow-wrap:anywhere;min-width:0;max-width:100%}pre{padding:8px 6px;margin:6px 0;min-width:0;max-width:100%;box-sizing:border-box}.code-block{margin:6px 0;min-width:0;max-width:100%}.code-block pre{padding:6px;font-size:10px;min-width:0;max-width:100%}}.custom-message--incoming .markdown-message{color:#202124}.custom-message--incoming .markdown-h1,.custom-message--incoming .markdown-h2,.custom-message--incoming .markdown-h3,.custom-message--incoming .markdown-h4{color:#1a73e8}.custom-message--outgoing .markdown-message{color:#fff}.custom-message--outgoing .markdown-h1,.custom-message--outgoing .markdown-h2,.custom-message--outgoing .markdown-h3,.custom-message--outgoing .markdown-h4{color:#ffffffe6;border-bottom-color:#ffffff4d}.custom-message--outgoing .inline-code{background:#fff3;color:#ffffffe6;border-color:#ffffff4d}.custom-message--outgoing .markdown-link{color:#ffffffe6}.custom-message--outgoing .markdown-link:hover{border-bottom-color:#ffffffb3;background-color:#ffffff1a}.metric-value{font-family:Roboto Mono,monospace;font-weight:600;color:#1a73e8}.metric-trend-up{color:#34a853}.metric-trend-down{color:#ea4335}.metric-trend-neutral{color:#f9ab00}.status-good{color:#34a853;font-weight:500}.status-warning{color:#f9ab00;font-weight:500}.status-critical{color:#ea4335;font-weight:500}.driver-score-excellent{background:#e6f4ea;color:#137333;padding:2px 6px;border-radius:12px;font-weight:500;font-size:.85em}.driver-score-good{background:#fef7e0;color:#b8860b;padding:2px 6px;border-radius:12px;font-weight:500;font-size:.85em}.driver-score-poor{background:#fce8e6;color:#d93025;padding:2px 6px;border-radius:12px;font-weight:500;font-size:.85em}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#1866a7;padding:1rem;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}.login-container{background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;padding:2.5rem;width:100%;max-width:520px;animation:slideUp .6s ease-out;position:relative;overflow:hidden}.login-header{text-align:center;margin-bottom:2.5rem}.logo-container{display:flex;flex-direction:column;align-items:center}.logo-container h1{color:#2c3e50;font-size:2.2rem;font-weight:700;margin-bottom:.5rem;letter-spacing:-.5px}.logo-image-large{transform:scale(1.5);margin-bottom:.5rem;display:block}.logo-subtitle{color:#667eea;font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem}.welcome-text{color:#6c757d;font-size:1.1rem;margin:0;line-height:1.5}.error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1rem;margin-bottom:0;display:flex;align-items:flex-start;gap:.75rem;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.animate-shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-icon{font-size:1.8rem;flex-shrink:0;color:#dc3545;display:flex;align-items:center;justify-content:center}.error-content strong{color:#dc3545;display:block;margin-bottom:.25rem;font-weight:600}.error-content p{color:#721c24;margin:0;font-size:.9rem}.preset-section{margin-bottom:.75rem;margin-top:-.75rem}.preset-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:#495057;margin-bottom:1rem;font-weight:600}.preset-badge{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;padding:.2rem .5rem;border-radius:4px;font-size:.7rem;font-weight:700;letter-spacing:.5px}.preset-customers{display:grid;gap:.75rem;margin-bottom:1.5rem}.preset-button{display:flex;align-items:center;padding:1rem;border:2px solid #e9ecef;border-radius:8px;background:#fff;outline:none;cursor:pointer;transition:all .3s ease;text-align:left;width:100%;position:relative;overflow:hidden}.preset-button:hover:not(:disabled){border-color:#667eea;background-color:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea26}.preset-button:disabled{opacity:.7;cursor:not-allowed}.preset-button.loading{border-color:#667eea;background-color:#f0f4ff}.preset-content{flex:1}.preset-header{display:flex;justify-content:between;align-items:center;margin-bottom:.5rem}.preset-header strong{color:#2c3e50;font-weight:600}.preset-spinner{font-size:1.2rem;animation:spin 1s linear infinite;color:#667eea}.preset-details{display:flex;flex-direction:column;gap:.25rem}.customer-id{color:#6c757d;font-size:.85rem;font-weight:500}.preset-description{color:#adb5bd;font-size:.8rem;font-style:italic}.disclosure-wrapper{display:flex;flex-direction:column;border:2px solid #e9ecef;border-radius:8px;overflow:hidden}.disclosure-toggle{width:100%;display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#f8f9fa;border:none;border-radius:0;cursor:pointer;font-size:.95rem;font-weight:500;color:#495057;transition:all .3s ease;margin-bottom:0;text-align:left;outline:none;-webkit-tap-highlight-color:transparent}.disclosure-toggle[aria-expanded=true]{border-bottom:1px solid #e9ecef}.disclosure-toggle:hover:not(:disabled){background:#f0f1f3;color:#1866a7}.disclosure-toggle[aria-expanded=false]:hover:not(:disabled){background:#f8f9fa;color:#495057}.disclosure-toggle:focus{outline:none;box-shadow:none}.disclosure-toggle:focus-visible{outline:none;box-shadow:none}.disclosure-toggle:disabled{opacity:.7;cursor:not-allowed}.toggle-icon{display:flex;align-items:center;font-size:.9rem;color:#6c757d;transition:transform .3s ease}.disclosure-toggle[aria-expanded=true] .toggle-icon{color:#1866a7}.toggle-label{font-weight:600;flex:1;color:inherit}.disclosure-content{animation:slideDown .1s ease-out;border:none;border-radius:0;background:#fafbfc;padding:1.25rem;margin:0}.disclosure-toggle+.disclosure-content{margin-top:0}@keyframes slideDown{0%{opacity:0;max-height:0;overflow:hidden}to{opacity:1;max-height:1000px;overflow:visible}}.disclosure-content .form-section{margin-bottom:1.25rem}.disclosure-content .form-section:last-child{margin-bottom:0}.disclosure-content .form-section.compact{margin-bottom:.75rem}.disclosure-content .form-section.compact:last-child{margin-bottom:0}.disclosure-content .preset-section{margin-top:1.25rem;margin-bottom:0;padding-top:1.25rem;border-top:1px solid #dee2e6}.disclosure-content .preset-section.compact{margin-top:.75rem;padding-top:.75rem}.preset-button.compact{padding:.75rem 1rem;border:none;background:#f5ead2;font-size:.95rem;justify-content:center;text-align:center;gap:0}.preset-icon{font-size:1.5rem;color:#adb5bd;flex-shrink:0}.preset-button.compact .preset-content{display:flex;align-items:center;justify-content:center;gap:.75rem}.preset-button.compact:hover:not(:disabled){border-color:#c69563;background-color:#ede0c3;box-shadow:0 2px 8px #d4a57433}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-section{display:flex;flex-direction:column;gap:.75rem}.form-label{font-weight:600;color:#2c3e50;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px;display:flex;justify-content:space-between;align-items:center}.error-text{color:#dc3545;font-weight:500;font-size:.8rem;text-transform:none;letter-spacing:normal}.optional-badge{background:#e9ecef;color:#6c757d;padding:.2rem .4rem;border-radius:4px;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.input-container{position:relative;display:flex;align-items:center}.form-input{width:100%;padding:.875rem 3rem .875rem 1rem;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#fff}.form-input:focus{outline:none;border-color:#1866a7;box-shadow:0 0 0 3px #1866a71a}.form-input.error{border-color:#dc3545;box-shadow:0 0 0 3px #dc35451a}.form-input:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.form-input::placeholder{color:#adb5bd}.input-icon{position:absolute;right:1rem;font-size:1.5rem;color:#adb5bd;pointer-events:none}.password-container .input-icon{display:none}.clear-button{position:absolute;right:3.5rem;background:none;border:none;outline:none;cursor:pointer;font-size:1rem;color:#adb5bd;transition:color .2s ease;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center}.clear-button:hover:not(:disabled){color:#dc3545}.clear-button:disabled{cursor:not-allowed;opacity:.5}.password-container{position:relative}.password-toggle{position:absolute;right:.5rem;background:none;border:none;outline:none;cursor:pointer;font-size:1.5625rem;color:#6c757d;transition:color .2s ease;padding:.5rem;border-radius:4px;display:flex;align-items:center;justify-content:center;width:2.5rem}.password-toggle:hover:not(:disabled){color:#667eea;background-color:#667eea1a}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.form-help{color:#6c757d;font-size:.8rem;font-style:italic;margin-top:.25rem}.login-button{background:#1866a7;color:#fff;border:none;outline:none;padding:1rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;margin-top:0}.login-button:hover:not(:disabled){background:#145a91;transform:translateY(-2px);box-shadow:0 8px 25px #1866a74d}.login-button:disabled{background:#adb5bd;cursor:not-allowed;transform:none;box-shadow:none}.login-button.loading{background:#1866a7}.button-content{display:flex;align-items:center;justify-content:center;gap:.5rem}.spinner{animation:spin 1s linear infinite;font-size:1.2rem}.login-icon{font-size:1.1rem}.login-footer{margin-top:2rem;text-align:center}.provider-status{margin-bottom:1rem;padding:.75rem;background:#f8f9fa;border-radius:6px;border-left:3px solid #667eea}.provider-info{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem}.provider-label{font-size:.8rem;color:#6c757d;font-weight:500}.provider-name{font-size:.8rem;font-weight:600;padding:.25rem .5rem;border-radius:4px}.provider-name.development{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.provider-name.production{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.development-notice{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.75rem;color:#856404;background:#fff3cd;padding:.4rem .8rem;border-radius:4px;border:1px solid #ffeaa7}.dev-icon{font-size:.9rem}.security-badge{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:#f8f9fa;border-radius:8px;margin-bottom:1rem}.security-icon{font-size:1.5rem;color:#28a745}.security-text strong{color:#2c3e50;display:block;margin-bottom:.25rem;font-size:.9rem}.security-text p{color:#6c757d;margin:0;font-size:.8rem}.version-info{padding-top:1rem;border-top:1px solid #e9ecef}.version-info p{color:#adb5bd;margin:0;font-size:.75rem;letter-spacing:.5px}@media (max-width: 768px){.login-screen{padding:.5rem}.login-container{padding:1.5rem;margin:.5rem}.logo-container h1{font-size:1.8rem}.preset-customers{gap:.5rem}.preset-button{padding:.75rem}.security-badge{flex-direction:column;text-align:center;gap:.5rem}}@media (max-width: 480px){.login-container{padding:1rem}.logo-container h1{font-size:1.5rem}.preset-title{font-size:.9rem}.form-input{padding:.75rem;font-size:.9rem}.login-button{padding:.875rem 1rem;font-size:.9rem}}.login-container *{animation:fadeIn .3s ease-out}@media (prefers-contrast: high){.login-container{border:2px solid #000}.form-input,.preset-button{border-width:2px}}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem;animation:backgroundShift 15s ease-in-out infinite}@keyframes backgroundShift{0%,to{background:linear-gradient(135deg,#667eea,#764ba2)}50%{background:linear-gradient(135deg,#764ba2,#667eea)}}.loading-container{background:#fff;border-radius:16px;box-shadow:0 20px 40px #00000026;padding:3rem 2rem;text-align:center;max-width:400px;width:100%;animation:fadeInUp .8s ease-out;position:relative;overflow:hidden}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.loading-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2)}.loading-animation{position:relative;margin-bottom:2rem}.loading-spinner{position:relative;width:80px;height:80px;margin:0 auto 1rem}.spinner-ring{position:absolute;top:0;left:0;width:100%;height:100%;border:3px solid transparent;border-radius:50%;animation:spin 2s linear infinite}.spinner-ring:nth-child(1){border-top-color:#667eea;animation-delay:0s}.spinner-ring:nth-child(2){border-top-color:#764ba2;animation-delay:-.4s;width:90%;height:90%;top:5%;left:5%}.spinner-ring:nth-child(3){border-top-color:#28a745;animation-delay:-.8s;width:80%;height:80%;top:10%;left:10%}.loading-logo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.logo-icon{font-size:2rem;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.loading-content{margin-bottom:2rem}.loading-title{color:#2c3e50;font-size:1.8rem;font-weight:700;margin-bottom:.5rem;letter-spacing:-.5px;animation:fadeIn 1s ease-out .3s both}.loading-subtitle{color:#667eea;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:1.5rem;animation:fadeIn 1s ease-out .6s both}.loading-message{margin:1.5rem 0;min-height:3rem;display:flex;flex-direction:column;justify-content:center}.primary-message{color:#495057;font-size:1rem;font-weight:500;margin-bottom:.5rem;animation:fadeIn .5s ease-out;height:1.5rem;display:flex;align-items:center;justify-content:center}.sub-message{color:#6c757d;font-size:.85rem;margin:0;font-style:italic;animation:fadeIn .5s ease-out .2s both}.loading-progress{margin:1.5rem 0}.progress-bar{width:100%;height:4px;background-color:#e9ecef;border-radius:2px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:2px;animation:progressFill 3s ease-in-out infinite}@keyframes progressFill{0%{width:0%;opacity:1}50%{width:70%;opacity:1}to{width:100%;opacity:.3}}.loading-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef;animation:fadeIn 1s ease-out 1s both}.loading-footer p{color:#adb5bd;font-size:.75rem;margin:0;letter-spacing:.5px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.loading-container{padding:2rem 1.5rem;margin:1rem}.loading-spinner{width:60px;height:60px}.loading-title,.logo-icon{font-size:1.5rem}}@media (max-width: 480px){.loading-container{padding:1.5rem 1rem}.loading-title{font-size:1.3rem}.primary-message{font-size:.9rem}}@media (prefers-reduced-motion: reduce){.loading-spinner,.spinner-ring,.logo-icon,.progress-fill{animation:none}.loading-container{animation:fadeIn .3s ease-out}}@media (prefers-contrast: high){.loading-container{border:2px solid #000}.loading-title,.primary-message{color:#000}.loading-subtitle{color:#0056b3}}.server-error-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica,Arial,sans-serif}.error-container{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:40px;max-width:500px;width:100%;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.error-header{text-align:center;margin-bottom:32px}.error-icon-large{font-size:64px;margin-bottom:16px;animation:pulse 2s infinite;display:flex;justify-content:center;align-items:center;color:#667eea}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(.95)}}.error-title{margin:16px 0 8px;font-size:24px;font-weight:600;color:#1a202c;line-height:1.4}.error-subtitle{margin:0;font-size:14px;color:#718096}.error-message{background:#f7fafc;border-left:4px solid #ed8936;padding:16px;border-radius:4px;margin-bottom:24px}.error-message p{margin:0;font-size:14px;color:#2d3748;line-height:1.6}.error-suggestions{background:#edf2f7;padding:20px;border-radius:8px;margin-bottom:24px}.error-suggestions h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#1a202c}.error-suggestions ul{margin:0;padding-left:20px;list-style:disc}.error-suggestions li{font-size:13px;color:#2d3748;line-height:1.6;margin-bottom:6px}.error-suggestions li:last-child{margin-bottom:0}.error-actions{display:flex;flex-direction:column;gap:12px}.action-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;outline:none}.retry-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.retry-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px #667eea66}.retry-button:active:not(:disabled){transform:translateY(0)}.retry-button:disabled{opacity:.7;cursor:not-allowed}.retry-button.loading{opacity:.8}.logout-button{background:#e2e8f0;color:#2d3748;border:1px solid #cbd5e0}.logout-button:hover:not(:disabled){background:#cbd5e0;transform:translateY(-2px)}.logout-button:active:not(:disabled){transform:translateY(0)}.logout-button:disabled{opacity:.5;cursor:not-allowed}.button-content{display:flex;align-items:center;justify-content:center;gap:8px}.button-icon{font-size:16px}.spinner{display:inline-block;animation:spin 1s linear infinite}.error-footer{text-align:center;padding-top:20px;border-top:1px solid #e2e8f0;color:#a0aec0;font-size:12px}@media (max-width: 480px){.error-container{padding:30px 20px}.error-icon-large{font-size:48px}.error-title{font-size:20px}.error-actions{flex-direction:column}.action-button{width:100%}}.chat-layout{height:100vh;height:100dvh;flex:1;display:flex;flex-direction:column;background-color:var(--cs-main-container-bg-color, #fff);overflow:hidden;position:relative}.chat-body{flex:1;display:flex;flex-direction:row;overflow:hidden;min-height:0}body.chat-active{overflow:hidden!important;height:100vh;height:100dvh;touch-action:none}html.chat-active{overflow:hidden!important;height:100vh;height:100dvh}.chat-main{flex:1;overflow:hidden;display:flex;flex-direction:column;min-height:0;height:100%;max-width:58rem;margin:0 auto;width:calc(100% - 4rem);padding:0 2rem;background-color:#fff}.chat-header{min-height:40px;height:auto;background-color:#fff;color:#333;display:flex;align-items:flex-start;padding:.5rem .75rem;border-bottom:1px solid #dee2e6;flex-shrink:0;gap:.75rem}.header-left{display:flex;align-items:center;gap:.75rem;flex:1 1 auto;min-width:0;flex-wrap:wrap;align-self:stretch}.header-right{display:flex;align-items:flex-start;gap:.5rem;flex:0 0 auto;align-self:stretch}.header-left h1{margin:0;font-size:1.25rem;font-weight:600}.header-button-group{display:flex;align-items:center;gap:0;flex-shrink:0;background-color:#f8f9fa;border-radius:8px;border:1px solid #dee2e6;overflow:hidden;height:100%}.header-icon-btn{background:none;border:none;color:#333;padding:.4rem;width:32px;height:100%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:all .2s ease;flex-shrink:0;position:relative}.header-icon-btn:not(:last-child){border-right:1px solid #dee2e6}.header-icon-btn:hover{background-color:#e9ecef;color:#007bff}.header-icon-btn:active{background-color:#dee2e6;transform:scale(.95)}.header-icon-btn img{width:16px;height:16px;filter:invert(.3);transition:filter .2s ease}.header-icon-btn:hover img{filter:invert(.1)}.logo-container{margin:0;padding:0;transition:opacity .2s;align-self:center}.logo-container:hover{opacity:.8}.chat-header .logo-container img,.chat-header .logo-image-large{display:block;margin:0;height:32px;width:auto;transform:none!important}.header-fleet-selector{padding:.4rem 1.8rem .4rem .6rem;border:1px solid #dee2e6;border-radius:6px;background-color:#fff;color:#333;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s ease-in-out;flex:1 1 auto;max-width:300px;min-width:120px;align-self:center;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .4rem center;background-size:1rem;margin-left:auto}.header-fleet-selector:focus{border-color:#86b7fe;outline:0;box-shadow:0 0 0 .2rem #0d6efd26}.header-fleet-selector:hover{border-color:#b0b8c1;background-color:#f8f9fa}.user-menu{position:relative;z-index:1000;height:100%}.header-button-group .user-menu-button{border-radius:0;border:none;background:none;padding:.5rem;width:40px;height:40px}.header-button-group .user-menu-button:hover{background-color:#e9ecef}.user-menu-dropdown{position:absolute;top:100%;right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;min-width:240px;max-width:90vw;margin-top:.5rem;z-index:1001;border:1px solid #e9ecef;overflow:visible;display:flex;flex-direction:column}.user-menu-dropdown>*{overflow:visible}.menu-section{padding:.75rem 0;border-bottom:1px solid #f0f0f0}.menu-header{padding:.75rem 1rem;font-size:.95rem;color:#333;font-weight:600;border-bottom:1px solid #f0f0f0}.menu-info{padding:.5rem 1rem;font-size:.85rem;display:flex;flex-direction:column;gap:.25rem;background:none;cursor:default;border:none!important}.menu-info:hover{background:none!important}.info-label{color:#999;font-weight:600;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.2rem}.info-value{color:#333;font-weight:500;font-size:.9rem;word-break:break-word;line-height:1.4}.menu-item{padding:.75rem 1rem;cursor:pointer;background:none;border:none;width:100%;text-align:left;transition:background-color .2s ease;color:#333;border-bottom:1px solid #f8f9fa;font-size:.9rem}.menu-item strong{display:inline-flex;align-items:center;gap:.5rem}.menu-item:last-child{border-bottom:none}.menu-item:hover{background-color:#f8f9fa}.admin-menu-item{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:#6c9bd1;font-weight:500;padding:.75rem 1rem!important}.admin-menu-item:hover{background-color:#e8f0f8!important;color:#5785bc}.admin-menu-item .admin-icon{font-size:1rem;flex-shrink:0}.menu-divider{height:1px;background-color:#e9ecef;margin:.5rem 0}.logout-item{color:#fff!important;background-color:#6c9bd1!important;font-weight:600;padding:.75rem 1rem!important;display:flex;align-items:center;justify-content:center;gap:.75rem;border-radius:6px;margin:.75rem!important;transition:all .2s ease;cursor:pointer;border:none!important;outline:none;width:calc(100% - 1.5rem);box-sizing:border-box}.logout-item:hover{background-color:#5a8bc4!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 8px #6c9bd14d}.logout-item:focus{outline:none;box-shadow:0 0 0 3px #6c9bd166}.welcome-message{display:flex;align-items:center;justify-content:center;height:100%;padding:2rem}.welcome-content{text-align:center;max-width:600px;animation:welcomeContentFadeIn .5s ease-out}@keyframes welcomeContentFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.welcome-text{font-size:1.25rem;color:#333;margin-bottom:1.5rem;font-weight:500;line-height:1.6}.welcome-content h3{color:#007bff;margin-bottom:1rem;font-size:1.5rem}.welcome-content p{color:#666;margin-bottom:2rem;font-size:1.1rem}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-top:1.5rem}.quick-action-button{background:#fff;border:2px solid #e9ecef;border-radius:8px;padding:1rem;cursor:pointer;transition:all .2s ease;font-size:.95rem;font-weight:500;color:#333}.quick-action-button:hover{border-color:#007bff;background-color:#f8f9ff;transform:translateY(-2px);box-shadow:0 4px 8px #007bff1a}.error-banner{background-color:#f8d7da;color:#721c24;padding:.75rem 1rem;display:flex;align-items:center;gap:.5rem;border-top:1px solid #f5c6cb}.error-icon{font-weight:700}.error-text{flex:1;font-size:.875rem}.error-dismiss{background:none;border:none;color:#721c24;cursor:pointer;font-size:1.25rem;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.error-dismiss:hover{background-color:#721c241a;border-radius:4px}@media (max-width: 500px){.chat-main{padding:0;width:100%}.chat-header{padding:.4rem .6rem;min-height:56px}.header-left h1{font-size:1rem}.header-left{gap:.5rem}.header-fleet-selector{font-size:.8rem;padding:.35rem .5rem;max-width:250px;min-width:100px}.header-button-group{gap:0;height:100%}.header-icon-btn{width:28px;height:100%;padding:.3rem;font-size:.9rem}.header-icon-btn img{width:14px;height:14px}.chat-header .logo-container img,.chat-header .logo-image-large{height:28px}.message-feedback-buttons{gap:6px;margin-top:10px;padding-top:6px}.feedback-btn-inline{min-width:32px;height:28px;font-size:14px;padding:4px 8px}}@media (max-width: 480px){.chat-header{padding:.35rem .5rem;gap:.5rem}.header-left{gap:.5rem}.header-button-group{height:100%}.header-icon-btn{width:26px;height:100%;padding:.25rem;font-size:.85rem}.header-icon-btn img{width:13px;height:13px}.header-fleet-selector{font-size:.75rem;padding:.3rem .4rem;min-width:0;flex:1 1 100%}.chat-header .logo-container img,.chat-header .logo-image-large{height:26px}.user-menu-dropdown{right:-.5rem;left:auto;min-width:200px}}@supports (-webkit-appearance: none){.chat-layout,body.chat-active,html.chat-active{height:-webkit-fill-available}}.loading-spinner-message{display:flex;align-items:center;justify-content:center;padding:2rem}.message-feedback-buttons{display:flex;gap:8px;margin-top:12px;padding-top:8px;border-top:1px solid rgba(0,0,0,.06);justify-content:flex-start}.feedback-btn-inline{background:none;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:6px 10px;font-size:16px;cursor:pointer;transition:all .2s ease;color:#6b7280;display:flex;align-items:center;justify-content:center;min-width:36px;height:32px}.feedback-btn-inline:hover{background-color:#0000000a;border-color:#00000026;transform:translateY(-1px)}.feedback-btn-inline:active{transform:translateY(0)}.feedback-btn-inline:focus{outline:none;box-shadow:0 0 0 2px #3b82f680}@media (prefers-color-scheme: dark){.message-feedback-buttons{border-top-color:#ffffff1a}.feedback-btn-inline{border-color:#ffffff26;color:#9ca3af}.feedback-btn-inline:hover{background-color:#ffffff14;border-color:#ffffff40}}:root{--color-primary: #1976d2;--color-primary-dark: #1565c0;--color-primary-light: #e3f2fd;--color-success: #4caf50;--color-success-light: #e8f5e9;--color-success-dark: #2e7d32;--color-error: #f44336;--color-error-light: #ffebee;--color-error-dark: #c62828;--color-warning: #ff9800;--color-warning-light: #fff3cd;--color-warning-dark: #856404;--color-info: #2196f3;--color-info-light: #d1ecf1;--color-info-dark: #0c5460;--color-background: #f5f5f5;--color-background-hover: #fafafa;--color-background-alt: #f9f9f9;--color-background-disabled: #f5f5f5;--color-surface: #ffffff;--color-text-primary: #333;--color-text-secondary: #666;--color-text-tertiary: #999;--color-border: #ddd;--color-border-light: #eee;--color-divider: #e0e0e0;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--border-radius: 4px;--border-radius-lg: 8px;--border-radius-pill: 12px;--shadow: 0 2px 4px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .3);--transition: all .2s}.admin-dashboard{min-height:100vh;background:var(--color-background);padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.card{background:var(--color-surface);border-radius:var(--border-radius-lg);box-shadow:var(--shadow);margin-bottom:20px}.card-padding{padding:20px}.btn{border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-secondary{background:#757575;color:#fff}.btn-secondary:hover:not(:disabled){background:#616161}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#d32f2f}.btn-ghost{background:#fff;color:var(--color-primary);border:1px solid var(--color-border)}.btn-ghost:hover:not(:disabled){background:var(--color-background)}.btn-lg{padding:12px 20px}.btn-md{padding:8px 16px}.btn-sm{padding:6px 12px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.table-header{background:var(--color-background);padding:12px;text-align:left;font-weight:600;color:var(--color-text-primary);border-bottom:2px solid var(--color-border)}.table-cell{padding:12px;border-bottom:1px solid var(--color-border-light)}.table-row{cursor:pointer;-webkit-user-select:none;user-select:none}.table-row:hover{background:#fafafa}.table-row:active{background:#e3f2fd}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--border-radius-pill);font-size:13px;font-weight:500}.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-error{background:var(--color-error-light);color:var(--color-error-dark)}.badge-info{background:var(--color-primary-light);color:var(--color-primary)}.badge-success-light{background:var(--color-success-light);color:var(--color-success)}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--border-radius-pill);font-size:12px;font-weight:500;white-space:nowrap}.status-badge.status-success{background:var(--color-success-light);color:var(--color-success-dark)}.status-badge.status-error{background:var(--color-error-light);color:var(--color-error-dark)}.status-badge.status-warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.status-badge.status-info{background:var(--color-info-light);color:var(--color-info-dark)}.icon-with-text{display:flex;align-items:center;gap:6px}.icon-with-text svg{font-size:1.1em}.text-sm{font-size:12px}.text-md{font-size:14px}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.text-mono{font-family:Courier New,monospace}.admin-header{display:flex;justify-content:space-between;align-items:center;background:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--border-radius-lg);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow)}.admin-header h1{margin:0;font-size:24px;color:var(--color-text-primary);display:flex;align-items:center}.admin-header h1 svg{margin-right:var(--spacing-md);font-size:1.2em}.close-button{padding:8px 16px;border-radius:var(--border-radius);display:flex;align-items:center;gap:6px;background:var(--color-error);border:none;cursor:pointer;color:#fff;transition:var(--transition)}.close-button:hover{background:#d32f2f}.admin-tabs{display:flex;gap:10px;background:var(--color-surface);padding:10px;border-radius:var(--border-radius-lg);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow)}.admin-tabs button{flex:1;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;border-radius:var(--border-radius);font-size:14px;font-weight:500;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:6px}.admin-tabs button svg{font-size:1.1em}.admin-tabs button:hover{background:var(--color-background)}.admin-tabs button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.admin-error{background:#ffebee;color:#c62828;padding:15px;border-radius:4px;margin-bottom:20px;border-left:4px solid #c62828}.admin-success{background:#e8f5e9;color:#2e7d32;padding:15px;border-radius:4px;margin-bottom:20px;border-left:4px solid #2e7d32;display:flex;flex-direction:column;gap:10px}.admin-success strong{display:flex;align-items:center;gap:8px;font-weight:600}.admin-success p{margin:0;font-size:14px;line-height:1.5}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background:#fff;border-radius:8px}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite}.spinner-small{display:inline-block;width:14px;height:14px;border:2px solid #f3f3f3;border-top:2px solid #1976d2;border-radius:50%;animation:spin .8s linear infinite;margin-left:6px;vertical-align:middle}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-content{background:var(--color-surface);padding:var(--spacing-lg);border-radius:var(--border-radius-lg);box-shadow:var(--shadow)}.admin-content h2{margin:0 0 10px;font-size:20px;color:var(--color-text-primary)}.admin-content h3{margin:20px 0 10px;font-size:16px;color:var(--color-text-secondary)}.result-count,.period-info{color:var(--color-text-secondary);font-size:14px;margin-bottom:15px}.traces-table-container,.cost-table-container,.analytics-table-container,.sessions-list,.feedback-container{overflow-x:auto;margin:0;padding:20px}.traces-table,.cost-table,.analytics-table,.admin-table{width:100%;border-collapse:collapse;font-size:14px}.traces-table th,.cost-table th,.analytics-table th,.admin-table th{background:var(--color-background);padding:12px;text-align:left;font-weight:600;color:var(--color-text-primary);border-bottom:2px solid var(--color-border)}.traces-table td,.cost-table td,.analytics-table td,.admin-table td{padding:12px;border-bottom:1px solid var(--color-border-light)}.traces-table tr:hover,.cost-table tr:hover,.analytics-table tr:hover,.admin-table tr:hover{background:#fafafa}.traces-table .trace-row,.admin-table .session-row,.admin-table .feedback-row{cursor:pointer;-webkit-user-select:none;user-select:none}.traces-table .trace-row:active,.admin-table .session-row:active,.admin-table .feedback-row:active{background:#e3f2fd}.btn-small{padding:6px 12px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:12px;transition:var(--transition)}.btn-small:hover{background:var(--color-primary-dark)}.detail-button{background:var(--color-primary);color:#fff;border:none;padding:6px 12px;border-radius:var(--border-radius);cursor:pointer;font-size:13px;transition:var(--transition)}.detail-button:hover{background:var(--color-primary-dark)}.trace-button{background:#9c27b0;color:#fff;border:none;padding:6px 12px;border-radius:var(--border-radius);cursor:pointer;font-size:12px;transition:var(--transition);display:inline-flex;align-items:center;gap:4px}.trace-button:hover:not(:disabled){background:#7b1fa2}.trace-button:disabled{background:#ce93d8;cursor:not-allowed;opacity:.8}.analysis-button{border:none;padding:6px 10px;border-radius:var(--border-radius);cursor:pointer;font-size:13px;font-weight:600;transition:var(--transition);display:inline-flex;align-items:center;gap:6px;min-width:60px;justify-content:center}.analysis-button--high{background:#4caf50;color:#fff}.analysis-button--high:hover{background:#45a049}.analysis-button--high:active{background:#3d8b40}.analysis-button--low{background:#f44336;color:#fff}.analysis-button--low:hover{background:#da190b}.analysis-button--low:active{background:#ba0000}.analysis-icon{font-size:16px;line-height:1}.analysis-cell{text-align:center;padding:8px!important}.analysis-cell:empty:before{content:"—";color:var(--color-text-tertiary)}.analysis-json-container{margin-top:0;border-radius:var(--border-radius);background-color:var(--color-background);overflow:hidden;border:1px solid var(--color-border)}.analysis-json-box{margin:0;padding:12px;max-height:250px;overflow-y:auto;overflow-x:auto;background-color:var(--color-background-alt);border:none;font-size:12px;font-family:Courier New,Courier,monospace;line-height:1.5;color:#333;white-space:pre-wrap;word-wrap:break-word}.analysis-json-box code{font-family:Courier New,Courier,monospace;color:#333;font-size:12px;line-height:1.5}.analysis-json-box::-webkit-scrollbar{width:8px;height:8px}.analysis-json-box::-webkit-scrollbar-track{background:#f1f1f1}.analysis-json-box::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.analysis-json-box::-webkit-scrollbar-thumb:hover{background:#555}.analysis-json-box .hljs-number{color:#d73a49}.analysis-json-box .hljs-attr{color:#24292e}.analysis-json-box .hljs-string{color:#22863a}.analysis-json-box .hljs-literal{color:#005cc5}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:20px;padding:15px;background:#f9f9f9;border-radius:var(--border-radius)}.pagination button{padding:8px 16px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;font-size:14px;transition:var(--transition)}.pagination button:hover:not(:disabled){background:var(--color-primary-dark)}.pagination button:disabled{background:#ccc;cursor:not-allowed}.pagination span{font-size:14px;color:var(--color-text-secondary)}.pagination-info{font-size:14px;color:var(--color-text-secondary);white-space:nowrap}.cost-aggregations{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin:0;padding:20px;border-bottom:1px solid var(--color-border-light)}.stat-card{background:linear-gradient(135deg,#23743e,#38f9d7);color:#fff;padding:20px;border-radius:8px;box-shadow:0 4px 6px #0000001a}.stat-card:nth-child(2){background:linear-gradient(135deg,#937896,#b65965)}.stat-card:nth-child(3){background:linear-gradient(135deg,#4facfe,#02b3bd)}.stat-card:nth-child(4){background:linear-gradient(135deg,#667eea,#764ba2)}.stat-card h3{margin:0 0 10px;font-size:14px;font-weight:500;opacity:.9;color:#fff}.stat-value{margin:0;font-size:28px;font-weight:700}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.modal-content{background:var(--color-surface);border-radius:var(--border-radius-lg);max-width:900px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-content.form-modal{max-width:400px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border-light)}.modal-header h2{margin:0;font-size:20px;color:var(--color-text-primary)}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-text-secondary);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.modal-close svg{font-size:1.3em}.modal-close:hover{color:var(--color-error)}.modal-body{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-lg);overflow-y:auto;flex:1}.modal-body h3{margin-top:var(--spacing-md);margin-bottom:var(--spacing-md);font-size:16px;font-weight:600;color:var(--color-text-primary)}.modal-body h3:first-child{margin-top:0}.modal-body p{margin:0 0 var(--spacing-md) 0;color:var(--color-text-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border-light);background:var(--color-surface)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:10px;margin:1px 0;font-size:14px}.detail-grid div{padding:10px;background:var(--color-background-alt);border-radius:var(--border-radius);word-wrap:break-word;overflow-wrap:break-word;word-break:break-word}.detail-grid>div{display:flex;flex-direction:column;gap:4px;padding:0;background:transparent}.detail-grid strong{font-weight:600;color:var(--color-text-primary);font-size:13px}.detail-grid code{background:var(--color-background);padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:12px;word-break:break-all}.rating-display{display:inline-flex;align-items:center;gap:6px;font-weight:600;padding:4px 10px;border-radius:4px;margin-left:8px}.rating-display.rating-positive{background:var(--color-success-light);color:var(--color-success-dark)}.rating-display.rating-negative{background:var(--color-error-light);color:var(--color-error-dark)}.rating-display svg{font-size:16px}.message-content{background:var(--color-background-alt);padding:15px;border-radius:var(--border-radius);margin:10px 0;font-size:14px;line-height:1.6;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word;white-space:pre-wrap}.feedback-modal .modal-body>div{margin-bottom:var(--spacing-xl)}.feedback-modal .modal-body>div:last-child{margin-bottom:0}.feedback-modal .modal-body>div:first-child>div{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.feedback-modal .modal-body>div:first-child .btn{margin:0;padding:var(--spacing-sm) var(--spacing-lg);min-height:40px}.feedback-modal .modal-body>div:nth-child(2){display:flex;flex-direction:column;gap:var(--spacing-sm)}.feedback-modal .modal-body>div:nth-child(2) label{display:block;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.feedback-modal .modal-body>div:nth-child(2)>div:nth-child(2){display:flex;flex-direction:column;gap:var(--spacing-sm)}.feedback-modal textarea{width:100%;min-height:120px;padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--border-radius);background:var(--color-background);color:var(--color-text-primary);font-family:inherit;font-size:14px;resize:vertical;max-height:300px}.feedback-modal textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1976d21a}.feedback-modal textarea:disabled{background:var(--color-background-disabled);cursor:not-allowed;opacity:.6}.feedback-modal .modal-body>div:nth-child(2)>div:nth-child(2)>div:last-child{font-size:12px;color:var(--color-text-secondary);text-align:right}.feedback-modal .modal-body>div:nth-child(2)>div:nth-child(2)>div.error-message{color:var(--color-error);font-size:12px;padding:var(--spacing-sm);background:#f443361a;border-radius:var(--border-radius)}.truncation-indicator{color:var(--color-text-tertiary);font-style:italic;font-size:12px;margin-left:4px}.events-list{display:flex;flex-direction:column;gap:10px;margin:15px 0}.event-item{background:var(--color-background-alt);padding:12px;border-radius:var(--border-radius);border-left:3px solid var(--color-primary)}.event-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.event-type{font-weight:600;color:var(--color-primary);font-size:13px}.event-duration{font-size:12px;color:var(--color-text-secondary)}.event-content{font-size:13px;color:var(--color-text-secondary);line-height:1.5;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word}.event-reasoning{margin-top:10px;padding:10px;background:var(--color-surface);border:1px solid var(--color-divider);border-radius:var(--border-radius)}.event-reasoning strong{display:block;margin-bottom:8px;color:var(--color-primary);font-size:13px}.event-reasoning pre{margin:0;font-size:12px;font-family:Courier New,monospace;color:var(--color-text-primary);white-space:pre-wrap;word-wrap:break-word;line-height:1.5}.tools-list{display:flex;flex-direction:column;gap:15px;margin:15px 0}.tool-item{background:var(--color-background-alt);padding:15px;border-radius:var(--border-radius);border-left:3px solid var(--color-success)}.tool-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-wrap:wrap;gap:10px}.tool-name{font-weight:600;color:var(--color-text-primary);font-size:14px;display:flex;align-items:center;gap:6px}.tool-name svg{font-size:1.1em}.tool-status{font-size:12px;padding:4px 8px;border-radius:3px;display:flex;align-items:center;gap:4px}.tool-status svg{font-size:1.1em}.tool-status.success{background:var(--color-success-light);color:var(--color-success-dark)}.tool-status.error{background:var(--color-error-light);color:var(--color-error-dark)}.tool-duration{font-size:12px;color:var(--color-text-secondary)}.tool-details{margin-top:10px;font-size:13px}.tool-details summary{cursor:pointer;font-weight:500;color:var(--color-primary);-webkit-user-select:none;user-select:none}.tool-details pre{margin:10px 0 0;padding:10px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);overflow-x:auto;font-size:12px;line-height:1.4;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;word-break:break-word}.access-denied{text-align:center;padding:60px 20px;background:var(--color-surface);border-radius:var(--border-radius-lg);margin:40px auto;max-width:600px}.access-denied h1{color:#c62828;margin-bottom:10px}.access-denied p{color:var(--color-text-secondary);font-size:16px}@media (max-width: 768px){.admin-dashboard{padding:10px}.admin-header{flex-direction:column;gap:15px;text-align:center}.admin-tabs{flex-direction:column}.cost-aggregations,.detail-grid{grid-template-columns:1fr}.modal-content{max-height:95vh}.traces-table th,.traces-table td{padding:8px;font-size:12px}.btn-small{padding:4px 8px;font-size:11px}}.sessions-tab,.traces-tab,.feedback-tab,.cost-tab,.analytics-tab{background:var(--color-surface);padding:0;border-radius:0;box-shadow:none}.tab-header{display:flex;justify-content:space-between;align-items:center;padding:0 20px 15px;border-bottom:1px solid var(--color-border-light)}.tab-header h2{margin:0;font-size:20px;color:var(--color-text-primary)}.tab-header p,.result-count{margin:0;color:var(--color-text-secondary);font-size:14px}.header-controls{display:flex;align-items:center;gap:20px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--color-text-secondary);-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{cursor:pointer;margin:0;width:16px;height:16px}.checkbox-label:hover{color:var(--color-text-primary)}.export-button{background:var(--color-primary);color:#fff;border:none;padding:6px 12px;border-radius:var(--border-radius);cursor:pointer;font-size:13px;transition:var(--transition);display:inline-flex;align-items:center;gap:6px}.export-button:hover:not(:disabled){background:var(--color-primary-dark)}.export-button:disabled{opacity:.5;cursor:not-allowed}.export-icon{font-size:14px;display:inline-flex;align-items:center}.sessions-list,.feedback-container,.traces-table-container,.cost-table-container,.analytics-table-container{margin:0;padding:20px;overflow-x:auto}.customer-cell,.user-cell{font-size:13px;color:var(--color-text-secondary);max-width:300px;word-break:break-word}.message-preview{font-size:13px;color:var(--color-text-secondary);max-width:300px;word-break:break-word;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-id{font-family:Courier New,monospace;background:var(--color-background);padding:2px 6px;border-radius:3px;font-size:12px}.rating{font-size:12px;font-weight:500;gap:3px}.rating-positive{color:#2e7d32}.rating-negative{color:#c62828}.rating svg{font-size:1.4em}.comments{font-size:13px;color:var(--color-text-secondary);max-width:250px;word-break:break-word;text-align:left}.no-comments{color:var(--color-text-tertiary);font-style:italic}.id-paren{color:var(--color-text-tertiary);font-size:12px;font-weight:400;margin-left:3px}.no-data{color:var(--color-text-tertiary);font-style:italic}.empty-state{text-align:center;padding:40px 20px}.empty-state p{color:var(--color-text-tertiary);font-size:16px;margin:0}.feedback-tab .empty-state{text-align:center;padding:40px 20px}.feedback-tab .empty-state p{color:var(--color-text-tertiary);font-size:16px;margin:0}.session-detail-modal .modal-content{max-width:900px;max-height:90vh}.session-detail-modal .modal-body{overflow-y:hidden;display:flex;flex-direction:column}.session-detail-modal .session-detail{display:flex;flex-direction:column;overflow:hidden;height:100%}.messages-list{margin-top:15px;max-height:calc(90vh - 300px);overflow-y:auto;display:flex;flex-direction:column;gap:15px}.message-item{border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:15px;background:var(--color-background-alt)}.message-item.message-user{border-left:4px solid var(--color-primary)}.message-item.message-assistant{border-left:4px solid var(--color-success)}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;flex-wrap:wrap;gap:10px}.role-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--border-radius-pill);font-size:13px;font-weight:500}.role-badge.user{background:var(--color-primary-light);color:var(--color-primary)}.role-badge.assistant{background:var(--color-success-light);color:var(--color-success)}.message-meta{font-size:12px;color:var(--color-text-secondary)}.response-time,.fleet-name{color:var(--color-text-tertiary)}.message-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px;flex-wrap:wrap;gap:10px}.feedback-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:13px;color:var(--color-text-secondary)}.feedback-comment-wrapper{display:flex;flex-direction:column;gap:8px}.feedback-badge-header{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:13px;width:fit-content}.feedback-badge .feedback-icon{font-size:1.1em;margin-top:2px}.feedback-badge .thumbs-up{color:var(--color-success)}.feedback-badge .thumbs-down{color:var(--color-error)}.feedback-badge-header .thumbs-up{color:var(--color-success)}.feedback-badge-header .thumbs-down{color:var(--color-error)}.feedback-comment{color:var(--color-text-primary);display:block;white-space:pre-wrap;word-wrap:break-word;background:var(--color-background-alt);padding:15px;border-radius:var(--border-radius);margin:0;border:1px solid var(--color-border-light)}.feedback-header{display:flex;align-items:flex-start;gap:6px;margin-bottom:8px;font-size:12px;font-weight:600}.feedback-label{color:var(--color-text-primary);font-weight:600;font-size:13px}.session-analysis-modal .modal-content{max-width:800px;max-height:90vh}.session-analysis-modal .modal-body{overflow-y:auto;display:flex;flex-direction:column}.session-analysis-modal .session-analysis{display:flex;flex-direction:column;height:100%}.analysis-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin:15px 0}.analysis-card{border:2px solid var(--color-border);border-radius:var(--border-radius-lg);padding:20px;text-align:center;background:var(--color-background-alt);transition:var(--transition)}.analysis-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #0000001a}.analysis-score-label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.analysis-score-value{font-size:32px;font-weight:700;color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;gap:8px}.analysis-score-value.high{color:var(--color-success)}.analysis-score-value.low{color:var(--color-error)}.score-indicator{display:inline-flex;align-items:center;font-size:20px}.score-indicator .thumbs-icon{margin-top:2px}.score-indicator .thumbs-icon.up{color:var(--color-success)}.score-indicator .thumbs-icon.down{color:var(--color-error)}.validation-messages{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:15px;white-space:pre-wrap;word-wrap:break-word;font-family:Courier New,monospace;font-size:13px;color:var(--color-text-primary);max-height:200px;overflow-y:auto}@media (max-width: 1024px){.sessions-list{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table{min-width:800px}.message-preview{max-width:200px}}@media (max-width: 768px){.sessions-tab{padding:12px}.admin-table{min-width:700px;font-size:13px}.admin-table th,.admin-table td{padding:8px}.message-preview{max-width:150px}.session-id{font-size:11px;max-width:120px;overflow:hidden;text-overflow:ellipsis;display:inline-block}}@media (max-width: 480px){.sessions-tab{padding:8px}.admin-table{min-width:600px;font-size:12px}.admin-table th,.admin-table td{padding:6px 4px}.message-preview{max-width:100px}.session-id{max-width:80px}.detail-button{padding:4px 8px;font-size:12px}}.action-buttons{display:flex;gap:8px;align-items:center;flex-wrap:nowrap}.action-buttons .detail-button,.action-buttons .delete-button{display:inline-flex;align-items:center;gap:4px;white-space:nowrap;height:32px;padding:6px 12px;font-size:13px}.delete-button{background:#dc3545;color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;transition:var(--transition)}.delete-button:hover{background:#c82333}.generate-report-button{background:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:var(--transition);box-shadow:0 2px 4px #0000001a}.generate-report-button:hover{background:#218838;box-shadow:0 4px 8px #00000026}.generate-report-button:active{background:#1e7e34;box-shadow:0 1px 2px #0000001a}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--color-text);font-size:14px}.form-control{width:100%;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:14px;background:var(--color-background);color:var(--color-text);transition:var(--transition)}.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #007bff1a}.form-control:disabled{background:var(--color-border-light);cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.availability-check{padding:12px 16px;border-radius:var(--border-radius);display:flex;align-items:center;gap:8px;font-size:14px;margin-top:16px}.availability-check.loading{background:#f8f9fa;color:#6c757d}.availability-check.sufficient{background:#d4edda;color:#155724}.availability-check.insufficient{background:#fff3cd;color:#856404}/*!
  Theme: GitHub
  Description: Light theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-light
  Current colors taken from GitHub's CSS
*/.hljs{color:#24292e;background:#fff}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#d73a49}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#6f42c1}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#005cc5}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#032f62}.hljs-built_in,.hljs-symbol{color:#e36209}.hljs-comment,.hljs-code,.hljs-formula{color:#6a737d}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#22863a}.hljs-subst{color:#24292e}.hljs-section{color:#005cc5;font-weight:700}.hljs-bullet{color:#735c0f}.hljs-emphasis{color:#24292e;font-style:italic}.hljs-strong{color:#24292e;font-weight:700}.hljs-addition{color:#22863a;background-color:#f0fff4}.hljs-deletion{color:#b31d28;background-color:#ffeef0}.welcome-pills-container{display:flex;flex-direction:column;gap:.5rem;margin-top:0rem;max-width:530px;margin-left:auto;margin-right:auto}.welcome-pill{background-color:transparent;border:none;border-radius:0;padding:.5rem 0;font-size:.95rem;font-weight:400;color:#1866a7;cursor:pointer;transition:all .2s ease;text-align:left;white-space:normal;word-wrap:break-word;flex:1;min-width:0;display:flex;align-items:center;gap:.5rem}.welcome-pill-icon{flex-shrink:0;transition:transform .2s ease;font-size:1.25rem}.welcome-pill:hover{background-color:#f5f5f5;color:#1866a7;text-decoration:none;padding:.5rem .75rem;margin:0 -.75rem;border-radius:6px;box-shadow:0 2px 8px #00000014}.welcome-pill:hover .welcome-pill-icon{transform:scale(1.1)}.welcome-pill:active{opacity:.8;outline-offset:2px}.welcome-panel{display:flex;align-items:center;justify-content:center;height:100%;padding:2rem;background-color:#fff;animation:welcomePanelFadeIn .5s ease-out}@keyframes welcomePanelFadeIn{0%{opacity:0}to{opacity:1}}@keyframes welcomePanelFadeOut{0%{opacity:1}to{opacity:0;pointer-events:none}}.welcome-panel.fade-out{animation:welcomePanelFadeOut .5s ease-out forwards}.welcome-panel-content{display:flex;flex-direction:column;gap:1.5rem;max-width:600px;width:100%;animation:contentSlideUp .5s ease-out}@keyframes contentSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes inputJiggle{0%{transform:scale(1)}25%{transform:scale(1.02)}50%{transform:scale(1)}75%{transform:scale(1.02)}to{transform:scale(1)}}.welcome-panel-message{text-align:center}.welcome-panel-text{font-size:1.5rem;color:#333;font-weight:500;line-height:1.6}.welcome-panel-input-wrapper{margin-top:1rem;animation:inputJiggle .5s ease-in-out .4s}.welcome-panel-input-wrapper .message-input-container{border-top:none!important}@media (max-width: 768px){.welcome-panel{padding:1.5rem}.welcome-panel-content{gap:1rem}.welcome-panel-text{font-size:1.1rem}}@media (max-width: 480px){.welcome-panel{padding:1rem}.welcome-panel-content{gap:.75rem;max-width:100%}.welcome-panel-text{font-size:1rem}}.custom-message-list{display:flex;flex-direction:column;gap:12px;padding:16px;height:calc(100vh - 120px);overflow-y:auto;overflow-x:hidden;background-color:#fff;overscroll-behavior-y:contain;-webkit-overflow-scrolling:auto}.custom-message-list::-webkit-scrollbar{width:8px}.custom-message-list::-webkit-scrollbar-track{background:transparent}.custom-message-list::-webkit-scrollbar-thumb{background-color:transparent;border-radius:4px;height:120px!important}.custom-message-list::-webkit-scrollbar-thumb:hover{background-color:#999}.custom-message-list::-webkit-scrollbar-button{display:none}.custom-message-list.scrolling::-webkit-scrollbar-thumb{background-color:#c7e0fdaf}.custom-message-list.scrolling::-webkit-scrollbar-thumb:hover{background-color:#c7e0fd}.messages-end-anchor{display:block;flex-shrink:0}.custom-message{display:flex;gap:8px;animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.custom-message--incoming{justify-content:flex-start;align-items:flex-start}.custom-message--outgoing{justify-content:flex-end;align-items:flex-end;margin:0}.custom-message__content-wrapper{display:flex;flex-direction:column;max-width:80%;word-wrap:break-word}.custom-message--incoming .custom-message__content-wrapper{max-width:80%}.custom-message--outgoing .custom-message__content-wrapper{align-items:flex-end}.message-content{padding:8px 12px;margin:0;border-radius:12px;line-height:1.5;word-wrap:break-word;overflow-wrap:break-word}.custom-message--incoming .message-content{background-color:#ebf1f8;color:#333;border-radius:0 12px 12px;border:none}.custom-message--outgoing .message-content{background-color:#c7e0fd;color:#333;border-radius:12px 12px 0;border:none;padding:8px 12px}.message-content p{margin:0;padding:0}.message-content[data-loading=true]{opacity:.7}.bot-message-container{display:flex;flex-direction:column;gap:12px}.stream-events-panel{margin:0}.stream-events-summary{cursor:pointer;font-size:12px;font-weight:600;list-style:none}.stream-events-summary::-webkit-details-marker{display:none}.stream-events-list{display:flex;flex-direction:column;gap:4px;margin-top:6px}.stream-event-item{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px;opacity:.8}.stream-event-icon{font-size:12px;flex-shrink:0}.stream-event-text{line-height:1.3}.stream-event-reasoning{margin:2px 0 0 18px;padding:8px;border-radius:6px;font-size:12px;line-height:1.4;background-color:#0000000d}.copilot-response{font-size:14px;line-height:1.6}.message-citations{margin-top:8px;padding:8px;background-color:#0000000d;border-radius:6px;cursor:pointer}.message-citations summary{font-size:12px;font-weight:600;color:#0009;-webkit-user-select:none;user-select:none}.message-citations[open] summary{margin-bottom:8px}.citations-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.citation-item{padding:6px 8px;background-color:#ffffff80;border-radius:4px;font-size:12px}.citation-content{font-size:12px;margin:0}.message-feedback-buttons{display:flex;gap:0px;margin-top:0}.feedback-btn-inline{background:none;border:none;cursor:pointer;padding:10px 14px;border-radius:4px;color:#00000080;font-size:22px;transition:all .2s ease}.feedback-btn-inline:hover{background-color:#0000001a;color:#000c}.feedback-btn-inline:active{transform:scale(.95)}.message-avatar{border-radius:50%;object-fit:cover;flex-shrink:0}.message-avatar--sm{width:28px;height:28px}.message-avatar--md{width:36px;height:36px}.message-avatar--lg{width:48px;height:48px}.custom-message--incoming .message-avatar{width:42px;height:42px}.custom-message--outgoing .message-avatar{width:36px;height:36px}.typing-indicator{display:flex;align-items:center;gap:12px;padding:12px 16px;background-color:#f0f0f0;border-radius:12px;width:fit-content}.typing-dots{display:flex;gap:4px;align-items:center}.typing-dots .dot{width:8px;height:8px;border-radius:50%;background-color:#999;animation:typingBounce 1.4s infinite}.typing-dots .dot:nth-child(2){animation-delay:.2s}.typing-dots .dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.typing-text{font-size:12px;color:#666;margin:0}.message-input-container{display:flex;gap:8px;padding:12px 16px;background-color:#fff;border-top:1px solid #e0e0e0;flex-shrink:0}.message-input-container.disabled{opacity:.6}.message-input-field{flex:1;padding:10px 12px;border:1px solid #ffffff00;border-radius:16px;font-size:15px;font-family:inherit;resize:none;min-height:40px;max-height:200px;line-height:1.4;background-color:#c7e0fd;overflow:hidden;field-sizing:content}.message-input-field:focus{outline:none;border:1px solid #aaccf0;box-shadow:0 0 #007bff1a}.message-input-field:disabled{background-color:#f5f5f5;cursor:not-allowed}.message-send-button{padding:10px 20px;background-color:#6c9bd1;color:#f0f8ff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.message-send-button:hover:not(:disabled){background-color:#0056b3}.message-send-button:disabled{background-color:#ccc;cursor:not-allowed}.loading-spinner-message{display:flex;justify-content:center;align-items:center;padding:40px;width:100%}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:16px}.spinner{width:40px;height:40px;border:3px solid #f0f0f0;border-top-color:#007bff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner p{color:#666;font-size:14px;margin:0}@media (max-width: 500px){.custom-message-list{height:calc(100vh - 140px);padding:12px;gap:8px}.custom-message__content-wrapper{max-width:95%}.custom-message--incoming .custom-message__content-wrapper{max-width:100%}.message-input-container{padding:8px 12px;gap:6px}.message-input-field{min-height:36px;font-size:16px}.message-avatar{display:none!important}.custom-message{gap:0}.message-send-button{padding:8px 16px;font-size:20px}.message-citations{max-width:100%}.citation-item{font-size:11px}}.history-sidebar{position:relative;background-color:#f8f9fa;border-right:1px solid #dee2e6;display:flex;flex-direction:column;transition:width .3s ease;flex-shrink:0;height:100%}.history-sidebar.collapsed{width:50px}.history-sidebar.open{width:300px}.history-toggle-btn{position:absolute;top:.5rem;left:.5rem;width:36px;height:36px;border:none;background-color:transparent;color:#666;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease,color .2s ease;z-index:10;font-size:1.25rem}.history-toggle-btn:hover{background-color:#e9ecef;color:#333}.history-toggle-btn:active{background-color:#dee2e6}.history-content{padding-top:3rem;display:flex;flex-direction:column;height:100%;overflow:hidden}.history-title{font-size:1.125rem;font-weight:600;color:#333;padding:0 1rem;margin:0}.history-empty{padding:2rem 1rem;text-align:center;color:#6c757d;font-size:.875rem}.history-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:5px .5rem 0}.history-item{padding:.75rem;margin-bottom:.5rem;background-color:#fff;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease}.history-item:hover{background-color:#f8f9fa;border-color:#dee2e6;box-shadow:0 2px 4px #0000000d}.history-item:active{background-color:#e9ecef}.history-item:focus{outline:2px solid #759bd4a6;outline-offset:2px}.history-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.history-item-date{font-size:.75rem;color:#6c757d;font-weight:500}.history-item-time{font-size:.75rem;color:#999;font-weight:400}.history-item-description{font-size:.875rem;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}.history-load-more-item{padding:0;background-color:transparent;border:none;cursor:default;margin-bottom:.5rem}.history-load-more-item:hover{background-color:transparent;border:none;box-shadow:none}.history-load-more{width:100%;padding:.75rem;background-color:#fff;border:1px solid #dee2e6;border-radius:6px;color:#0d6efd;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.history-load-more:hover:not(:disabled){background-color:#f8f9fa;border-color:#7d96bbd2}.history-load-more:active:not(:disabled){background-color:#e9ecef}.history-load-more:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.history-sidebar.open{position:absolute;top:0;left:0;bottom:0;width:100%;z-index:1000;box-shadow:2px 0 8px #0000001a}.history-sidebar.collapsed{width:50px}}.history-list::-webkit-scrollbar{width:6px}.history-list::-webkit-scrollbar-track{background:transparent}.history-list::-webkit-scrollbar-thumb{background-color:#dee2e6;border-radius:3px}.history-list::-webkit-scrollbar-thumb:hover{background-color:#ced4da}.copy-markdown-button{background:#2196f3;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s ease;display:inline-flex;align-items:center;gap:4px}.copy-markdown-button:hover{background:#1976d2}.copy-markdown-button.copied{background:#4caf50}.session-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.session-dialog{background-color:#fff;border-radius:8px;box-shadow:0 4px 16px #0003;display:flex;flex-direction:column;max-width:800px;width:100%;max-height:90vh;overflow:hidden}.session-dialog-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #dee2e6;background-color:#f8f9fa;flex-shrink:0}.session-dialog-info{flex:1;min-width:0;margin-right:1rem}.session-dialog-title{font-size:1.125rem;font-weight:600;color:#333;margin:0 0 .25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-dialog-date{font-size:.875rem;color:#6c757d}.session-dialog-actions{display:flex;gap:.5rem;flex-shrink:0}.session-delete-btn,.session-close-btn,.session-delete-confirm-btn,.session-delete-cancel-btn{width:36px;height:36px;border:none;background-color:transparent;color:#666;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease,color .2s ease}.session-delete-btn:hover{background-color:#dc3545;color:#fff}.session-close-btn:hover{background-color:#e9ecef;color:#333}.session-delete-confirm-btn,.session-delete-cancel-btn{width:auto;padding:.5rem 1rem;font-size:.875rem;font-weight:500}.session-delete-confirm-btn{background-color:#dc3545;color:#fff}.session-delete-confirm-btn:hover:not(:disabled){background-color:#bb2d3b}.session-delete-cancel-btn{background-color:#6c757d;color:#fff}.session-delete-cancel-btn:hover:not(:disabled){background-color:#5c636a}.session-delete-confirm-btn:disabled,.session-delete-cancel-btn:disabled{opacity:.6;cursor:not-allowed}.session-dialog-body{flex:1;overflow-y:auto;overflow-x:hidden;background-color:#fff;position:relative}.session-message-list{height:100%!important;min-height:400px;padding:16px 24px;display:flex;flex-direction:column;gap:12px}.session-dialog-body::-webkit-scrollbar{width:8px}.session-dialog-body::-webkit-scrollbar-track{background:#f8f9fa}.session-dialog-body::-webkit-scrollbar-thumb{background-color:#dee2e6;border-radius:4px}.session-dialog-body::-webkit-scrollbar-thumb:hover{background-color:#ced4da}@media (max-width: 768px){.session-dialog-overlay{padding:1rem;align-items:flex-start;justify-content:center;overflow-y:auto}.session-dialog{max-width:100%;max-height:calc(100vh - 2rem);border-radius:8px;margin:1rem 0}.session-dialog-header{padding:.75rem 1rem}.session-dialog-title{font-size:1rem}.session-dialog-actions button{width:32px;height:32px}.session-delete-confirm-btn,.session-delete-cancel-btn{font-size:.8125rem;padding:.4rem .75rem}}.bot-message-container{display:flex;flex-direction:column;gap:.25rem}.message-footer{display:flex;gap:.5rem;margin-top:.5rem}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;border-top:1px solid var(--color-border);background:var(--color-background-alt)}.pagination__button{padding:8px 12px;border:1px solid var(--color-border);background:var(--color-surface);border-radius:var(--border-radius);cursor:pointer;font-size:14px;font-weight:500;transition:var(--transition);display:inline-flex;align-items:center;gap:6px;color:var(--color-text-primary);flex-shrink:0}.pagination__button:hover:not(:disabled){background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination__button:disabled{opacity:.5;cursor:not-allowed}.pagination__info{font-size:14px;color:var(--color-text-secondary);min-width:200px;text-align:center;flex-shrink:0}.pagination__page-info{font-size:14px;color:var(--color-text-secondary);min-width:auto;padding:0 8px;flex-shrink:0}.pagination--basic,.pagination--detailed{justify-content:center}@media (max-width: 768px){.pagination{flex-wrap:wrap;gap:8px}.pagination__info{min-width:100%;order:3}.pagination__button{flex:1;min-width:100px}}.admin-filters{background:var(--color-surface);padding:20px;border-radius:var(--border-radius-lg);margin-bottom:20px;box-shadow:var(--shadow)}.admin-filters__row{display:flex;gap:15px;flex-wrap:wrap;align-items:flex-end}.admin-filters__group{display:flex;flex-direction:column;gap:5px;min-width:150px}.admin-filters__label{font-size:12px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase}.admin-filters__input,.admin-filters__select{padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:14px;background:#fff;transition:border-color .2s}.admin-filters__input:hover:not(:disabled),.admin-filters__select:hover:not(:disabled){border-color:var(--color-primary)}.admin-filters__input:focus,.admin-filters__select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.admin-filters__input:disabled,.admin-filters__select:disabled{background:var(--color-background-disabled);cursor:not-allowed;opacity:.6}.admin-filters__actions{display:flex;gap:8px;margin-left:auto}.admin-filters__button{padding:8px 16px;border-radius:var(--border-radius);border:none;cursor:pointer;font-size:14px;transition:var(--transition);display:flex;align-items:center;gap:6px;font-weight:500}.admin-filters__button:disabled{opacity:.5;cursor:not-allowed}.admin-filters__button svg{font-size:1.1em}.admin-filters__button--refresh{background:var(--color-primary);color:#fff}.admin-filters__button--refresh:hover:not(:disabled){background:var(--color-primary-dark)}.admin-filters__button--reset{background:var(--color-text-secondary);color:#fff}.admin-filters__button--reset:hover:not(:disabled){background:#4a4a4a}.admin-filters__button--advanced{background:#e0e0e0;color:#424242}.admin-filters__button--advanced:hover:not(:disabled){background:#d5d5d5}.admin-filters__advanced{margin-top:15px;padding-top:15px;border-top:1px solid var(--color-border)}.admin-filters__info{font-size:14px;color:var(--color-text-secondary)}.admin-filters__info p{margin:5px 0}@media (max-width: 768px){.admin-filters__row{flex-direction:column}.admin-filters__group{width:100%;min-width:100%}.admin-filters__actions{margin-left:0;width:100%}.admin-filters__button{flex:1}}.admin-table{width:100%;border-collapse:collapse;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);overflow:hidden}.admin-table.striped tbody tr:nth-child(2n){background-color:var(--color-background-alt)}.admin-table.bordered{border:2px solid var(--color-border)}.admin-table.bordered th,.admin-table.bordered td{border:1px solid var(--color-border)}.admin-table thead{background:var(--color-background);border-bottom:2px solid var(--color-border)}.admin-table thead th{padding:12px;text-align:left;font-weight:600;font-size:14px;color:var(--color-text-primary)}.admin-table tbody td{padding:12px;border-bottom:1px solid var(--color-border-light);font-size:14px}.admin-table tbody tr{transition:background-color var(--transition)}.admin-table tbody tr:hover{background-color:var(--color-background)}.admin-table tbody tr.clickable{cursor:pointer}.admin-table-empty{display:flex;justify-content:center;align-items:center;padding:40px;color:var(--color-text-tertiary);font-size:14px}.admin-table-loading{display:flex;justify-content:center;align-items:center;padding:40px}.admin-table-container{overflow-x:auto}@media (max-width: 768px){.admin-table thead th,.admin-table tbody td{padding:8px;font-size:12px}}.link-clicks-cell{text-align:center}.link-clicks-button{background:var(--color-primary);color:#fff;border:none;padding:6px 12px;border-radius:var(--border-radius);cursor:pointer;font-size:13px;transition:var(--transition)}.link-clicks-button:hover{background:var(--color-primary-dark)}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{color:#383a42;background:#fafafa}.hljs-comment,.hljs-quote{color:#a0a1a7;font-style:italic}.hljs-doctag,.hljs-keyword,.hljs-formula{color:#a626a4}.hljs-section,.hljs-name,.hljs-selector-tag,.hljs-deletion,.hljs-subst{color:#e45649}.hljs-literal{color:#0184bb}.hljs-string,.hljs-regexp,.hljs-addition,.hljs-attribute,.hljs-meta .hljs-string{color:#50a14f}.hljs-attr,.hljs-variable,.hljs-template-variable,.hljs-type,.hljs-selector-class,.hljs-selector-attr,.hljs-selector-pseudo,.hljs-number{color:#986801}.hljs-symbol,.hljs-bullet,.hljs-link,.hljs-meta,.hljs-selector-id,.hljs-title{color:#4078f2}.hljs-built_in,.hljs-title.class_,.hljs-class .hljs-title{color:#c18401}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}
