:root{
  --ink:#10242B; --inkSoft:#1B3A42; --brand:#0E9F77; --brand1:#0E9F77; --brand2:#1FC79A;
  --brandDark:#0A7A5B; --gold:#C79A46; --surface:#F3F7F5; --card:#FFFFFF;
  --muted:#5E6B6A; --line:#E5EBE8; --warn:#D9683C; --amber:#E0962F; --paid:#2F8F5B;
  --grad:linear-gradient(135deg,#0E9F77,#1FC79A);
  --shadow:0 1px 3px rgba(16,36,43,.06),0 10px 30px rgba(16,36,43,.05);
}
*{box-sizing:border-box}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;background:var(--surface);color:var(--ink);-webkit-font-smoothing:antialiased}
.num{font-variant-numeric:tabular-nums}
header.bar{background:linear-gradient(120deg,var(--ink),var(--inkSoft));color:#fff;position:sticky;top:0;z-index:20}
.barIn{max-width:900px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.logo{display:flex;align-items:center;gap:10px}
.logo .mk{width:36px;height:36px;border-radius:11px;background:var(--grad);display:grid;place-items:center;box-shadow:0 4px 14px rgba(14,159,119,.4);flex:none}
.logo .nm{line-height:1.05} .logo .nm b{font-size:15px;font-weight:800;letter-spacing:-.01em;display:block}
.logo .nm small{font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;opacity:.65}
.iconbtn{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;background:rgba(255,255,255,.12);color:#fff;border:0}
.wrap{max-width:900px;margin:0 auto;padding:18px 16px}
.wrap.staffpad{padding-bottom:100px}
.muted{color:var(--muted)} .small{font-size:12px} .tiny{font-size:11px}
.card{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:16px;box-shadow:var(--shadow)}
.row{display:flex;gap:10px} .between{justify-content:space-between;align-items:center}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:560px){.grid4{grid-template-columns:1fr 1fr}}
label{display:block} label .lab{font-size:11px;color:var(--muted);margin-bottom:4px;display:block}
input,select,textarea{width:100%;border:1px solid var(--line);border-radius:11px;padding:10px;font-size:14px;background:#fff;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;box-shadow:0 0 0 2px rgba(14,159,119,.2)}
textarea{resize:vertical}
button{font-family:inherit;cursor:pointer;border:0}
.btn{background:var(--grad);color:#fff;border-radius:14px;padding:12px 16px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.btn:active{transform:scale(.99)}
.btn.dark{background:var(--ink)} .btn.warn{background:var(--warn)} .btn.paid{background:var(--paid)}
.btn.block{width:100%} .btn:disabled{background:#B9C7C2;cursor:default}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink);font-weight:500}
.stat{border:1px solid var(--line);border-radius:18px;padding:13px;background:#fff}
.stat.accent{background:linear-gradient(135deg,var(--ink),var(--inkSoft));border-color:transparent}
.stat .l{font-size:12px;color:var(--muted);margin-bottom:3px;display:flex;align-items:center;gap:5px}
.stat.accent .l{color:rgba(255,255,255,.6)} .stat .v{font-size:22px;font-weight:700}
.stat.accent .v{color:#fff}
.chip{font-size:10px;padding:2px 6px;border-radius:5px;display:inline-block}
.tab{white-space:nowrap;font-size:14px;padding:9px 14px;border-radius:13px;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#fff;color:var(--muted);position:relative}
.tab.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px}
.seg{display:inline-flex;background:#E6EBE8;border-radius:11px;padding:2px;flex-wrap:wrap}
.seg button{font-size:12px;padding:7px 12px;border-radius:9px;font-weight:500;color:var(--muted);background:transparent}
.seg button.on{background:#fff;color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.08)}
.badge{font-size:10px;color:#fff;background:var(--gold);border-radius:10px;padding:1px 6px;font-weight:700;margin-left:4px}
.shift{border:1px solid var(--line);border-radius:18px;padding:13px;background:#fff;box-shadow:var(--shadow)}
.shift.pending{border-color:var(--amber)}
.divider{display:flex;align-items:center;gap:8px;margin:16px 0}
.divider .l{flex:1;height:1px;background:var(--line)} .divider span{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.mini{background:var(--surface);border-radius:12px;padding:9px}
.mini .l{font-size:10px;color:var(--muted)} .mini .v{font-size:16px;font-weight:700}
.pill{font-size:11px;padding:3px 9px;border-radius:7px;background:#E4F2EC;color:var(--brandDark)}
.center{display:grid;place-items:center;min-height:78vh}
.ringWrap{position:relative;width:200px;height:200px;margin:0 auto}
.ringWrap .c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.note{background:var(--surface);border-radius:14px;padding:14px;font-size:13px;color:var(--muted);text-align:center}
.flexwrap{display:flex;flex-wrap:wrap;gap:8px}
.tag{font-size:12px;padding:6px 12px;border-radius:11px;border:1px solid var(--line);background:#fff;color:var(--ink)}
.tag.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.tag.teal.on{background:var(--grad);border-color:transparent}
.spacer{height:14px}
.linkish{color:var(--brand);font-size:12px;background:none}
/* bottom nav */
.bnav{position:fixed;bottom:0;left:0;right:0;z-index:20;background:rgba(255,255,255,.93);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.bnavIn{max-width:900px;margin:0 auto;display:flex;justify-content:space-around;padding:8px 24px calc(8px + env(safe-area-inset-bottom))}
.bnavIn button{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;color:var(--muted);font-size:11px;font-weight:500;padding:4px 16px}
.bnavIn button.on{color:var(--brand);font-weight:700}
/* calendar */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal .dow{text-align:center;font-size:10px;color:var(--muted)}
.cal .cell{aspect-ratio:1;border-radius:13px;display:flex;align-items:center;justify-content:center;position:relative;font-size:14px;background:none;color:var(--ink)}
.cal .cell.today{background:var(--surface);font-weight:700;color:var(--brand)}
.cal .cell.sel{background:var(--grad);color:#fff;font-weight:700}
.cal .cell .dot{position:absolute;bottom:6px;width:6px;height:6px;border-radius:50%;background:var(--brand)}
.cal .cell.sel .dot{background:#fff}
.calnav{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;background:var(--surface)}
/* profit headline */
.profit{border-radius:18px;padding:13px;background:linear-gradient(135deg,#0E242B,#16323A);color:#fff}
.profit .bar{height:6px;border-radius:99px;background:rgba(255,255,255,.15);overflow:hidden;margin-top:8px}
.profit .bar>div{height:100%;background:var(--grad)}
