:root{
  --bg:#f6f7f9; --card:#fff; --ink:#1f2329; --muted:#5f6b7a; --line:#e3e7ec;
  --blue:#1a73e8; --blue-d:#1558b0; --green:#188038; --green-bg:#e6f4ea;
  --amber:#9a6700; --amber-bg:#fef7e0; --red:#c5221f; --red-bg:#fce8e6;
  --chip:#eef1f5;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);
  font:14px/1.5 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
.topbar{display:flex;align-items:center;justify-content:space-between;
  background:var(--card);border-bottom:1px solid var(--line);padding:12px 24px;position:sticky;top:0;z-index:10}
.brand{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px}
.brand .sep{color:var(--muted);font-weight:400}
.dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,#4285f4,#9b72cb,#d96570)}
.nav{display:flex;align-items:center;gap:18px}
.who{color:var(--muted);font-size:13px}
.btn-ghost{border:1px solid var(--line);padding:5px 12px;border-radius:8px;color:var(--ink)}
.wrap{max-width:1180px;margin:24px auto;padding:0 24px}
.foot{max-width:1180px;margin:32px auto;padding:0 24px;color:var(--muted);font-size:12px}
h1{font-size:22px;margin:0 0 4px}
h2{font-size:16px;margin:24px 0 10px}
.sub{color:var(--muted);margin:0 0 18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px;margin-bottom:18px}
.cards{display:flex;gap:14px;flex-wrap:wrap}
.scorecard{flex:1;min-width:170px}
.scorecard .n{font-size:30px;font-weight:700}
.scorecard .l{color:var(--muted);font-size:13px}
.banner{background:var(--red-bg);border:1px solid #f3c2c0;border-radius:14px;padding:14px 18px;margin-bottom:18px}
.banner h3{margin:0 0 6px;color:var(--red);font-size:15px}
.banner .pill{display:inline-block;background:#fff;border:1px solid #f3c2c0;color:var(--red);
  border-radius:999px;padding:2px 10px;margin:3px 4px 0 0;font-size:12px}
table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden}
th,td{text-align:left;padding:9px 12px;border-bottom:1px solid var(--line);vertical-align:top}
th{background:#f1f3f6;font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
tr:last-child td{border-bottom:none}
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:12px}
.tablewrap table{border:none}
.badge{display:inline-block;border-radius:999px;padding:1px 9px;font-size:11.5px;font-weight:600;white-space:nowrap}
.b-ok{background:var(--green-bg);color:var(--green)}
.b-no{background:var(--chip);color:var(--muted)}
.b-warn{background:var(--amber-bg);color:var(--amber)}
.b-proj{background:var(--red-bg);color:var(--red)}
.b-app{background:#e8f0fe;color:var(--blue-d)}
.b-custom{background:#f3e8fd;color:#8430ce}
.tiny{font-size:11.5px;color:var(--muted)}
.cell{font-size:12px}
.cell .row{display:flex;gap:4px;flex-wrap:wrap;margin-top:3px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}
form.inline{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
input,select{font:inherit;padding:7px 10px;border:1px solid var(--line);border-radius:8px;background:#fff}
button{font:inherit;font-weight:600;padding:7px 14px;border:none;border-radius:8px;background:var(--blue);color:#fff;cursor:pointer}
button:hover{background:var(--blue-d)}
button.danger{background:#fff;color:var(--red);border:1px solid #f3c2c0}
button.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.right{text-align:right}
.filterbox{margin:0 0 12px;max-width:320px}
.spacer{height:8px}
.notice{color:var(--amber);font-size:12.5px}
.check{color:var(--green);font-weight:700}
.cross{color:var(--muted)}

/* loading: top progress bar + skeleton + pager */
#ge-bar{position:fixed;top:0;left:0;height:3px;width:0;z-index:1000;
  background:linear-gradient(90deg,#4285f4,#9b72cb,#d96570);box-shadow:0 0 8px rgba(66,133,244,.5)}
.skeleton{position:relative;overflow:hidden;background:#eceff3;border-radius:8px;color:transparent}
.skeleton::after{content:"";position:absolute;inset:0;transform:translateX(-100%);
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:sk 1.2s infinite}
@keyframes sk{100%{transform:translateX(100%)}}
.sk-line{height:14px;margin:8px 0;display:inline-block;min-width:120px}
.pager{display:flex;align-items:center;gap:10px;margin:10px 0;color:var(--muted);font-size:13px}
.pager button{background:#fff;color:var(--ink);border:1px solid var(--line);padding:5px 12px;font-weight:600}
.pager button:disabled{opacity:.4;cursor:default}

/* polished list toolbar: filter search + pagination */
.listbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:20px 0 14px}
.search{position:relative;flex:1 1 240px;max-width:380px}
.search svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.filterbox{width:100%;margin:0;padding:10px 14px 10px 40px;border:1px solid var(--line);border-radius:12px;
  background:#fff;font-size:14px;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.filterbox::placeholder{color:#9aa6b2}
.filterbox:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,115,232,.15)}
.pager{display:inline-flex;align-items:center;gap:8px;margin:0}
.pager .pgbtn{background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:10px;
  padding:8px 16px;font-weight:600;font-size:13px;line-height:1;box-shadow:0 1px 2px rgba(20,40,80,.05)}
.pager .pgbtn:hover:not(:disabled){background:#f3f6fb;border-color:#c3ccd6}
.pager .pgbtn:disabled{opacity:.4;cursor:default;box-shadow:none}
.pager .pginfo{color:var(--muted);font-size:13px;padding:0 6px;min-width:96px;text-align:center;font-variant-numeric:tabular-nums}
