/* Lifted from the <style> block in ../../../src/ui-html.ts, plus additions
   for the hosted tier's login page, nav, and key-management UI. */
:root { --bg:#0f1115; --panel:#171a21; --line:#262b36; --text:#d7dce4; --dim:#8b93a3; --accent:#7aa2f7; --ok:#9ece6a; --warn:#e0af68; --bad:#f7768e; }
* { box-sizing:border-box; }
body { margin:0; background:var(--bg); color:var(--text); font:14px/1.5 ui-sans-serif,system-ui,sans-serif; }
header { display:flex; align-items:baseline; gap:12px; padding:18px 28px; border-bottom:1px solid var(--line); }
.lastused { font-size:11px; margin-top:8px; }
header h1 { font-size:18px; margin:0; letter-spacing:.5px; }
header .db { color:var(--dim); font-size:12px; font-family:ui-monospace,monospace; }
header nav { margin-left:auto; display:flex; gap:16px; align-items:baseline; }
header nav a { color:var(--dim); text-decoration:none; font-size:13px; }
header nav a.active { color:var(--accent); }
header nav button { background:none; border:1px solid var(--line); color:var(--dim); border-radius:6px; padding:4px 10px; font-size:12px; cursor:pointer; }
main { max-width:1100px; margin:0 auto; padding:20px 28px 60px; }
h2 { font-size:13px; text-transform:uppercase; letter-spacing:1.2px; color:var(--dim); margin:28px 0 10px; }
.card { background:var(--panel); border:1px solid var(--line); border-radius:10px; padding:14px 16px; margin-bottom:10px; }
.card h3 { margin:0 0 4px; font-size:15px; }
.badge { display:inline-block; font-size:11px; padding:1px 8px; border-radius:999px; border:1px solid var(--line); color:var(--dim); margin-left:8px; vertical-align:middle; }
.badge.active { color:var(--ok); border-color:var(--ok); }
.dim { color:var(--dim); }
.chips { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.chip { font-size:12px; padding:2px 9px; border-radius:999px; background:#1f2430; color:var(--text); }
ul.tasks { margin:8px 0 0; padding-left:18px; }
table { width:100%; border-collapse:collapse; font-size:13px; }
th, td { text-align:left; padding:7px 10px; border-bottom:1px solid var(--line); vertical-align:top; }
th { color:var(--dim); font-weight:500; font-size:12px; }
td.time { white-space:nowrap; color:var(--dim); font-family:ui-monospace,monospace; font-size:12px; }
.action-create { color:var(--ok); } .action-update { color:var(--accent); }
.action-supersede { color:var(--warn); } .action-revert { color:var(--bad); }
tr.reverted td { text-decoration:line-through; opacity:.45; }
tr.reverted td:last-child { text-decoration:none; }
button.revert { background:none; border:1px solid var(--line); color:var(--bad); border-radius:6px; padding:2px 10px; cursor:pointer; font-size:12px; }
button.revert:hover { border-color:var(--bad); }
#search { width:100%; background:var(--panel); border:1px solid var(--line); border-radius:10px; color:var(--text); padding:10px 14px; font-size:14px; outline:none; }
#search:focus { border-color:var(--accent); }
#results .kind { color:var(--accent); font-size:11px; text-transform:uppercase; letter-spacing:1px; }
#toast { position:fixed; bottom:20px; right:20px; background:var(--panel); border:1px solid var(--line); border-radius:8px; padding:10px 16px; display:none; }
#gap-banner { display:none; margin:0 0 18px; padding:10px 16px; border:1px solid var(--warn); border-radius:10px; background:#2a2310; color:var(--warn); font-size:13px; }

/* login / landing page */
.center-screen { min-height:100vh; display:flex; align-items:center; justify-content:center; flex-direction:column; gap:18px; text-align:center; padding:24px; }
.center-screen h1 { font-size:28px; margin:0; }
.center-screen p { color:var(--dim); max-width:420px; margin:0; }
.btn-google { display:inline-flex; align-items:center; gap:10px; background:#fff; color:#1f1f1f; border:none; border-radius:8px; padding:10px 20px; font-size:14px; font-weight:500; cursor:pointer; text-decoration:none; }
.btn-google:hover { background:#f1f1f1; }

/* keys page */
.key-row { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.key-row .meta { color:var(--dim); font-size:12px; }
.btn { background:var(--accent); color:#0f1115; border:none; border-radius:8px; padding:9px 16px; font-size:13px; font-weight:500; cursor:pointer; }
.btn:hover { opacity:.9; }
.btn.danger { background:none; border:1px solid var(--bad); color:var(--bad); }
.token-reveal { background:#1f2430; border:1px solid var(--accent); border-radius:8px; padding:12px 14px; font-family:ui-monospace,monospace; font-size:13px; word-break:break-all; margin-top:10px; }
.modal-backdrop { position:fixed; inset:0; background:rgba(0,0,0,.6); display:flex; align-items:center; justify-content:center; }
.modal { background:var(--panel); border:1px solid var(--line); border-radius:10px; padding:22px; max-width:480px; width:90%; }
.modal input { width:100%; background:var(--bg); border:1px solid var(--line); border-radius:8px; color:var(--text); padding:9px 12px; font-size:14px; margin:10px 0; }
