*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #000000;--color-background: #FFFFFF;--color-secondary: #F5F5F5;--color-border: #E5E5E5;--color-text: #000000;--color-text-secondary: #666666;--color-text-light: #999999;--color-error: #DC2626;--color-success: #16A34A;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--border-radius: 4px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1)}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:var(--color-background);color:var(--color-text);line-height:1.5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.text-center{text-align:center}.text-secondary{color:var(--color-text-secondary)}.text-light{color:var(--color-text-light)}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mt-4{margin-top:var(--spacing-xl)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.mb-4{margin-bottom:var(--spacing-xl)}.p-1{padding:var(--spacing-sm)}.p-2{padding:var(--spacing-md)}.p-3{padding:var(--spacing-lg)}.p-4{padding:var(--spacing-xl)}.loading-spinner{display:inline-flex;align-items:center;justify-content:center}.spinner{border:2px solid var(--color-border);border-top:2px solid var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-sm .spinner{width:16px;height:16px;border-width:2px}.loading-spinner-md .spinner{width:24px;height:24px;border-width:2px}.loading-spinner-lg .spinner{width:32px;height:32px;border-width:3px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-primary);background-color:var(--color-background);color:var(--color-primary);font-size:14px;font-weight:500;cursor:pointer;border-radius:var(--border-radius);transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.btn:hover:not(:disabled){background-color:var(--color-secondary)}.btn:active:not(:disabled){background-color:var(--color-border)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--color-background)}.btn-primary:hover:not(:disabled){background-color:var(--color-text-secondary);border-color:var(--color-text-secondary)}.btn-secondary{background-color:var(--color-background);color:var(--color-primary);border-color:var(--color-border)}.btn-danger{background-color:var(--color-background);color:var(--color-error);border-color:var(--color-error)}.btn-danger:hover:not(:disabled){background-color:var(--color-error);color:var(--color-background)}.header{background-color:var(--color-background);border-bottom:1px solid var(--color-border);padding:var(--spacing-md);position:sticky;top:0;z-index:100}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.header-title{font-size:20px;font-weight:600;color:var(--color-primary)}.header-right{display:flex;align-items:center;gap:var(--spacing-md)}.header-tenant{font-size:14px;color:var(--color-text-secondary)}.header-user{font-size:14px;color:var(--color-text)}.header-logout{font-size:14px}.sidebar{width:240px;background-color:var(--color-background);border-right:1px solid var(--color-border);height:calc(100vh - 64px);position:sticky;top:64px;overflow-y:auto}.sidebar-nav{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.sidebar-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);text-decoration:none;color:var(--color-text);transition:background-color .2s;font-size:14px}.sidebar-item:hover{background-color:var(--color-secondary)}.sidebar-item-active{background-color:var(--color-primary);color:var(--color-background)}.sidebar-item-active:hover{background-color:var(--color-text-secondary)}.sidebar-icon{font-size:18px}.sidebar-label{font-weight:500}.sidebar-divider{height:1px;background-color:var(--color-border);margin:var(--spacing-md) 0}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-body{display:flex;flex:1}.layout-main{flex:1;overflow-y:auto;background-color:var(--color-secondary)}.layout-content{padding:var(--spacing-xl);max-width:1400px;margin:0 auto}.alert{padding:var(--spacing-md);border-radius:var(--border-radius);border:1px solid;display:flex;align-items:flex-start;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.alert-content{flex:1}.alert-close{background:none;border:none;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:inherit;opacity:.7;transition:opacity .2s}.alert-close:hover{opacity:1}.alert-info{background-color:var(--color-secondary);border-color:var(--color-border);color:var(--color-text)}.alert-success{background-color:#f0fdf4;border-color:var(--color-success);color:#166534}.alert-error{background-color:#fef2f2;border-color:var(--color-error);color:#991b1b}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.error-boundary-content{text-align:center;max-width:500px}.error-boundary-content h1{font-size:32px;font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-primary)}.error-boundary-actions{display:flex;gap:var(--spacing-md);justify-content:center;margin-top:var(--spacing-lg)}.input-group{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.input-label{font-size:14px;font-weight:500;color:var(--color-text)}.required{color:var(--color-error);margin-left:2px}.input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--border-radius);font-size:14px;background-color:var(--color-background);color:var(--color-text);transition:border-color .2s}.input:focus{outline:none;border-color:var(--color-primary)}.input-error{border-color:var(--color-error)}.input-error-message{font-size:12px;color:var(--color-error)}.input::placeholder{color:var(--color-text-light)}textarea.input{min-height:100px;resize:vertical;font-family:inherit}.card{background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);font-weight:600;font-size:16px}.card-body{padding:var(--spacing-md)}.card-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border);background-color:var(--color-secondary)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-secondary);padding:var(--spacing-md)}.login-card{width:100%;max-width:400px}.login-title{font-size:28px;font-weight:600;text-align:center;margin-bottom:var(--spacing-xs);color:var(--color-primary)}.login-subtitle{text-align:center;color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);font-size:14px}.login-form{margin-top:var(--spacing-md)}.login-button{width:100%;margin-top:var(--spacing-md)}.dashboard{padding:var(--spacing-lg)}.dashboard-header{margin-bottom:var(--spacing-xl)}.dashboard-header h1{font-size:32px;font-weight:600;margin-bottom:var(--spacing-xs)}.dashboard-loading{display:flex;justify-content:center;align-items:center;height:400px}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.stat-value{font-size:48px;font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-xs)}.stat-label{font-size:16px;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.stat-action{width:100%}.dashboard-actions{margin-top:var(--spacing-xl)}.action-buttons{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.table-container{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--border-radius)}.table{width:100%;border-collapse:collapse;background-color:var(--color-background)}.table thead{background-color:var(--color-secondary)}.table th{padding:var(--spacing-md);text-align:left;font-weight:600;font-size:14px;border-bottom:1px solid var(--color-border)}.table td{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);font-size:14px}.table tbody tr:last-child td{border-bottom:none}.table-row-clickable{cursor:pointer;transition:background-color .2s}.table-row-clickable:hover{background-color:var(--color-secondary)}.table-empty{padding:var(--spacing-2xl);text-align:center;color:var(--color-text-light)}.badge{display:inline-block;padding:2px var(--spacing-sm);font-size:12px;font-weight:500;border-radius:12px;border:1px solid transparent}.badge-default{background-color:var(--color-secondary);color:var(--color-text);border-color:var(--color-border)}.badge-success{background-color:var(--color-success);color:var(--color-background)}.badge-error{background-color:var(--color-error);color:var(--color-background)}.badge-primary{background-color:var(--color-primary);color:var(--color-background)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background-color:var(--color-background);border-radius:var(--border-radius);box-shadow:var(--shadow-md);max-width:900px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;position:relative}.modal-header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.modal-title{font-size:18px;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius);transition:background-color .2s}.modal-close:hover{background-color:var(--color-secondary)}.modal-body{padding:var(--spacing-md);flex:1;overflow-y:auto;overflow-x:visible;position:relative}.modal-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.agent-list{padding:var(--spacing-lg)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.page-header h1{font-size:32px;font-weight:600}.page-loading{display:flex;justify-content:center;align-items:center;height:400px}.placeholder-helper{position:relative;display:inline-block}.placeholder-helper-toggle{background:var(--color-secondary);border:1px solid var(--color-border);border-radius:var(--border-radius);padding:6px 12px;font-size:12px;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.placeholder-helper-toggle:hover{background:var(--color-border);color:var(--color-text)}.placeholder-helper-menu{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--border-radius);box-shadow:0 4px 12px #00000026;min-width:300px;max-width:400px;max-height:400px;overflow-y:auto}.placeholder-helper-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--color-border);font-weight:600;font-size:14px}.placeholder-helper-close{background:none;border:none;font-size:20px;color:var(--color-text-secondary);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px}.placeholder-helper-close:hover{background:var(--color-secondary);color:var(--color-text)}.placeholder-helper-list{padding:8px 0}.placeholder-helper-item{padding:10px 16px;cursor:pointer;transition:background .2s;display:flex;flex-direction:column;gap:4px}.placeholder-helper-item:hover{background:var(--color-secondary)}.placeholder-helper-item code{font-family:Courier New,monospace;font-size:13px;color:var(--color-primary);font-weight:500}.placeholder-helper-desc{font-size:12px;color:var(--color-text-secondary)}.placeholder-helper-footer{padding:8px 16px;border-top:1px solid var(--color-border);text-align:center;color:var(--color-text-secondary);font-size:11px}.placeholder-helper-loading{padding:20px;text-align:center;color:var(--color-text-secondary);font-size:12px}.placeholder-helper-toggle:disabled{opacity:.6;cursor:not-allowed}.agent-detail{padding:var(--spacing-lg)}.agent-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-border)}.detail-item:last-child{border-bottom:none}.detail-label{font-weight:500;color:var(--color-text-secondary)}.prompt-text{white-space:pre-wrap;word-wrap:break-word;font-family:Courier New,monospace;font-size:13px;line-height:1.6;color:var(--color-text);background-color:var(--color-secondary);padding:var(--spacing-md);border-radius:var(--border-radius);margin:0}.agent-create{padding:var(--spacing-lg)}.form-section{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.form-section:last-of-type{border-bottom:none}.agent-executions{padding:24px}.executions-layout{display:grid;grid-template-columns:400px 1fr;gap:24px;margin-top:24px}.executions-list{max-height:calc(100vh - 200px);overflow-y:auto}.executions-list-items{display:flex;flex-direction:column;gap:8px}.execution-item{padding:12px;border:1px solid var(--color-border);border-radius:4px;cursor:pointer;transition:all .2s}.execution-item:hover{background:var(--color-secondary);border-color:var(--color-primary)}.execution-item.selected{background:var(--color-primary-light);border-color:var(--color-primary)}.execution-item-header{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.execution-id-row{display:flex;justify-content:space-between;align-items:center}.execution-id{font-size:12px;font-family:monospace;color:var(--color-text)}.execution-date{font-size:11px;margin-left:0}.execution-item-details{display:flex;gap:16px;font-size:12px;color:var(--color-text-secondary)}.execution-error{margin-top:8px;padding-top:8px;border-top:1px solid var(--color-border)}.execution-details{max-height:calc(100vh - 200px);overflow-y:auto}.detail-section{display:flex;flex-direction:column;gap:12px}.detail-item{display:flex;gap:12px}.detail-label{font-weight:500;min-width:100px}.logs-container{display:flex;flex-direction:column;gap:12px;max-height:500px;overflow-y:auto}.log-entry{padding:12px;border-left:3px solid var(--color-border);background:var(--color-secondary);border-radius:4px}.log-entry.log-error{border-left-color:var(--color-error);background:#dc35451a}.log-entry.log-warn{border-left-color:#ffc107;background:#ffc1071a}.log-entry.log-info{border-left-color:var(--color-primary)}.log-entry.log-debug{border-left-color:var(--color-text-secondary)}.log-header{display:flex;align-items:center;margin-bottom:8px}.log-message{font-family:monospace;font-size:13px;white-space:pre-wrap;word-break:break-word}.json-preview{background:var(--color-secondary);padding:12px;border-radius:4px;overflow-x:auto;font-size:12px;font-family:Courier New,monospace;max-height:400px;overflow-y:auto}.json-preview-small{background:var(--color-secondary);padding:8px;border-radius:4px;overflow-x:auto;font-size:11px;font-family:Courier New,monospace;max-height:200px;overflow-y:auto;margin-top:4px}.data-section{display:flex;flex-direction:column}.data-subsection{padding:16px;background:var(--color-secondary);border-radius:4px}.data-subsection h3{margin:0 0 12px;font-size:16px;font-weight:600}.tool-executions-list{display:flex;flex-direction:column;gap:12px}.tool-execution-item{padding:12px;background:#fff;border:1px solid var(--color-border);border-radius:4px}.tool-execution-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.tool-execution-details{font-size:13px}@media(max-width:1200px){.executions-layout{grid-template-columns:1fr}.executions-list{max-height:300px}}.user-list,.user-create{padding:var(--spacing-lg)}.tool-list{padding:var(--spacing-lg)}.tool-detail-item{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.tool-detail-item:last-child{border-bottom:none}.tool-detail-label{font-weight:500;color:var(--color-text-secondary);display:block;margin-bottom:var(--spacing-xs)}.tool-schema{background-color:var(--color-secondary);padding:var(--spacing-md);border-radius:var(--border-radius);font-family:Courier New,monospace;font-size:12px;overflow-x:auto;margin-top:var(--spacing-xs)}.tenant-list,.tenant-create{padding:var(--spacing-lg)}.super-admin-list,.super-admin-create{padding:var(--spacing-lg)}.form-section{margin-bottom:var(--spacing-xl)}.form-section-title{font-size:20px;font-weight:600;margin-bottom:var(--spacing-md);color:var(--color-primary)}.form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.input-module-list,.output-module-list,.agent-tool-list,.connected-clients{padding:var(--spacing-lg)}.connected-clients-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.connected-clients-header h1{margin:0;font-size:32px;font-weight:600;color:var(--color-text)}.connected-clients-stats{display:flex;gap:var(--spacing-lg);align-items:center}.stat-card{text-align:center}.stat-value{font-size:2rem;font-weight:600;color:var(--color-primary);margin-bottom:var(--spacing-xs)}.stat-label{font-size:.875rem;color:var(--color-text-secondary)}.stat-indicator{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-text-secondary)}.pulse-dot{width:8px;height:8px;background:var(--color-success);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.1)}}.client-user{display:flex;flex-direction:column;gap:.25rem}.client-email{font-weight:500;color:var(--color-text)}.client-user-id{font-size:.75rem;color:var(--color-text-secondary);font-family:Monaco,Menlo,Courier New,monospace}.connection-id{font-family:Monaco,Menlo,Courier New,monospace;background:var(--color-secondary);padding:.25rem .5rem;border-radius:var(--border-radius);font-size:.875rem;color:var(--color-text-secondary)}.connection-time{display:flex;flex-direction:column;gap:.125rem}.connection-time>div:first-child{font-weight:500;color:var(--color-text)}.connection-timestamp{font-size:.75rem;color:var(--color-text-secondary)}.no-clients{text-align:center;padding:3rem 2rem}.no-clients-icon{font-size:4rem;margin-bottom:1rem;opacity:.3}.no-clients h3{margin:0 0 .5rem;color:var(--color-text);font-size:1.25rem;font-weight:600}.no-clients p{margin:.5rem 0;color:var(--color-text-secondary)}.no-clients-hint{font-size:.875rem;color:var(--color-text-light);margin-top:1rem!important}
