.processing-management-view{background:#1a1a2e;border-radius:12px;padding:1.5rem;min-height:400px}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #333;flex-wrap:wrap;gap:1rem}.view-header h2{margin:0;font-size:1.25rem;color:#fff}.instance-info{color:#888;font-size:.875rem}.instance-info strong{color:#646cff}.connection-status{display:flex;align-items:center;gap:.5rem}.status-indicator{width:10px;height:10px;border-radius:50%;background:#666}.status-indicator.disconnected{background:#666}.status-indicator.connecting{background:#f0ad4e;animation:pulse 1s infinite}.status-indicator.connected{background:#5cb85c}.status-indicator.error{background:#d9534f}.status-text{font-size:.875rem;color:#888;text-transform:capitalize}.connection-form{display:flex;flex-direction:column;gap:1rem;max-width:400px;margin:2rem auto}.connection-form input{padding:.75rem 1rem;font-size:1rem;border-radius:8px;border:1px solid #444;background:#2a2a3e;color:#fff}.connection-form input:focus{outline:none;border-color:#646cff}.connect-btn{padding:.75rem 1.5rem;font-size:1rem;border-radius:8px;border:none;background:#646cff;color:#fff;cursor:pointer;transition:background .2s}.connect-btn:hover:not(:disabled){background:#535bf2}.connect-btn:disabled{opacity:.6;cursor:not-allowed}.global-controls{display:flex;gap:1rem;margin-bottom:1.5rem;justify-content:center}.global-toggle-btn{padding:.75rem 1.5rem;font-size:1rem;border-radius:8px;border:none;cursor:pointer;transition:all .2s}.global-toggle-btn.processing{background:#f0ad4e;color:#000}.global-toggle-btn.processing:hover:not(:disabled){background:#ec971f}.global-toggle-btn.paused{background:#5cb85c;color:#fff}.global-toggle-btn.paused:hover:not(:disabled){background:#449d44}.global-toggle-btn:disabled{opacity:.6;cursor:not-allowed}.disconnect-btn{padding:.75rem 1.5rem;font-size:1rem;border-radius:8px;border:1px solid #d9534f;background:transparent;color:#d9534f;cursor:pointer;transition:all .2s}.disconnect-btn:hover:not(:disabled){background:#d9534f;color:#fff}.disconnect-btn:disabled{opacity:.6;cursor:not-allowed}.streams-list{display:flex;flex-direction:column;gap:.75rem}.no-streams{text-align:center;color:#666;padding:2rem;font-style:italic}.stream-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#2a2a3e;border-radius:8px;border-left:4px solid #666;transition:all .2s}.stream-card.active{border-left-color:#5cb85c}.stream-card.paused{border-left-color:#f0ad4e;opacity:.8}.stream-info{display:flex;align-items:center;gap:1rem}.stream-icon{font-size:1.5rem}.stream-icon .stream-muted{color:#e74c3c}.stream-details{display:flex;flex-direction:column}.stream-id{font-weight:500;color:#fff}.stream-type{font-size:.75rem;color:#888;text-transform:uppercase}.stream-controls{display:flex;align-items:center;gap:1rem}.stream-status-badges{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem}.connection-badge{display:flex;align-items:center;gap:.375rem;padding:.2rem .6rem;font-size:.7rem;border-radius:10px;text-transform:uppercase;font-weight:500}.connection-badge.connected{background:#5cb85c26;color:#5cb85c}.connection-badge.connecting{background:#646cff26;color:#646cff}.connection-badge.disconnected{background:#66666626;color:#888}.connection-badge.failed{background:#d9534f26;color:#d9534f}.connection-indicator{width:6px;height:6px;border-radius:50%}.connection-indicator.connected{background:#5cb85c}.connection-indicator.connecting{background:#646cff;animation:pulse 1s infinite}.connection-indicator.disconnected{background:#666}.connection-indicator.failed{background:#d9534f}.state-badge{padding:.25rem .75rem;font-size:.75rem;border-radius:12px;text-transform:uppercase;font-weight:500}.state-badge.active{background:#5cb85c33;color:#5cb85c}.state-badge.paused{background:#f0ad4e33;color:#f0ad4e}.toggle-btn{width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;font-size:1rem;transition:all .2s}.toggle-btn.pause{background:#f0ad4e;color:#000}.toggle-btn.pause:hover:not(:disabled){background:#ec971f}.toggle-btn.resume{background:#5cb85c;color:#fff}.toggle-btn.resume:hover:not(:disabled){background:#449d44}.toggle-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:.75rem 1rem;background:#d9534f33;border:1px solid #d9534f;border-radius:8px;color:#d9534f}.dismiss-btn{background:none;border:none;color:#d9534f;font-size:1.25rem;cursor:pointer;padding:0;line-height:1}.dismiss-btn:hover{color:#fff}.waiting-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:3rem 1rem}.waiting-message{display:flex;align-items:center;gap:1rem;font-size:1.1rem;color:#888}.waiting-spinner{width:20px;height:20px;border:2px solid #444;border-top-color:#646cff;border-radius:50%;animation:spin 1s linear infinite}.monitor-btn{width:40px;height:40px;border-radius:50%;border:1px solid #555;background:transparent;cursor:pointer;font-size:1rem;transition:all .2s;opacity:.6;display:flex;align-items:center;justify-content:center;padding:0}.monitor-btn:hover{opacity:1;border-color:#646cff}.monitor-btn.active{background:#646cff33;border-color:#646cff;opacity:1}.stream-preview{position:relative;width:120px;flex-shrink:0;border-radius:6px;overflow:hidden;background:#111;cursor:pointer;transition:width .25s ease}.stream-preview.expanded{width:480px}.stream-preview:hover{outline:2px solid #646cff;outline-offset:2px}.stream-video{width:100%;display:block;border-radius:6px}.stream-paused-badge{position:absolute;top:4px;right:6px;font-size:.6rem;color:#f0ad4e;background:#000000b3;padding:1px 6px;border-radius:3px;z-index:1}.stream-preview-placeholder{padding:.75rem;text-align:center;color:#666;font-size:.75rem;font-style:italic}.context-management-view{background:#1a1a2e;border-radius:12px;padding:1.5rem;min-height:400px}.context-management-view .view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #333}.context-management-view .view-header h2{margin:0;font-size:1.25rem;color:#fff}.context-management-view .sub-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid #333;padding-bottom:.75rem}.context-management-view .sub-tab{padding:.5rem 1rem;font-size:.875rem;border:none;background:transparent;color:#888;cursor:pointer;border-radius:6px 6px 0 0;transition:all .2s;position:relative}.context-management-view .sub-tab:hover{color:#fff;background:#646cff1a}.context-management-view .sub-tab.active{color:#646cff;background:#646cff26}.context-management-view .sub-tab.active:after{content:"";position:absolute;bottom:-.75rem;left:0;right:0;height:2px;background:#646cff}.context-management-view .section{margin-bottom:2rem;padding:1.25rem;background:#2a2a3e;border-radius:8px}.context-management-view .section h3{margin:0 0 1rem;font-size:1rem;color:#888;text-transform:uppercase;letter-spacing:.5px}.current-time-display{background:#1a1a2e;border-radius:8px;padding:1rem;margin-bottom:1rem}.time-info-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0}.time-info-row:not(:last-child){border-bottom:1px solid #333}.time-label{color:#888;font-size:.875rem}.time-value{color:#fff;font-weight:500}.time-of-day-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase}.time-of-day-badge.morning{background:#ffc10733;color:#ffc107}.time-of-day-badge.afternoon{background:#ff980033;color:#ff9800}.time-of-day-badge.evening{background:#9c27b033;color:#9c27b0}.time-of-day-badge.night{background:#3f51b533;color:#3f51b5}.time-mode-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500}.time-mode-badge.virtual{background:#646cff33;color:#646cff}.time-mode-badge.system{background:#5cb85c33;color:#5cb85c}.time-controls{display:flex;flex-direction:column;gap:1rem}.time-input-group{display:flex;flex-direction:column;gap:.5rem}.time-input-group label{color:#888;font-size:.875rem}.time-input-group input{padding:.75rem 1rem;font-size:1rem;border-radius:8px;border:1px solid #444;background:#1a1a2e;color:#fff}.time-input-group input:focus{outline:none;border-color:#646cff}.time-buttons{display:flex;gap:.75rem}.set-time-btn,.clear-time-btn{flex:1;padding:.75rem 1rem;font-size:.875rem;border-radius:8px;border:none;cursor:pointer;transition:all .2s}.set-time-btn{background:#646cff;color:#fff}.set-time-btn:hover:not(:disabled){background:#535bf2}.clear-time-btn{background:transparent;border:1px solid #666;color:#888}.clear-time-btn:hover:not(:disabled){border-color:#888;color:#fff}.set-time-btn:disabled,.clear-time-btn:disabled{opacity:.5;cursor:not-allowed}.upload-controls{display:flex;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.file-input{display:none}.upload-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;border-radius:8px;border:2px dashed #444;background:transparent;color:#888;cursor:pointer;transition:all .2s}.upload-btn:hover{border-color:#646cff;color:#646cff}.upload-btn.folder-btn{border-color:#646cff;color:#646cff;background:#646cff1a}.upload-btn.folder-btn:hover{background:#646cff33}.upload-btn.secondary{border-style:dotted;font-size:.8rem;padding:.5rem 1rem}.upload-method-hint{margin:0 0 1rem;color:#666;font-size:.75rem;font-style:italic}.uploaded-files{margin-bottom:1rem}.files-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;color:#888;font-size:.875rem}.files-list{display:flex;flex-direction:column;gap:.5rem}.file-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#1a1a2e;border-radius:8px;border-left:3px solid #666}.file-item.valid{border-left-color:#5cb85c}.file-item.invalid{border-left-color:#d9534f}.file-info{display:flex;align-items:center;gap:.75rem}.file-icon{font-size:1rem}.file-details{display:flex;flex-direction:column}.file-name{color:#fff;font-weight:500;font-size:.875rem}.file-meta{color:#666;font-size:.75rem}.file-error{color:#d9534f}.remove-file-btn{background:none;border:none;color:#666;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;line-height:1;transition:color .2s}.remove-file-btn:hover:not(:disabled){color:#d9534f}.remove-file-btn:disabled{opacity:.5;cursor:not-allowed}.reset-controls{display:flex;flex-direction:column;gap:.5rem}.reset-btn{padding:.75rem 1.5rem;font-size:1rem;border-radius:8px;border:none;background:#f0ad4e;color:#000;cursor:pointer;transition:all .2s}.reset-btn:hover:not(:disabled){background:#ec971f}.reset-btn:disabled{opacity:.5;cursor:not-allowed}.reset-hint{margin:0;color:#666;font-size:.75rem;font-style:italic}.context-management-view .waiting-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:3rem 1rem}.context-management-view .waiting-message{display:flex;align-items:center;gap:1rem;font-size:1.1rem;color:#888}.context-management-view .waiting-spinner{width:20px;height:20px;border:2px solid #444;border-top-color:#646cff;border-radius:50%;animation:spin 1s linear infinite}.context-management-view .progress-message{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem 1rem;background:#646cff26;border:1px solid rgba(100,108,255,.4);border-radius:8px;color:#a0a8ff;font-size:.875rem}.context-management-view .progress-spinner{font-size:18px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.context-management-view .success-message{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:.75rem 1rem;background:#5cb85c33;border:1px solid #5cb85c;border-radius:8px;color:#5cb85c}.context-management-view .error-message{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:.75rem 1rem;background:#d9534f33;border:1px solid #d9534f;border-radius:8px;color:#d9534f}.context-management-view .dismiss-btn{background:none;border:none;color:inherit;font-size:1.25rem;cursor:pointer;padding:0;line-height:1;opacity:.7}.context-management-view .dismiss-btn:hover{opacity:1}.manifest-info{background:#1a1a2e;border-radius:8px;padding:1rem;margin-bottom:1rem;border-left:3px solid #646cff}.manifest-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.manifest-icon{font-size:1.25rem}.manifest-name{color:#fff;font-weight:600;font-size:1rem}.manifest-version{color:#888;font-size:.75rem;background:#333;padding:.125rem .5rem;border-radius:4px}.manifest-description{color:#888;font-size:.875rem;margin:.5rem 0;line-height:1.4}.manifest-files-status{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.75rem;border-top:1px solid #333;font-size:.875rem;color:#888}.manifest-files-status .complete{color:#5cb85c}.manifest-files-status .incomplete{color:#f0ad4e}.missing-files-warning{display:flex;gap:.75rem;padding:.75rem 1rem;background:#f0ad4e26;border:1px solid rgba(240,173,78,.3);border-radius:8px;margin-bottom:1rem}.warning-icon{font-size:1rem}.warning-content{flex:1}.warning-title{color:#f0ad4e;font-size:.875rem;font-weight:500}.missing-files-list{margin:.5rem 0 0;padding-left:1.25rem;color:#888;font-size:.8rem}.missing-files-list li{margin:.25rem 0}.extra-files-notice{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#646cff1a;border-radius:6px;margin-bottom:1rem;font-size:.8rem;color:#888}.notice-icon{font-size:.875rem}.file-item.manifest{border-left-color:#646cff;background:#646cff1a}.file-type-badge{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;font-size:.65rem;font-weight:500;text-transform:uppercase;background:#646cff;color:#fff;border-radius:4px}.upload-actions{display:flex;flex-direction:column;gap:.5rem}.upload-snapshot-btn{padding:.75rem 1.5rem;font-size:1rem;border-radius:8px;border:none;background:#646cff;color:#fff;cursor:pointer;transition:all .2s}.upload-snapshot-btn:hover:not(:disabled){background:#535bf2}.upload-snapshot-btn:disabled{opacity:.5;cursor:not-allowed}.upload-hint{margin:0;color:#666;font-size:.75rem;font-style:italic}.load-snapshot-section{margin-top:1rem}.no-snapshots{color:#666;font-style:italic;text-align:center;padding:1rem}.snapshot-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem;max-height:200px;overflow-y:auto}.snapshot-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#1a1a2e;border-radius:8px;border-left:3px solid #646cff}.snapshot-info{flex:1}.snapshot-name{color:#fff;font-weight:500}.snapshot-version{margin-left:.5rem;color:#888;font-size:.75rem}.snapshot-description{margin:.25rem 0 0;color:#666;font-size:.8rem}.snapshot-actions{display:flex;gap:.5rem}.activate-btn{padding:.375rem .75rem;font-size:.8rem;border-radius:6px;border:none;background:#5cb85c;color:#fff;cursor:pointer;transition:all .2s}.activate-btn:hover:not(:disabled){background:#4cae4c}.activate-btn.enabled{background:#5cb85c;cursor:pointer}.activate-btn.enabled:hover{background:#4cae4c}.activate-btn.disabled-processing{background:#666;color:#999;cursor:not-allowed}.activate-btn:disabled{opacity:.6;cursor:not-allowed}.icon-btn{width:28px;height:28px;padding:0;border-radius:6px;border:1px solid #555;background:transparent;color:#ccc;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}.icon-btn .material-icons{font-size:18px}.icon-btn.view-btn:hover:not(:disabled){border-color:#646cff;color:#646cff}.icon-btn.download-btn:hover:not(:disabled){border-color:#5cb85c;color:#5cb85c}.icon-btn.delete-btn:hover:not(:disabled){border-color:#d9534f;color:#d9534f}.icon-btn:disabled{opacity:.5;cursor:not-allowed}.btn-icon{font-size:18px;vertical-align:middle;margin-right:.25rem}.badge-icon{font-size:14px;vertical-align:middle;margin-right:.25rem}.status-icon{font-size:16px;vertical-align:middle;margin-right:.25rem}.load-hint{margin:.5rem 0 0;padding:.5rem .75rem;color:#f0ad4e;font-size:.8rem;font-style:normal;background:#f0ad4e26;border-left:3px solid #f0ad4e;border-radius:4px}.create-snapshot-btn{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.5rem 1rem;font-size:.875rem;border-radius:6px;border:none;background:#5cb85c;color:#fff;cursor:pointer;transition:all .2s}.create-snapshot-btn:hover:not(:disabled){background:#4cae4c}.create-snapshot-btn.enabled{background:#5cb85c;cursor:pointer}.create-snapshot-btn.enabled:hover{background:#4cae4c}.create-snapshot-btn.disabled-processing{background:#666;color:#999;cursor:not-allowed}.create-snapshot-btn:disabled{opacity:.6;cursor:not-allowed}.context-management-view .sub-tab.monitoring-tab{margin-left:auto;display:inline-flex;align-items:center;gap:4px;border:none;background:#5cb85c;color:#fff}.context-management-view .sub-tab.monitoring-tab:hover{background:#4cae4c}.context-management-view .sub-tab.monitoring-tab.active{background:#666;color:#999;cursor:default}.scenario-view{padding:1rem}.scenario-view .view-header{margin-bottom:1.5rem}.scenario-view .view-header h2{margin:0;color:var(--text-primary, #e0e0e0)}.scenario-view .waiting-section{display:flex;justify-content:center;padding:3rem}.scenario-view .waiting-message{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary, #888);font-size:1rem}.scenario-view .waiting-spinner{width:20px;height:20px;border:2px solid var(--border-color, #333);border-top-color:var(--accent-color, #646cff);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.scenario-loader{text-align:center;padding:3rem 1rem}.loader-content{max-width:400px;margin:0 auto}.loader-icon{font-size:3rem;margin-bottom:1rem}.loader-content h3{margin:0 0 .5rem;color:var(--text-primary, #e0e0e0)}.loader-content p{color:var(--text-secondary, #888);margin-bottom:1.5rem}.scenario-loader .file-input{display:none}.scenario-loader .upload-btn{display:inline-block;padding:.75rem 1.5rem;background:var(--accent-color, #646cff);color:#fff;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.scenario-loader .upload-btn:hover{background:var(--accent-hover, #535bf2)}.scenario-loader .upload-btn.secondary{background:#646cff26;color:#a0a8ff;border:1px solid rgba(100,108,255,.3);font-size:.8rem;padding:.5rem 1rem}.scenario-loader .upload-btn.secondary:hover{background:#646cff40}.enrollment-upload{margin-top:1rem;padding-top:1rem;padding-bottom:1rem;margin-bottom:1rem;border-top:1px solid rgba(255,255,255,.1)}.enrollment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.enrollment-header h4{margin:0}.enrollment-hint{color:var(--text-secondary, #888);font-size:.8rem;margin-bottom:.75rem}.enrollment-warning{padding:.5rem .75rem;background:#ffc1071f;border:1px solid rgba(255,193,7,.35);border-radius:6px;color:#ffc107;font-size:.85rem;font-weight:500;margin-bottom:.5rem}.actor-enrollment-list{display:flex;flex-direction:column;gap:.5rem}.actor-enrollment-row{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#ffffff08;border-radius:6px;border:1px solid rgba(255,255,255,.06);flex-wrap:wrap}.actor-enrollment-name{min-width:80px;font-weight:500;color:var(--text-primary, #e0e0e0);font-size:.85rem}.actor-enrollment-files{flex:1;display:flex;flex-wrap:wrap;gap:.25rem;min-width:100px}.actor-file-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;background:#646cff26;color:#a0a8ff;border-radius:4px;font-size:.7rem;font-family:monospace}.actor-file-remove{background:none;border:none;color:#a0a8ff;cursor:pointer;font-size:.8rem;padding:0;line-height:1;opacity:.6}.actor-file-remove:hover{opacity:1;color:#d9534f}.actor-file-none{color:var(--text-secondary, #666);font-size:.75rem;font-style:italic}.actor-enrollment-actions{display:flex;gap:.25rem}.upload-btn.secondary.small{padding:.25rem .5rem;font-size:.7rem}.scenario-loader .upload-btn.secondary.matched,.scene-selector .upload-btn.secondary.matched{background:#5cb85c26;color:#5cb85c;border-color:#5cb85c4d}.enrollment-upload-action{margin-top:.75rem;display:flex;flex-direction:column;gap:.5rem}.upload-enrollments-btn{padding:.5rem 1rem;background:var(--accent-color, #646cff);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:.85rem;transition:background .2s;align-self:flex-start}.upload-enrollments-btn:hover:not(:disabled){background:var(--accent-hover, #535bf2)}.upload-enrollments-btn:disabled{opacity:.5;cursor:not-allowed}.upload-progress{display:flex;flex-direction:column;gap:.25rem}.upload-progress-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.upload-progress-fill{height:100%;background:var(--accent-color, #646cff);border-radius:3px;transition:width .2s ease}.upload-progress-text{font-size:.75rem;color:var(--text-secondary, #888)}.validation-errors,.validation-warnings{max-width:600px;margin:1.5rem auto 0;text-align:left;padding:1rem;border-radius:8px}.validation-errors{background:#dc35451a;border:1px solid rgba(220,53,69,.3)}.validation-warnings{background:#ffc1071a;border:1px solid rgba(255,193,7,.3)}.validation-errors h4,.validation-warnings h4{margin:0 0 .75rem;font-size:.875rem}.validation-errors h4{color:#dc3545}.validation-warnings h4{color:#ffc107}.validation-errors ul,.validation-warnings ul{margin:0;padding:0;list-style:none}.error-item,.warning-item{display:flex;flex-direction:column;gap:.25rem;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.error-item:last-child,.warning-item:last-child{border-bottom:none}.error-path,.warning-path{font-family:monospace;font-size:.75rem;color:var(--text-secondary, #888)}.error-msg{color:#dc3545}.warning-msg{color:#ffc107}.scene-selector{max-width:800px}.scenario-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #333)}.scenario-info h3{margin:0 0 .5rem;color:var(--text-primary, #e0e0e0)}.scenario-description{color:var(--text-secondary, #888);margin:0 0 .75rem}.scenario-tags{display:flex;gap:.5rem;flex-wrap:wrap}.tag{padding:.25rem .5rem;background:#646cff33;color:var(--accent-color, #646cff);border-radius:4px;font-size:.75rem}.unload-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color, #333);color:var(--text-secondary, #888);border-radius:6px;cursor:pointer;transition:all .2s}.unload-btn:hover{border-color:#dc3545;color:#dc3545}.environment-summary{margin-bottom:1.5rem;padding:1rem;background:var(--surface-color, #2a2a3e);border-radius:8px}.environment-summary h4{margin:0 0 .75rem;color:var(--text-primary, #e0e0e0);font-size:.875rem}.spaces-list{display:flex;gap:.5rem;flex-wrap:wrap}.space-badge{padding:.25rem .75rem;background:#ffffff1a;border-radius:4px;font-size:.8rem;color:var(--text-secondary, #888)}.scenes-list h4{margin:0 0 1rem;color:var(--text-primary, #e0e0e0)}.scene-card{display:flex;flex-direction:column;padding:1rem;background:var(--surface-color, #2a2a3e);border-radius:8px;margin-bottom:.75rem;transition:background .2s}.scene-card:hover{background:var(--surface-hover, #3a3a4e)}.scene-info{display:flex;align-items:flex-start;gap:1rem;flex:1;min-width:0}.scene-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--accent-color, #646cff);color:#fff;border-radius:50%;font-size:.875rem;font-weight:600;flex-shrink:0}.scene-details{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.scene-name{font-weight:500;color:var(--text-primary, #e0e0e0)}.scene-card .scene-description{font-size:.8rem;color:var(--text-secondary, #888);margin:0}.scene-meta{display:flex;gap:.75rem;font-size:.75rem;color:var(--text-secondary, #888)}.time-badge{padding:.125rem .5rem;background:#ffc10733;color:#ffc107;border-radius:4px;text-transform:capitalize}.start-scene-btn{padding:.5rem 1rem;background:var(--accent-color, #646cff);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s;align-self:center;flex-shrink:0;white-space:nowrap}.start-scene-btn:hover:not(:disabled){background:var(--accent-hover, #535bf2)}.start-scene-btn:disabled{opacity:.5;cursor:not-allowed}.scene-executor{max-width:800px}.scene-executor.bootstrapping{display:flex;justify-content:center;padding:3rem}.bootstrap-status{text-align:center}.bootstrap-spinner{display:inline-block;width:40px;height:40px;border:3px solid var(--border-color, #333);border-top-color:var(--accent-color, #646cff);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.bootstrap-status h3{margin:0 0 .5rem;color:var(--text-primary, #e0e0e0)}.bootstrap-status p{color:var(--text-secondary, #888);margin:0}.awaiting-streams{margin-top:1rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}.stream-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem}.stream-badge.pending{background:#ffc10733;color:#ffc107}.abort-scene-btn{margin-top:1.25rem;padding:.5rem 1.25rem;border-radius:8px;border:1px solid #d9534f;background:transparent;color:#d9534f;cursor:pointer;font-size:.875rem;transition:all .2s}.abort-scene-btn:hover{background:#d9534f;color:#fff}.scene-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #333)}.scene-title{display:flex;align-items:center;gap:1rem}.scene-title .scene-number{font-size:.75rem;color:var(--text-secondary, #888);background:none;width:auto;height:auto}.scene-title h3{margin:0;color:var(--text-primary, #e0e0e0)}.end-scene-btn{padding:.5rem 1rem;background:transparent;border:1px solid #dc3545;color:#dc3545;border-radius:6px;cursor:pointer;transition:all .2s}.end-scene-btn:hover:not(:disabled){background:#dc35451a}.actors-panel{margin-bottom:1.5rem;padding:1rem;background:var(--surface-color, #2a2a3e);border-radius:8px}.actors-panel h4{margin:0 0 .75rem;font-size:.875rem;color:var(--text-secondary, #888)}.actors-list{display:flex;gap:.75rem;flex-wrap:wrap}.actor-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff0d;border-radius:6px}.actor-icon{font-size:1.25rem}.actor-name{font-weight:500;color:var(--text-primary, #e0e0e0)}.actor-location{font-size:.75rem;color:var(--text-secondary, #888);padding:.125rem .375rem;background:#ffffff1a;border-radius:4px}.exploratory-mode{text-align:center;padding:3rem;background:var(--surface-color, #2a2a3e);border-radius:8px}.exploratory-icon{font-size:3rem;margin-bottom:1rem}.exploratory-mode h4{margin:0 0 .5rem;color:var(--text-primary, #e0e0e0)}.exploratory-mode p{color:var(--text-secondary, #888);margin:0}.step-progress{display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.75rem;background:var(--surface-color, #2a2a3e);border-radius:8px;flex-wrap:wrap}.progress-dot{width:12px;height:12px;border-radius:50%;background:var(--border-color, #333);transition:all .2s}.progress-dot.current{transform:scale(1.3);box-shadow:0 0 0 3px #646cff4d}.progress-dot.pending{background:var(--border-color, #333)}.progress-dot.active{background:var(--accent-color, #646cff)}.progress-dot.passed{background:#28a745}.progress-dot.failed{background:#dc3545}.progress-dot.skipped{background:#6c757d}.progress-dot.timeout{background:#ffc107}.step-display{padding:1.5rem;background:var(--surface-color, #2a2a3e);border-radius:8px;margin-bottom:1rem;border-left:4px solid var(--accent-color, #646cff)}.step-display.user_action{border-left-color:#17a2b8}.step-display.expected_response{border-left-color:#ffc107}.step-display.system_action{border-left-color:#28a745}.step-display.inject_context{border-left-color:#6f42c1}.step-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.step-counter{font-size:.75rem;color:var(--text-secondary, #888)}.step-type-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;text-transform:capitalize}.step-type-badge.user_action{background:#17a2b833;color:#17a2b8}.step-type-badge.expected_response{background:#ffc10733;color:#ffc107}.step-type-badge.system_action{background:#28a74533;color:#28a745}.step-type-badge.inject_context{background:#6f42c133;color:#6f42c1}.step-status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;margin-left:auto}.step-status-badge.active{background:#646cff33;color:var(--accent-color, #646cff)}.step-status-badge.passed{background:#28a74533;color:#28a745}.step-status-badge.failed{background:#dc354533;color:#dc3545}.step-status-badge.skipped{background:#6c757d33;color:#6c757d}.step-status-badge.timeout{background:#ffc10733;color:#ffc107}.step-description{color:var(--text-primary, #e0e0e0);margin:0 0 1rem}.user-action-content{display:flex;flex-direction:column;gap:.75rem}.action-detail{display:flex;align-items:center;gap:.5rem}.detail-icon{font-size:1rem;width:24px;text-align:center}.detail-label{font-size:.8rem;color:var(--text-secondary, #888);min-width:60px}.detail-value{color:var(--text-primary, #e0e0e0)}.action-detail.utterance .detail-value{font-style:italic;color:#17a2b8}.operator-prompt{display:flex;align-items:flex-start;gap:.5rem;margin-top:.5rem;padding:1rem;background:#17a2b81a;border-radius:6px;border:1px solid rgba(23,162,184,.3)}.prompt-icon{font-size:1.25rem}.prompt-text{color:#17a2b8;font-weight:500}.expected-response-content{display:flex;flex-direction:column;gap:.75rem}.expected-detail{display:flex;align-items:center;gap:.5rem}.timeout-display{display:flex;align-items:center;gap:.75rem;margin-top:.5rem;padding:.75rem;background:#ffc1071a;border-radius:6px}.timeout-icon{font-size:1.25rem}.timeout-value{font-weight:600;color:#ffc107;min-width:30px}.timeout-bar{flex:1;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.timeout-progress{height:100%;background:#ffc107;transition:width 1s linear}.optional-badge{align-self:flex-start;padding:.25rem .5rem;background:#6c757d33;color:#6c757d;border-radius:4px;font-size:.75rem}.inject-context-info{display:flex;align-items:center;gap:.5rem;color:#6f42c1}.inject-icon{font-size:1.25rem}.step-controls{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.control-btn{padding:.75rem 1.25rem;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn.prev,.control-btn.next{background:var(--surface-color, #2a2a3e);color:var(--text-primary, #e0e0e0);border:1px solid var(--border-color, #333)}.control-btn.prev:hover:not(:disabled),.control-btn.next:hover:not(:disabled){background:var(--surface-hover, #3a3a4e)}.control-btn.done{background:#28a745;color:#fff}.control-btn.done:hover:not(:disabled){background:#218838}.control-btn.skip{background:transparent;color:var(--text-secondary, #888);border:1px solid var(--border-color, #333)}.control-btn.skip:hover:not(:disabled){border-color:#ffc107;color:#ffc107}.scenario-view .error-message{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#dc35451a;border:1px solid rgba(220,53,69,.3);border-radius:6px;color:#dc3545;margin-top:1rem}.scenario-view .dismiss-btn{background:none;border:none;color:#dc3545;font-size:1.25rem;cursor:pointer;padding:0;line-height:1}.scene-feeds{margin-bottom:1.25rem}.scene-feeds h4{margin:0 0 .5rem;color:var(--text-secondary, #888);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.feeds-grid{display:flex;gap:.5rem;flex-wrap:wrap}.feed-tile{position:relative;width:180px;border-radius:6px;overflow:hidden;background:#111;border:1px solid #333;cursor:pointer;transition:width .25s ease}.feed-tile:hover{outline:2px solid var(--accent-color, #646cff);outline-offset:2px}.feed-tile.disconnected{cursor:default}.feed-tile.disconnected:hover{outline:none}.feed-tile.expanded{width:480px}.feed-label{position:absolute;top:4px;left:6px;font-size:.65rem;color:#fff;background:#0009;padding:1px 5px;border-radius:3px;z-index:1}.feed-paused-badge{position:absolute;top:4px;right:6px;font-size:.6rem;color:#f0ad4e;background:#000000b3;padding:1px 6px;border-radius:3px;z-index:1}.feed-video{width:100%;display:block}.feed-placeholder{display:flex;align-items:center;justify-content:center;height:100px;color:#555}.feed-placeholder .material-icons{font-size:2rem}.scene-card-row{display:flex;align-items:flex-start;gap:1rem}.scene-left-col{display:flex;flex-direction:column;align-items:center;gap:.375rem;flex-shrink:0}.scene-card-row>.start-scene-btn{margin-left:auto;align-self:center}.view-scene-btn{width:36px;height:36px;border-radius:6px;border:1px solid var(--border-color, #333);background:transparent;color:var(--text-secondary, #888);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s}.view-scene-btn:hover{border-color:var(--accent-color, #646cff);color:var(--accent-color, #646cff)}.view-scene-btn.active{background:#646cff26;border-color:var(--accent-color, #646cff);color:var(--accent-color, #646cff)}.scene-details-panel{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:1rem}.detail-section h5{margin:0 0 .5rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #888)}.detail-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-primary, #e0e0e0)}.detail-row strong{color:var(--accent-color, #646cff)}.detail-actors-list{display:flex;flex-direction:column;gap:.375rem}.detail-actor{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-primary, #e0e0e0)}.detail-actor-name{font-weight:500}.detail-actor-role{font-size:.7rem;padding:.1rem .4rem;background:#ffffff14;border-radius:3px;color:var(--text-secondary, #888);text-transform:capitalize}.detail-actor-location{font-size:.75rem;color:var(--text-secondary, #888)}.detail-steps-list{margin:0;padding-left:1.25rem;display:flex;flex-direction:column;gap:.375rem}.detail-step{font-size:.85rem;color:var(--text-primary, #e0e0e0);display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.detail-step-type{font-size:.65rem;padding:.1rem .4rem;border-radius:3px;text-transform:capitalize;font-weight:500;flex-shrink:0}.detail-step-type.user_action{background:#17a2b833;color:#17a2b8}.detail-step-type.expected_response{background:#ffc10733;color:#ffc107}.detail-step-type.system_action{background:#28a74533;color:#28a745}.detail-step-type.inject_context{background:#6f42c133;color:#6f42c1}.detail-step-desc{color:var(--text-secondary, #888)}.detail-step-prompt{width:100%;font-size:.8rem;color:#17a2b8;font-style:italic;padding-left:.25rem}.detail-exploratory{font-size:.85rem;color:var(--text-secondary, #888)}.detail-streams-list{display:flex;flex-direction:column;gap:.375rem}.detail-stream{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-primary, #e0e0e0)}.detail-stream-icon{font-size:1rem;color:var(--text-secondary, #888)}.detail-stream-id{font-weight:500}.detail-stream-device{font-size:.75rem;color:var(--text-secondary, #888);padding:.1rem .4rem;background:#ffffff0f;border-radius:3px}.scene-header-actions{display:flex;align-items:center;gap:.5rem}.scene-toggle-btn{padding:.5rem 1rem;border-radius:6px;border:none;cursor:pointer;font-weight:500;transition:all .2s;white-space:nowrap}.scene-toggle-btn.processing{background:#f0ad4e;color:#000}.scene-toggle-btn.processing:hover:not(:disabled){background:#ec971f}.scene-toggle-btn.paused{background:#5cb85c;color:#fff}.scene-toggle-btn.paused:hover:not(:disabled){background:#449d44}.scene-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.simulator-view{display:flex;flex-direction:column;gap:16px}.simulator-header{display:flex;flex-direction:column;gap:4px}.simulator-header h2{margin:0;color:#fff;font-size:1.25rem;display:flex;align-items:center;gap:8px}.simulator-header h2 .material-icons{font-size:1.4rem}.simulator-subtitle{color:#888;font-size:.85rem}.add-producer-form{background:#1a1a2e;padding:16px;border-radius:10px}.form-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.form-field{display:flex;flex-direction:column;gap:4px}.form-field label{font-size:.8rem;color:#888}.form-field input[type=text]{padding:8px 10px;border:1px solid #444;border-radius:6px;background:#2a2a3e;color:#fff;font-size:.85rem;min-width:160px}.form-field input[type=text]:focus{outline:none;border-color:#646cff}.form-field input[type=file]{font-size:.8rem;color:#ccc}.form-field select{padding:8px 10px;border:1px solid #444;border-radius:6px;background:#2a2a3e;color:#fff;font-size:.85rem;cursor:pointer}.form-field select:focus{outline:none;border-color:#646cff}.source-type-radios{display:flex;flex-direction:column;gap:4px}.radio-label{display:flex;align-items:center;gap:6px;color:#ccc;font-size:.85rem;cursor:pointer}.form-field-checkbox{justify-content:flex-end}.form-field-checkbox label{display:flex;align-items:center;gap:6px;color:#ccc;font-size:.85rem;cursor:pointer}.add-btn{padding:8px 16px;border:none;border-radius:6px;background:#646cff;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap;display:flex;align-items:center;gap:4px}.add-btn:hover{background:#535bf2}.bulk-actions{display:flex;gap:8px}.bulk-btn{padding:6px 14px;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:4px}.bulk-btn.start{background:#059669;color:#fff}.bulk-btn.start:hover{background:#047857}.bulk-btn.stop{background:#dc2626;color:#fff}.bulk-btn.stop:hover{background:#b91c1c}.producers-list{display:flex;flex-direction:column;gap:10px}.empty-state{text-align:center;padding:2rem;color:#666;font-style:italic;background:#1a1a2e;border-radius:10px}.producer-card{background:#1a1a2e;border-radius:10px;border-left:4px solid #444;overflow:hidden}.producer-card.streaming{border-left-color:#059669}.producer-card.connecting{border-left-color:#d97706}.producer-card.error{border-left-color:#dc2626}.producer-card-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px}.producer-identity{display:flex;align-items:center;gap:10px}.status-dot{width:8px;height:8px;border-radius:50%;background:#666;flex-shrink:0}.status-dot.streaming{background:#059669}.status-dot.connecting{background:#d97706;animation:pulse 1s infinite}.status-dot.error{background:#dc2626}.device-name{font-weight:600;color:#fff;font-size:.9rem}.file-name{color:#888;font-size:.8rem}.loop-badge{font-size:.7rem;padding:2px 6px;background:#2a2a3e;border-radius:4px;color:#a78bfa;display:inline-flex;align-items:center;gap:3px}.source-badge{font-size:.7rem;padding:2px 6px;background:#2a2a3e;border-radius:4px;color:#60a5fa;display:inline-flex;align-items:center;gap:3px}.producer-actions{display:flex;gap:6px}.action-btn{padding:4px 10px;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:3px}.action-btn.start{background:#059669;color:#fff}.action-btn.start:hover{background:#047857}.action-btn.stop{background:#dc2626;color:#fff}.action-btn.stop:hover{background:#b91c1c}.action-btn.remove{background:transparent;color:#888;border:1px solid #444}.action-btn.remove:hover{color:#dc2626;border-color:#dc2626}.producer-preview{padding:0 16px 12px}.preview-video{width:100%;max-width:320px;border-radius:6px;background:#000;aspect-ratio:16/9}.producer-error{padding:8px 16px 12px;color:#dc2626;font-size:.8rem}.simulator-log{margin-top:8px}.simulator-log h3{margin:0 0 8px;font-size:.9rem;color:#fff}.simulator-log .log-container{background:#1a1a2e;padding:10px;border-radius:8px;max-height:180px;overflow-y:auto;font-family:Courier New,monospace;font-size:.75rem}.simulator-log .log-entry{margin-bottom:3px;color:#ccc}.simulator-log .log-entry.success{color:#27ae60}.simulator-log .log-entry.error{color:#e74c3c}.simulator-log .log-time{color:#666}.btn-icon{font-size:16px;vertical-align:middle;line-height:1}.badge-icon{font-size:14px;vertical-align:middle;line-height:1}.status-panel{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#2a2a3ee6;border-radius:8px;border:1px solid #333}.status-panel .status-info{display:flex;align-items:center;gap:.5rem}.status-panel .status-label{color:#888;font-size:.8rem}.status-panel .status-value{display:flex;align-items:center;gap:.25rem;color:#fff;font-weight:500;font-size:.875rem}.status-panel .status-value .status-icon{font-size:16px;color:#666}.status-panel .status-value .status-icon.active{color:#5cb85c}.status-panel .status-value.none{color:#666}.status-panel .status-value .snapshot-version{color:#888;font-size:.7rem;margin-left:.25rem}.status-panel .global-toggle-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;font-size:.8rem;border-radius:6px;border:none;cursor:pointer;transition:all .2s;font-weight:500}.status-panel .global-toggle-btn .btn-icon{font-size:16px}.status-panel .global-toggle-btn.processing{background:#f0ad4e;color:#000}.status-panel .global-toggle-btn.processing:hover:not(:disabled){background:#ec971f}.status-panel .global-toggle-btn.paused{background:#5cb85c;color:#fff}.status-panel .global-toggle-btn.paused:hover:not(:disabled){background:#4cae4c}.status-panel .global-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.status-panel .status-controls{display:flex;align-items:center;gap:.5rem}.status-panel .reset-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;font-size:.8rem;border-radius:6px;border:none;cursor:pointer;transition:all .2s;font-weight:500}.status-panel .reset-btn .btn-icon{font-size:16px}.status-panel .reset-btn.enabled{background:#646cff;color:#fff}.status-panel .reset-btn.enabled:hover:not(:disabled){background:#535bf2}.status-panel .reset-btn.disabled-processing{background:#666;color:#999;cursor:not-allowed}.status-panel .reset-btn:disabled{opacity:.5;cursor:not-allowed}.status-panel .processing-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-panel .processing-badge .badge-icon{font-size:16px}.status-panel .processing-badge.active{background:#5cb85c26;color:#5cb85c;border:1px solid rgba(92,184,92,.3)}.status-panel .processing-badge.pausing{background:#f0ad4e26;color:#f0ad4e;border:1px solid rgba(240,173,78,.3)}.status-panel .processing-badge.pausing .badge-icon{animation:pulse 1s ease-in-out infinite}.status-panel .processing-badge.paused{background:#d9534f26;color:#d9534f;border:1px solid rgba(217,83,79,.3)}.status-panel .global-toggle-btn.pausing{background:#666;color:#ccc;cursor:wait}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.log-panel{position:fixed;bottom:0;left:0;right:0;background:#1e1e1e;border-top:1px solid #333;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;z-index:1000}.log-panel.collapsed{height:auto}.log-panel.expanded{display:flex;flex-direction:column}.log-panel>.resize-handle{height:4px;cursor:ns-resize;background:transparent;flex-shrink:0}.log-panel>.resize-handle:hover{background:#646cff}.log-panel-header{display:flex;align-items:center;padding:8px 12px;background:#252526;cursor:pointer;-webkit-user-select:none;user-select:none}.log-panel-header:hover{background:#2d2d2d}.log-panel-toggle{margin-right:8px;color:#888;font-size:10px}.log-panel-title{font-weight:600;color:#ccc;margin-right:12px}.log-panel-count{color:#888;font-size:11px;display:flex;align-items:center;gap:8px}.error-badge{background:#f44336;color:#fff;padding:2px 6px;border-radius:10px;font-size:10px}.warn-badge{background:#ff9800;color:#fff;padding:2px 6px;border-radius:10px;font-size:10px}.log-panel-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.log-panel-toolbar{display:flex;align-items:center;gap:12px;padding:6px 12px;background:#2d2d2d;border-bottom:1px solid #333}.log-filter{background:#3c3c3c;color:#ccc;border:1px solid #555;padding:4px 8px;border-radius:4px;font-size:11px}.auto-scroll-label{display:flex;align-items:center;gap:4px;color:#888;font-size:11px;cursor:pointer}.auto-scroll-label input{cursor:pointer}.copy-btn{background:#3c3c3c;color:#ccc;border:1px solid #555;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:11px;margin-left:auto}.copy-btn:hover{background:#4c4c4c}.clear-btn{background:#3c3c3c;color:#ccc;border:1px solid #555;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:11px}.clear-btn:hover{background:#4c4c4c}.log-entries{flex:1;overflow-y:auto;padding:4px 0}.no-logs{color:#666;text-align:center;padding:20px}.log-entry{display:flex;padding:2px 12px;line-height:1.4;border-bottom:1px solid #2a2a2a}.log-entry:hover{background:#2a2a2a}.log-entry.error{background:#f443361a}.log-entry.warn{background:#ff98001a}.log-time{color:#666;margin-right:8px;flex-shrink:0;width:90px}.log-level{margin-right:8px;flex-shrink:0;width:50px;font-weight:600}.log-level.log{color:#888}.log-level.info{color:#4fc3f7}.log-level.warn{color:#ffb74d}.log-level.error{color:#ef5350}.log-level.debug{color:#9575cd}.log-message{color:#d4d4d4;white-space:pre-wrap;word-break:break-word;flex:1}.log-entry.error .log-message{color:#ef9a9a}.log-entry.warn .log-message{color:#ffe082}.monitoring-panel{flex-shrink:0;align-self:stretch;background:#1a1a2e;border-left:1px solid #333;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;z-index:10;display:flex;flex-direction:row;overflow:hidden}.monitoring-panel.collapsed{width:auto}.monitoring-panel-tab{writing-mode:vertical-rl;text-orientation:mixed;display:flex;align-items:center;gap:8px;padding:12px 6px;background:#242444;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;flex-shrink:0;border-right:1px solid #333}.monitoring-panel-tab:hover{background:#2d2d4d}.monitoring-panel-toggle{color:#888;font-size:10px}.monitoring-panel-title{font-weight:600;color:#646cff}.monitoring-panel-count{color:#888;font-size:11px}.monitoring-panel>.resize-handle{width:4px;cursor:ew-resize;background:transparent;flex-shrink:0}.monitoring-panel>.resize-handle:hover{background:#646cff}.monitoring-panel-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.monitoring-panel-toolbar{display:flex;align-items:center;gap:10px;padding:6px 12px;background:#1e1e36;border-bottom:1px solid #2a2a3e;flex-wrap:wrap;flex-shrink:0}.monitoring-filters{display:flex;gap:4px;flex-wrap:wrap}.monitoring-filter-chip{padding:2px 8px;font-size:.7rem;border-radius:10px;border:1px solid #444;background:transparent;color:#888;cursor:pointer;transition:all .15s}.monitoring-filter-chip.active{border-color:#646cff;background:#646cff33;color:#646cff}.monitoring-filter-chip:hover{border-color:#646cff}.monitoring-auto-scroll,.monitoring-pause-label{display:flex;align-items:center;gap:4px;color:#888;font-size:11px;cursor:pointer}.monitoring-clear-btn{background:#3c3c3c;color:#ccc;border:1px solid #555;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:11px;margin-left:auto}.monitoring-clear-btn:hover{background:#4c4c4c}.monitoring-paused-banner{text-align:center;padding:4px;background:#f0ad4e33;color:#f0ad4e;font-size:.75rem;flex-shrink:0}.monitoring-timeline{flex:1;overflow-y:auto;padding:4px 12px 60px}.monitoring-timeline::-webkit-scrollbar{width:6px}.monitoring-timeline::-webkit-scrollbar-track{background:transparent}.monitoring-timeline::-webkit-scrollbar-thumb{background:#444;border-radius:3px}.monitoring-empty{color:#555;text-align:center;padding:20px}.monitoring-element{padding:6px 10px;margin-bottom:4px;background:#2a2a3e;border-radius:6px;border-left:3px solid #646cff;animation:monitorFadeIn .2s ease-out;cursor:pointer;-webkit-user-select:none;user-select:none}.monitoring-element:hover{background:#32324a}@keyframes monitorFadeIn{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.monitoring-element-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.monitoring-expand-icon{font-size:.65rem;color:#666;margin-left:8px}.monitoring-type-badge{font-size:.65rem;padding:1px 6px;border-radius:8px;font-weight:600;text-transform:uppercase}.monitoring-ts{font-size:.65rem;color:#666}.monitoring-content{font-size:.75rem;color:#aaa;line-height:1.4;white-space:pre-wrap;word-break:break-word;max-height:80px;overflow:hidden;text-overflow:ellipsis}.monitoring-content.expanded{max-height:none;overflow:visible;-webkit-user-select:text;user-select:text}.type-utterance{background:#4caf5026;color:#4caf50;border-left-color:#4caf50}.type-person-detection{background:#2196f326;color:#2196f3;border-left-color:#2196f3}.type-scene-description{background:#ff980026;color:#ff9800;border-left-color:#ff9800}.type-activity-recognition{background:#9c27b026;color:#9c27b0;border-left-color:#9c27b0}.type-default{background:#646cff1a;color:#646cff;border-left-color:#646cff}.app{flex:1;min-width:0;padding:2rem;padding-bottom:90px;overflow-y:auto}.app-layout{display:flex;height:100vh;overflow:hidden}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.app-header h1{font-size:2rem;color:#646cff}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.app-main{display:flex;flex-direction:column;gap:1.5rem}.connection-panel{display:flex;gap:1rem;justify-content:center;align-items:center}.connection-panel input{padding:.6rem 1rem;font-size:1rem;border-radius:8px;border:1px solid #646cff;background:transparent;color:inherit;min-width:250px}.connection-panel input:focus{outline:none;border-color:#535bf2}.connection-panel input:disabled{opacity:.6;cursor:not-allowed}.login-panel{text-align:center;padding:3rem;background:#1a1a2e;border-radius:12px}.login-panel p{margin-bottom:1.5rem;color:#888}.login-btn{padding:.75rem 2rem;font-size:1rem;border-radius:8px;border:none;background:#646cff;color:#fff;cursor:pointer;transition:background .2s}.login-btn:hover{background:#535bf2}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{color:#888;font-size:.875rem}.user-info .connection-status{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background:#1a1a2e;border-radius:16px}.user-info .session-info-header{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem .25rem .75rem;background:#1a1a2e;border-radius:16px}.user-info .instance-name{color:#646cff;font-weight:500;font-size:.875rem}.user-info .disconnect-btn-small{padding:.25rem .5rem;font-size:.75rem;border-radius:4px;border:1px solid #d9534f;background:transparent;color:#d9534f;cursor:pointer;transition:all .2s;margin-left:.25rem}.user-info .disconnect-btn-small:hover{background:#d9534f;color:#fff}.user-info .status-indicator{width:8px;height:8px;border-radius:50%;background:#666}.user-info .status-indicator.connecting{background:#f0ad4e;animation:pulse 1s infinite}.user-info .status-indicator.connected{background:#5cb85c}.user-info .status-indicator.error{background:#d9534f}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.user-info .status-text{font-size:.75rem;color:#888;text-transform:capitalize}.logout-btn{padding:.5rem 1rem;font-size:.875rem;border-radius:6px;border:1px solid #666;background:transparent;color:#888;cursor:pointer;transition:all .2s}.logout-btn:hover{border-color:#d9534f;color:#d9534f}.producer-btn{padding:.5rem 1rem;font-size:.875rem;border-radius:6px;border:1px solid #646cff;background:transparent;color:#646cff;cursor:pointer;transition:all .2s}.producer-btn:hover{background:#646cff;color:#fff}.loading{text-align:center;padding:3rem;color:#888}.instance-connect-panel{background:#1a1a2e;border-radius:12px;padding:2rem;max-width:500px;margin:2rem auto}.instance-connect-panel h2{text-align:center;margin-bottom:1.5rem;color:#fff;font-size:1.5rem}.connect-form{display:flex;flex-direction:column;gap:1rem}.connect-form label{color:#888;font-size:.875rem}.connect-form input{padding:.75rem 1rem;font-size:1rem;border-radius:8px;border:1px solid #444;background:#2a2a3e;color:#fff}.connect-form input:focus{outline:none;border-color:#646cff}.connect-form input:disabled{opacity:.6;cursor:not-allowed}.connect-form .connect-btn{padding:.75rem 1.5rem;font-size:1rem;border-radius:8px;border:none;background:#646cff;color:#fff;cursor:pointer;transition:background .2s;margin-top:.5rem}.connect-form .connect-btn:hover:not(:disabled){background:#535bf2}.connect-form .connect-btn:disabled{opacity:.6;cursor:not-allowed}.instance-connect-panel .error-message{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:.75rem 1rem;background:#d9534f33;border:1px solid #d9534f;border-radius:8px;color:#d9534f}.instance-connect-panel .dismiss-btn{background:none;border:none;color:#d9534f;font-size:1.25rem;cursor:pointer;padding:0;line-height:1}.instance-connect-panel .dismiss-btn:hover{color:#fff}.tabs-row{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;margin-bottom:0}.view-tabs{display:flex;gap:.5rem;padding:.25rem;background:#1a1a2e;border-radius:8px;align-self:flex-start}.tab-btn{padding:.5rem 1.25rem;font-size:.875rem;border-radius:6px;border:none;background:transparent;color:#888;cursor:pointer;transition:all .2s}.tab-btn:hover{color:#fff}.tab-btn.active{background:#646cff;color:#fff}
