:root{color-scheme:dark;--bg: #1b1e24;--bg-elevated: #22262e;--bg-hover: #292d36;--bg-active: #30343f;--surface: #232730;--surface-2: #272b35;--border: #353a46;--border-strong: #424857;--border-active: #5a6173;--text: #f1f3f8;--text-muted: #b3b9c8;--text-subtle: #7e8497;--accent: #8b9bff;--accent-soft: rgba(139, 155, 255, .16);--accent-strong: #6f81ff;--ok: #4ade80;--warn: #fbbf24;--critical: #fb7185;--info: #7dd3fc;--ok-soft: rgba(74, 222, 128, .16);--warn-soft: rgba(251, 191, 36, .16);--critical-soft: rgba(251, 113, 133, .18);--info-soft: rgba(125, 211, 252, .16);--shadow-soft: 0 1px 0 rgba(255, 255, 255, .04) inset, 0 0 0 1px rgba(0, 0, 0, .3);--shadow-elevated: 0 14px 36px rgba(0, 0, 0, .45), 0 0 0 1px rgba(255, 255, 255, .05);--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--sidebar-width: 232px;--rail-height: 52px;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);margin:0;font-feature-settings:"ss01","cv11"}.mono{font-family:ui-monospace,JetBrains Mono,SF Mono,Menlo,Consolas,monospace;font-feature-settings:"tnum","zero";font-variant-numeric:tabular-nums}button{font:inherit;color:inherit;cursor:pointer;background:none;border:0}input{font:inherit;color:inherit;background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:8px 10px;outline:none}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--border-active)}.app{display:grid;grid-template-columns:var(--sidebar-width) 1fr;height:100vh}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:14px 12px;overflow-y:auto}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:8px 10px 18px}.sidebar-brand-mark{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--accent),#4953c0);display:grid;place-items:center;color:#fff}.sidebar-brand h1{font-size:.92rem;font-weight:600;margin:0;letter-spacing:-.01em}.sidebar-brand small{display:block;color:var(--text-subtle);font-size:.72rem;margin-top:2px}.sidebar-section{margin-top:10px;display:flex;flex-direction:column;gap:2px}.sidebar-label{color:var(--text-subtle);font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;padding:8px 10px 4px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--text-muted);font-size:.875rem;cursor:pointer;border:1px solid transparent;width:100%;text-align:left}.sidebar-link:hover{background:var(--bg-hover);color:var(--text)}.sidebar-link.active{background:var(--bg-active);color:var(--text);border-color:var(--border)}.sidebar-link svg{flex-shrink:0}.sidebar-link-badge{margin-left:auto;font-size:.72rem;color:var(--text-subtle);font-variant-numeric:tabular-nums}.sidebar-link.active .sidebar-link-badge{color:var(--text-muted)}.sidebar-foot{margin-top:auto;padding:12px 8px 4px;border-top:1px solid var(--border);color:var(--text-subtle);font-size:.72rem;display:flex;align-items:center;gap:8px}.kbd{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:4px;background:var(--bg-active);border:1px solid var(--border);color:var(--text-muted);font-family:ui-monospace,JetBrains Mono,monospace;font-size:.68rem}.main{display:flex;flex-direction:column;min-width:0;overflow:hidden}.rail{height:var(--rail-height);flex-shrink:0;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;background:var(--bg);position:sticky;top:0;z-index:10}.rail-title{font-size:.92rem;font-weight:600;letter-spacing:-.01em}.rail-host{color:var(--text-subtle);font-size:.82rem}.rail-spacer{flex:1}.rail-status-pill{display:inline-flex;align-items:center;gap:8px;padding:5px 11px;border-radius:999px;font-size:.78rem;font-weight:500;border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-muted)}.rail-status-pill.ok{border-color:#34d3994d;background:var(--ok-soft);color:var(--ok)}.rail-status-pill.warning{border-color:#fbbf244d;background:var(--warn-soft);color:var(--warn)}.rail-status-pill.critical{border-color:#f871714d;background:var(--critical-soft);color:var(--critical);animation:pulse 1.6s ease-in-out infinite}.rail-dot{width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 0 0 currentColor}.rail-status-pill.critical .rail-dot{animation:pulseDot 1.6s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 #f8717100}50%{box-shadow:0 0 0 4px #f871712e}}@keyframes pulseDot{0%,to{box-shadow:0 0 #f8717166}50%{box-shadow:0 0 0 6px #f8717100}}.rail-button{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-muted);border-radius:var(--radius-sm);font-size:.78rem;transition:all .15s ease}.rail-button:hover{color:var(--text);border-color:var(--border-active);background:var(--bg-hover)}.page{padding:24px;overflow-y:auto;flex:1}.page-title{font-size:.78rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);margin:0 0 14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.card-head h2{font-size:.82rem;font-weight:600;margin:0;color:var(--text)}.card-head p{margin:2px 0 0;color:var(--text-subtle);font-size:.75rem}.card-action{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;color:var(--text-muted);padding:4px 8px;border-radius:var(--radius-sm);border:1px solid var(--border)}.card-action:hover{color:var(--text);background:var(--bg-hover)}.metric-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:18px}.metric{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden}.metric-label{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:1.55rem;font-weight:600;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.metric-detail{color:var(--text-subtle);font-size:.78rem}.metric-meter{margin-top:8px;height:4px;background:var(--bg-active);border-radius:999px;overflow:hidden}.metric-meter>i{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .5s ease}.metric-meter.ok>i{background:var(--ok)}.metric-meter.warning>i{background:var(--warn)}.metric-meter.critical>i{background:var(--critical)}.row{display:grid;gap:14px;margin-bottom:14px}.row.cols-2{grid-template-columns:1.4fr 1fr}.row.cols-3{grid-template-columns:repeat(3,1fr)}@media(max-width:1100px){.row.cols-2,.row.cols-3{grid-template-columns:1fr}}.tbl{width:100%;border-collapse:collapse;font-size:.82rem}.tbl th{text-align:left;font-weight:500;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.06em;font-size:.66rem;padding:6px 10px;border-bottom:1px solid var(--border)}.tbl td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}.tbl tr.expandable{cursor:pointer}.tbl tr.expandable:hover td{background:var(--bg-hover)}.tbl td.num{font-variant-numeric:tabular-nums}.tbl .name-cell strong{display:block;font-weight:500}.tbl .name-cell small{display:block;color:var(--text-subtle);font-size:.7rem;margin-top:1px}.state{display:inline-flex;align-items:center;gap:5px;padding:2px 7px;border-radius:999px;font-size:.7rem;font-weight:500;letter-spacing:.02em}.state:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.state.online,.state.ok{color:var(--ok);background:var(--ok-soft)}.state.errored,.state.critical,.state.offline,.state.stopped{color:var(--critical);background:var(--critical-soft)}.state.warning{color:var(--warn);background:var(--warn-soft)}.state.launching,.state.info{color:var(--info);background:var(--info-soft)}.state.unknown{color:var(--text-subtle);background:var(--bg-active)}.drilldown{background:var(--surface-2);border-top:1px solid var(--border);padding:0}.drilldown-inner{display:grid;gap:12px;padding:14px 16px}.drilldown-actions{display:flex;gap:8px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 11px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-muted);font-size:.78rem;transition:all .12s ease}.btn:hover:not(:disabled){color:var(--text);background:var(--bg-hover);border-color:var(--border-active)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.primary{border-color:var(--accent-strong);background:var(--accent-soft);color:var(--accent)}.btn.primary:hover:not(:disabled){background:#7c8aff38;color:#fff}.btn.danger{border-color:#f871714d;background:#f8717114;color:var(--critical)}.btn.danger:hover:not(:disabled){background:#f871712e;color:#fff}.btn.warn{border-color:#fbbf244d;background:#fbbf2414;color:var(--warn)}.btn.warn:hover:not(:disabled){background:#fbbf242e}.log{background:#161920;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;max-height:360px;overflow:auto;white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,JetBrains Mono,monospace;font-size:.78rem;color:#d6dae6;line-height:1.55}.log-empty{color:var(--text-subtle);font-style:italic}.log-tabs{display:flex;gap:4px;margin-bottom:8px}.log-tab{padding:4px 10px;border-radius:var(--radius-sm);font-size:.74rem;color:var(--text-muted)}.log-tab:hover{color:var(--text);background:var(--bg-hover)}.log-tab.active{color:var(--text);background:var(--bg-active)}.sparkline{width:100%;height:28px;display:block}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:6px}.apps-cell{display:grid;grid-template-columns:8px 1fr auto auto;align-items:center;gap:10px;padding:8px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:all .12s ease}.apps-cell:hover{border-color:var(--border-active);background:var(--bg-hover)}.apps-dot{width:8px;height:8px;border-radius:50%;background:var(--text-subtle)}.apps-dot-online{background:var(--ok);box-shadow:0 0 0 2px #4ade802e}.apps-dot-errored,.apps-dot-stopping,.apps-dot-stopped{background:var(--critical);box-shadow:0 0 0 2px #fb71852e}.apps-dot-launching{background:var(--info);box-shadow:0 0 0 2px #7dd3fc2e}.apps-cell-name{display:flex;flex-direction:column;min-width:0}.apps-cell-name strong{font-weight:500;font-size:.84rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.apps-cell-name small{color:var(--text-subtle);font-size:.68rem}.apps-cell-stats{display:flex;flex-direction:column;align-items:flex-end;font-size:.74rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.apps-cell-errored,.apps-cell-stopped{border-left:2px solid var(--critical)}.list{display:flex;flex-direction:column;gap:8px}.list-row{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.list-row .row-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.list-row strong{font-weight:500}.list-row small{color:var(--text-subtle);font-size:.72rem}.bar{margin-top:4px;height:4px;background:var(--bg-active);border-radius:999px;overflow:hidden}.bar>i{display:block;height:100%;background:var(--accent);transition:width .4s ease}.bar.thin{height:2px}.finding{border:1px solid var(--border);background:var(--surface-2);padding:10px 12px;border-radius:var(--radius-sm)}.finding strong{font-weight:500;display:block}.finding small{color:var(--text-subtle);font-size:.7rem}.finding p{margin:6px 0 0;font-size:.8rem;color:var(--text-muted)}.finding.warning{border-left:3px solid var(--warn)}.finding.critical{border-left:3px solid var(--critical)}.events{display:flex;flex-direction:column}.event{display:grid;grid-template-columns:1fr auto;align-items:start;gap:16px;padding:11px 12px;border-bottom:1px solid var(--border)}.event:last-child{border-bottom:none}.event strong{display:block;font-weight:500}.event p{margin:2px 0 0;font-size:.78rem;color:var(--text-muted);white-space:pre-wrap}.event time{color:var(--text-subtle);font-size:.74rem;font-variant-numeric:tabular-nums;white-space:nowrap}.event.severity-critical strong{color:var(--critical)}.event.severity-warning strong{color:var(--warn)}.event.severity-info strong{color:var(--text)}.summary-text{margin:0;white-space:pre-wrap;word-break:break-word;font-family:inherit;color:var(--text);font-size:.85rem;line-height:1.55}.path-list{display:flex;flex-direction:column;gap:4px;margin-top:6px}.path-row{display:grid;grid-template-columns:1fr auto 60px;gap:8px;font-size:.78rem;align-items:center}.path-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted);font-family:ui-monospace,monospace;font-size:.74rem}.path-count{color:var(--text-subtle);font-variant-numeric:tabular-nums}.chip{display:inline-block;padding:1px 6px;border-radius:999px;font-size:.7rem;border:1px solid var(--border);color:var(--text-muted);margin-right:4px}.chip.ok{color:var(--ok);border-color:#34d3994d}.chip.warning{color:var(--warn);border-color:#fbbf244d}.chip.critical{color:var(--critical);border-color:#f871714d}.chip.info{color:var(--info);border-color:#60a5fa4d}.status-chips{margin-top:6px}.empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:28px 18px;color:var(--text-subtle);font-size:.82rem;text-align:center}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c0e13a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:start center;padding-top:14vh;z-index:100}.token-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;width:min(420px,90vw);display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-elevated)}.token-box h2{margin:0;font-size:1rem;font-weight:600}.token-box p{margin:0;color:var(--text-muted);font-size:.84rem}.palette{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(620px,90vw);box-shadow:var(--shadow-elevated);overflow:hidden;display:flex;flex-direction:column}.palette-input{border:0;border-bottom:1px solid var(--border);border-radius:0;padding:14px 16px;font-size:.92rem;background:transparent}.palette-input:focus{border-color:var(--border);box-shadow:none}.palette-list{max-height:380px;overflow-y:auto;padding:6px}.palette-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;color:var(--text-muted)}.palette-item:hover,.palette-item.active{background:var(--bg-hover);color:var(--text)}.palette-item-meta{margin-left:auto;color:var(--text-subtle);font-size:.72rem}.palette-foot{border-top:1px solid var(--border);padding:8px 14px;display:flex;gap:14px;color:var(--text-subtle);font-size:.72rem}.confirm{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 24px;width:min(420px,90vw);display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow-elevated)}.confirm h3{margin:0;font-size:.95rem;font-weight:600}.confirm p{margin:0;color:var(--text-muted);font-size:.85rem}.confirm-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}.toasts{position:fixed;right:16px;bottom:16px;display:flex;flex-direction:column;gap:8px;z-index:90;max-width:360px}.toast{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--info);border-radius:var(--radius-sm);padding:10px 14px;font-size:.82rem;color:var(--text);box-shadow:var(--shadow-elevated);animation:slideIn .18s ease-out}.toast.success{border-left-color:var(--ok)}.toast.warning{border-left-color:var(--warn)}.toast.error{border-left-color:var(--critical)}.toast small{display:block;color:var(--text-subtle);margin-top:2px;font-size:.74rem}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.loading{position:fixed;bottom:14px;left:calc(var(--sidebar-width) + 14px);background:var(--bg-elevated);border:1px solid var(--border);padding:6px 10px;border-radius:var(--radius-sm);font-size:.74rem;color:var(--text-muted)}.rail-menu-toggle{display:none;background:transparent;border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);width:36px;height:36px;align-items:center;justify-content:center;cursor:pointer;padding:0;margin-right:10px;flex-shrink:0}.rail-menu-toggle:hover{background:var(--bg-hover);border-color:var(--border-active)}.mobile-nav-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:90;cursor:pointer}@media(max-width:900px){.app{grid-template-columns:1fr}.rail-menu-toggle{display:inline-flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(280px,80vw);transform:translate(-100%);transition:transform .2s ease;z-index:100;box-shadow:6px 0 24px #0006}.app.mobile-nav-open .sidebar{transform:translate(0)}.app.mobile-nav-open .mobile-nav-backdrop{display:block}.main{min-width:0}.rail{padding:10px 14px;gap:8px;flex-wrap:wrap}.rail-title{font-size:.95rem}.rail-button span:not(.kbd){display:none}.rail-button .kbd{display:none}.rail-status-pill{font-size:.7rem;padding:3px 8px}.page{padding:12px;gap:12px}.card{padding:12px;border-radius:var(--radius)}.card-header{flex-wrap:wrap;gap:6px}.row{gap:10px}.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.tbl{font-size:.78rem;min-width:480px}.tbl th,.tbl td{padding:8px}.modal{padding:16px}.token-box{width:100%;max-width:360px}.toasts{bottom:12px;right:12px;left:12px}.toast{max-width:none}.loading{left:14px;right:14px;bottom:14px;text-align:center}}@media(max-width:480px){.rail-title{font-size:.88rem}.rail-host{font-size:.66rem}.page,.card{padding:10px}.rail-status-pill{margin-left:auto}}
