:root{
  --em:#343cd1; --em2:#262ea3; --em-soft:#e8eafb;
  --appbar-1:#4f57ec; --appbar-2:#2a31b8;
  --ink:#14233e; --slate:#5b6b85; --muted:#8a97ac;
  --line:#e6e9f0; --bg:#f3f4f8; --card:#fff;
  --green:#0a8a6f; --green-soft:#e3f6f1;
  --amber:#a9701a; --amber-soft:#fcf1de;
  --red:#c0303f; --red-soft:#fde8ea;
  --radius:16px; --shadow:0 1px 3px rgba(20,35,62,.06); --shadow-lg:0 12px 32px rgba(20,35,62,.14);
  --font:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif; --display:'Sora',var(--font);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--ink);-webkit-tap-highlight-color:transparent;overscroll-behavior-y:contain}
button{font-family:inherit;cursor:pointer}
img{max-width:100%}
.hidden{display:none!important}

/* ---------- App shell ---------- */
#app{max-width:520px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}
.appbar{position:sticky;top:0;z-index:1000;display:flex;align-items:center;gap:10px;padding:12px 16px;
  background:linear-gradient(135deg,var(--appbar-1),var(--appbar-2));color:#fff;box-shadow:var(--shadow)}
.appbar .logo{width:34px;height:34px;border-radius:9px;background:#fff;padding:3px;object-fit:contain}
.appbar .title{font-family:var(--display);font-weight:700;font-size:16px;line-height:1.1}
.appbar .sub{font-size:11px;opacity:.85}
.appbar .spacer{flex:1}
.bell{position:relative;background:rgba(255,255,255,.16);border:none;color:#fff;width:38px;height:38px;border-radius:11px;font-size:17px;display:grid;place-items:center}
.bell .badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:10px;min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px;font-weight:700;border:2px solid #2a31b8}
main{flex:1;padding:16px;padding-bottom:88px}
.view{animation:fade .2s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ---------- Cards & bits ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card.pad{padding:16px}
.h{font-family:var(--display);font-weight:700}
.muted{color:var(--muted)}
.slate{color:var(--slate)}
.center{text-align:center}
.row{display:flex;gap:10px;align-items:center}
.between{justify-content:space-between}
.mt{margin-top:14px}.mt8{margin-top:8px}.mb{margin-bottom:12px}
.sectitle{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:18px 4px 8px}

.btn{border:none;background:var(--em);color:#fff;font-weight:700;padding:13px 16px;border-radius:12px;font-size:14.5px;width:100%}
.btn:active{transform:translateY(1px)}
.btn[disabled]{opacity:.5;pointer-events:none}
.btn.ghost{background:var(--em-soft);color:var(--em2)}
.btn.line{background:#fff;border:1px solid var(--line);color:var(--ink)}
.btn.sm{padding:9px 12px;font-size:13px;width:auto;border-radius:10px}
.btn.danger{background:var(--red)}
.btn.red{background:var(--red)}
/* Tombol absen: warna STATIS (lepas dari tema) — Masuk hijau, Pulang merah, agar selalu jelas bedanya walau tema site merah */
#absenBtn{background:var(--green)}
#absenBtn.red{background:var(--red)}

.field{margin-bottom:12px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--slate);margin-bottom:6px}
.input,select,textarea{width:100%;padding:12px;border:1px solid var(--line);border-radius:11px;font-family:inherit;font-size:14.5px;background:#fff;color:var(--ink)}
.input:focus,select:focus,textarea:focus{outline:none;border-color:var(--em);box-shadow:0 0 0 3px var(--em-soft)}
textarea{min-height:78px;resize:vertical}

.tag{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px}
.tags{display:flex;align-items:center;gap:5px;flex-wrap:wrap;justify-content:flex-end}
.t-green{background:var(--green-soft);color:var(--green)}
.t-amber{background:var(--amber-soft);color:var(--amber)}
.t-red{background:var(--red-soft);color:var(--red)}
.t-blue{background:var(--em-soft);color:var(--em2)}
.t-gray{background:#eef1f6;color:var(--slate)}
.t-purple{background:#ede9fe;color:#6d28d9}

/* ---------- Location status (signature element) ---------- */
.loc{margin-top:14px;border-radius:var(--radius);padding:16px;color:#fff;transition:background .3s}
.loc.green{background:linear-gradient(135deg,#0fa884,#0a7a63)}
.loc.amber{background:linear-gradient(135deg,#d79a3a,#a9701a)}
.loc.red{background:linear-gradient(135deg,#d9596a,#b3293a)}
.loc .dot{width:12px;height:12px;border-radius:50%;background:#fff;box-shadow:0 0 0 0 rgba(255,255,255,.7);animation:pulse 1.6s infinite}
.loc.green .dot{animation:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.6)}70%{box-shadow:0 0 0 10px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.loc .lbl{font-weight:700;font-size:15px}
.loc .meta{font-size:12px;opacity:.9;margin-top:3px}
.alert{display:flex;gap:8px;align-items:flex-start;background:var(--amber-soft);color:#7a531a;border:1px solid #f0dcae;border-radius:12px;padding:10px 12px;font-size:13px;margin-top:12px}

.bigclock{font-family:var(--display);font-weight:700;font-size:34px;letter-spacing:.5px}
.statgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.stat{background:#f7f9fc;border-radius:12px;padding:12px}
.stat .n{font-family:var(--display);font-size:20px;font-weight:700}
.stat .l{font-size:11.5px;color:var(--slate)}

.list .item{padding:12px 14px;border-bottom:1px solid var(--line)}
.list .item:last-child{border-bottom:none}
.list .item .t{font-weight:600;font-size:13.5px}
.list .item .s{font-size:12px;color:var(--muted);margin-top:2px}

/* ---------- Bottom nav ---------- */
.nav{position:fixed;left:0;right:0;bottom:0;z-index:1000;max-width:520px;margin:0 auto;display:flex;
  background:#fff;border-top:1px solid var(--line);padding:6px 6px calc(6px + env(safe-area-inset-bottom))}
.nav a{flex:1;text-align:center;padding:7px 4px;border-radius:12px;color:var(--muted);text-decoration:none;font-size:10.5px;font-weight:600}
.nav a .ic{display:block;font-size:19px;line-height:1.2}
.nav a.active{color:var(--em);background:var(--em-soft)}

/* ---------- Login ---------- */
.login{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:28px 22px;
  background:radial-gradient(1100px 460px at 50% -8%, #e8eafb, var(--bg))}
.login .brand{display:flex;flex-direction:column;align-items:center;margin-bottom:22px}
.login .brand img{width:76px;height:76px}
.login .brand h1{font-family:var(--display);font-size:21px;margin:12px 0 2px}
.login .brand p{margin:0;color:var(--slate);font-size:13px}

/* ---------- Notif panel & sheet ---------- */
.sheet-bg{position:fixed;inset:0;background:rgba(20,35,62,.45);z-index:9999;display:flex;align-items:flex-end;justify-content:center}
.sheet{background:#fff;width:100%;max-width:520px;border-radius:18px 18px 0 0;max-height:90vh;height:90vh;overflow:auto;animation:up .22s ease}
@keyframes up{from{transform:translateY(20px);opacity:.6}to{transform:none;opacity:1}}
.sheet .hd{position:sticky;top:0;background:#fff;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}
.sheet .hd .x{border:none;background:#eef1f6;width:32px;height:32px;border-radius:9px;font-size:16px}
.notif{padding:13px 16px;border-bottom:1px solid var(--line);display:flex;gap:10px}
.notif.unread{background:var(--em-soft)}
.notif .ic{width:34px;height:34px;border-radius:10px;background:var(--em-soft);color:var(--em2);display:grid;place-items:center;flex:none}
.notif .t{font-weight:600;font-size:13.5px}
.notif .b{font-size:12.5px;color:var(--slate);margin-top:2px}
.notif .tm{font-size:11px;color:var(--muted);margin-top:3px}

/* ---------- Toast ---------- */
#toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);z-index:10000;display:flex;flex-direction:column;gap:8px;width:calc(100% - 32px);max-width:480px}
.toast{background:var(--ink);color:#fff;padding:11px 14px;border-radius:12px;font-size:13px;box-shadow:var(--shadow-lg);animation:fade .2s}
.toast.ok{background:#0a7a63}.toast.err{background:var(--red)}.toast.warn{background:var(--amber)}
.spinner{display:inline-block;width:15px;height:15px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px}
.spinner.dark{border-color:var(--em-soft);border-top-color:var(--em)}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion: reduce){*{animation:none!important;transition:none!important}}
