:root{
  --blue:#0057FF;--ink:#0c1426;--muted:#5e6c88;--bg:#eef1f7;--card:#fff;--line:#e2e8f3;
  --green:#1fb255;--red:#ef4444;--amber:#f59e0b;
  --disp:"Bricolage Grotesque",sans-serif;--body:"Plus Jakarta Sans",-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
html,body{height:100%}
body{font-family:var(--body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}
#app{min-height:100%}
.boot{position:fixed;inset:0;display:grid;place-items:center}
.spin{width:34px;height:34px;border:3px solid #cfd8ea;border-top-color:var(--blue);border-radius:50%;animation:sp 0.8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.bspin{width:16px;height:16px;border:2.5px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;display:inline-block;animation:sp .7s linear infinite}

/* login */
.login{min-height:100vh;display:grid;place-items:center;padding:24px}
.login .box{width:100%;max-width:380px;background:var(--card);border-radius:22px;padding:26px;box-shadow:0 24px 60px -24px rgba(10,18,40,.3)}
.brand{font-family:var(--disp);font-weight:800;font-size:24px;letter-spacing:-.5px}
.brand b{color:var(--blue)}
.muted{color:var(--muted)}
.inp{width:100%;height:50px;border:1.5px solid var(--line);border-radius:13px;padding:0 14px;font-family:var(--body);font-size:15px;font-weight:600;outline:none;background:#fff;margin-top:10px}
textarea.inp{height:auto;padding:11px 14px;min-height:64px;resize:vertical}
.btn{width:100%;height:50px;border:none;border-radius:13px;background:var(--blue);color:#fff;font-family:var(--body);font-weight:800;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px}
.btn:active{transform:scale(.99)} .btn[disabled]{opacity:.5}
.btn.sm{height:38px;font-size:13px;border-radius:10px;width:auto;padding:0 14px;margin:0}
.btn.ghost{background:#fff;color:var(--blue);border:1.5px solid var(--line)}
.btn.ok{background:var(--green)} .btn.danger{background:var(--red)}
.devcode{margin-top:14px;background:#eaf1ff;border:1.5px dashed var(--blue);border-radius:12px;padding:10px;text-align:center}
.otpwrap{display:flex;gap:8px;margin-top:14px;justify-content:center}
.otpwrap input{width:44px;height:54px;border:1.5px solid var(--line);border-radius:12px;text-align:center;font-family:var(--disp);font-weight:800;font-size:22px;outline:none}

/* shell */
.top{position:sticky;top:0;z-index:20;background:#0a1430;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:14px 18px}
.top .t{font-family:var(--disp);font-weight:800;font-size:18px}
.top .t b{color:#5e8bff}
.lo{background:rgba(255,255,255,.12);border:none;color:#fff;font-weight:700;font-size:12px;padding:7px 12px;border-radius:9px;cursor:pointer}
.wrap{max-width:920px;margin:0 auto;padding:16px 16px 60px}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.stat{background:var(--card);border:1.5px solid var(--line);border-radius:16px;padding:13px 14px}
.stat .k{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
.stat .v{font-family:var(--disp);font-weight:800;font-size:23px;margin-top:3px}
.stat.warn{background:#fff7ed;border-color:#fed7aa} .stat.warn .v{color:#c2410c}

.tabs{display:flex;gap:8px;overflow-x:auto;margin:16px 0 12px;-webkit-overflow-scrolling:touch}
.tabs button{flex:none;background:#fff;border:1.5px solid var(--line);color:var(--muted);font-weight:700;font-size:13px;padding:9px 14px;border-radius:11px;cursor:pointer;white-space:nowrap}
.tabs button.on{background:var(--blue);color:#fff;border-color:var(--blue)}

.card{background:var(--card);border:1.5px solid var(--line);border-radius:16px;padding:14px;margin-bottom:11px}
.row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.row.wrap{flex-wrap:wrap}
.h{font-family:var(--disp);font-weight:800;font-size:16px}
.sub{font-size:12px;color:var(--muted);margin-top:2px}
.pill{display:inline-block;font-size:10px;font-weight:800;padding:3px 8px;border-radius:7px;letter-spacing:.3px}
.pill.green{color:var(--green);background:rgba(31,178,85,.12)}
.pill.amber{color:#c2410c;background:#fff2e6}
.pill.red{color:var(--red);background:rgba(239,68,68,.1)}
.pill.blue{color:var(--blue);background:rgba(0,87,255,.1)}
.pill.gray{color:var(--muted);background:#eef1f7}
.dek{width:52px;height:52px;border-radius:10px;object-fit:cover;border:1px solid var(--line);cursor:pointer;flex:none}
.acts{display:flex;gap:8px;flex-wrap:wrap}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.lbl{font-size:11px;font-weight:700;color:var(--muted);margin:8px 0 2px}
.empty{text-align:center;color:var(--muted);padding:28px 10px;font-size:13px}
table.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
table.tbl th{text-align:left;color:var(--muted);font-weight:700;font-size:11px;padding:6px 6px;border-bottom:1.5px solid var(--line)}
table.tbl td{padding:8px 6px;border-bottom:1px solid #eef1f7}
.tblwrap{overflow-x:auto}

#scrim{position:fixed;inset:0;background:rgba(8,12,24,.55);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:.2s;z-index:80;display:grid;place-items:center;padding:20px}
#scrim.show{opacity:1;pointer-events:auto}
#scrim img{max-width:100%;max-height:88vh;border-radius:14px}
#toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.92);background:#0a1430;color:#fff;font-weight:700;font-size:14px;padding:13px 20px;border-radius:14px;box-shadow:0 18px 40px -14px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:.18s;z-index:120;max-width:78%;text-align:center}
#toast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
#toast.ok{background:#16a34a}#toast.err{background:#dc2626}
.center{text-align:center}.right{text-align:right}
