:root{
  --bg:#0a1611; --surface:#0f2018; --surface2:#13271d; --border:#1d3a2c;
  --text:#e8f3ee; --muted:#8aa99a; --green:#10b981; --green2:#0d9668;
  --red:#ef4444; --amber:#f59e0b; --blue:#3b82f6;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);color:var(--text);overscroll-behavior-y:contain}
.screen{display:none;min-height:100%}
.screen.active{display:block}
.muted{color:var(--muted)} .small{font-size:13px}
.err{color:var(--red);font-size:14px;margin:6px 0 0}

/* login */
#login{display:none;align-items:center;justify-content:center;padding:24px;min-height:100vh}
#login.active{display:flex}
.login-box{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);
  border-radius:20px;padding:26px}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.brand-mark{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--green),var(--green2));
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;color:#04130c}
.brand small{display:block;color:var(--muted);font-size:12px}
.login-box h1{font-size:22px;margin:0 0 4px}
form label{display:block;font-size:13px;color:var(--muted);margin:14px 0 0}
form input,form select{width:100%;margin-top:6px;padding:13px 14px;border-radius:12px;
  background:var(--surface2);border:1px solid var(--border);color:var(--text);font-size:16px}
form input:focus,form select:focus{outline:none;border-color:var(--green)}

/* buttons */
.btn{display:block;width:100%;margin-top:18px;padding:15px;border:none;border-radius:14px;
  font-size:16px;font-weight:700;cursor:pointer}
.btn.primary{background:linear-gradient(135deg,var(--green),var(--green2));color:#04130c}
.btn.primary:active{transform:translateY(1px)}
.link{background:none;border:none;color:var(--muted);font-size:14px;cursor:pointer}

/* app shell */
.topbar{display:flex;align-items:center;gap:12px;padding:14px 16px;
  background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:5}
.topbar .who{flex:1}.topbar .who b{display:block;font-size:15px}.topbar .who small{color:var(--muted);font-size:12px}
.net{width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green)}
.net.off{background:var(--amber);box-shadow:0 0 8px var(--amber)}
#views{padding:16px 16px 90px}
.view{display:none}.view.active{display:block}
.view-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.view-head h2{font-size:19px;margin:0}
.back{background:var(--surface2);border:1px solid var(--border);color:var(--text);
  width:34px;height:34px;border-radius:10px;font-size:22px;line-height:1;cursor:pointer}

.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:16px}
.hero small{color:var(--muted);font-size:12px}.hero b{display:block;font-size:20px;margin-top:2px}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:14px 0}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px;text-align:center}
.stat b{display:block;font-size:26px;color:var(--green)}.stat small{color:var(--muted);font-size:12px}
.actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.action{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px 12px;
  color:var(--text);font-size:15px;font-weight:600;cursor:pointer;display:flex;flex-direction:column;
  align-items:center;gap:8px}
.action span{font-size:28px}
.action:active{border-color:var(--green)}

.field{margin-bottom:10px}.field label{display:block;color:var(--muted);font-size:13px;margin-bottom:6px}
.field select{width:100%;padding:12px;border-radius:12px;background:var(--surface2);
  border:1px solid var(--border);color:var(--text);font-size:16px}
.form label{margin-top:14px}

/* worker attendance list */
.worker-list{margin:8px 0 80px}
.worker-row{display:flex;align-items:center;gap:12px;padding:14px;margin-bottom:8px;
  background:var(--surface);border:1px solid var(--border);border-radius:14px;cursor:pointer}
.worker-row .nm{flex:1}.worker-row .nm b{display:block;font-size:15px}
.worker-row .nm small{color:var(--muted);font-size:12px}
.badge{min-width:46px;text-align:center;padding:7px 10px;border-radius:10px;font-weight:800;font-size:14px}
.badge.P{background:rgba(16,185,129,.18);color:var(--green)}
.badge.H{background:rgba(245,158,11,.18);color:var(--amber)}
.badge.OT{background:rgba(59,130,246,.2);color:var(--blue)}
.badge.A{background:rgba(239,68,68,.16);color:var(--red)}

.btn.sticky{position:fixed;left:16px;right:16px;bottom:72px;width:auto;margin:0;z-index:6;
  box-shadow:0 8px 24px rgba(0,0,0,.4)}
.preview{width:100%;max-height:220px;object-fit:cover;border-radius:12px;margin-top:12px;border:1px solid var(--border)}
.photo-label input{margin-top:8px}
.queue-note{margin-top:14px;padding:10px 12px;background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.3);
  border-radius:10px;color:var(--amber);font-size:13px}

/* tab bar */
.tabbar{position:fixed;bottom:0;left:0;right:0;display:grid;grid-template-columns:repeat(4,1fr);
  background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom)}
.tab{background:none;border:none;color:var(--muted);font-size:11px;padding:9px 0 7px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:3px}
.tab span{font-size:20px}.tab.active{color:var(--green)}

.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:#04130c;
  border:1px solid var(--green);color:var(--text);padding:11px 18px;border-radius:12px;font-size:14px;z-index:20;
  box-shadow:0 8px 24px rgba(0,0,0,.5)}
