:root{
  --blue:#5485A2; --blue-dark:#3d6580; --gold:#C9AA39; --cream:#FAF7F4;
  --ink:#1f2d36; --line:#e3ddd4; --ok:#2e9e5b; --warn:#e07b00; --bad:#cc3344;
}
*{box-sizing:border-box}
body{margin:0;font:16px/1.45 -apple-system,'Segoe UI',Roboto,sans-serif;background:var(--cream);color:var(--ink);padding-bottom:76px}
a{color:var(--blue-dark)}
header.top{position:sticky;top:0;z-index:20;display:flex;justify-content:space-between;align-items:center;
  background:var(--blue);color:#fff;padding:10px 14px;padding-top:calc(10px + env(safe-area-inset-top))}
.brand{color:#fff;text-decoration:none;font-weight:700;letter-spacing:.06em}
.brand span{color:var(--gold)}
.who{font-size:14px;opacity:.95}
.linkbtn{background:none;border:none;color:#fff;opacity:.7;text-decoration:underline;cursor:pointer;font-size:13px}
main{padding:14px;max-width:1100px;margin:0 auto}
nav.bottom{position:fixed;bottom:0;left:0;right:0;z-index:20;display:flex;background:#fff;border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom)}
nav.bottom a{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;padding:8px 0 6px;text-decoration:none;
  color:#7d8a93;font-size:11px}
nav.bottom a.on{color:var(--blue-dark);font-weight:600}
nav.bottom a span{display:block}
h1{font-size:20px;margin:4px 0 12px}
h2{font-size:16px;margin:18px 0 8px;color:var(--blue-dark)}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px}
.muted{color:#7d8a93;font-size:13px}
.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.grow{flex:1}
button,.btn{background:var(--blue);color:#fff;border:none;border-radius:10px;padding:10px 16px;font-size:15px;cursor:pointer;text-decoration:none;display:inline-block}
button.sec,.btn.sec{background:#eef2f5;color:var(--ink)}
button.ok{background:var(--ok)} button.warn{background:var(--warn)} button.ghost{background:none;color:var(--blue-dark);text-decoration:underline;padding:4px}
button:disabled{opacity:.5}
input,select,textarea{width:100%;padding:10px;border:1px solid var(--line);border-radius:10px;font-size:15px;background:#fff;color:var(--ink)}
label{font-size:13px;color:#5a676f;display:block;margin:8px 0 3px}
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;
  padding:10px 18px;border-radius:99px;z-index:99;font-size:14px;box-shadow:0 4px 14px rgba(0,0,0,.25)}
.toast.bad{background:var(--bad)}
/* priority + status chips */
.chip{display:inline-block;font-size:11px;font-weight:700;border-radius:6px;padding:2px 7px;vertical-align:middle}
.p1{background:#fde3e6;color:var(--bad)} .p2{background:#fdeede;color:var(--warn)}
.p3{background:#e4eef5;color:var(--blue-dark)} .p4{background:#eee;color:#777}
.s-open{background:#e4eef5;color:var(--blue-dark)} .s-in_progress{background:#fdf3d7;color:#8a6d00}
.s-done{background:#dff3e6;color:var(--ok)} .s-cancelled{background:#eee;color:#999}
.t-turnover{background:#efe6f7;color:#6b3fa0} .t-checkin_prep{background:#e0f0ff;color:#0b62a8}
/* task list items */
.task{display:flex;gap:10px;align-items:flex-start}
.task .info{flex:1;min-width:0}
.task .title{font-weight:600}
.task.overdue{border-left:4px solid var(--bad)}
.task .meta{font-size:12.5px;color:#7d8a93;margin-top:2px}
/* login */
.staffgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:10px}
.staffgrid button{background:#fff;color:var(--ink);border:1px solid var(--line);padding:16px 8px;border-radius:12px;font-size:15px}
.staffgrid button.sel{border-color:var(--blue);background:#e4eef5;font-weight:700}
.pinpad{max-width:280px;margin:16px auto;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.pinpad button{font-size:22px;padding:16px;background:#fff;color:var(--ink);border:1px solid var(--line)}
.pindots{text-align:center;font-size:30px;letter-spacing:12px;min-height:42px}
/* board */
.villagrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px}
.vcard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px;text-decoration:none;color:var(--ink);position:relative}
.vcard .vn{font-weight:700;font-size:14px;margin-bottom:4px}
.vcard .state{font-size:12px;border-radius:6px;padding:2px 6px;display:inline-block}
.st-turnover{background:#fde3e6;color:var(--bad);font-weight:700}
.st-checkout{background:#fdeede;color:var(--warn)} .st-checkin{background:#e0f0ff;color:#0b62a8}
.st-occupied{background:#dff3e6;color:var(--ok)} .st-empty{background:#f1f1ef;color:#888}
.vcard .prog{font-size:12.5px;margin-top:6px;color:#5a676f}
.badge{position:absolute;top:-7px;right:-7px;background:var(--bad);color:#fff;border-radius:99px;
  font-size:11px;font-weight:700;padding:2px 7px}
.seg{display:inline-flex;background:#eef2f5;border-radius:99px;padding:3px;margin-bottom:12px}
.seg a{padding:6px 16px;border-radius:99px;text-decoration:none;color:#5a676f;font-size:14px}
.seg a.on{background:#fff;color:var(--ink);font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.12)}
/* calendar */
.calwrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table.cal{border-collapse:collapse;min-width:900px;width:100%;background:#fff;border:1px solid var(--line);border-radius:12px}
table.cal th,table.cal td{border:1px solid var(--line);padding:4px 6px;font-size:12px;vertical-align:top}
table.cal th{background:#eef2f5;position:sticky;top:0}
table.cal td.vn{font-weight:700;white-space:nowrap;background:#fbfaf8;position:sticky;left:0}
table.cal td{min-width:110px;height:54px}
table.cal td.occ{background:#f3f8f3}
table.cal td.today{outline:2px solid var(--gold);outline-offset:-2px}
.mk{display:block;font-size:11px;border-radius:5px;padding:1px 5px;margin:1px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mk.in{background:#e0f0ff;color:#0b62a8}.mk.out{background:#fdeede;color:var(--warn)}
.tk{display:block;font-size:11px;border-radius:5px;padding:1px 5px;margin:1px 0;text-decoration:none;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#e4eef5;color:var(--blue-dark)}
.tk.done{background:#dff3e6;color:var(--ok);text-decoration:line-through}
.tk.p1{background:#fde3e6;color:var(--bad)}
.addcell{display:block;text-align:center;color:#c4bfb6;text-decoration:none;font-size:13px}
/* photos */
.photos{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.photos a img,.photos a video{width:84px;height:84px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
/* table */
table.list{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;font-size:14px}
table.list th,table.list td{padding:8px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
table.list th{font-size:12px;color:#7d8a93;text-transform:uppercase}
@media(max-width:640px){ table.list .hidemob{display:none} main{padding:10px} }
dialog{border:none;border-radius:14px;max-width:480px;width:92%;padding:18px}
dialog::backdrop{background:rgba(20,30,40,.5)}
