:root{
  --bg:#0a0e16;--bg2:#0e1420;--panel:#131b2a;--panel2:#17202f;--line:#23304a;--line2:#2c3b59;
  --ink:#e8eef9;--muted:#93a3c0;--faint:#64748b;--cyan:#22d3ee;--cyan-d:#0e7490;
  --green:#34d399;--green-bg:#0c2a22;--amber:#fbbf24;--amber-bg:#2a210a;--orange:#fb923c;
  --red:#f87171;--red-bg:#2a1014;--violet:#a78bfa;
  --mono:'SF Mono',ui-monospace,'JetBrains Mono',Menlo,Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Inter,system-ui,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:radial-gradient(1100px 600px at 82% -10%,#10243a 0%,transparent 55%),var(--bg);
  color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
code{font-family:var(--mono);font-size:.86em;background:#0c1626;border:1px solid var(--line2);padding:1px 6px;border-radius:5px;color:#bfe9f5}
h1{font-size:24px;margin:0 0 4px;letter-spacing:-.02em}
h2{font-size:16px;margin:26px 0 10px}
.muted{color:var(--muted)}.small{font-size:12.5px}
.mag{background:linear-gradient(90deg,#22d3ee,#a78bfa);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* topbar */
.topbar{display:flex;align-items:center;gap:18px;padding:12px 20px;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,#0f1726,#0b1120);position:sticky;top:0;z-index:10}
.brand{font-weight:800;font-size:16px;display:flex;align-items:center;gap:9px}
.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan)}
.env{font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:5px;margin-left:4px;letter-spacing:.05em}
.env.dev{background:var(--amber-bg);color:var(--amber);border:1px solid #4a3c10}
.env.prod{background:var(--green-bg);color:var(--green);border:1px solid #1c4a3a}
.tabs{display:flex;gap:6px}
.tab{color:var(--muted);text-decoration:none;font-size:14px;padding:7px 14px;border-radius:9px;border:1px solid transparent}
.tab:hover{color:var(--ink);background:#0d1626}
.tab.active{color:#04121a;background:var(--cyan);font-weight:700}
.logout{margin-left:auto;display:flex;align-items:center;gap:10px}
.logout .who{color:var(--faint);font-size:13px;font-family:var(--mono)}
.logout button,.ghost{background:#0d1626;border:1px solid var(--line2);color:var(--muted);border-radius:8px;padding:6px 12px;font-size:13px;cursor:pointer}
.logout button:hover{border-color:var(--red);color:var(--red)}
.content{padding:24px 20px;max-width:1180px;margin:0 auto}
.page{max-width:1000px}
.lede{color:var(--muted);margin:0 0 20px}

/* login */
.login-body{display:grid;place-items:center;min-height:100vh}
.login-card{width:340px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:0 18px 50px rgba(0,0,0,.5)}
.login-brand{font-weight:800;font-size:20px;display:flex;align-items:center;gap:9px}
.login-brand .dot{width:11px;height:11px;border-radius:50%;background:var(--cyan);box-shadow:0 0 12px var(--cyan)}
.login-sub{color:var(--faint);margin:4px 0 20px;font-size:13px}
.login-card label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:14px}
.login-card input{width:100%;margin-top:5px;background:#0c1422;border:1px solid var(--line2);border-radius:9px;color:var(--ink);padding:10px 12px;font-size:14px}
.login-card input:focus{outline:none;border-color:var(--cyan)}
button.primary{width:100%;background:var(--cyan);color:#04121a;font-weight:700;border:none;border-radius:9px;padding:11px;font-size:15px;cursor:pointer}
button.primary:hover{filter:brightness(1.07)}
.login-error{background:var(--red-bg);border:1px solid #4a1820;color:#f7c9cd;border-radius:9px;padding:10px 12px;font-size:13px;margin-bottom:16px}

/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:8px 0 6px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:16px}
.card-h{font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);margin-bottom:10px}
.big{font-size:30px;font-weight:800;font-family:var(--mono);letter-spacing:-.02em}
.big.ok{color:var(--green)}.big.warn{color:var(--amber)}.big.danger{color:var(--red)}
.kv{display:flex;justify-content:space-between;gap:10px;font-size:13px;margin-bottom:5px}
.kv span{color:var(--faint)}
.badge{display:inline-block;margin-top:8px;font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:6px}
.badge.ok{background:var(--green-bg);color:var(--green);border:1px solid #1c4a3a}
.badge.danger{background:var(--red-bg);color:var(--red);border:1px solid #4a1820}

/* tools table */
table{width:100%;border-collapse:collapse;font-size:13.5px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
th,td{text-align:left;padding:9px 13px;border-bottom:1px solid var(--line)}
th{background:#101a29;color:var(--faint);font-size:11px;text-transform:uppercase;letter-spacing:.04em}
tr:last-child td{border-bottom:none}
.kind{font-family:var(--mono);font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px}
.kind.READ{background:#0c2230;color:#7dd3fc;border:1px solid #164a5e}
.kind.MUTATE{background:var(--amber-bg);color:var(--amber);border:1px solid #4a3c10}
.kind.EGRESS{background:var(--red-bg);color:var(--red);border:1px solid #4a1820}
.note{margin-top:16px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-size:13px;color:#c7d2e6}

/* sandbox */
.sandbox-wrap{display:grid;grid-template-columns:1fr 380px;gap:16px;align-items:start}
@media(max-width:900px){.sandbox-wrap{grid-template-columns:1fr}}
.chat-col,.actions-col{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px}
.chat-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.seal{font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:6px}
.seal.on{background:var(--green-bg);color:var(--green);border:1px solid #1c4a3a}
.seal.off{background:var(--red-bg);color:var(--red);border:1px solid #4a1820}
.enginechip{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--faint);border:1px solid var(--line2);padding:3px 9px;border-radius:999px}
.chat-log{min-height:340px;max-height:56vh;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:6px 2px}
.bubble{max-width:82%;padding:10px 13px;border-radius:13px;font-size:14px;white-space:pre-wrap;word-wrap:break-word}
.bubble.me{align-self:flex-end;background:#0e2a33;border:1px solid #155;color:#dff6fb}
.bubble.skippy{align-self:flex-start;background:#161f30;border:1px solid var(--line2)}
.bubble.sys{align-self:center;background:transparent;color:var(--faint);font-size:12px}
.bubble .who{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--faint);margin-bottom:4px;font-family:var(--mono)}
.chat-input{display:flex;gap:8px;margin-top:12px}
.chat-input textarea{flex:1;background:#0c1422;border:1px solid var(--line2);border-radius:10px;color:var(--ink);padding:10px 12px;font-size:14px;font-family:var(--sans);resize:vertical}
.chat-input textarea:focus{outline:none;border-color:var(--cyan)}
.chat-input button{background:var(--cyan);color:#04121a;font-weight:700;border:none;border-radius:10px;padding:0 18px;cursor:pointer}
.chat-input button:disabled{opacity:.5;cursor:default}

.actions-head{display:flex;align-items:center;justify-content:space-between}
.actions-list{margin-top:10px;display:flex;flex-direction:column;gap:10px;max-height:64vh;overflow-y:auto}
.act{border:1px solid var(--line2);border-radius:11px;padding:11px;background:var(--bg2);border-left:3px solid var(--line2)}
.act.EGRESS{border-left-color:var(--red)}.act.MUTATE{border-left-color:var(--amber)}.act.READ{border-left-color:#7dd3fc}
.act-top{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.act-top code{font-size:12px}
.act .dec{margin-left:auto;font-family:var(--mono);font-size:10px;padding:2px 7px;border-radius:5px;background:#0d1626;color:var(--muted);border:1px solid var(--line2)}
.act .dec.redirected{color:var(--green);border-color:#1c4a3a}
.act .dec.recorded{color:var(--amber);border-color:#4a3c10}
.act dl{margin:0;font-size:12px}
.act dt{color:var(--faint);font-family:var(--mono);font-size:10px;text-transform:uppercase;margin-top:5px}
.act dd{margin:1px 0 0;color:#cdd8ec;word-break:break-word}
.act .note{margin-top:7px;padding:6px 8px;font-size:11.5px;background:#0c1626;border:none}
.empty{color:var(--faint);font-size:13px;text-align:center;padding:24px 0}

/* settings */
.ok-banner{background:var(--green-bg);border:1px solid #1c4a3a;color:#bfeeda;border-radius:10px;padding:11px 14px;margin-bottom:18px;font-size:14px}
code.ok{background:var(--green-bg);color:var(--green);border-color:#1c4a3a}
code.warn{background:var(--amber-bg);color:var(--amber);border-color:#4a3c10}
.cardlink{display:inline-block;margin-top:10px;font-size:13px}
.keyform{max-width:560px;background:var(--panel);border:1px solid var(--line);border-radius:13px;padding:18px;margin-bottom:12px}
.keyrow{margin-bottom:16px}
.keyrow label{display:block;font-size:13.5px;margin-bottom:6px}
.keyline{display:flex;align-items:center;gap:10px}
.keyline input{flex:1;background:#0c1422;border:1px solid var(--line2);border-radius:9px;color:var(--ink);padding:10px 12px;font-size:14px;font-family:var(--mono)}
.keyline input:focus{outline:none;border-color:var(--cyan)}
.setpill{font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:6px;background:var(--green-bg);color:var(--green);border:1px solid #1c4a3a;white-space:nowrap}
.unsetpill{font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:6px;background:var(--amber-bg);color:var(--amber);border:1px solid #4a3c10;white-space:nowrap}
button.primary.narrow{width:auto;display:inline-block;padding:10px 20px;margin-right:12px}
.delrow{display:flex;gap:10px;margin-bottom:8px}
.delrow form{display:inline}
.ghost.danger{color:var(--red);border-color:#4a1820}
.ghost.danger:hover{background:var(--red-bg)}
