:root{
  --bg:#f4f6f9; --panel:#fff; --ink:#1a2230; --muted:#6b7686; --line:#e2e7ee;
  --accent:#2563eb; --accent-ink:#1d4ed8;
  --yes-bg:#e7f6ec; --yes-ink:#1b7a3d; --no-bg:#fdeaea; --no-ink:#b3261e;
  --chip-bg:#eef2f7; --chip-ink:#3a4658;
  --mono:"SFMono-Regular",ui-monospace,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);
  font:14px/1.45 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
.small{font-size:12px}
.mono{font-family:var(--mono);font-size:.92em}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;
  background:#0f172a;color:#fff;padding:10px 20px;position:sticky;top:0;z-index:5}
.topbar .brand{color:#fff;font-weight:600;font-size:16px}
.topbar .brand span{color:#7dd3fc;font-weight:400}
.topbar nav a{color:#cbd5e1;margin-left:18px}
.topbar nav a:hover{color:#fff}
main{max-width:1280px;margin:0 auto;padding:20px}

/* login */
.login-body{display:flex;min-height:100vh;align-items:center;justify-content:center;background:#0f172a}
.login-card{background:#fff;padding:32px;border-radius:12px;width:340px;
  box-shadow:0 12px 40px rgba(0,0,0,.35);display:flex;flex-direction:column;gap:8px}
.login-card h1{margin:0;font-size:24px}
.login-card label{font-size:12px;color:var(--muted);margin-top:8px}
.login-card input{padding:10px;border:1px solid var(--line);border-radius:8px;font-size:15px}
.login-card button{margin-top:14px;padding:10px;background:var(--accent);color:#fff;
  border:0;border-radius:8px;font-size:15px;cursor:pointer}
.login-card button:hover{background:var(--accent-ink)}
.login-error{background:var(--no-bg);color:var(--no-ink);padding:8px 10px;border-radius:6px;margin:4px 0;font-size:13px}

/* page head + filters */
.page-head h1{font-size:20px;margin:0 0 14px}
.filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}
.filters input[type=search],.filters select{padding:7px 9px;border:1px solid var(--line);
  border-radius:7px;background:#fff;font-size:13px}
.filters input[type=search]{min-width:260px;flex:1}
.filters .toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}
.filters .reset{font-size:12px;color:var(--muted)}
.result-count{font-size:13px;color:var(--muted);margin-bottom:8px}

/* grid table */
.grid{width:100%;border-collapse:collapse;background:var(--panel);
  border:1px solid var(--line);border-radius:10px;overflow:hidden}
.grid thead th{background:#f0f3f8;text-align:left;font-size:11px;text-transform:uppercase;
  letter-spacing:.04em;color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap}
.grid thead th a{color:var(--muted);display:block;padding:9px 12px}
.grid thead th.sorted a{color:var(--ink)}
.grid thead th .arrow{margin-left:4px}
.grid th.num,.grid td.num{text-align:right;font-variant-numeric:tabular-nums}
.grid tbody td{padding:8px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.grid tbody tr:hover{background:#f7faff;cursor:pointer}
.grid tbody tr:last-child td{border-bottom:0}
.grid td a{font-weight:600}
.empty{text-align:center;color:var(--muted);padding:24px!important}
.tag-faint{margin-left:8px;font-size:11px;color:var(--muted);background:#f0f0f3;
  padding:1px 6px;border-radius:4px;vertical-align:middle}

/* chips / status */
.chip{display:inline-block;background:var(--chip-bg);color:var(--chip-ink);
  padding:1px 8px;border-radius:11px;font-size:12px;margin:1px 3px 1px 0;white-space:nowrap}
.chip-mode{background:#e6eefc;color:#1d4ed8}
.chip-yes{background:var(--yes-bg);color:var(--yes-ink)}
.chip-no{background:var(--no-bg);color:var(--no-ink)}
.chip-null{background:#eef0f3;color:#9aa3b2}
.chip-faint{background:#f0f0f3;color:#7a8190}
.status{font-size:12px;padding:1px 8px;border-radius:11px;background:#eef0f3;color:#5a6473;white-space:nowrap}
.status-live{background:var(--yes-bg);color:var(--yes-ink)}
.status-pipeline{background:#fef3e7;color:#b5651d}
.status-integrating{background:#e6eefc;color:#1d4ed8}
.status-on-hold{background:#f3e8f9;color:#8e44ad}

/* pager */
.pager{display:flex;gap:14px;align-items:center;justify-content:center;margin:16px 0;font-size:13px}
.pager .disabled{color:#b8bfca}
.pager .page-of{color:var(--muted)}

/* detail */
.crumbs{font-size:12px;color:var(--muted);margin-bottom:10px}
.crumbs span{margin:0 6px}
.detail-head{margin-bottom:16px}
.detail-head h1{margin:0 0 6px;font-size:24px}
.code-badge{font-size:14px;background:#eef2f7;padding:2px 8px;border-radius:6px;vertical-align:middle}
.head-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px;margin-bottom:16px}
.card h2{font-size:14px;margin:0 0 12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.card h3{font-size:13px;margin:14px 0 6px}
.narrative p{margin:0 0 8px}
.bullets{margin:0;padding-left:18px}
.bullets li{margin:2px 0}
.fields{margin:0;display:grid;grid-template-columns:1fr;gap:0}
.field{display:grid;grid-template-columns:160px 1fr;gap:10px;padding:5px 0;border-bottom:1px dashed var(--line)}
.field:last-child{border-bottom:0}
.field dt{color:var(--muted);font-size:12px}
.field dd{margin:0}

/* cities accordion */
.countries{display:flex;flex-direction:column;gap:4px}
.country{border:1px solid var(--line);border-radius:7px;padding:4px 10px;background:#fafbfd}
.country summary{cursor:pointer;font-size:13px;padding:3px 0}
.city-list{columns:3;column-gap:18px;margin:8px 0 4px;padding-left:16px;font-size:12px}
.city-list li{break-inside:avoid;margin:1px 0}

/* json cards / mini tables */
.subgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.jcard{border:1px solid var(--line);border-radius:7px;padding:8px 10px;margin-bottom:8px;background:#fafbfd}
.jcard-head{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.feat{margin:6px 0 0;padding-left:16px;font-size:12px}
.feat li{margin:2px 0}
.related{margin:0;padding-left:16px}
.mini{width:100%;border-collapse:collapse;font-size:12px}
.mini th,.mini td{text-align:left;padding:4px 6px;border-bottom:1px solid var(--line)}
.mini th.num,.mini td.num{text-align:right}

@media(max-width:860px){
  .detail-grid,.subgrid{grid-template-columns:1fr}
  .city-list{columns:2}
  .filters input[type=search]{min-width:160px}
}
