:root{--bg: #0a0a0f;--surface: #12121a;--surface-hover: #1a1a25;--border: #2a2a35;--text: #e0e0e8;--text-dim: #8888a0;--accent: #6366f1;--accent-hover: #818cf8;--danger: #ef4444;--success: #22c55e;--warning: #f59e0b}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:14px;line-height:1.5}.login{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:40px;width:360px;text-align:center}.login-card h1{margin-bottom:24px;font-size:22px}.login-card input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:14px;margin-bottom:12px}.login-card button{width:100%;padding:10px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px}.login-card button:hover{background:var(--accent-hover)}.app{max-width:1100px;margin:0 auto;padding:24px}header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}header h1{font-size:22px;font-weight:600}.back{background:none;border:1px solid var(--border);color:var(--text);padding:6px 14px;border-radius:6px;cursor:pointer;margin-right:16px}.dispatch-btn{background:var(--accent);color:#fff;border:none;padding:8px 18px;border-radius:8px;cursor:pointer;font-size:14px}.dispatch-btn:hover{background:var(--accent-hover)}.header-actions{display:flex;align-items:center;gap:12px}.user-badge{font-size:12px;color:var(--text-dim);padding:4px 10px;border:1px solid var(--border);border-radius:12px}section{margin-bottom:32px}section h2{font-size:16px;font-weight:500;color:var(--text-dim);margin-bottom:12px}.empty{color:var(--text-dim);font-style:italic}.error{color:var(--danger);margin-bottom:12px}.env-list{display:flex;flex-direction:column;gap:8px}.env-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 18px;cursor:pointer;transition:background .15s}.env-card:hover{background:var(--surface-hover)}.env-card.running{border-left:3px solid var(--success)}.env-card.starting,.env-card.provisioning,.env-card.stopping{border-left:3px solid var(--warning)}.env-card.failed{border-left:3px solid var(--danger)}.env-card-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.status-icon{font-size:12px}.env-id{font-weight:600;font-family:monospace}.env-project{color:var(--accent)}.env-stack{color:var(--text-dim);font-size:12px}.env-user{margin-left:auto;color:var(--text-dim)}.env-card-details{display:flex;gap:16px;font-size:13px;color:var(--text-dim)}.env-card-details .branch{font-family:monospace}.env-card-actions{display:flex;gap:8px;margin-top:10px}.env-card-actions a,.env-card-actions button.small{font-size:12px;padding:4px 10px;border-radius:5px;text-decoration:none;border:1px solid var(--border);background:none;color:var(--text);cursor:pointer}.env-card-actions a:hover,.env-card-actions button.small:hover{background:var(--surface-hover)}.env-card-actions .danger{color:var(--danger);border-color:var(--danger)}.env-card-pr{margin-top:8px;font-size:13px}.env-card-pr a{color:var(--accent);text-decoration:none}.detail-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.detail-header h2{font-size:20px}.status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.status-badge.running{background:#052e16;color:var(--success)}.status-badge.starting,.status-badge.provisioning{background:#422006;color:var(--warning)}.status-badge.stopped{background:#1a1a25;color:var(--text-dim)}.status-badge.failed{background:#450a0a;color:var(--danger)}.detail-actions{display:flex;gap:10px;margin-bottom:24px;flex-wrap:wrap}.btn{padding:8px 16px;border-radius:7px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:13px;text-decoration:none}.btn:hover{background:var(--surface-hover)}.btn.danger{color:var(--danger);border-color:var(--danger)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:24px}.detail-section{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px}.detail-section h3{font-size:14px;font-weight:500;color:var(--text-dim);margin-bottom:12px}dl{display:grid;grid-template-columns:auto 1fr;gap:6px 16px}dt{color:var(--text-dim);font-size:13px}dd{font-size:13px}dd code{font-family:monospace;background:var(--bg);padding:1px 5px;border-radius:3px}dd.prompt{font-size:12px;color:var(--text-dim);max-height:60px;overflow:hidden}.activity-feed{display:flex;flex-direction:column;gap:4px}.activity-item{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:13px;border-bottom:1px solid var(--border)}.activity-icon{font-size:12px;width:20px;text-align:center}.activity-time{color:var(--text-dim);font-family:monospace;min-width:60px}.activity-env{font-family:monospace;font-weight:500;min-width:80px}.activity-action{color:var(--accent);min-width:100px}.activity-details{color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.dispatch-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px;width:480px;max-height:90vh;overflow-y:auto}.dispatch-form h2{margin-bottom:20px;font-size:18px}.dispatch-form label{display:block;margin-bottom:14px;font-size:13px;color:var(--text-dim)}.dispatch-form input,.dispatch-form select,.dispatch-form textarea{display:block;width:100%;margin-top:4px;padding:8px 12px;border:1px solid var(--border);border-radius:7px;background:var(--bg);color:var(--text);font-size:14px;font-family:inherit}.dispatch-form textarea{resize:vertical}.radio-group{display:flex;gap:16px;margin-top:6px}.radio-group label{display:flex;align-items:center;gap:6px;color:var(--text);margin-bottom:0}.form-row{display:flex;gap:14px}.form-row label{flex:1}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.form-actions button{padding:8px 18px;border-radius:7px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:14px}.form-actions .primary{background:var(--accent);border-color:var(--accent);color:#fff}.form-actions .primary:hover{background:var(--accent-hover)}.form-actions .primary:disabled{opacity:.6;cursor:not-allowed}.tab-bar{display:flex;gap:2px;margin-bottom:20px;border-bottom:1px solid var(--border)}.tab{padding:8px 18px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-dim);cursor:pointer;font-size:14px}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.logs-section{max-width:100%}.logs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.logs-output{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:14px;font-family:Cascadia Code,Fira Code,monospace;font-size:12px;line-height:1.5;max-height:500px;overflow:auto;white-space:pre-wrap;word-break:break-all;color:var(--text-dim)}.command-form{display:flex;gap:8px;margin-top:12px}.command-input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:7px;background:var(--bg);color:var(--text);font-family:monospace;font-size:13px}.command-input::placeholder{color:var(--text-dim)}.command-status{margin-top:6px;font-size:12px;color:var(--text-dim)}.btn-sm{padding:5px 12px;font-size:12px}
