:root{
  --green:#0e7a44; --green-d:#0a4226; --green-l:#16a05a; --green-2:#1f7a4d;
  --gold:#d9b66a; --red:#c0392b; --amber:#d97b15;
  --ink:#1f2a3d; --ink-2:#3a4760; --muted:#7a8699; --muted-2:#9aa4b4;
  --line:#e6eaf1; --bg:#e6f0ea; --card:#fff; --soft:#f4f6fa;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Sarabun',sans-serif;color:var(--ink);background:var(--bg);-webkit-tap-highlight-color:transparent}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
.hidden{display:none!important}

#login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(165deg,#0e7a44 0%,#16a05a 55%,#1f7a4d 160%)}
.login-card{width:100%;max-width:380px;background:rgba(255,255,255,.06);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.18);border-radius:22px;padding:34px 28px;color:#fff;text-align:center}
.login-logo{width:96px;height:96px;border-radius:50%;background:#fff;padding:8px;margin:0 auto 16px;display:block;object-fit:contain;box-shadow:0 8px 24px -10px rgba(0,0,0,.35)}
.login-card h1{font-size:21px;font-weight:800;margin:0;line-height:1.3}
.login-card .sub{font-size:14px;opacity:.85;margin:4px 0 26px}
.field{text-align:left;margin-bottom:15px}
.field label{font-size:13px;font-weight:600;opacity:.92}
.field input{width:100%;margin-top:6px;padding:13px 15px;border:none;border-radius:12px;font-size:15px;background:rgba(255,255,255,.96);color:var(--ink)}
.btn-primary{width:100%;padding:15px;border:none;border-radius:12px;font-size:16px;font-weight:700;color:var(--green);background:var(--gold);box-shadow:0 8px 20px -8px rgba(217,182,106,.8)}
.btn-primary:disabled{opacity:.55;box-shadow:none}
.login-hint{font-size:12px;opacity:.78;margin-top:18px;line-height:1.7}
.login-err{background:rgba(192,57,43,.92);color:#fff;border-radius:10px;padding:10px;font-size:13px;font-weight:600;margin-bottom:14px}

#app{display:none;min-height:100vh;background:var(--soft);max-width:520px;margin:0 auto;
  flex-direction:column;position:relative;box-shadow:0 0 60px -20px rgba(0,0,0,.2)}
#app.show{display:flex}
.topbar{background:var(--green);color:#fff;padding:14px 18px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:40}
.topbar img{width:42px;height:42px;border-radius:50%;background:#fff;padding:3px;flex:none}
.topbar .who{flex:1;line-height:1.25}
.topbar .who .hi{font-size:11px;opacity:.78;font-weight:500}
.topbar .who .nm{font-size:15px;font-weight:700}
.topbar .who .role{font-size:11px;opacity:.78}
.icon-btn{background:none;border:none;color:#fff;opacity:.9;padding:6px;display:inline-flex}
.scroll{flex:1;overflow-y:auto;padding-bottom:84px}

.tabbar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:520px;
  background:#fff;border-top:1px solid var(--line);display:flex;z-index:40}
.tabbar button{flex:1;background:none;border:none;padding:9px 4px 11px;color:var(--muted);font-size:11px;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:3px}
.tabbar button.active{color:var(--green)}
.tabbar svg{width:23px;height:23px}

.pad{padding:16px}
.clock-card{background:linear-gradient(150deg,var(--green-l),var(--green));border-radius:18px;padding:18px 20px;color:#fff;text-align:center;box-shadow:0 14px 30px -16px rgba(14,122,68,.6)}
.clock-card .d{font-size:13px;opacity:.85}
.clock-card .t{font-size:46px;font-weight:800;line-height:1.1;margin:2px 0;font-variant-numeric:tabular-nums}
.pill{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;background:rgba(255,255,255,.18);padding:5px 13px;border-radius:20px;margin-top:4px}
.pill .dot{width:8px;height:8px;border-radius:50%}
.two{display:flex;gap:12px;margin-top:14px}
.stat{flex:1;background:#fff;border-radius:14px;padding:13px 14px;border:1px solid var(--line)}
.stat .k{font-size:12px;color:var(--muted);font-weight:600}
.stat .v{font-size:24px;font-weight:800;color:var(--green);font-variant-numeric:tabular-nums}
.stat .s{font-size:11px;font-weight:600}

#map{height:230px;border-radius:16px;margin-top:14px;border:1px solid var(--line);z-index:1}
#map.admin-map{height:300px}
.geo-line{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-2);margin-top:10px;font-weight:500}
.badge-in{color:var(--green);font-weight:700}
.badge-out{color:var(--red);font-weight:700}

.cta{width:100%;margin-top:16px;padding:16px;border:none;border-radius:14px;font-size:16px;font-weight:700;color:#fff}
.ghost{width:100%;margin-top:10px;padding:13px;border:1.5px solid var(--line);background:#fff;border-radius:12px;font-size:14px;font-weight:600;color:var(--ink-2)}

.sec-title{font-size:15px;font-weight:700;color:var(--ink-2);margin:22px 4px 10px}
.list-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.row{display:flex;align-items:center;gap:12px;padding:13px 15px;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:none}
.row .av{width:38px;height:38px;border-radius:10px;background:var(--soft);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--green);flex:none;font-size:14px}
.row .main{flex:1;line-height:1.35;min-width:0}
.row .main .t1{font-size:14px;font-weight:600}
.row .main .t2{font-size:12px;color:var(--muted)}
.tag{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}

.form-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}
.form-card label{font-size:13px;font-weight:600;color:var(--ink-2);display:block;margin:12px 0 5px}
.form-card label:first-child{margin-top:0}
.form-card input,.form-card select,.form-card textarea{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:10px;font-size:14px;color:var(--ink)}
.form-card textarea{resize:vertical;min-height:70px}
.help{font-size:12px;color:var(--muted);line-height:1.6;margin-top:8px}

.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.kpi .n{font-size:30px;font-weight:800;line-height:1}
.kpi .l{font-size:12.5px;color:var(--muted);font-weight:600;margin-top:4px}
.btn-line{display:inline-flex;align-items:center;gap:7px;border:1.5px solid var(--green);color:var(--green);background:#fff;border-radius:10px;padding:9px 14px;font-size:13px;font-weight:700}

.modal{position:fixed;inset:0;background:rgba(10,32,20,.78);z-index:90;display:flex;align-items:center;justify-content:center;padding:18px}
.cam-card{width:100%;max-width:420px;background:#0a4226;border-radius:22px;padding:16px;color:#fff;text-align:center}
.cam-card h3{margin:6px 0 2px;font-size:17px;font-weight:800}
.cam-card p{margin:0 0 12px;font-size:13px;opacity:.85}
.cam-wrap{position:relative;width:100%;aspect-ratio:3/4;background:#000;border-radius:16px;overflow:hidden}
.cam-wrap video,.cam-wrap canvas{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cam-frame{position:absolute;inset:14% 18%;border:3px solid rgba(255,255,255,.85);border-radius:50%/40%;pointer-events:none}
.cam-actions{display:flex;gap:10px;margin-top:14px}
.cam-actions button{flex:1;padding:14px;border:none;border-radius:12px;font-size:15px;font-weight:700}
.shutter{background:var(--gold);color:var(--green)}
.cancel{background:rgba(255,255,255,.16);color:#fff}

#toast{position:fixed;bottom:96px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:12px 20px;border-radius:30px;font-size:14px;font-weight:600;z-index:120;opacity:0;pointer-events:none;
  transition:opacity .25s, transform .25s;max-width:90%;text-align:center}
#toast.show{opacity:1;transform:translateX(-50%) translateY(-6px)}
#toast.err{background:var(--red)}

.spin{width:26px;height:26px;border:3px solid var(--line);border-top-color:var(--green);border-radius:50%;animation:rot .8s linear infinite;margin:30px auto}
@keyframes rot{to{transform:rotate(360deg)}}
@media (min-width:560px){ .login-card{max-width:400px} }
