.dashboard-layout{display:flex;flex-direction:column;height:100vh;width:100%}.dashboard-header{background-color:#2c3e50;color:#fff;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 4px #0000001a}.header-left{display:flex;align-items:center;gap:1rem}.sidebar-toggle{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s}.sidebar-toggle:hover{background-color:#ffffff1a}.dashboard-header h1{font-size:1.25rem;font-weight:600;margin:0}.dashboard-content{display:flex;flex:1;overflow:hidden}.sidebar{width:250px;background-color:#34495e;color:#fff;transition:transform .3s ease;overflow-y:auto}.sidebar.closed{transform:translate(-100%)}.sidebar-nav{padding:1rem 0}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:#fffc;text-decoration:none;transition:background-color .2s,color .2s}.nav-item:hover{background-color:#ffffff1a;color:#fff}.nav-item.active{background-color:#3498db;color:#fff}.nav-icon{font-size:1.25rem}.nav-label{font-size:.95rem;font-weight:500}.main-content{flex:1;overflow-y:auto;padding:2rem;background-color:#f5f5f5}@media (max-width: 768px){.sidebar{position:fixed;height:100%;z-index:1000}.sidebar.closed{transform:translate(-100%)}.main-content{padding:1rem}}.review-list-table-wrap{overflow-x:auto;border:1px solid #e0e0e0;border-radius:8px;background:#fff}.review-list-table{width:100%;border-collapse:collapse;font-size:.9rem}.review-list-table th,.review-list-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #eee}.review-list-table th{background:#f5f5f5;font-weight:600;color:#333}.review-list-table tbody tr:hover{background:#fafafa}.review-list-table .link-btn{background:none;border:none;color:#3498db;cursor:pointer;padding:0;font-size:inherit;text-decoration:underline}.review-list-table .link-btn:hover{color:#2980b9}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.action-buttons button{padding:.35rem .75rem;border:none;border-radius:4px;font-size:.85rem;cursor:pointer}.btn-view{background:#95a5a6;color:#fff}.btn-view:hover{background:#7f8c8d}.btn-approve{background:#27ae60;color:#fff}.btn-approve:hover{background:#219a52}.btn-reject{background:#e74c3c;color:#fff}.btn-reject:hover{background:#c0392b}.review-list-empty{padding:2rem;text-align:center;color:#7f8c8d;background:#f9f9f9;border-radius:8px}.diagnosis-modal.modal-content{background:#fff;border-radius:8px;max-width:560px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.modal-back{background:none;border:none;color:#3498db;cursor:pointer;font-size:.9rem;padding:0 .5rem 0 0;margin-right:.5rem}.modal-back:hover{text-decoration:underline}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #eee;background:#f9f9f9}.modal-header-left{display:flex;align-items:center}.modal-header h3{margin:0;font-size:1.25rem}.modal-body{padding:1.25rem;overflow-y:auto;flex:1}.diagnosis-meta p,.diagnosis-main p{margin:.5rem 0}.diagnosis-section{margin-top:1rem}.diagnosis-section ul{margin:.25rem 0 0 1rem;padding:0}.evidence-pre{background:#f5f5f5;padding:.75rem;border-radius:4px;font-size:.8rem;overflow-x:auto;margin:.25rem 0 0}.confidence-bar-wrap{display:inline-flex;align-items:center;gap:.5rem}.confidence-bar{display:inline-block;height:8px;min-width:4px;background:#27ae60;border-radius:4px}.confidence-text{font-size:.9rem}.modal-footer{padding:1rem 1.25rem;border-top:1px solid #eee;background:#f9f9f9;display:flex;flex-wrap:wrap;align-items:flex-start;gap:1rem}.footer-actions{display:flex;flex-wrap:wrap;gap:1rem;flex:1}.action-group{display:flex;flex-direction:column;gap:.35rem;min-width:200px}.action-group label{font-size:.85rem;color:#555}.action-group textarea{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;resize:vertical}.modal-footer .btn-approve{background:#27ae60;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.modal-footer .btn-approve:hover:not(:disabled){background:#219a52}.modal-footer .btn-reject{background:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.modal-footer .btn-reject:hover:not(:disabled){background:#c0392b}.modal-footer .btn-close{background:#95a5a6;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.modal-footer .btn-close:hover{background:#7f8c8d}.modal-footer .footer-buttons{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.modal-footer .footer-buttons .btn-cancel{padding:.5rem 1.25rem;background:#ecf0f1;color:#2c3e50;border:1px solid #bdc3c7;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500}.modal-footer .footer-buttons .btn-cancel:hover{background:#dfe6e9;border-color:#95a5a6}.modal-footer .footer-buttons .btn-approve-only{padding:.5rem 1.25rem;background:#3498db;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500}.modal-footer .footer-buttons .btn-approve-only:hover:not(:disabled){background:#2980b9}.modal-footer .footer-buttons .btn-approve-only:disabled{opacity:.6;cursor:not-allowed}.modal-footer .footer-buttons .btn-submit{padding:.5rem 1.25rem;background:#27ae60;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500}.modal-footer .footer-buttons .btn-submit:hover:not(:disabled){background:#219a52}.modal-footer .footer-buttons .btn-submit:disabled{opacity:.6;cursor:not-allowed}.approve-sf-overlay{z-index:1100}.approve-sf-modal{max-width:560px;max-height:90vh;overflow-y:auto}.approve-sf-loading{padding:2rem;text-align:center;color:#666}.approve-sf-analysis{margin-bottom:1rem}.approve-sf-analysis h4,.approve-sf-similar h4,.approve-sf-form h4{margin:0 0 .5rem;font-size:.95rem;color:#333}.approve-sf-analysis p{margin:0;font-size:.9rem;color:#555}.approve-sf-similar{margin-bottom:1rem}.approve-sf-similar ul{margin:0;padding-left:1.25rem}.approve-sf-similar li{margin:.35rem 0}.approve-sf-similar a{color:#3498db;text-decoration:none}.approve-sf-similar a:hover{text-decoration:underline}.case-priority{margin-left:.5rem;font-size:.8rem;color:#888}.approve-sf-form{margin-top:1rem}.approve-sf-form .form-row{margin-bottom:.75rem}.approve-sf-form .form-row-group{display:flex;gap:1rem;margin-bottom:.75rem}.approve-sf-form .form-row-group .form-row{flex:1;margin-bottom:0}.approve-sf-form label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.25rem;color:#333}.approve-sf-form input,.approve-sf-form textarea,.approve-sf-form select{width:100%;padding:.5rem .6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;font-family:inherit}.approve-sf-form textarea{resize:vertical}.approve-sf-error{padding:.5rem 0;font-size:.85rem;color:#e74c3c}.approve-sf-modal .footer-buttons{display:flex;gap:.5rem;justify-content:flex-end}.approve-sf-modal .btn-approve-only{padding:.5rem 1rem;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.9rem}.approve-sf-modal .btn-approve-only:hover:not(:disabled){background:#eee}.approve-sf-modal .btn-cancel{padding:.5rem 1rem;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.9rem}.approve-sf-modal .btn-cancel:hover{background:#eee}.approve-sf-modal .btn-submit{padding:.5rem 1rem;background:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.approve-sf-modal .btn-submit:hover:not(:disabled){background:#219a52}.approve-sf-modal .btn-submit:disabled{opacity:.6;cursor:not-allowed}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.loading-spinner{width:40px;height:40px;border:4px solid #e0e0e0;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner-container p{color:#666;font-size:.9rem}.pagination-wrap{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.75rem 0;margin-top:.5rem}.pagination-info{font-size:.9rem;color:#666}.pagination-buttons{display:flex;align-items:center;gap:.25rem}.pagination-btn{min-width:2rem;padding:.35rem .5rem;border:1px solid #ddd;background:#fff;border-radius:4px;font-size:.9rem;cursor:pointer}.pagination-btn:hover:not(:disabled){background:#f0f0f0;border-color:#bbb}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn.active{background:#3498db;border-color:#3498db;color:#fff}.pagination-btn.active:hover{background:#2980b9;border-color:#2980b9}.review-queue-page{width:100%}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h2{font-size:1.5rem;font-weight:600;color:#2c3e50}.filters{display:flex;gap:.75rem;align-items:center}.filters select,.filters input{padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.filters button{padding:.5rem 1rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.filters button:hover{background-color:#2980b9}.alerts-table-wrap{overflow-x:auto;border:1px solid #e0e0e0;border-radius:8px;background:#fff}.alerts-table{width:100%;border-collapse:collapse;font-size:.9rem}.alerts-table th,.alerts-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #eee}.alerts-table th{background:#f5f5f5;font-weight:600;color:#333}.alerts-table-row-clickable{cursor:pointer}.alerts-table tbody tr:hover{background:#fafafa}.alerts-table .link-btn{color:#3498db;text-decoration:none}.alerts-table .link-btn:hover{text-decoration:underline}.badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.badge.severity-warning{background:#f39c12;color:#fff}.badge.severity-critical{background:#e74c3c;color:#fff}.badge:not(.severity-warning):not(.severity-critical){background:#bdc3c7;color:#333}.alerts-table-empty{padding:2rem;text-align:center;color:#7f8c8d;background:#f9f9f9;border-radius:8px}.alert-diagnosis-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.alert-diagnosis-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;width:90%;max-width:720px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid #eee}.modal-header h3{margin:0;font-size:1.1rem}.modal-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:#666;padding:0 .25rem}.modal-close:hover{color:#333}.modal-loading{padding:2rem;text-align:center;color:#666}.modal-alert-summary{display:flex;flex-wrap:wrap;gap:.75rem;padding:.75rem 1.25rem;background:#f5f5f5;font-size:.9rem}.modal-alert-summary .badge{padding:.2rem .5rem;border-radius:4px}.modal-alert-summary .severity-warning{background:#fff3cd;color:#856404}.modal-alert-summary .severity-critical{background:#f8d7da;color:#721c24}.modal-diagnosis-block{padding:1rem 1.25rem;border-bottom:1px solid #eee}.modal-diagnosis-block h4{margin:0 0 .5rem;font-size:.95rem;color:#555}.current-diagnosis p{margin:.35rem 0;font-size:.9rem}.no-diagnosis{color:#888;font-size:.9rem;margin:0}.modal-actions{display:flex;gap:.5rem;padding:.5rem 1.25rem;border-bottom:1px solid #eee}.btn-quick{padding:.4rem .75rem;background:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.btn-quick:hover:not(:disabled){background:#2980b9}.btn-quick:disabled{opacity:.6;cursor:not-allowed}.btn-save{padding:.4rem .75rem;background:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.btn-save:hover:not(:disabled){background:#219a52}.btn-save:disabled{opacity:.6;cursor:not-allowed}.btn-review{padding:.4rem .75rem;background:#9b59b6;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.btn-review:hover:not(:disabled){background:#8e44ad}.btn-review:disabled{opacity:.6;cursor:not-allowed}.modal-badge-in-queue{font-size:.85rem;color:#27ae60;font-weight:500}.modal-chat{flex:1;min-height:200px;display:flex;flex-direction:column;overflow:hidden}.modal-chat-messages{flex:1;overflow-y:auto;padding:.75rem 1.25rem;max-height:280px}.modal-chat-messages .message{margin-bottom:.75rem}.modal-chat-messages .message-role{font-size:.75rem;color:#666;margin-bottom:.2rem}.modal-chat-messages .message-content{font-size:.9rem}.modal-chat-messages .message-content pre{margin:.25rem 0;padding:.5rem;background:#f5f5f5;border-radius:4px;font-size:.8rem;overflow-x:auto;white-space:pre-wrap}.modal-chat-messages .message-steps .step{margin:.35rem 0;padding:.35rem .5rem;background:#f9f9f9;border-radius:4px;font-size:.8rem}.modal-chat-messages .step-label{margin-right:.5rem;color:#666}.modal-chat-messages .step-tool{color:#3498db}.modal-chat-messages .typing-dots .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#999;margin:0 2px;animation:typing 1.4s infinite}.modal-chat-messages .typing-dots .dot:nth-child(2){animation-delay:.2s}.modal-chat-messages .typing-dots .dot:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3}30%{opacity:1}}.modal-chat-error{padding:.5rem 1.25rem;font-size:.85rem;color:#c0392b;background:#fdeaea}.modal-chat-input-wrap{display:flex;gap:.5rem;padding:.75rem 1.25rem;border-top:1px solid #eee;background:#fafafa}.modal-chat-input{flex:1;padding:.5rem .75rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;font-family:inherit;resize:none}.modal-chat-input-wrap .btn-send{padding:.5rem 1rem;background:#3498db;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.modal-chat-input-wrap .btn-send:hover:not(:disabled){background:#2980b9}.modal-chat-input-wrap .btn-send:disabled{opacity:.6;cursor:not-allowed}.alerts-page{width:100%}.page-size-label{display:flex;align-items:center;gap:.35rem;font-size:.9rem;color:#555}.page-size-label select{padding:.4rem .5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.sensor-dashboard{margin-top:1rem}.sensor-dashboard-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;font-size:.85rem;color:#666}.fault-badge,.severity-badge{padding:.2rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.fault-badge{background:#e74c3c;color:#fff}.severity-badge.severity-warning{background:#f39c12;color:#fff}.severity-badge.severity-critical{background:#e74c3c;color:#fff}.sensor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.sensor-card{background:#f9f9f9;border:1px solid #eee;border-radius:8px;padding:1rem;text-align:center}.sensor-label{font-size:.8rem;color:#666;margin-bottom:.35rem}.sensor-value{font-size:1.25rem;font-weight:600;color:#2c3e50}.sensor-unit{font-size:.8rem;font-weight:400;color:#7f8c8d;margin-left:.2rem}.sensor-charts{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #eee}.sensor-charts-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.sensor-charts-header h3{margin:0;font-size:1.1rem;font-weight:600;color:#374151}.time-range-controls{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.time-range-buttons{display:flex;gap:.5rem}.time-range-btn{padding:.4rem .75rem;font-size:.85rem;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#374151;cursor:pointer}.time-range-btn:hover{background:#f3f4f6;border-color:#9ca3af}.time-range-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.time-range-custom{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;justify-content:flex-end}.time-range-custom label{display:flex;align-items:center;gap:.25rem;font-size:.8rem;color:#4b5563}.time-range-custom input[type=datetime-local]{padding:.2rem .4rem;border:1px solid #d1d5db;border-radius:4px;font-size:.8rem}.time-range-custom input[type=datetime-local]:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 1px #2563eb26}.sensor-charts-error{color:#dc2626;font-size:.9rem;padding:1rem}.sensor-charts-empty{color:#6b7280;text-align:center;padding:2rem;font-size:.95rem}.charts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.chart-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1rem;min-height:260px}.chart-title{font-size:.9rem;font-weight:600;color:#374151;margin-bottom:.5rem}.chart-unit{font-size:.8rem;font-weight:400;color:#6b7280;margin-left:.25rem}.asset-selector{display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.asset-selector label{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.asset-selector label span{color:#555}.asset-selector select{padding:.4rem .6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.asset-selector .checkbox-label{cursor:pointer}.asset-selector .checkbox-label input{margin:0}.sensors-page{width:100%}.empty-state{text-align:center;padding:3rem;color:#999;font-size:1.1rem}.chat-layout{display:flex;height:calc(100vh - 120px);min-height:400px;border:1px solid #e0e0e0;border-radius:8px;background:#fff;overflow:hidden}.chat-sessions{width:240px;flex-shrink:0;border-right:1px solid #eee;display:flex;flex-direction:column;background:#f9f9f9}.btn-new-session{margin:.75rem;padding:.5rem 1rem;background:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.btn-new-session:hover{background:#2980b9}.session-list{list-style:none;margin:0;padding:.5rem 0;overflow-y:auto}.session-list-item{display:flex;align-items:center;position:relative}.session-list-item:hover .session-delete-btn{opacity:1}.session-delete-btn{flex-shrink:0;width:24px;height:24px;padding:0;margin-left:.25rem;border:none;background:transparent;color:#999;font-size:1.2rem;line-height:1;cursor:pointer;border-radius:4px;opacity:0;transition:opacity .15s}.session-delete-btn:hover{color:#e74c3c;background:#fdeaea}.session-item{flex:1;display:block;min-width:0;padding:.6rem 1rem;text-align:left;border:none;background:none;cursor:pointer;font-size:.85rem;border-left:3px solid transparent}.session-item:hover{background:#eee}.session-item.active{background:#e8f4fc;border-left-color:#3498db}.session-preview{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#333}.session-date{display:block;font-size:.75rem;color:#888;margin-top:.2rem}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0}.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:1rem 1.25rem;min-width:0}.chat-empty{color:#888;text-align:center;padding:2rem}.message{margin-bottom:1.25rem;max-width:100%}.message-user{display:flex;flex-direction:column;align-items:flex-end}.message-user .message-role{margin-right:.5rem}.message-user .message-content{max-width:min(85%,720px);text-align:right}.message-assistant{display:flex;flex-direction:column;align-items:flex-start;margin-left:1.5rem}.message-assistant .message-role{margin-left:.5rem}.message-assistant .message-content{max-width:min(85%,720px)}.message-role{font-size:.8rem;font-weight:600;color:#666;margin-bottom:.25rem}.message-user .message-content{background:#2563eb;color:#fff;padding:.75rem 1rem;border-radius:12px 12px 4px;display:inline-block;word-break:break-word;overflow-wrap:break-word}.message-assistant .message-content{padding:.5rem 0;word-break:break-word;overflow-wrap:break-word}.message-assistant .message-content p{margin:.5rem 0}.message-loading .message-content{min-height:1.5rem}.message-loading-content{display:flex;align-items:center;padding:.5rem 0}.typing-dots{display:inline-flex;gap:4px;align-items:center}.typing-dots .dot{width:6px;height:6px;border-radius:50%;background:#94a3b8;animation:typing-bounce 1.4s ease-in-out infinite both}.typing-dots .dot:nth-child(1){animation-delay:0s}.typing-dots .dot:nth-child(2){animation-delay:.2s}.typing-dots .dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,80%,to{transform:scale(.6);opacity:.6}40%{transform:scale(1);opacity:1}}.message-steps{margin-top:.5rem;padding-left:.5rem;border-left:3px solid #ddd;max-width:100%;min-width:0}.step{font-size:.8rem;margin-bottom:.6rem;padding:.35rem .5rem;border-radius:6px;border-left:3px solid #ddd}.step-label{font-size:.7rem;font-weight:600;color:#666;margin-right:.5rem}.step-thought{border-left-color:#3498db;background:#f0f8ff}.step-tool_call{border-left-color:#9b59b6;background:#f5eef8}.step-tool_result{border-left-color:#27ae60;background:#eafaf1}.step-tool{display:inline-block;background:#95a5a6;color:#fff;padding:.15rem .4rem;border-radius:3px;margin-right:.5rem}.step-content{margin:.25rem 0 0;white-space:pre-wrap;word-break:break-word;overflow-wrap:break-word;font-size:.8rem;color:#555;max-width:100%}.streaming-steps .message-content{display:none}.chat-error{padding:.5rem 1rem;background:#fdecea;color:#c0392b;font-size:.9rem}.chat-input-wrap{display:flex;gap:.5rem;padding:1rem;border-top:1px solid #eee;background:#f9f9f9}.chat-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;font-family:inherit;resize:none}.chat-input:focus{outline:none;border-color:#3498db}.btn-send{padding:.75rem 1.25rem;background:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;align-self:flex-end}.btn-send:hover:not(:disabled){background:#219a52}.btn-send:disabled{background:#bdc3c7;cursor:not-allowed}.chat-page{width:100%;height:calc(100vh - 80px)}.scenario-list-table-wrap{overflow-x:auto;border:1px solid #e0e0e0;border-radius:8px;background:#fff!important;box-shadow:0 1px 3px #0000000f}.scenario-list-table{width:100%;border-collapse:collapse;font-size:.9rem;background:#fff}.scenario-list-table td{background:#fff}.scenario-list-table th,.scenario-list-table td{padding:.875rem 1.25rem;text-align:left;vertical-align:middle}.scenario-list-table thead{border-bottom:2px solid #e0e0e0}.scenario-list-table th{background:#f5f5f5;font-weight:600;color:#333}.scenario-list-table tbody tr{border-bottom:1px solid #eee}.scenario-list-table tbody tr:last-child{border-bottom:none}.scenario-list-table tbody tr:hover td{background:#f8f9fa}.scenario-list-table .badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500}.badge.status-running{background:#27ae60;color:#fff}.badge.status-stopped{background:#95a5a6;color:#fff}.progress-wrap{display:flex;align-items:center;gap:.5rem}.progress-bar{height:8px;min-width:4px;background:#3498db;border-radius:4px;max-width:80px}.progress-text{font-size:.85rem;color:#666}.scenario-list-table .action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.scenario-list-table .action-buttons button{padding:.35rem .75rem;border:none;border-radius:4px;font-size:.85rem;cursor:pointer}.btn-start{background:#27ae60;color:#fff}.btn-start:hover{background:#219a52}.btn-stop{background:#e74c3c;color:#fff}.btn-stop:hover{background:#c0392b}.btn-reset{background:#95a5a6;color:#fff}.btn-reset:hover{background:#7f8c8d}.scenario-list-empty{padding:2rem;text-align:center;color:#7f8c8d;background:#f9f9f9;border-radius:8px}.load-scenario-modal.modal-content{background:#fff;border-radius:8px;max-width:560px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.load-scenario-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #eee;background:#f9f9f9}.load-scenario-modal .modal-header h3{margin:0;font-size:1.25rem}.load-scenario-modal .modal-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:#666;padding:0 .25rem}.load-scenario-modal .modal-close:hover{color:#333}.load-scenario-modal .modal-body{padding:1rem 1.25rem;overflow-y:auto}.load-scenario-modal .template-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.load-scenario-modal .template-row label{font-size:.9rem;font-weight:500;color:#333;flex-shrink:0}.load-scenario-modal .template-row select{flex:1;max-width:280px;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background:#fff}.load-scenario-modal .hint{font-size:.85rem;color:#666;margin-bottom:.75rem}.load-scenario-modal .hint code{background:#f0f0f0;padding:.1rem .3rem;border-radius:3px;font-size:.8rem}.scenario-json-input{width:100%;min-height:200px;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-family:monospace;font-size:.85rem;resize:vertical;box-sizing:border-box}.modal-error{margin-top:.75rem;padding:.5rem;background:#fdecea;color:#c0392b;border-radius:4px;font-size:.9rem}.load-scenario-modal .modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid #eee;background:#f9f9f9}.load-scenario-modal .btn-cancel{padding:.5rem 1rem;background:#95a5a6;color:#fff;border:none;border-radius:4px;cursor:pointer}.load-scenario-modal .btn-primary{padding:.5rem 1rem;background:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer}.load-scenario-modal .btn-primary:hover{background:#2980b9}.trigger-alert-modal.modal-content{background:#fff;border-radius:8px;max-width:420px;width:100%;box-shadow:0 4px 20px #00000026}.trigger-alert-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid #eee;background:#f9f9f9}.trigger-alert-modal .modal-header h3{margin:0;font-size:1.25rem}.trigger-alert-modal .modal-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:#666;padding:0 .25rem}.trigger-alert-modal .modal-close:hover{color:#333}.trigger-alert-modal .modal-body{padding:1rem 1.25rem}.trigger-alert-modal .form-row{margin-bottom:1rem}.trigger-alert-modal .form-row label{display:block;font-size:.9rem;margin-bottom:.35rem;color:#333}.trigger-alert-modal .form-row input,.trigger-alert-modal .form-row select{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;box-sizing:border-box}.trigger-alert-modal .modal-footer{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid #eee;background:#f9f9f9}.trigger-alert-modal .btn-cancel{padding:.5rem 1rem;background:#95a5a6;color:#fff;border:none;border-radius:4px;cursor:pointer}.trigger-alert-modal .btn-primary{padding:.5rem 1rem;background:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer}.trigger-alert-modal .btn-primary:hover{background:#c0392b}.create-rule-modal.modal-content{max-width:520px;width:100%;background:#fff!important;border-radius:8px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column}.create-rule-modal .modal-header{padding:1rem 1.25rem;border-bottom:1px solid #eee;background:#f9f9f9}.create-rule-modal .modal-header h3{margin:0;font-size:1.25rem}.create-rule-modal .modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.create-rule-modal .modal-body{padding:1.25rem;background:#fff}.create-rule-modal .mode-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.create-rule-modal .mode-tabs button{padding:.5rem 1rem;border:1px solid #ddd;background:#f9f9f9;color:#333;border-radius:6px;cursor:pointer;font-size:.9rem}.create-rule-modal .mode-tabs button.active{background:#3498db;color:#fff;border-color:#3498db}.create-rule-modal .hint{margin:0 0 .75rem;font-size:.9rem;color:#555}.create-rule-modal .rule-text-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;font-family:inherit;resize:vertical;min-height:120px;background:#fff}.create-rule-modal .file-upload{margin-top:.5rem}.create-rule-modal .file-upload input[type=file]{display:none}.create-rule-modal .file-upload .file-label{display:inline-block;padding:.75rem 1rem;border:2px dashed #bdc3c7;border-radius:6px;cursor:pointer;font-size:.9rem;color:#555;transition:border-color .2s}.create-rule-modal .file-upload .file-label:hover{border-color:#3498db;color:#3498db}.create-rule-modal .modal-error{margin-top:1rem;padding:.5rem;background:#fee;color:#c0392b;border-radius:4px;font-size:.9rem}.create-rule-modal .modal-footer{padding:1rem 1.25rem;border-top:1px solid #eee;background:#fff;display:flex;justify-content:flex-end;gap:.75rem;border-radius:0 0 8px 8px}.create-rule-modal .btn-cancel{padding:.5rem 1rem;background:#ecf0f1;border:1px solid #bdc3c7;border-radius:6px;cursor:pointer;font-size:.9rem}.create-rule-modal .btn-primary{padding:.5rem 1.25rem;background:#27ae60;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.9rem}.create-rule-modal .btn-primary:hover:not(:disabled){background:#219a52}.create-rule-modal .btn-primary:disabled{opacity:.6;cursor:not-allowed}.view-rule-modal.modal-content{max-width:560px;width:100%;max-height:80vh;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column}.view-rule-modal .modal-header{padding:1rem 1.25rem;border-bottom:1px solid #eee;background:#f9f9f9;display:flex;justify-content:space-between;align-items:center}.view-rule-modal .modal-header h3{margin:0;font-size:1.25rem}.view-rule-modal .modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.view-rule-modal .modal-body{padding:1.25rem;overflow-y:auto;background:#fff}.view-rule-modal .view-rule-loading{padding:2rem;text-align:center;color:#666}.view-rule-modal .view-rule-error{padding:1rem;background:#fee;color:#c0392b;border-radius:6px}.view-rule-modal .view-rule-content{margin:0;padding:1rem;background:#f8f9fa;border:1px solid #eee;border-radius:6px;font-size:.9rem;font-family:ui-monospace,Consolas,monospace;white-space:pre-wrap;word-break:break-word;overflow-x:auto}.rules-list-table-wrap{overflow-x:auto;border:1px solid #e0e0e0;border-radius:8px;background:#fff!important;box-shadow:0 1px 3px #0000000f}.rules-list-table{width:100%;border-collapse:collapse;font-size:.9rem;background:#fff}.rules-list-table td{background:#fff}.rules-list-table th,.rules-list-table td{padding:.875rem 1.25rem;text-align:left;vertical-align:middle}.rules-list-table thead{border-bottom:2px solid #e0e0e0}.rules-list-table th{background:#f5f5f5;font-weight:600;color:#333;white-space:nowrap}.rules-list-table th:nth-child(1){min-width:180px}.rules-list-table th:nth-child(2){min-width:140px}.rules-list-table th:nth-child(3){min-width:140px}.rules-list-table tbody tr{border-bottom:1px solid #eee}.rules-list-table tbody tr:last-child{border-bottom:none}.rules-list-table tbody tr:hover td{background:#f8f9fa}.rules-list-table code{font-size:.85rem;background:#f0f0f0;padding:.25rem .5rem;border-radius:4px;font-family:ui-monospace,monospace}.rules-list-table .action-buttons{display:flex;gap:.5rem}.rules-list-table .btn-view{padding:.4rem .85rem;background:#3498db;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:background .2s}.rules-list-table .btn-view:hover{background:#2980b9}.rules-list-table .btn-delete{padding:.4rem .85rem;background:#fff;border:1px solid #e74c3c;color:#e74c3c;border-radius:6px;cursor:pointer;font-size:.85rem;transition:background .2s,color .2s}.rules-list-table .btn-delete:hover{background:#e74c3c;color:#fff}.rules-list-empty{padding:2.5rem 2rem;text-align:center;background:#f9f9f9;border-radius:8px;border:1px dashed #ddd}.rules-list-empty p{margin:.5rem 0;color:#555;line-height:1.5}.rules-list-empty .hint{font-size:.9rem;color:#888;margin-top:.5rem}.rules-list-empty .path-hint{margin-top:1rem;font-size:.85rem}.rules-list-empty .path-hint code{background:#eee;padding:.15rem .4rem;border-radius:4px;font-size:.8rem}.scenarios-page{width:100%}.page-header{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem}.page-header h2{margin:0}.page-tabs{display:flex;gap:.25rem}.page-tabs button{padding:.5rem 1rem;border:1px solid #ddd;background:#f9f9f9;border-radius:6px;cursor:pointer;font-size:.9rem}.page-tabs button.active{background:#3498db;color:#fff;border-color:#3498db}.actions{display:flex;gap:.75rem;margin-left:auto}.btn-primary{padding:.5rem 1rem;background-color:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.btn-primary:hover{background-color:#229954}.btn-secondary{padding:.5rem 1rem;background-color:#e67e22;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.btn-secondary:hover{background-color:#d35400}.btn-refresh{padding:.5rem 1rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.btn-refresh:hover{background-color:#2980b9}*{margin:0;padding:0;box-sizing:border-box}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-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{width:100%;height:100vh}.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;padding:1rem}
