:root{--bg: #0b0d10;--bg2: #11141a;--bg3: #161a21;--border: #232831;--border-hi: #2f3641;--fg: #d7dde0;--fg-dim: #8a929b;--fg-mute: #5b626c;--accent: #7ee787;--accent-dim: #1f3325;--warn: #f0b54a;--err: #ef6f6c;--ok: #7ee787;--info: #79b8ff;color-scheme:dark;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--fg);font-size:12px;line-height:1.45;-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}input{font:inherit}a{color:var(--accent);text-decoration:none}.tabular{font-variant-numeric:tabular-nums}.loading,.empty{padding:1.5rem;color:var(--fg-mute);font-size:12px}.error{color:var(--err);margin:.5rem 0;font-size:12px}.login{min-height:100vh;display:grid;place-items:center;padding:1rem;background:var(--bg)}.login .card{background:var(--bg);border:1px solid var(--border);padding:28px 32px;width:340px;display:flex;flex-direction:column;gap:18px}.login .brand{display:flex;align-items:center;gap:10px;margin-bottom:4px}.login .brand .logo{width:22px;height:22px;background:var(--accent);color:var(--bg);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.login .brand .name{font-size:14px;letter-spacing:.02em}.login .brand .name .dim{color:var(--fg-dim)}.login label{display:flex;flex-direction:column;gap:6px;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-mute)}.login input{padding:9px 11px;background:var(--bg2);border:1px solid var(--border);color:var(--fg);font-size:13px;letter-spacing:0}.login input:focus{outline:none;border-color:var(--accent)}.login button{padding:9px 0;background:var(--accent);color:var(--bg);border:none;font-weight:600;font-size:12px;letter-spacing:.04em;text-transform:uppercase}.login button:disabled{opacity:.4;cursor:not-allowed}.app{display:grid;grid-template-columns:200px 1fr;min-height:100vh}aside{background:var(--bg);border-right:1px solid var(--border);display:flex;flex-direction:column;min-width:0}aside .brand{padding:18px 18px 22px;display:flex;align-items:center;gap:9px}aside .brand .logo{width:18px;height:18px;background:var(--accent);color:var(--bg);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700}aside .brand .name{font-size:13px;letter-spacing:.02em}aside .brand .name .dim{color:var(--fg-dim)}aside nav{padding:0 10px;display:flex;flex-direction:column;gap:1px}aside nav .item{display:flex;align-items:center;gap:10px;padding:7px 10px;font-size:12.5px;color:var(--fg-dim);background:transparent;border:none;border-left:2px solid transparent;text-align:left;cursor:pointer;font-family:inherit;width:100%}aside nav .item:hover{color:var(--fg);background:#ffffff05}aside nav .item .icon{color:var(--fg-mute);width:12px;text-align:center}aside nav .item.active{color:var(--fg);background:var(--bg2);border-left-color:var(--accent)}aside nav .item.active .icon{color:var(--accent)}aside .foot{margin-top:auto;padding:14px 18px;border-top:1px solid var(--border);font-size:11px;color:var(--fg-mute);line-height:1.7}aside .foot .ok{color:var(--ok)}aside .signout{background:transparent;border:none;color:var(--fg-mute);padding:0;font-size:11px}aside .signout:hover{color:var(--fg)}main{display:flex;flex-direction:column;min-width:0}.topbar{height:44px;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:14px;flex-shrink:0;font-size:12px}.topbar .crumbs{display:flex;align-items:center;gap:6px;color:var(--fg-dim)}.topbar .crumbs .sep{color:var(--fg-mute)}.topbar .crumbs .last{color:var(--fg)}.topbar .grow{flex:1}.topbar .search{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border:1px solid var(--border);color:var(--fg-mute);font-size:11.5px}.topbar .user{color:var(--fg-mute);font-size:11.5px}.content{padding:22px 24px;overflow:auto;flex:1}.page-head{display:flex;align-items:baseline;gap:14px;margin-bottom:16px}.page-head h1{margin:0;font-size:22px;font-weight:500;letter-spacing:-.01em}.page-head .note{color:var(--fg-mute);font-size:12px}.page-head .spacer{flex:1}.btn{background:transparent;color:var(--fg-dim);border:1px solid var(--border);padding:5px 12px;font-family:inherit;font-size:11.5px}.btn:hover{color:var(--fg);border-color:var(--border-hi)}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600}.btn-primary:hover{background:var(--accent);filter:brightness(1.08)}.btn-danger{color:var(--err);border-color:var(--border)}.btn-danger:hover{border-color:var(--err)}.btn:disabled{opacity:.4;cursor:not-allowed}.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:24px}.tile{background:var(--bg);padding:14px 16px}.tile .label{font-size:10.5px;color:var(--fg-mute);letter-spacing:.08em}.tile .value{font-size:26px;font-weight:400;margin:6px 0 2px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.tile .sub{font-size:11px}.tile.warn .sub{color:var(--warn)}.tile.ok .sub{color:var(--ok)}.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.dot.online,.dot.running,.dot.applied{background:var(--ok)}.dot.offline,.dot.crashed,.dot.failed{background:var(--err)}.dot.pending,.dot.warning{background:var(--warn)}.dot.idle,.dot.default{background:var(--fg-mute)}.badge{display:inline-flex;align-items:center;gap:5px;padding:1px 7px 2px;font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--border);border-radius:2px;font-variant-numeric:tabular-nums;color:var(--fg-dim);background:#8a929b14}.badge .ball{width:5px;height:5px;border-radius:50%;background:currentColor}.badge.online,.badge.running,.badge.applied{color:var(--ok);background:#7ee78714;border-color:#7ee78740}.badge.offline,.badge.crashed,.badge.failed{color:var(--err);background:#ef6f6c0f;border-color:#ef6f6c38}.badge.warning,.badge.pending{color:var(--warn);background:#f0b54a12;border-color:#f0b54a40}.table{border:1px solid var(--border);font-variant-numeric:tabular-nums;font-size:12.5px}.table .row{display:grid;padding:11px 14px;align-items:center;gap:8px;border-bottom:1px solid var(--border)}.table .row:last-child{border-bottom:none}.table .head{background:var(--bg2);font-size:10.5px;letter-spacing:.08em;color:var(--fg-mute);padding:9px 14px}.table .row.clickable{cursor:pointer}.table .row.clickable:hover,.table .row.selected{background:var(--bg2)}.dim{color:var(--fg-dim)}.mute{color:var(--fg-mute)}.row-fleet{grid-template-columns:12px 1.5fr 1fr .7fr 1fr .9fr .6fr .7fr .7fr}.row-projects-all{grid-template-columns:12px 1.1fr 1fr .7fr .7fr 1.5fr .7fr}.row-deploys{grid-template-columns:12px .7fr 1fr 1.1fr .8fr .8fr .6fr}.row-keys{grid-template-columns:1.4fr .8fr .8fr auto}.row-keys button{font-size:11px;padding:3px 9px}.kv{display:flex;gap:8px;align-items:stretch}.kv .code{font-size:12.5px}.howto{margin:0;padding-left:1.25em;color:var(--fg-dim);font-size:12.5px;line-height:1.7}.howto li{margin-bottom:6px}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.section-head .section-label{margin:0}.row-fleet .host{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.row-deployments{grid-template-columns:.7fr .9fr 1fr .6fr}.row-projects{grid-template-columns:12px 1.2fr .7fr .7fr 1.4fr}.spark-cell{display:flex;align-items:center;gap:8px}.spark-cell .pct{min-width:32px}.bar{height:4px;background:var(--bg3);position:relative;flex:1;max-width:80px}.bar>span{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent);width:0}.bar.warn>span{background:var(--warn)}.bar.info>span{background:var(--info)}.bar.dim>span{background:var(--fg-dim)}.pi-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:20px}.pi-head h1{margin:0 0 6px;font-size:22px;font-weight:500;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:12px}.pi-head .meta{color:var(--fg-dim);font-size:12px}.pi-head .actions{display:flex;gap:6px;margin-left:auto}.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:24px}.metric{background:var(--bg);padding:14px 16px}.metric .top{display:flex;justify-content:space-between;align-items:baseline}.metric .label{font-size:10.5px;color:var(--fg-mute);letter-spacing:.08em}.metric .sub{font-size:11px;color:var(--fg-mute)}.metric .value{font-size:24px;margin:6px 0;font-variant-numeric:tabular-nums;letter-spacing:-.01em}.section-label{font-size:11px;color:var(--fg-mute);letter-spacing:.08em;margin:0 0 8px;text-transform:uppercase}.section{margin-bottom:24px}.logtail-wrap{border:1px solid var(--border);background:var(--bg)}.logtail-header{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--bg2);border-bottom:1px solid var(--border);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-mute)}.logtail-header .name{color:var(--fg)}.logtail{height:280px;overflow-y:auto;padding:8px 14px;font-size:12px;line-height:1.55;background:var(--bg)}.logtail .line{display:flex;gap:10px;white-space:pre-wrap;word-break:break-all}.logtail .line.stderr{color:var(--err)}.logtail .ts{color:var(--fg-mute);flex-shrink:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;padding:1rem;z-index:100}.modal{background:var(--bg);border:1px solid var(--border-hi);padding:22px 24px;width:520px;max-width:100%;display:flex;flex-direction:column;gap:16px}.modal h2{margin:0;font-size:14px;letter-spacing:.02em;text-transform:uppercase;color:var(--fg);font-weight:500}.modal label{display:flex;flex-direction:column;gap:6px;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-mute)}.modal input{padding:8px 11px;background:var(--bg2);border:1px solid var(--border);color:var(--fg);font-size:13px}.modal input:focus{outline:none;border-color:var(--accent)}.modal .hint{font-size:11px;color:var(--fg-mute);margin:0}.modal .actions{display:flex;justify-content:flex-end;gap:8px}.code{font-size:11.5px;background:var(--bg2);border:1px solid var(--border);padding:10px 12px;white-space:pre-wrap;word-break:break-all;margin:0;color:var(--fg)}.empty.hint{text-align:left;padding:14px;border:1px dashed var(--border);color:var(--fg-mute)}.kbd{background:var(--bg3);border:1px solid var(--border);padding:1px 5px;color:var(--fg)}.logtail::-webkit-scrollbar{width:6px}.logtail::-webkit-scrollbar-thumb{background:var(--border-hi)}.picker{display:flex;gap:16px;margin-bottom:16px;align-items:flex-end}.picker label{display:flex;flex-direction:column;gap:6px;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-mute)}.picker select{padding:6px 10px;background:var(--bg2);border:1px solid var(--border);color:var(--fg);font:inherit;font-size:12.5px;min-width:200px}.picker select:focus{outline:none;border-color:var(--accent)}.picker select:disabled{opacity:.5}
