:root{--bg-base: #080a0f;--bg-surface: #111520;--bg-elevated: #1c2130;--bg-hover: #252c3e;--bg-active: #2e3650;--border: #2a3248;--border-bright: #3d4a6a;--text-primary: #eef0f8;--text-secondary: #9aa3bf;--text-muted: #5a6480;--accent: #7c6fff;--accent-dim: #2a2560;--green: #00e5a0;--green-dim: #003d2a;--yellow: #ffd166;--yellow-dim: #3d2e00;--red: #ff4d6a;--red-dim: #3d0015;--blue: #5bc8f5;--blue-dim: #003d5a;--orange: #ff9f43;--orange-dim: #3d2200;--purple: #b39dfe;--purple-dim: #2d2560;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--font-ui: "Inter", -apple-system, BlinkMacSystemFont, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-base);color:var(--text-primary);font-family:var(--font-ui);font-size:13px;line-height:1.5;min-height:100vh}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;background:var(--bg-surface);border-bottom:2px solid var(--border-bright);flex-shrink:0;box-shadow:0 2px 16px #00000080}.logo{display:flex;align-items:center;gap:8px}.logo-icon{font-size:20px;color:var(--accent)}.logo-text{font-family:var(--font-mono);font-size:14px;font-weight:700;letter-spacing:2px;color:var(--text-primary)}.logo-sub{font-size:10px;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase}.status-bar{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.status-dot.green{background:var(--green);box-shadow:0 0 6px var(--green)}.status-dot.red{background:var(--red);box-shadow:0 0 6px var(--red)}.status-label{font-weight:700;letter-spacing:1px}.status-badge{padding:2px 6px;border-radius:3px;font-size:10px;font-weight:700;letter-spacing:1px}.status-badge.red{background:var(--red-dim);color:var(--red);border:1px solid var(--red)}.status-version{color:var(--text-muted)}.nav-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-family:var(--font-mono);transition:all .15s;margin-left:6px}.nav-btn:hover,.nav-btn.active{background:var(--bg-elevated);border-color:var(--accent);color:var(--accent)}.app-main{display:flex;flex-direction:column;flex:1;overflow:hidden;padding:16px;gap:12px}.command-box{flex-shrink:0}.command-input-row{display:flex;align-items:center;gap:8px;background:var(--bg-surface);border:1px solid var(--border-bright);border-radius:8px;padding:10px 14px;transition:border-color .15s;box-shadow:0 2px 8px #0006}.command-input-row:focus-within{border-color:var(--accent)}.command-prompt{color:var(--accent);font-size:16px;flex-shrink:0}.command-input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:14px;font-family:var(--font-ui)}.command-input::placeholder{color:var(--text-muted)}.env-select{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);padding:4px 8px;border-radius:4px;font-size:12px;cursor:pointer;outline:none}.command-submit{background:var(--accent);border:none;color:#fff;padding:6px 16px;border-radius:4px;cursor:pointer;font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:1px;transition:opacity .15s}.command-submit:disabled{opacity:.4;cursor:not-allowed}.command-submit.loading{opacity:.6}.content-area{flex:1;overflow:hidden}.task-list-container{display:flex;flex-direction:column;gap:12px;height:100%;overflow:hidden}.live-feed{background:var(--bg-surface);border:1px solid var(--border-bright);border-radius:6px;padding:8px 12px;flex-shrink:0}.live-feed-header{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:2px;color:var(--text-muted);margin-bottom:6px}.live-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 4px var(--green);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.live-feed-events{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px}.live-event{display:flex;gap:6px;align-items:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;padding:3px 8px;white-space:nowrap;font-family:var(--font-mono);font-size:11px}.live-event-worker{color:var(--accent)}.live-event-type{color:var(--text-secondary)}.live-event-task{color:var(--text-muted)}.live-empty{color:var(--text-muted);font-size:12px}.task-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:10px;overflow-y:auto;flex:1;padding-right:4px}.task-empty{grid-column:1 / -1;color:var(--text-muted);text-align:center;padding:40px;font-size:14px}.task-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;padding:14px;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #0006}.task-card:hover{background:var(--bg-hover);border-color:var(--accent);box-shadow:0 4px 16px #7c6fff26;transform:translateY(-1px)}.task-card-header{display:flex;gap:6px;align-items:center;margin-bottom:8px;flex-wrap:wrap}.task-status-badge{padding:2px 8px;border-radius:3px;font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.task-status-badge.blue,.task-status-badge.planning{background:var(--blue-dim);color:var(--blue);border:1px solid var(--blue)}.task-status-badge.purple,.task-status-badge.saved{background:var(--purple-dim);color:var(--purple);border:1px solid var(--purple)}.task-status-badge.yellow,.task-status-badge.executing{background:var(--yellow-dim);color:var(--yellow);border:1px solid var(--yellow)}.task-status-badge.orange,.task-status-badge.awaiting_prod,.task-status-badge.prod_deploying{background:var(--orange-dim);color:var(--orange);border:1px solid var(--orange)}.task-status-badge.green,.task-status-badge.done{background:var(--green-dim);color:var(--green);border:1px solid var(--green)}.task-status-badge.red,.task-status-badge.failed,.task-status-badge.stuck,.task-status-badge.killed_iterations,.task-status-badge.rolled_back{background:var(--red-dim);color:var(--red);border:1px solid var(--red)}.task-status-badge.gray{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.task-env-badge{padding:2px 6px;border-radius:3px;font-family:var(--font-mono);font-size:10px;color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border)}.task-worker-badge{padding:2px 6px;border-radius:3px;font-size:10px;color:var(--accent);background:var(--accent-dim);border:1px solid var(--accent)}.task-card-intent{color:var(--text-primary);font-size:13px;line-height:1.4;margin-bottom:8px}.task-card-footer{display:flex;gap:8px;align-items:center;font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}.task-id{flex:1}.task-detail{display:flex;flex-direction:column;height:100%;gap:12px}.detail-header{display:flex;align-items:center;gap:12px;flex-shrink:0}.back-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:4px 10px;border-radius:4px;cursor:pointer;font-size:12px}.back-btn:hover{border-color:var(--accent);color:var(--accent)}.detail-title{display:flex;gap:8px;align-items:center;flex:1}.detail-id{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}.detail-env{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);background:var(--bg-elevated);border:1px solid var(--border);padding:2px 6px;border-radius:3px}.detail-cost{font-family:var(--font-mono);font-size:12px;color:var(--yellow)}.detail-intent{background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;padding:10px 14px;font-size:13px;flex-shrink:0}.detail-columns{display:grid;grid-template-columns:1fr 1fr;gap:12px;flex:1;overflow:hidden}.detail-left,.detail-right{background:var(--bg-surface);border:1px solid var(--border-bright);border-radius:8px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 2px 12px #0006}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:1px;color:var(--text-secondary);text-transform:uppercase;flex-shrink:0}.current-worker{font-size:11px;color:var(--accent)}.contract-editor{flex:1;background:var(--bg-elevated);border:none;color:var(--text-primary);font-family:var(--font-mono);font-size:12px;padding:12px;resize:none;outline:none;line-height:1.6}.contract-actions{padding:10px 12px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:center;flex-shrink:0}.btn-save{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);padding:6px 14px;border-radius:4px;cursor:pointer;font-size:12px}.btn-execute{background:var(--accent);border:none;color:#fff;padding:6px 16px;border-radius:4px;cursor:pointer;font-family:var(--font-mono);font-size:12px;font-weight:700}.prod-approval{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.prod-warning{color:var(--orange);font-size:12px;font-weight:700}.btn-prod-hold{background:var(--orange-dim);border:2px solid var(--orange);color:var(--orange);padding:6px 16px;border-radius:4px;cursor:pointer;font-family:var(--font-mono);font-size:12px;font-weight:700;-webkit-user-select:none;user-select:none}.btn-prod-hold.held{background:var(--green-dim);border-color:var(--green);color:var(--green)}.btn-approve-prod{background:var(--red);border:none;color:#fff;padding:6px 16px;border-radius:4px;cursor:pointer;font-family:var(--font-mono);font-size:12px;font-weight:700}.events-list{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.event-row{background:var(--bg-elevated);border:1px solid var(--border-bright);border-radius:4px;padding:6px 8px}.event-row.worker_started{border-left:2px solid var(--blue)}.event-row.worker_completed,.event-row.task_complete{border-left:2px solid var(--green)}.event-row.artifact_saved{border-left:2px solid var(--purple)}.event-row.escalated_to_tim,.event-row.tool_error_retry{border-left:2px solid var(--red)}.event-row.kicked_back,.event-row.awaiting_prod_approval{border-left:2px solid var(--orange)}.event-header{display:flex;gap:8px;align-items:center}.event-worker{font-family:var(--font-mono);font-size:11px;color:var(--accent);min-width:80px}.event-type{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);flex:1}.event-time{font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}.event-payload{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);margin-top:4px;white-space:pre-wrap;word-break:break-all;max-height:80px;overflow:hidden}.message-box{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border);flex-shrink:0}.message-input{flex:1;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);padding:6px 10px;border-radius:4px;font-size:13px;outline:none}.message-input:focus{border-color:var(--accent)}.message-send{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);padding:6px 14px;border-radius:4px;cursor:pointer;font-size:12px}.message-send:hover{border-color:var(--accent);color:var(--accent)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.memory-panel{display:flex;height:100%;gap:0;background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.memory-sidebar{width:220px;min-width:180px;border-right:1px solid var(--border);display:flex;flex-direction:column;background:var(--bg-base)}.memory-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;font-size:10px;font-weight:700;letter-spacing:.1em;color:var(--text-muted);border-bottom:1px solid var(--border);text-transform:uppercase}.refresh-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:14px;padding:2px 4px;border-radius:3px;transition:color .15s}.refresh-btn:hover{color:var(--accent)}.memory-file-list{flex:1;overflow-y:auto;padding:4px 0}.memory-file-item{display:flex;flex-direction:column;width:100%;padding:8px 12px;background:none;border:none;border-left:2px solid transparent;color:var(--text-secondary);cursor:pointer;text-align:left;transition:all .15s;gap:2px}.memory-file-item:hover{background:var(--bg-hover);color:var(--text-primary);border-left-color:var(--border-bright)}.memory-file-item.active{background:var(--bg-elevated);color:var(--accent);border-left-color:var(--accent)}.memory-file-name{font-size:12px;font-family:var(--font-mono);font-weight:500}.memory-file-meta{font-size:10px;color:var(--text-muted)}.memory-empty{padding:16px 12px;color:var(--text-muted);font-size:12px}.memory-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.memory-content-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.memory-content-title{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--accent)}.memory-content-actions{display:flex;align-items:center;gap:8px}.save-msg{font-size:11px;color:var(--green)}.btn-edit{background:var(--bg-hover);border:1px solid var(--border-bright);color:var(--text-primary);padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .15s}.btn-edit:hover{border-color:var(--accent);color:var(--accent)}.btn-cancel{background:none;border:1px solid var(--border);color:var(--text-secondary);padding:4px 10px;border-radius:4px;cursor:pointer;font-size:12px}.btn-cancel:hover{border-color:var(--red);color:var(--red)}.btn-save{background:var(--accent);border:none;color:#fff;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;transition:opacity .15s}.btn-save:hover{opacity:.85}.btn-save:disabled{opacity:.5;cursor:not-allowed}.memory-viewer{flex:1;overflow:auto;padding:16px 20px;font-family:var(--font-mono);font-size:12px;line-height:1.7;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.memory-editor{flex:1;padding:16px 20px;font-family:var(--font-mono);font-size:12px;line-height:1.7;color:var(--text-primary);background:var(--bg-base);border:none;outline:none;resize:none;width:100%;height:100%;min-height:400px}.memory-loading{padding:20px;color:var(--text-muted);font-size:12px}.memory-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;text-align:center}.memory-placeholder-icon{font-size:36px;opacity:.4}.memory-placeholder-text{font-size:14px;color:var(--text-secondary)}.memory-placeholder-sub{font-size:12px;color:var(--text-muted);line-height:1.6}.attachments-section{margin-top:8px}.attachment-count{color:var(--text-muted);font-weight:400}.attachments-list{display:flex;flex-direction:column;gap:4px;margin:6px 0;min-height:32px}.attachments-empty{font-size:11px;color:var(--text-muted);padding:6px 0;font-style:italic}.attachment-item{display:flex;align-items:center;gap:6px;padding:5px 8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:4px;font-size:12px}.attachment-icon{font-size:13px}.attachment-name{flex:1;font-family:var(--font-mono);color:var(--text-primary)}.attachment-size{color:var(--text-muted);font-size:10px}.attachment-upload{display:flex;align-items:center;gap:8px;margin-top:6px}.file-input-hidden{display:none}.btn-attach{display:inline-block;background:var(--bg-elevated);border:1px dashed var(--border-bright);color:var(--text-secondary);padding:5px 12px;border-radius:4px;cursor:pointer;font-size:11px;font-weight:500;transition:all .15s}.btn-attach:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.btn-attach.uploading{opacity:.6;cursor:not-allowed}.upload-msg{font-size:11px;color:var(--green)}.nav-btn{background:none;border:1px solid transparent;color:var(--text-secondary);padding:4px 10px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .15s}.nav-btn:hover{color:var(--text-primary);border-color:var(--border)}.nav-btn.active{color:var(--accent);border-color:var(--accent);background:var(--accent-dim)}.detail-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-bright);flex-shrink:0;background:var(--bg-elevated)}.detail-tab{display:flex;align-items:center;gap:5px;padding:9px 16px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;font-size:12px;font-family:var(--font-mono);font-weight:600;letter-spacing:.5px;text-transform:uppercase;transition:all .15s;margin-bottom:-1px}.detail-tab:hover{color:var(--text-secondary);background:var(--bg-hover)}.detail-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--bg-surface)}.tab-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);display:inline-block}.tab-badge{background:var(--accent-dim);color:var(--accent);border-radius:10px;padding:0 5px;font-size:10px;font-weight:700;min-width:16px;text-align:center}.job-memory-panel{display:flex;flex-direction:column;flex:1;overflow:hidden}.job-memory-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-elevated);flex-shrink:0}.job-memory-label{font-family:var(--font-mono);font-size:10px;color:var(--text-muted);letter-spacing:.05em}.job-memory-actions{display:flex;align-items:center;gap:6px}.btn-save-accent{background:var(--accent);border:none;color:#fff;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;transition:opacity .15s}.btn-save-accent:hover{opacity:.85}.btn-save-accent:disabled{opacity:.5;cursor:not-allowed}.attachments-panel{display:flex;flex-direction:column;flex:1;padding:12px;gap:10px;overflow-y:auto}.pending-approvals-badge{display:inline-block;margin-left:10px;padding:2px 8px;background:var(--red);color:#fff;border-radius:10px;font-size:11px;font-weight:700;letter-spacing:.03em;animation:pulse-badge 1.5s ease-in-out infinite}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.6}}.event-row.approval-card{background:var(--bg-elevated);border:1.5px solid var(--yellow);border-radius:8px;padding:12px 14px;margin-bottom:4px}.event-row.approval-card.resolved{border-color:var(--border);opacity:.65}.event-row.approval-card.pending{border-color:var(--yellow);box-shadow:0 0 10px #ffd1662e}.approval-card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.approval-icon{font-size:15px}.approval-title{flex:1;font-size:12px;font-weight:600;color:var(--text-primary);font-family:var(--font-mono)}.approval-operation{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:11px}.approval-op-label{color:var(--text-muted)}.approval-op-value{color:var(--text-secondary);font-weight:600;font-family:var(--font-mono)}.approval-risk{margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.08em;font-family:var(--font-mono)}.approval-command{background:#0d1018;border:1px solid var(--border);border-radius:4px;padding:8px 10px;font-size:11px;font-family:var(--font-mono);color:#a8d8a8;white-space:pre-wrap;word-break:break-all;margin-bottom:10px;max-height:120px;overflow-y:auto}.approval-resolved{font-size:11px;color:var(--green);font-weight:600;font-family:var(--font-mono)}.approval-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.deny-reason-input{flex:1;min-width:100px;padding:4px 8px;background:var(--bg-base);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-size:11px;outline:none}.deny-reason-input:focus{border-color:var(--red)}.btn-deny-approval{padding:4px 12px;background:transparent;border:1px solid var(--red);border-radius:4px;color:var(--red);font-size:11px;font-weight:600;cursor:pointer;transition:background .15s;font-family:var(--font-mono)}.btn-deny-approval:hover{background:var(--red-dim)}.btn-approve-tool{padding:4px 14px;background:var(--green);border:none;border-radius:4px;color:#080a0f;font-size:11px;font-weight:700;cursor:pointer;transition:opacity .15s;font-family:var(--font-mono)}.btn-approve-tool:hover{opacity:.85}.approval-msg{font-size:11px;font-weight:600;color:var(--accent);font-family:var(--font-mono)}
