:root{--bg: #0f1115;--surface: #181b22;--surface-2: #20242d;--border: #2c313c;--text: #e8eaf0;--text-dim: #a4abba;--accent: #6ea8fe;--accent-strong: #3b82f6;--ok: #4ade80;--warn: #fbbf24;--danger: #f87171;--radius: 10px;--radius-sm: 6px;--shadow: 0 6px 24px rgba(0, 0, 0, .35);--font: "Hiragino Kaku Gothic ProN", "Noto Sans JP", system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.55}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{line-height:1.25;margin:0 0 .4em}.app-shell{min-height:100%;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:1.25rem;padding:.75rem 1.5rem;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.brand{font-weight:700;font-size:1.1rem;letter-spacing:.02em}.topnav{display:flex;gap:.25rem;flex-wrap:wrap}.topnav a{color:var(--text-dim);padding:.4rem .7rem;border-radius:var(--radius-sm);font-size:.92rem}.topnav a:hover{color:var(--text);background:var(--surface-2);text-decoration:none}.topnav a.active{color:var(--text);background:var(--surface-2)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:.75rem}.tenant-chip{font-size:.82rem;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);padding:.25rem .6rem;border-radius:999px}.content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem}.auth-wrap{min-height:100%;display:grid;place-items:center;padding:2rem}.auth-card{width:100%;max-width:380px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.card+.card{margin-top:1rem}.grid{display:grid;gap:1rem}.grid-agents{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.agent-card{display:flex;flex-direction:column;gap:.5rem}.agent-card h3{margin:0}.agent-card .key{font-size:.78rem;color:var(--text-dim);font-family:ui-monospace,monospace}.spacer{flex:1}button,.btn{font-family:inherit;font-size:.95rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text);padding:.5rem .9rem;cursor:pointer;transition:background .12s,border-color .12s}button:hover:not(:disabled),.btn:hover:not(:disabled){border-color:var(--accent)}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-strong);border-color:var(--accent-strong);color:#fff;font-weight:600}.btn-primary:hover:not(:disabled){background:#2f6fd6}.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-row{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}label{display:block;font-size:.86rem;color:var(--text-dim);margin-bottom:.3rem}.field{margin-bottom:1rem}input,textarea,select{width:100%;font-family:inherit;font-size:.95rem;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.55rem .7rem}input:focus,textarea:focus,select:focus,button:focus-visible,a:focus-visible{outline:2px solid var(--accent);outline-offset:1px}textarea{min-height:120px;resize:vertical}.badge{display:inline-block;font-size:.74rem;padding:.12rem .5rem;border-radius:999px;border:1px solid var(--border);color:var(--text-dim)}.badge-ok{color:var(--ok);border-color:var(--ok)}.badge-warn{color:var(--warn);border-color:var(--warn)}.badge-danger{color:var(--danger);border-color:var(--danger)}.badge-accent{color:var(--accent);border-color:var(--accent)}.alert{border:1px solid var(--border);border-left-width:4px;border-radius:var(--radius-sm);padding:.75rem 1rem;margin:.5rem 0;background:var(--surface-2)}.alert-error{border-left-color:var(--danger)}.alert-warn{border-left-color:var(--warn)}.alert-info{border-left-color:var(--accent)}.alert-ok{border-left-color:var(--ok)}.run-layout{display:grid;grid-template-columns:280px 1fr;gap:1.25rem;align-items:start}@media(max-width:860px){.run-layout{grid-template-columns:1fr}}.step-rail{list-style:none;margin:0;padding:0}.step-rail li{display:flex;gap:.6rem;padding:.5rem 0;border-bottom:1px dashed var(--border);align-items:flex-start}.step-rail li:last-child{border-bottom:none}.step-dot{flex:0 0 auto;width:1.5rem;height:1.5rem;border-radius:999px;border:1px solid var(--border);display:grid;place-items:center;font-size:.74rem;color:var(--text-dim)}.step-running .step-dot{border-color:var(--accent);color:var(--accent);animation:pulse 1.2s ease-in-out infinite}.step-done .step-dot{border-color:var(--ok);color:var(--ok)}.step-awaiting .step-dot{border-color:var(--warn);color:var(--warn)}.step-failed .step-dot{border-color:var(--danger);color:var(--danger)}.step-meta{display:flex;flex-direction:column}.step-kind{font-size:.9rem}.step-status{font-size:.76rem;color:var(--text-dim)}@keyframes pulse{50%{opacity:.5}}.reasoning-pane{background:var(--bg);border:1px dashed var(--accent);border-radius:var(--radius-sm);padding:1rem;min-height:160px;max-height:360px;overflow-y:auto;white-space:pre-wrap;font-family:ui-monospace,SFMono-Regular,monospace;font-size:.85rem;color:var(--text-dim)}.reasoning-label{font-size:.78rem;color:var(--accent);margin-bottom:.4rem;font-weight:600}.estimate-bar{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.9rem}.estimate-bar strong{font-size:1.1rem}.vp-list{list-style:none;padding:0;margin:0;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.vp-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}.vp-card .vp-ja{font-weight:600;font-size:1.02rem}.vp-card .vp-en{color:var(--text-dim);font-style:italic;margin-top:.25rem}table.journey{width:100%;border-collapse:collapse;font-size:.85rem}table.journey caption{text-align:left;font-weight:600;margin-bottom:.5rem}table.journey th,table.journey td{border:1px solid var(--border);padding:.5rem .6rem;vertical-align:top;text-align:left}table.journey th[scope=row]{background:var(--surface-2);white-space:nowrap}table.journey thead th{background:var(--surface-2)}.note-callout{border:1px solid var(--warn);border-radius:var(--radius-sm);background:#fbbf2414;padding:.75rem 1rem}.dl dt{font-size:.8rem;color:var(--text-dim);margin-top:.5rem}.dl dd{margin:.1rem 0 0}table.list{width:100%;border-collapse:collapse}table.list th,table.list td{text-align:left;padding:.55rem .6rem;border-bottom:1px solid var(--border);font-size:.9rem}table.list th{color:var(--text-dim);font-weight:600}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:50}.dialog{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;max-width:440px;width:90%;box-shadow:var(--shadow)}.muted{color:var(--text-dim)}.row-between{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.stack>*+*{margin-top:.75rem}.spinner{width:1.1rem;height:1.1rem;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;display:inline-block;animation:spin .7s linear infinite;vertical-align:-2px}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--surface-2) 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.2s infinite;border-radius:var(--radius-sm);height:1rem}@keyframes shimmer{to{background-position:-200% 0}}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.pill-list{display:flex;gap:.4rem;flex-wrap:wrap}.chip{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:.15rem .6rem;font-size:.8rem}
