:root{
  --bg:#06121d; --panel:#0a1c2b; --panel2:#0c2233; --line:rgba(205,169,114,.20);
  --ink:#e9eff3; --muted:#8aa1b1; --dim:#5d7384; --gold:#e3c389; --gold2:#cda972;
  --sea:#6fa8d6; --green:#67c79a; --red:#e0796f;
}
*{box-sizing:border-box}
/* A class that sets display: (.modal/.login use flex) would otherwise override the UA's
   [hidden]{display:none} — keep the hidden attribute authoritative everywhere. */
[hidden]{display:none !important}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font-family:'IBM Plex Sans',-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px}
a{color:var(--sea);text-decoration:none} a:hover{text-decoration:underline}
b{color:var(--gold);font-weight:600}
h1{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;font-size:30px;margin:0 0 8px}
h2{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;font-size:24px;margin:0}
h3{font-size:14px;margin:0 0 6px;color:var(--ink)}
.mono,code,pre{font-family:'IBM Plex Mono',ui-monospace,Menlo,monospace}
.muted{color:var(--muted);font-size:13px;line-height:1.6}
.dim{color:var(--dim)}

/* brand */
.brand{font-family:'Cormorant Garamond',Georgia,serif;font-size:21px;color:var(--ink);display:flex;align-items:center;gap:9px}
.brand b{color:var(--gold);font-weight:600}
.brand-mark{width:16px;height:16px;border-radius:4px;background:linear-gradient(180deg,#e3c389,#cda972);display:inline-block}
.brand-tag{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--gold2);border:1px solid var(--line);
  border-radius:999px;padding:2px 9px;letter-spacing:.04em;text-transform:uppercase}

/* login */
.login{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background-image:radial-gradient(900px 540px at 50% -10%,#163a54 0%,rgba(20,58,84,0) 55%);padding:24px}
.login-card{width:100%;max-width:430px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:30px 32px}
.login-card .brand{margin-bottom:22px}
.sub{color:var(--muted);line-height:1.6;margin:0 0 20px}
.fld{display:block;margin:0 0 14px}
.fld span{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}
.fld input,.fld select{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:9px;
  color:var(--ink);padding:11px 12px;font-size:14px;font-family:inherit}
.fld input:focus,.fld select:focus{outline:none;border-color:var(--gold2)}
.err{color:var(--red);font-size:13px;min-height:18px;margin:8px 0 0}
.link{display:inline-block;margin-top:16px;font-size:13px}
.foot{color:var(--dim);font-size:12px;margin-top:22px}

/* buttons */
.btn{background:var(--panel2);border:1px solid var(--line);color:var(--ink);border-radius:9px;
  padding:11px 16px;font-size:14px;font-family:inherit;cursor:pointer;width:100%}
.btn:hover{border-color:var(--gold2)}
.btn.gold{background:linear-gradient(180deg,#e3c389,#cda972);color:#2a1d08;border:none;font-weight:600}
.btn.gold:hover{filter:brightness(1.05)}
.btn.sm{width:auto;padding:8px 14px;font-size:13px}
.btn.ghost{background:transparent}
.btn.danger{color:var(--red);border-color:rgba(224,121,111,.4)}
.btn.danger:hover{background:rgba(224,121,111,.12)}

/* topbar */
.topbar{display:flex;align-items:center;gap:20px;padding:14px 26px;border-bottom:1px solid var(--line);
  background:rgba(10,28,43,.7);position:sticky;top:0;z-index:5;backdrop-filter:blur(6px)}
.tabs{display:flex;gap:4px;margin-left:14px}
.tab{background:none;border:none;color:var(--muted);font-family:inherit;font-size:14px;padding:8px 14px;
  border-radius:8px;cursor:pointer}
.tab:hover{color:var(--ink)} .tab.on{color:var(--gold);background:rgba(227,195,137,.08)}
.who{margin-left:auto;display:flex;align-items:center;gap:12px;color:var(--muted);font-size:13px}

/* layout */
.wrap{max-width:1000px;margin:0 auto;padding:28px 26px 80px}
.view{animation:fade .2s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.phead{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.phead .muted{margin:0}

/* tables / cards */
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-top:14px}
table{width:100%;border-collapse:collapse;font-size:13px;margin-top:14px}
th{text-align:left;color:var(--muted);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.04em;
  padding:8px 10px;border-bottom:1px solid var(--line)}
td{padding:11px 10px;border-bottom:1px solid rgba(205,169,114,.08);vertical-align:middle}
tr:hover td{background:rgba(12,34,51,.5)}
.badge{font-size:11px;border:1px solid var(--line);border-radius:999px;padding:2px 9px;color:var(--muted);white-space:nowrap}
.badge.gold{color:var(--gold);border-color:var(--gold)} .badge.sea{color:var(--sea);border-color:var(--sea)}
.badge.green{color:var(--green);border-color:var(--green)} .badge.red{color:var(--red);border-color:var(--red)}
.empty{color:var(--dim);padding:26px;text-align:center;border:1px dashed var(--line);border-radius:12px;margin-top:14px}
.keybar{display:flex;align-items:center;gap:14px;margin:14px 0 0;flex-wrap:wrap}
.keybar label{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:8px}
.keybar select{background:var(--bg);border:1px solid var(--line);border-radius:8px;color:var(--ink);padding:7px 10px;font-family:inherit}

/* key reveal */
.reveal{background:var(--bg);border:1px solid var(--gold2);border-radius:9px;padding:12px 14px;
  font-family:'IBM Plex Mono',monospace;font-size:13px;color:var(--gold);word-break:break-all;margin:10px 0}
.scopes{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 2px}
.scopes label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);
  border:1px solid var(--line);border-radius:8px;padding:6px 10px;cursor:pointer}
.scopes input{accent-color:var(--gold2)}
.row2{display:flex;gap:12px} .row2 .fld{flex:1}

/* intents editor */
.iedit td{padding:6px 6px}
.iedit input,.iedit select{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:7px;
  color:var(--ink);padding:7px 8px;font-family:inherit;font-size:12px}
.iedit .x{color:var(--red);cursor:pointer;text-align:center;width:30px}

/* modal */
.modal{position:fixed;inset:0;background:rgba(2,9,16,.74);display:flex;align-items:center;justify-content:center;
  z-index:20;padding:20px}
.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:24px 26px;
  width:100%;max-width:540px;max-height:88vh;overflow:auto}
.modal-card h2{margin-bottom:12px}
.modal-actions{display:flex;gap:10px;margin-top:18px}
.modal-actions .btn{width:auto}

/* docs */
.docs h2{margin:26px 0 6px}
.docs .ep{border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin-top:12px;background:var(--panel)}
.docs .ep .m{font-family:'IBM Plex Mono',monospace;font-size:12px}
.docs .verb{display:inline-block;font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:600;
  border-radius:6px;padding:2px 8px;margin-right:8px}
.verb.get{background:rgba(111,168,214,.16);color:var(--sea)}
.verb.post{background:rgba(103,199,154,.16);color:var(--green)}
.verb.put{background:rgba(227,195,137,.16);color:var(--gold)}
.verb.del{background:rgba(224,121,111,.16);color:var(--red)}
pre{background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:13px 14px;overflow:auto;
  font-size:12px;color:#cfe0ec;line-height:1.55;margin:10px 0}
.tryit{margin-top:10px}
.tryit textarea{width:100%;min-height:90px;background:var(--bg);border:1px solid var(--line);border-radius:8px;
  color:var(--ink);font-family:'IBM Plex Mono',monospace;font-size:12px;padding:10px}
.tryit .out{white-space:pre-wrap}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--panel2);
  border:1px solid var(--gold2);color:var(--ink);border-radius:10px;padding:11px 18px;font-size:13px;z-index:30}
