:root{--blue:#1565c0;--blue-dark:#0d47a1;--yellow:#ffc107;--bg:#f4f6f9;--surface:#ffffff;--ink:#1a2230;--muted:#5b6675;--border:#e3e8ef;--green:#15803d;--green-bg:#dcfce7;--amber:#b45309;--amber-bg:#fef3c7;--slate-bg:#eef2f7}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px}a{color:var(--blue)}.topbar{background:var(--blue);color:#fff;padding:12px 20px;display:flex;align-items:center;gap:12px}.topbar .brand{font-weight:700;font-size:16px;letter-spacing:.2px}.topbar .spacer{flex:1 1}.topbar .who{font-size:13px;opacity:.92}.wrap{max-width:1240px;margin:0 auto;padding:20px}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:12px;gap:12px;margin-bottom:16px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.stat .num{font-size:26px;font-weight:700;line-height:1.1}.stat .lbl{color:var(--muted);font-size:12px;margin-top:4px;text-transform:uppercase;letter-spacing:.4px}.stat.accent{border-top:3px solid var(--yellow)}.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:end;margin-bottom:16px}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:12px;color:var(--muted)}.input,select{height:38px;padding:0 10px;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:14px;color:var(--ink);min-width:150px}.toolbar .grow{flex:1 1}.btn{height:38px;padding:0 16px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--ink);font-weight:600;cursor:pointer;font-size:14px}.btn:hover{background:#f8fafc}.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff}.btn-primary:hover{background:var(--blue-dark)}.btn-accent{background:var(--yellow);border-color:var(--yellow);color:#3a2e00}.btn:disabled{opacity:.6;cursor:default}.section-title{font-weight:700;margin:18px 0 10px}.map-box{height:380px;border-radius:10px;overflow:hidden}.map-box,.table-scroll{border:1px solid var(--border)}.table-scroll{overflow-x:auto;border-radius:10px;background:#fff}table.data{border-collapse:collapse;width:100%;font-size:13px;white-space:nowrap}table.data td,table.data th{padding:9px 12px;border-bottom:1px solid var(--border);text-align:left}table.data th{background:var(--slate-bg);font-weight:600;position:-webkit-sticky;position:sticky;top:0}table.data tbody tr:hover{background:#f8fafc}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.badge,.mono{font-weight:600}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px}.badge.baru{background:var(--slate-bg);color:var(--muted)}.badge.ok{background:var(--green-bg);color:var(--green)}.badge.revisi{background:var(--amber-bg);color:var(--amber)}.empty,.loading{text-align:center;color:var(--muted);padding:40px}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:360px}.login-card h1{font-size:20px;margin:0 0 2px}.login-card .sub{color:var(--muted);margin-bottom:18px}.login-card .field{margin-bottom:12px}.login-card .input{width:100%}.err{color:#b91c1c;font-size:13px;margin-top:8px}