:root{--color-bg-app: #FFF8EE;--color-bg-panel: #FFFFFF;--color-border: #E8DDD0;--color-border-faint: rgba(160, 140, 110, .25);--color-text-primary: #1C1A17;--color-text-secondary:#6B6560;--color-text-faint: #A09890;--color-accent-green: #1D9E75;--color-accent-blue: #378ADD;--radius-sm: 6px;--radius-md: 10px;font-family:system-ui,Segoe UI,Noto Sans Thai,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--color-bg-app);color:var(--color-text-primary)}.app-shell{display:grid;grid-template-columns:220px 1fr 300px;grid-template-rows:48px 1fr;grid-template-areas:"topbar  topbar  topbar" "sidebar scene   history";height:100vh;overflow:hidden}.topbar{grid-area:topbar;display:flex;align-items:center;gap:12px;padding:0 16px;background:var(--color-bg-panel);border-bottom:1px solid var(--color-border);z-index:10}.topbar-brand{display:flex;align-items:center;gap:6px;flex-shrink:0}.topbar-logo{font-size:14px;background:#fdefd9;border-radius:var(--radius-sm);width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center}.topbar-title{font-size:13px;font-weight:700;color:var(--color-text-primary);white-space:nowrap}.topbar-scenario-badge{display:flex;align-items:center;gap:5px;background:#fdf5e8;border:1px solid var(--color-border);border-radius:999px;padding:3px 10px;font-size:11px;flex:1;max-width:380px;overflow:hidden}.scenario-badge-pattern{color:var(--color-text-secondary);white-space:nowrap}.scenario-badge-sep{color:var(--color-text-faint)}.scenario-badge-name{color:var(--color-text-primary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-status-dot{font-size:10px;margin-left:4px}.topbar-status-running{color:#378add}.topbar-status-completed{color:#1d9e75}.topbar-status-failed{color:#d85a30}.topbar-actions{display:flex;align-items:center;gap:6px;margin-left:auto;flex-shrink:0}.run-btn-main{background:var(--color-accent-green);border:none;color:#fff;border-radius:var(--radius-sm);padding:6px 16px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s;font-family:inherit}.run-btn-main:hover:not(:disabled){background:#168c65}.run-btn-main:disabled{background:#9dd4c1;cursor:not-allowed}.topbar-divider{width:1px;height:20px;background:var(--color-border)}.topbar-icon-btn{background:transparent;border:none;cursor:pointer;font-size:15px;padding:4px 6px;border-radius:var(--radius-sm);transition:background .12s;line-height:1}.topbar-icon-btn:hover{background:#f5efe4}.sidebar{grid-area:sidebar;background:var(--color-bg-panel);border-right:1px solid var(--color-border);overflow-y:auto;padding:12px 0 8px}.pattern-tree{display:flex;flex-direction:column;min-height:100%}.tree-section-label{font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--color-text-faint);padding:0 12px 6px;margin:0}.tree-row{display:flex;align-items:center;gap:5px;width:100%;border:none;background:transparent;text-align:left;cursor:pointer;padding:5px 8px 5px 12px;font-family:inherit;font-size:12px;color:var(--color-text-primary);transition:background .1s;line-height:1.3}.tree-row:hover:not(:disabled){background:#f5efe4}.tree-row--pattern{font-weight:600;padding-left:10px}.tree-row--project{padding-left:20px;font-size:11.5px;color:var(--color-text-secondary)}.tree-row--scenario{padding-left:32px;font-size:11px;color:var(--color-text-secondary)}.tree-row--scenario:disabled{opacity:.5;cursor:not-allowed}.tree-row--selected{background:#eaf5f0;color:var(--color-accent-green);font-weight:600}.tree-row--selected:hover{background:#dff0e9}.tree-chevron{font-size:10px;width:12px;flex-shrink:0;color:var(--color-text-faint)}.tree-icon{font-size:12px;flex-shrink:0}.tree-bullet{font-size:10px;width:12px;flex-shrink:0;color:var(--color-text-faint)}.tree-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-add-project{margin-top:auto;padding:12px 12px 8px;border-top:1px solid var(--color-border-faint)}.tree-add-btn{background:transparent;border:1px dashed var(--color-border);color:var(--color-text-faint);border-radius:var(--radius-sm);padding:5px 10px;font-size:11px;cursor:not-allowed;width:100%;font-family:inherit}.scene-area{grid-area:scene;display:flex;align-items:center;justify-content:center;padding:16px;overflow:auto;background:var(--color-bg-app)}.scene-canvas-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;box-shadow:0 4px 20px #b48c501f}.history-panel{grid-area:history;border-left:1px solid var(--color-border);background:var(--color-bg-panel);padding:12px 14px;overflow-y:auto;display:flex;flex-direction:column}.history-header{margin-bottom:10px;display:flex;flex-direction:column;gap:6px;flex-shrink:0}.history-panel h2{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-faint);margin:0;display:flex;align-items:center;gap:6px}.live-badge{color:var(--color-accent-blue);font-size:10px;font-weight:700}.done-badge{color:var(--color-accent-green);font-size:10px;font-weight:700}.fail-badge{color:#d85a30;font-size:10px;font-weight:700}.agent-filter{background:var(--color-bg-app);border:1px solid var(--color-border);color:var(--color-text-primary);border-radius:var(--radius-sm);padding:3px 6px;font-size:11px;cursor:pointer;width:100%;font-family:inherit}.history-empty{font-size:12px;color:var(--color-text-faint);margin:16px 0 0;text-align:center;line-height:1.6}.history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.history-item{font-size:11px;padding:5px 0;border-bottom:1px solid var(--color-border-faint);line-height:1.4}.hi-row{display:flex;align-items:center;gap:5px}.hi-icon{font-size:11px;width:14px;flex-shrink:0;text-align:center}.hi-type{font-weight:600;font-size:11px}.hi-agent{color:var(--color-text-faint);font-size:10px;font-family:monospace;margin-left:auto}.hi-text{color:var(--color-text-secondary);font-size:10px;margin-top:2px;padding-left:19px;word-break:break-word;white-space:pre-wrap}.app-shell-dashboard{grid-template-columns:1fr;grid-template-rows:48px 1fr;grid-template-areas:"topbar" "content"}.dashboard-area{grid-area:content;overflow-y:auto;background:var(--color-bg-app)}.dashboard{max-width:960px;margin:0 auto;padding:24px 24px 40px}.dashboard-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.dashboard-title{font-size:18px;font-weight:700;margin:0;color:var(--color-text-primary);flex:1}.dash-back-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-sm);padding:5px 12px;font-size:12px;cursor:pointer;font-family:inherit;transition:background .12s}.dash-back-btn:hover{background:#f5efe4}.dash-refresh-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-sm);padding:5px 12px;font-size:12px;cursor:pointer;font-family:inherit;transition:background .12s}.dash-refresh-btn:hover{background:#f5efe4}.metric-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}@media(max-width:700px){.metric-cards{grid-template-columns:repeat(2,1fr)}}.metric-card{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px 18px}.metric-card-green{border-top:3px solid var(--color-accent-green)}.metric-card-blue{border-top:3px solid var(--color-accent-blue)}.metric-value{font-size:28px;font-weight:700;color:var(--color-text-primary);line-height:1.1}.metric-label{font-size:11px;color:var(--color-text-secondary);margin-top:4px}.dash-filters{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.dash-filter-group{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-secondary)}.dash-filter-label{font-weight:600}.dash-select{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:4px 8px;font-size:12px;color:var(--color-text-primary);font-family:inherit;cursor:pointer}.dash-loading{text-align:center;color:var(--color-text-faint);padding:40px;font-size:13px}.dash-empty{text-align:center;color:var(--color-text-faint);padding:40px;font-size:13px;line-height:1.7}.run-table-wrap{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.run-table{width:100%;border-collapse:collapse;font-size:12px}.run-table th{background:#faf5ec;border-bottom:1px solid var(--color-border);padding:8px 12px;text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);white-space:nowrap}.run-table td{padding:9px 12px;border-bottom:1px solid var(--color-border-faint)}.run-row:last-child td{border-bottom:none}.run-row:hover{background:#fdfaf4}.run-td-date{color:var(--color-text-faint);white-space:nowrap;font-size:11px}.run-td-scenario{font-weight:500}.pattern-chip{display:inline-block;border-radius:999px;padding:2px 8px;font-size:10px;font-weight:600;white-space:nowrap}.pattern-chip-orchestrator-worker{background:#edf4ff;color:#378add}.pattern-chip-pipeline{background:#f0edff;color:#6d44c4}.status-chip{display:inline-block;border-radius:999px;padding:2px 8px;font-size:10px;font-weight:600;white-space:nowrap}.status-chip-completed{background:#e8f7f0;color:#1d9e75}.status-chip-failed{background:#fdecea;color:#d85a30}.status-chip-running{background:#edf4ff;color:#378add}.status-chip-unknown{background:#f3f3f3;color:#8b93a1}.replay-btn{background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:3px 10px;font-size:11px;cursor:pointer;color:var(--color-text-secondary);font-family:inherit;transition:background .1s,color .1s;white-space:nowrap}.replay-btn:hover{background:#f5efe4;color:var(--color-text-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c1a1773;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal{background:var(--color-bg-panel);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;max-width:480px;box-shadow:0 8px 40px #281e0a2e;display:flex;flex-direction:column;max-height:90vh}.modal-header{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-title{font-size:14px;font-weight:700;flex:1;color:var(--color-text-primary)}.modal-close{background:transparent;border:none;cursor:pointer;font-size:14px;color:var(--color-text-faint);padding:2px 6px;border-radius:var(--radius-sm);font-family:inherit;line-height:1;transition:background .1s}.modal-close:hover{background:#f5efe4}.modal-body{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.modal-footer{display:flex;align-items:center;gap:8px;padding:12px 16px;border-top:1px solid var(--color-border);flex-shrink:0}.setup-section{display:flex;flex-direction:column;gap:6px}.setup-section-title{font-size:12px;font-weight:700;color:var(--color-text-primary);margin:0}.setup-section-desc{font-size:11px;color:var(--color-text-secondary);margin:0;line-height:1.5}.setup-path-row{display:flex;gap:8px}.setup-path-input{flex:1;background:var(--color-bg-app);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:7px 10px;font-size:12px;font-family:monospace;color:var(--color-text-primary);outline:none;transition:border-color .12s}.setup-path-input:focus{border-color:var(--color-accent-blue)}.setup-path-input.path-ok{border-color:var(--color-accent-green)}.setup-path-input.path-error{border-color:#d85a30}.setup-validate-btn{background:var(--color-bg-app);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:7px 14px;font-size:12px;cursor:pointer;color:var(--color-text-secondary);font-family:inherit;white-space:nowrap;transition:background .1s}.setup-validate-btn:hover:not(:disabled){background:#f5efe4}.setup-validate-btn:disabled{opacity:.5;cursor:not-allowed}.path-feedback{font-size:11px;margin:0}.path-feedback-ok{color:var(--color-accent-green)}.path-feedback-error{color:#d85a30}.setup-radio-group{display:flex;flex-direction:column;gap:8px}.setup-radio-label{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--color-text-primary);cursor:pointer}.setup-key-status{font-size:10px;color:var(--color-accent-green);font-weight:600}.setup-key-missing{font-size:10px;color:#d85a30;font-weight:600}.setup-select{background:var(--color-bg-app);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:7px 10px;font-size:12px;color:var(--color-text-primary);font-family:inherit;cursor:pointer;width:100%}.save-msg{font-size:11px;flex:1}.save-msg-ok{color:var(--color-accent-green)}.save-msg-error{color:#d85a30}.modal-cancel-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary);border-radius:var(--radius-sm);padding:7px 16px;font-size:12px;cursor:pointer;font-family:inherit;transition:background .1s}.modal-cancel-btn:hover{background:#f5efe4}.modal-save-btn{background:var(--color-accent-green);border:none;color:#fff;border-radius:var(--radius-sm);padding:7px 18px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .12s}.modal-save-btn:hover:not(:disabled){background:#168c65}.modal-save-btn:disabled{background:#9dd4c1;cursor:not-allowed}
