/* layout */
:root { --bg:#0e1013; --fg:#e7eaee; --muted:#a9b1bc; --pill:#1b2130; --accent:#58a6ff; --ok:#34d399; --warn:#f59e0b; --bad:#ef4444; --card:#0f1520; --border:#202737;}
*{box-sizing:border-box} html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font:14px/1.5 system-ui,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial}
a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
.hidden{display:none}

/* header */
.topbar{display:flex;gap:16px;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:rgba(255,255,255,0.02);backdrop-filter:saturate(140%) blur(4px)}
.topbar h1{font-size:18px;margin:0}
.search{display:flex;gap:8px;align-items:center}
.search input{padding:8px 10px;border:1px solid var(--border);background:#0b0e13;color:var(--fg);border-radius:8px;min-width:260px}
.search button{padding:8px 12px;border:1px solid var(--border);background:var(--pill);color:var(--fg);border-radius:8px;cursor:pointer}
.search .link{margin-left:6px;color:var(--muted)}

/* stats */
.stats{display:flex;flex-wrap:wrap;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border)}
.pill{background:var(--pill);padding:6px 10px;border-radius:999px;color:var(--fg)}
.num{font-weight:700}

/* toolbar */
.toolbar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border)}
.view-toggle{display:flex;gap:8px}
.view-toggle button{padding:8px 10px;background:#121826;border:1px solid var(--border);color:var(--fg);border-radius:8px;cursor:pointer}
.view-toggle button.active{outline:2px solid var(--accent)}


/* table */
.table-wrap{padding:10px 16px}
.tbl{width:100%;border-collapse:collapse}
.tbl thead th{position:sticky;top:0;background:#0b0f19;border-bottom:1px solid var(--border);text-align:left;padding:10px 8px;font-weight:600}
.tbl tbody td{border-bottom:1px dashed #182030;padding:8px 8px;vertical-align:top}
.tbl .badge{display:inline-block;padding:2px 8px;border-radius:999px;background:#10172a;border:1px solid #22304a;color:#cde1ff}
.nowrap{white-space:nowrap}

/* cards */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;padding:12px 16px}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:6px}
.card .ip{font-weight:700}
.card small{color:var(--muted)}

/* errors */
#err{margin-left:auto;color:#fff;background:var(--bad);padding:6px 10px;border-radius:6px}
