:root{--bg: #f7f8fa;--bg-elev: #ffffff;--bg-elev-2: #f3f4f6;--bg-code: #0f172a;--border: #e5e7eb;--border-strong: #d1d5db;--text: #111827;--text-dim: #4b5563;--text-mute: #6b7280;--text-on-accent: #ffffff;--text-on-code: #e2e8f0;--accent: #10b981;--accent-hover: #059669;--accent-strong: #047857;--accent-soft: rgba(16, 185, 129, .1);--accent-ring: rgba(16, 185, 129, .2);--info: #2563eb;--info-soft: rgba(37, 99, 235, .1);--warn: #d97706;--warn-soft: rgba(217, 119, 6, .1);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .08);--tag-mobile-text: #047857;--tag-mobile-bg: rgba(16, 185, 129, .1);--tag-mobile-border: rgba(16, 185, 129, .28);--tag-cps-text: #1d4ed8;--tag-cps-bg: rgba(37, 99, 235, .08);--tag-cps-border: rgba(37, 99, 235, .25);--tag-meta-text: #1d4ed8;--tag-meta-bg: rgba(37, 99, 235, .08);--tag-meta-border: rgba(37, 99, 235, .25);--tag-affplus-text: #b45309;--tag-affplus-bg: rgba(217, 119, 6, .1);--tag-affplus-border: rgba(217, 119, 6, .28);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 32px;--space-8: 40px;--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--radius-pill: 999px;--fs-xs: 12px;--fs-sm: 13px;--fs-base: 15px;--fs-md: 16px;--fs-lg: 18px;--fs-xl: 22px;--fs-2xl: 26px;--shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);--shadow-sm: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 4px 12px rgba(15, 23, 42, .06), 0 1px 3px rgba(15, 23, 42, .04);--shadow-lg: 0 12px 32px rgba(15, 23, 42, .08);--font-display: "Inter", "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--ease: cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-display);font-size:var(--fs-base);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#root{min-height:100vh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;min-height:100vh}code{font-family:var(--font-mono);font-size:.92em;background:var(--bg-elev-2);padding:1px 6px;border-radius:4px;color:var(--text)}a{color:var(--accent-strong)}.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 32px;border-bottom:1px solid var(--border);background:var(--bg-elev);position:sticky;top:0;z-index:10}.brand{display:flex;align-items:center;gap:12px}.brand-mark{color:var(--accent);font-family:var(--font-mono);letter-spacing:-2px;font-size:22px;line-height:1}.brand-name{font-family:var(--font-display);font-weight:700;letter-spacing:.06em;font-size:var(--fs-sm);color:var(--text);text-transform:uppercase}nav{display:flex;gap:4px;align-items:center}.nav-btn{background:transparent;color:var(--text-dim);border:1px solid transparent;padding:9px 16px;cursor:pointer;font-family:var(--font-display);font-weight:500;font-size:var(--fs-sm);border-radius:var(--radius);transition:background .12s var(--ease),color .12s var(--ease),border-color .12s var(--ease)}.nav-btn:hover,.nav-btn.active{color:var(--text);background:var(--bg-elev-2)}.nav-btn.primary{background:var(--accent);color:var(--text-on-accent);font-weight:600;border-color:var(--accent);box-shadow:var(--shadow-xs)}.nav-btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:var(--text-on-accent)}.nav-btn.ghost{color:var(--text-mute)}.nav-btn.ghost:hover{color:var(--text);background:var(--bg-elev-2)}.nav-user{font-size:var(--fs-sm);color:var(--text-mute);margin-left:12px;padding:0 8px}main{flex:1;padding:32px;max-width:1400px;width:100%;margin:0 auto}.panel{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.panel-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border);gap:16px}.panel-head h2{font-size:var(--fs-lg);font-weight:600;letter-spacing:-.01em;color:var(--text)}.panel-meta{color:var(--text-mute);font-family:var(--font-mono);font-size:var(--fs-xs)}.empty{text-align:center;padding:96px 24px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.empty-title{font-size:var(--fs-lg);font-weight:600;margin-bottom:8px;color:var(--text)}.empty-sub{color:var(--text-dim);margin-bottom:28px;font-size:var(--fs-base)}.jobs-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}.jobs-table th{text-align:left;padding:12px 20px;font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-mute);border-bottom:1px solid var(--border);background:var(--bg-elev-2)}.jobs-table td{padding:16px 20px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.jobs-row{cursor:pointer;transition:background .1s var(--ease)}.jobs-row:hover{background:var(--bg-elev-2)}.jobs-row:last-child td{border-bottom:none}.mono{font-family:var(--font-mono)}.small{font-size:var(--fs-xs)}.muted{color:var(--text-mute)}.tag{display:inline-block;padding:3px 9px;border-radius:var(--radius-pill);font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.04em;line-height:1.6;border:1px solid transparent}.tag-mobile{background:var(--tag-mobile-bg);color:var(--tag-mobile-text);border-color:var(--tag-mobile-border)}.tag-cps{background:var(--tag-cps-bg);color:var(--tag-cps-text);border-color:var(--tag-cps-border)}.tag-meta{background:var(--tag-meta-bg);color:var(--tag-meta-text);border-color:var(--tag-meta-border)}.tag-affplus{background:var(--tag-affplus-bg);color:var(--tag-affplus-text);border-color:var(--tag-affplus-border)}.status{display:inline-block;padding:3px 10px;border-radius:var(--radius-pill);font-family:var(--font-display);font-size:11px;font-weight:600;text-transform:capitalize;letter-spacing:.02em;line-height:1.6;border:1px solid transparent}.status-pending{background:var(--bg-elev-2);color:var(--text-dim);border-color:var(--border)}.status-running{background:var(--warn-soft);color:var(--warn);border-color:#d9770647}.status-completed{background:var(--accent-soft);color:var(--accent-strong);border-color:#10b98147}.status-failed{background:var(--danger-soft);color:var(--danger);border-color:#dc262647}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border:1px solid var(--border-strong);background:var(--bg-elev);color:var(--text);font-family:var(--font-display);font-weight:500;font-size:var(--fs-sm);cursor:pointer;text-decoration:none;border-radius:var(--radius);transition:background .12s var(--ease),border-color .12s var(--ease),box-shadow .12s var(--ease),color .12s var(--ease);box-shadow:var(--shadow-xs);line-height:1.4}.btn:hover{background:var(--bg-elev-2);border-color:var(--text-mute)}.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring);border-color:var(--accent)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.primary{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent);font-weight:600}.btn.primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn.primary:disabled{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent);opacity:.5}.btn.ghost{background:transparent;border-color:transparent;color:var(--text-dim);box-shadow:none}.btn.ghost:hover{color:var(--text);background:var(--bg-elev-2);border-color:transparent}.btn.small{padding:6px 12px;font-size:var(--fs-xs);border-radius:var(--radius-sm)}.form-panel{padding-bottom:24px}.form-row{padding:24px 28px;border-bottom:1px solid var(--border)}.form-row:last-of-type{border-bottom:none}.form-row label{display:block;font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-mute);margin-bottom:12px}.input{width:100%;padding:11px 14px;background:var(--bg-elev);border:1px solid var(--border-strong);color:var(--text);font-family:var(--font-display);font-size:var(--fs-base);border-radius:var(--radius);transition:border-color .12s var(--ease),box-shadow .12s var(--ease);line-height:1.5}.input::placeholder{color:var(--text-mute)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}input[type=email].input,input[type=text].input{font-family:var(--font-display)}.form-hint{margin-top:10px;font-size:var(--fs-sm);color:var(--text-mute);line-height:1.55}.form-hint code{font-size:var(--fs-xs)}.checkbox-row{display:flex;flex-direction:column;gap:12px}.checkbox{display:flex!important;align-items:center;gap:12px;cursor:pointer;font-size:var(--fs-base)!important;text-transform:none!important;letter-spacing:0!important;font-weight:500!important;color:var(--text)!important;margin-bottom:0!important;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-elev);transition:border-color .12s var(--ease),background .12s var(--ease)}.checkbox:hover{border-color:var(--border-strong);background:var(--bg-elev-2)}.checkbox input{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.checkbox input:disabled{cursor:not-allowed}.checkbox input:disabled+span{opacity:.5}.form-actions{padding:24px 28px 0;display:flex;justify-content:flex-end;gap:12px}.error{margin:16px 28px;padding:14px 18px;background:var(--danger-soft);border:1px solid rgba(220,38,38,.28);color:var(--danger);border-radius:var(--radius);font-size:var(--fs-sm);line-height:1.55}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1px;background:var(--border)}.field{background:var(--bg-elev);padding:18px 24px;display:flex;flex-direction:column;gap:6px}.field-label{font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-mute)}.field-value{font-size:var(--fs-base);color:var(--text)}.cta-row{padding:24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px}.logs-section{border-top:1px solid var(--border)}.logs-section summary{padding:16px 24px;cursor:pointer;font-weight:600;font-size:var(--fs-sm);color:var(--text);background:var(--bg-elev-2);-webkit-user-select:none;user-select:none;list-style:none}.logs-section summary::-webkit-details-marker{display:none}.logs-section summary:before{content:"▸";display:inline-block;margin-right:8px;color:var(--text-mute);transition:transform .15s var(--ease)}.logs-section[open] summary:before{transform:rotate(90deg)}.logs-section summary:hover{background:var(--border)}.logs{font-family:var(--font-mono);font-size:var(--fs-xs);background:var(--bg-code);color:var(--text-on-code);padding:18px 24px;max-height:520px;overflow-y:auto;white-space:pre-wrap;line-height:1.6}.log-line{display:flex;gap:14px;padding:2px 0}.log-ts{color:#94a3b8;white-space:nowrap}.log-level{width:64px;color:#94a3b8}.log-msg{flex:1;word-break:break-word}.log-error .log-level{color:#f87171}.log-warn .log-level{color:#fbbf24}.log-info .log-level{color:#34d399}.settings-connected{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 18px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius)}.settings-connected code{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--text);background:var(--bg-elev);border:1px solid var(--border)}.settings-recipient{display:flex;gap:12px;align-items:stretch}.settings-recipient .input{flex:1}.phase-progress{padding:24px 28px;border-bottom:1px solid var(--border);background:var(--bg-elev-2)}.phase-stepper{display:flex;align-items:flex-start;gap:0;margin-bottom:18px;overflow-x:auto}.phase-step{position:relative;display:flex;flex-direction:column;align-items:center;flex:1;min-width:96px}.phase-step-dot{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--bg-elev);border:1.5px solid var(--border-strong);color:var(--text-mute);font-family:var(--font-mono);font-size:var(--fs-xs);font-weight:700;z-index:2;transition:all .18s var(--ease)}.phase-step-label{margin-top:10px;font-size:var(--fs-xs);font-weight:600;letter-spacing:.02em;color:var(--text-mute);text-align:center;white-space:nowrap}.phase-step-bar{position:absolute;top:15px;left:50%;right:-50%;height:2px;background:var(--border-strong);z-index:1}.phase-step-bar-complete{background:var(--accent)}.phase-step-complete .phase-step-dot{background:var(--accent);border-color:var(--accent);color:var(--text-on-accent)}.phase-step-complete .phase-step-label{color:var(--text-dim)}.phase-step-current .phase-step-dot{background:var(--bg-elev);border-color:var(--accent);color:var(--accent-strong);box-shadow:0 0 0 4px var(--accent-ring);animation:phase-pulse 1.8s ease-in-out infinite}.phase-step-current .phase-step-label{color:var(--accent-strong)}.phase-failed .phase-step-dot{border-color:var(--danger);color:var(--danger)}@keyframes phase-pulse{0%,to{box-shadow:0 0 0 4px var(--accent-ring)}50%{box-shadow:0 0 0 8px #10b9811a}}.phase-description{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);font-size:var(--fs-sm)}.phase-description-label{font-weight:600;color:var(--accent-strong);font-family:var(--font-display);font-size:var(--fs-xs);letter-spacing:.04em;text-transform:uppercase}.phase-description-detail{color:var(--text-dim);font-family:var(--font-mono);font-size:var(--fs-xs);word-break:break-word}.phase-failed .phase-description-label{color:var(--danger)}.phase-spinner{width:14px;height:14px;border-radius:50%;border:2px solid var(--accent-ring);border-top-color:var(--accent);animation:phase-spin .9s linear infinite;flex-shrink:0}@keyframes phase-spin{to{transform:rotate(360deg)}}.phase-pill{display:inline-flex;align-items:center;gap:7px;padding:4px 10px;border-radius:var(--radius-pill);background:var(--accent-soft);border:1px solid rgba(16,185,129,.28);color:var(--accent-strong);font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.02em}.phase-pill-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:phase-pulse-small 1.4s ease-in-out infinite}@keyframes phase-pulse-small{0%,to{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.8)}}@media (max-width: 768px){main{padding:20px 16px}.topbar{padding:14px 18px;flex-wrap:wrap;gap:12px}.nav-user{display:none}.panel-head{padding:16px 18px;flex-wrap:wrap}.form-row{padding:18px}.form-actions{padding:18px 18px 0}.field{padding:14px 18px}.jobs-table th,.jobs-table td{padding:12px 14px}}:root{--tag-appgoblin-text: #7c3aed;--tag-appgoblin-bg: rgba(124, 58, 237, .1);--tag-appgoblin-border: rgba(124, 58, 237, .28)}.tag-appgoblin{background:var(--tag-appgoblin-bg);color:var(--tag-appgoblin-text);border-color:var(--tag-appgoblin-border)}
