:root{--bg: #0f1115;--panel: #181b22;--panel-2: #1f232c;--border: #2a2f3a;--text: #e6e8ec;--muted: #9aa3b2;--accent: #5b8cff;--accent-2: #3a6df0;--ok: #3ecf8e;--err: #ff6b6b;--warn: #e0a83e}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}.app{max-width:1200px;margin:0 auto;padding:20px}header.topbar{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:12px;margin-bottom:16px}header.topbar h1{font-size:18px;margin:0}.tabs{display:flex;gap:8px;margin-bottom:16px}.tabs button{background:var(--panel);color:var(--muted);border:1px solid var(--border);padding:8px 14px;border-radius:8px;cursor:pointer;font-size:14px}.tabs button.active{background:var(--accent-2);color:#fff;border-color:var(--accent)}.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:16px}.panel h2{font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0 0 12px}label{display:block;font-size:13px;color:var(--muted);margin-bottom:4px}input[type=text],input[type=password],textarea,select{width:100%;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:14px;font-family:inherit}textarea{resize:vertical}textarea.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.row{display:flex;gap:12px;flex-wrap:wrap}.row>*{flex:1;min-width:0}.field{margin-bottom:12px}button.btn{background:var(--accent-2);color:#fff;border:none;border-radius:8px;padding:9px 16px;font-size:14px;cursor:pointer}button.btn:hover{background:var(--accent)}button.btn:disabled{opacity:.5;cursor:not-allowed}button.btn.secondary{background:var(--panel-2);border:1px solid var(--border)}.varfield{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px}.varfield .name{width:180px;flex:none;font-family:ui-monospace,monospace;font-size:13px;padding-top:8px;color:var(--accent)}.varfield .control{flex:1}.varflags{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:10px}.varflag{display:inline-flex;align-items:center;gap:6px;font-size:13px;cursor:pointer}.varflag input{accent-color:var(--accent)}.varflag code{color:var(--accent)}.row-inputs{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.row-input{display:flex;flex-direction:column;gap:4px;max-width:160px}.row-input .key{color:var(--accent);font-family:ui-monospace,monospace;font-size:12px}.row-input .val{font-size:12px;word-break:break-word;color:var(--muted)}.row-input img{max-width:160px;max-height:160px;border-radius:8px;border:1px solid var(--border)}.progress{height:10px;background:var(--panel-2);border-radius:6px;overflow:hidden;margin:8px 0}.progress>div{height:100%;background:var(--ok);transition:width .2s}.gallery{display:flex;flex-wrap:wrap;gap:12px}.gallery img{max-width:320px;max-height:320px;border-radius:8px;border:1px solid var(--border)}.muted{color:var(--muted);font-size:13px}.err{color:var(--err);font-size:13px;white-space:pre-wrap}.ok{color:var(--ok)}.log{font-family:ui-monospace,monospace;font-size:12px;color:var(--muted);max-height:140px;overflow:auto;background:var(--panel-2);border-radius:8px;padding:8px}.copybox{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px;margin-bottom:8px}.copybox pre{margin:6px 0 0;white-space:pre-wrap;font-size:12px;max-height:160px;overflow:auto}.host-combobox{position:relative}.host-combobox[data-state=preset]{--host-accent: var(--accent)}.host-combobox[data-state=custom]{--host-accent: var(--warn)}.host-combobox[data-state=empty]{--host-accent: var(--border)}.host-field{display:flex;align-items:center;gap:4px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding-right:4px}.host-field:focus-within{border-color:var(--host-accent);box-shadow:0 0 0 2px var(--host-accent)}input.host-input{flex:1;min-width:0;width:auto;border:none;background:transparent;box-shadow:none;padding:8px 10px;font-size:14px;color:var(--text)}input.host-input:focus{outline:none}.host-adornments{display:flex;align-items:center;gap:4px;flex:none}.host-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--host-accent);color:var(--bg)}.host-icon-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;padding:4px 6px;border-radius:6px}.host-icon-btn:hover{color:var(--text);background:var(--panel)}.host-icon-btn:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.host-chevron{transition:transform .15s}.host-chevron[aria-expanded=true]{transform:rotate(180deg)}.host-listbox{list-style:none;margin:4px 0 0;padding:4px;position:absolute;left:0;right:0;z-index:20;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;max-height:240px;overflow:auto;box-shadow:0 8px 24px #0006}.host-option{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:6px;cursor:pointer;font-size:13px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.host-option.highlight{background:var(--panel)}.host-option[aria-selected=true]{color:var(--accent)}.host-check{width:14px;flex:none;color:var(--accent)}.host-option-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(prefers-reduced-motion:reduce){.host-chevron{transition:none}}.template-editor{display:flex;flex-direction:column;gap:8px}.te-toolbar{display:flex;align-items:center;gap:8px}.te-menu-wrap{position:relative}.te-menu{min-width:280px}.te-upload-item{border-top:1px solid var(--border);margin-top:2px;padding-top:9px}.te-badge{font-size:12px;font-weight:600;padding:2px 10px;border-radius:999px;background:var(--accent);color:var(--bg);white-space:nowrap}.te-badge[data-warm=true]{background:var(--warn)}.te-cm{border:1px solid var(--border);border-radius:8px;overflow:hidden}.te-cm .cm-editor{border-radius:8px}.te-cm .cm-editor.cm-focused{outline:none;box-shadow:0 0 0 2px var(--accent)}.te-status{display:flex;gap:14px;align-items:baseline;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.hostinfo-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px}.hostinfo-bar .err{font-size:13px}.hostinfo-panel{border:1px solid var(--border);border-radius:10px;background:var(--panel-2);margin-bottom:16px;overflow:hidden}.hostinfo-header{display:flex;align-items:center;gap:8px;padding:4px 6px 4px 4px}.hostinfo-disclosure{flex:1;min-width:0;display:flex;align-items:center;gap:10px;background:none;border:none;color:var(--text);cursor:pointer;padding:8px 10px;border-radius:8px;text-align:left}.hostinfo-disclosure:hover{background:var(--panel)}.hostinfo-disclosure:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.hostinfo-caret{display:inline-block;color:var(--muted);font-size:12px}.hostinfo-disclosure[aria-expanded=true] .hostinfo-caret{transform:rotate(90deg)}.hostinfo-title{font-size:14px;font-weight:600;flex:none}.hostinfo-summary{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.hostinfo-refresh{flex:none}.hostinfo-body{padding:0 12px 14px}.hostinfo-panel>.err{margin:0 12px 12px}@media(prefers-reduced-motion:no-preference){.hostinfo-caret{transition:transform .15s}}.hostinfo-tabs{display:flex;flex-wrap:wrap;gap:4px;border-bottom:1px solid var(--border);margin-bottom:12px}.hostinfo-tab{background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px;padding:7px 10px;border-bottom:2px solid transparent;margin-bottom:-1px}.hostinfo-tab:hover{color:var(--text)}.hostinfo-tab[aria-selected=true]{color:var(--text);border-bottom-color:var(--accent)}.hostinfo-tab:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;border-radius:4px}.hostinfo-count{font-size:11px;color:var(--muted);background:var(--panel-2);padding:1px 6px;border-radius:999px}.hostinfo-tab[aria-selected=true] .hostinfo-count{color:var(--accent)}.hostinfo-filter{display:flex;align-items:center;gap:10px;margin-bottom:10px}.hostinfo-filter input{max-width:280px}.hostinfo-filter .muted{font-size:12px;white-space:nowrap}.hostinfo-chips{display:flex;flex-wrap:wrap;gap:6px}.hostinfo-chip{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--text);background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:4px 9px;cursor:pointer}.hostinfo-chip:hover{border-color:var(--accent);color:var(--accent)}.hostinfo-chip:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.hostinfo-chip.copied{border-color:var(--ok);color:var(--ok)}.hostinfo-empty{margin:0}@media(prefers-reduced-motion:no-preference){.hostinfo-chip{transition:border-color .12s,color .12s}}.login-wrap{max-width:360px;margin:80px auto}.history{display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px;align-items:start}.history-list,.history-detail{max-height:72vh;overflow:auto}.history-detail>.muted{margin-top:0}.history-meta{margin:0 0 12px;font-size:12px}.history-subhead{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:18px 0 8px}.history-subhead:first-of-type{margin-top:0}table.runs{width:100%;border-collapse:collapse;font-size:13px}table.runs td,table.runs th{border-bottom:1px solid var(--border);padding:8px;text-align:left}table.runs thead th{position:sticky;top:0;background:var(--panel);z-index:1}table.runs tbody tr{cursor:pointer}table.runs tbody tr:hover{background:var(--panel-2)}table.runs tbody tr.selected{background:var(--panel-2);box-shadow:inset 2px 0 0 var(--accent)}@media(max-width:860px){.history{grid-template-columns:1fr}.history-list,.history-detail{max-height:none}}.badge{padding:2px 8px;border-radius:6px;font-size:12px}.badge.completed{background:#3ecf8e26;color:var(--ok)}.badge.error{background:#ff6b6b26;color:var(--err)}.badge.running{background:#5b8cff26;color:var(--accent)}
