:root{--font-sans: "Inter", ui-sans-serif, system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;--bg: #f7f7f6;--panel: #ffffff;--panel-2: #fafafa;--ink: #18181b;--ink-2: #3f3f46;--muted: #71717a;--line: #e4e4e7;--line-2: #d4d4d8;--accent: #2563eb;--accent-ink: #1d4ed8;--ok: #15803d;--ok-bg: #dcfce7;--warn: #b45309;--warn-bg: #fef3c7;--err: #dc2626;--err-bg: #fee2e2;--gray: #71717a;--gray-bg: #f4f4f5;--radius: 8px;--radius-sm: 6px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04), 0 1px 3px rgba(0, 0, 0, .06);--ring: 0 0 0 3px rgba(37, 99, 235, .25)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}::selection{background:#2563eb2e}code{font-family:var(--font-mono);font-size:.92em}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--radius-sm)}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:999px;border:3px solid var(--bg)}*::-webkit-scrollbar-thumb:hover{background:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--line-2);background:var(--panel);color:var(--ink);font:inherit;font-weight:600;font-size:13px;cursor:pointer;transition:background .12s ease,border-color .12s ease,transform .04s ease,box-shadow .12s ease}.btn:hover{background:var(--panel-2);border-color:var(--muted)}.btn:active{transform:translateY(.5px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:disabled:hover{background:var(--panel);border-color:var(--line-2)}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-ink);border-color:var(--accent-ink)}.btn--danger{background:#fff;border-color:var(--err);color:var(--err)}.btn--danger:hover{background:var(--err-bg)}.btn--ghost{background:none;border:none;color:var(--accent);padding:2px 4px;font-weight:500}.btn--ghost:hover{background:none;color:var(--accent-ink);text-decoration:underline}.btn--block{width:100%}.input{width:100%;padding:7px 10px;border:1px solid var(--line-2);border-radius:var(--radius-sm);background:var(--panel);font-family:var(--font-mono);font-size:13px;color:var(--ink);transition:border-color .12s ease,box-shadow .12s ease}.input:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}.input:disabled{background:var(--gray-bg);color:var(--muted)}select.input{font-family:var(--font-sans);cursor:pointer}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 10px}.row-btn{display:block;width:100%;text-align:left;padding:11px 13px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel);color:var(--ink);font:inherit;font-size:14px;cursor:pointer;transition:border-color .12s ease,background .12s ease,box-shadow .12s ease}.row-btn:hover{border-color:var(--accent);background:var(--panel-2);box-shadow:var(--shadow-sm)}.step-rail{display:flex;align-items:center;gap:2px;padding:10px 20px;border-bottom:1px solid var(--line);background:var(--panel)}.step{background:none;border:none;font:inherit;font-size:12px;font-weight:500;color:var(--muted);padding:5px 10px;border-radius:999px;cursor:pointer;transition:background .12s ease,color .12s ease}.step:not(:disabled):hover{background:var(--gray-bg);color:var(--ink-2)}.step--done{color:var(--accent)}.step--active,.step--active:hover{background:var(--accent);color:#fff}.step:disabled{color:var(--line-2);cursor:not-allowed}.step-sep{color:var(--line-2);font-size:11px}.badge{justify-self:end;padding:2px 9px;border-radius:999px;font-family:var(--font-sans);font-size:11px;font-weight:600;white-space:nowrap}.badge--ok{background:var(--ok-bg);color:var(--ok)}.badge--warn{background:var(--warn-bg);color:var(--warn)}.badge--err{background:var(--err-bg);color:var(--err)}.badge--net{background:var(--gray-bg);color:var(--gray)}.badge--full{background:#e0e7ff;color:#3730a3}.badge--template{background:var(--gray-bg);color:var(--gray)}.seg{display:flex;gap:6px}.seg label{flex:1;border:1px solid var(--line-2);border-radius:var(--radius-sm);padding:8px 10px;font-size:12px;text-align:center;cursor:pointer;transition:border-color .12s ease,background .12s ease}.seg label:hover{border-color:var(--muted)}.seg label.on{border-color:var(--accent);background:#eff6ff;color:var(--accent);font-weight:600}.seg label small{display:block;color:var(--muted);font-weight:400;margin-top:2px}.seg input{position:absolute;opacity:0;pointer-events:none}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000002e;display:grid;place-items:center;z-index:50}.dialog{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 12px 40px #0000002e;width:380px;padding:18px}.log-row{transition:background .1s ease}.log-row:hover{background:var(--panel-2)}.check{display:flex;gap:8px;align-items:center;font-size:13px;cursor:pointer}.check input{accent-color:var(--accent);width:15px;height:15px}.app-too-small{display:none}@media (max-width: 1023px){.app-shell{display:none}.app-too-small{display:grid;place-items:center;height:100%;padding:24px;text-align:center;color:var(--muted)}}
