@font-face {
  font-family:"Space Grotesk"; src:url("/fonts/space-grotesk-var.woff2") format("woff2");
  font-weight:300 700; font-style:normal; font-display:swap;
}
:root{
  --bg:#07090E; --bg2:#0E141C; --bg3:#131C26; --ink:#ECF1F6; --ink2:#97A6B4;
  --line:#1C2632; --line2:#2A3848; --accent:#3DDC9E; --accent2:#2BD4C0;
  --amber:#F2B65A; --red:#F2715A; --shadow:0 14px 36px rgba(0,0,0,.5);
}
*{box-sizing:border-box;margin:0}
body{background:var(--bg);color:var(--ink);font:400 15px/1.55 ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;-webkit-font-smoothing:antialiased}
.disp{font-family:"Space Grotesk",ui-sans-serif,system-ui,sans-serif}
.mono{font-family:ui-monospace,"SF Mono",Menlo,Consolas,monospace;font-variant-numeric:tabular-nums}
a{color:var(--accent);text-decoration:none}
button{font:inherit;cursor:pointer}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}

/* login */
.login-wrap{min-height:100svh;display:grid;place-items:center;padding:1.5rem}
.login{width:min(380px,100%);background:var(--bg2);border:1px solid var(--line);border-radius:18px;padding:2rem;box-shadow:var(--shadow)}
.login h1{font-size:1.4rem;letter-spacing:-.02em;margin-bottom:.3rem}
.login p{color:var(--ink2);font-size:.9rem;margin-bottom:1.4rem}
.login label{display:block;font-size:.8rem;color:var(--ink2);margin-bottom:.4rem}
.login input{width:100%;background:var(--bg);border:1px solid var(--line2);border-radius:11px;padding:.75em .9em;color:var(--ink);font-size:1rem}
.login input:focus{border-color:var(--accent);outline:none}
.login button{width:100%;margin-top:1rem;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#05130C;border:none;border-radius:11px;padding:.8em;font-weight:600}
.login .err{color:var(--red);font-size:.85rem;margin-top:.8rem;min-height:1.2em}
.brandmark{font-family:ui-monospace,Menlo,monospace;color:var(--accent);font-weight:700}

/* shell */
.bar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
  padding:.85rem clamp(1rem,3vw,1.6rem);background:rgba(7,9,14,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.bar .logo{font-family:ui-monospace,Menlo,monospace;font-weight:700;color:var(--accent);font-size:1rem;white-space:nowrap}
.bar .logo b{color:var(--ink);font-family:"Space Grotesk",sans-serif;margin-left:.45em;font-weight:600}
.stats{display:flex;gap:1.1rem;flex-wrap:wrap;margin-left:auto;font-size:.8rem;color:var(--ink2)}
.stats .s b{color:var(--ink);font-variant-numeric:tabular-nums}
.meter{display:inline-block;width:54px;height:6px;border-radius:4px;background:var(--bg3);overflow:hidden;vertical-align:middle;margin-left:.4em}
.meter i{display:block;height:100%;background:var(--accent)}
.meter.warn i{background:var(--amber)} .meter.hot i{background:var(--red)}
.bar .upd{font-size:.72rem;color:var(--ink2);display:flex;align-items:center;gap:.4em}
.bar button.out{background:none;border:1px solid var(--line2);color:var(--ink2);border-radius:9px;padding:.4em .7em;font-size:.8rem}
.bar button.out:hover{border-color:var(--accent);color:var(--accent)}

main{max-width:1180px;margin:0 auto;padding:clamp(1rem,3vw,2rem)}
.grp{margin:1.8rem 0 .8rem;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink2);display:flex;align-items:center;gap:.7em}
.grp::after{content:"";flex:1;height:1px;background:var(--line)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:.9rem}

.card{background:var(--bg2);border:1px solid var(--line);border-radius:16px;padding:1.05rem 1.15rem;display:flex;flex-direction:column;gap:.6rem}
.card.down{border-color:color-mix(in srgb,var(--red) 45%,var(--line))}
.card .top{display:flex;align-items:center;gap:.55rem}
.card h3{font-size:1.05rem;letter-spacing:-.01em;font-weight:600;flex:1;font-family:"Space Grotesk",sans-serif}
.dot{width:9px;height:9px;border-radius:50%;flex:none;background:var(--ink2)}
.dot.online{background:var(--accent)} .dot.stopped,.dot.errored{background:var(--red)} .dot.launching{background:var(--amber)}
@media (prefers-reduced-motion:no-preference){.dot.online{animation:p 2.4s ease-out infinite}@keyframes p{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 50%,transparent)}70%{box-shadow:0 0 0 7px transparent}}}
.pill{font-family:ui-monospace,Menlo,monospace;font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;padding:.18em .5em;border-radius:6px;border:1px solid var(--line2);color:var(--ink2)}
.pill.up{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,transparent)}
.pill.bad{color:var(--red);border-color:color-mix(in srgb,var(--red) 45%,transparent)}
.pill.na{opacity:.6}
.kv{display:flex;gap:1.1rem;flex-wrap:wrap;font-size:.78rem;color:var(--ink2)}
.kv b{color:var(--ink);font-variant-numeric:tabular-nums;font-weight:600}
.url{font-size:.76rem;color:var(--ink2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.workers{font-size:.72rem;color:var(--ink2);display:flex;flex-wrap:wrap;gap:.3em .7em}
.workers .w{display:inline-flex;align-items:center;gap:.35em}
.acts{display:flex;gap:.5rem;margin-top:.2rem}
.acts button{flex:1;background:var(--bg3);border:1px solid var(--line2);color:var(--ink);border-radius:9px;padding:.45em;font-size:.8rem}
.acts button:hover{border-color:var(--accent);color:var(--accent)}
.acts button.stop:hover{border-color:var(--red);color:var(--red)}
.acts button:disabled{opacity:.4;cursor:not-allowed}
.static-note{font-size:.74rem;color:var(--ink2);font-style:italic}

.rev{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.9rem}
.rev .t{background:var(--bg2);border:1px solid var(--line);border-radius:16px;padding:1.1rem}
.rev .t .lab{font-size:.82rem;color:var(--ink2)}
.rev .t .v{font-family:ui-monospace,Menlo,monospace;font-size:1.7rem;font-weight:700;letter-spacing:-.02em;margin:.25rem 0}
.badge{font-family:ui-monospace,Menlo,monospace;font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;padding:.16em .5em;border-radius:6px;border:1px solid var(--line2);color:var(--ink2)}

.toast{position:fixed;bottom:1.2rem;left:50%;transform:translateX(-50%);background:var(--bg3);border:1px solid var(--line2);color:var(--ink);padding:.7em 1.1em;border-radius:11px;box-shadow:var(--shadow);font-size:.88rem;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.bad{border-color:var(--red)} .toast.good{border-color:var(--accent)}
.hide{display:none!important}
