/* Thorpe Woodlands Rota — shared styles. Priority: legibility at a glance. */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,600;12..96,700;12..96,800&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap');

:root{
  --bg:#f3f5f2;
  --panel:#ffffff;
  --ink:#16201c;          /* near-black, high contrast */
  --ink-soft:#56635d;
  --line:#e3e7e1;
  --line-strong:#cdd4cc;
  --accent:#1c4a3a;       /* woodland green */
  --accent-ink:#f3f5f2;
  --focus:#1f6feb;
  --lead:#1f5fd0;        --lead-bg:#e7eefc;
  --warden:#7a4fb5;      --warden-bg:#efe8f9;
  --absence:#b23b2e;     --absence-bg:#fae7e4;
  --radius:12px;
  --shadow:0 1px 2px rgba(20,30,25,.05), 0 4px 16px rgba(20,30,25,.06);
  --font-body:"IBM Plex Sans", system-ui, sans-serif;
  --font-display:"Bricolage Grotesque", var(--font-body);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);
  font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--font-display);margin:0;letter-spacing:-.01em;line-height:1.15}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--focus);outline-offset:2px;border-radius:6px}
a{color:var(--accent)}

/* ---------- buttons ---------- */
.btn{border:0;border-radius:10px;padding:11px 18px;font-weight:700;font-size:15px;
  background:var(--accent);color:var(--accent-ink);transition:filter .15s}
.btn:hover{filter:brightness(1.08)}
.btn.secondary{background:var(--panel);color:var(--ink);border:1.5px solid var(--line-strong)}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-strong)}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- inputs ---------- */
label{font-weight:600;font-size:14px;color:var(--ink-soft);display:block;margin-bottom:6px}
input,select,textarea{font-family:inherit;font-size:16px;width:100%;padding:11px 13px;
  border:1.5px solid var(--line-strong);border-radius:10px;background:var(--panel);color:var(--ink)}
input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:none}

/* ---------- auth pages ---------- */
.auth{min-height:100vh;display:grid;place-items:center;padding:24px}
.auth-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;
  box-shadow:var(--shadow);padding:40px;width:min(420px,100%)}
.auth-card .mark{width:46px;height:46px;border-radius:12px;background:var(--accent);
  color:var(--accent-ink);display:grid;place-items:center;font-family:var(--font-display);
  font-weight:800;font-size:22px;margin-bottom:18px}
.auth-card h1{font-size:24px;margin-bottom:4px}
.auth-card p.sub{color:var(--ink-soft);margin:0 0 24px}
.auth-card .field{margin-bottom:16px}
.auth-card .btn{width:100%;padding:13px}
.msg{margin-top:16px;padding:11px 14px;border-radius:10px;font-size:14px;font-weight:600;display:none}
.msg.show{display:block}
.msg.error{background:var(--absence-bg);color:#7c241a}
.msg.ok{background:#e3f0e8;color:#1c4a3a}

/* ---------- app shell ---------- */
.topbar{display:flex;align-items:center;gap:14px;padding:14px 22px;background:var(--panel);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.topbar .mark{width:34px;height:34px;border-radius:9px;background:var(--accent);color:var(--accent-ink);
  display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:17px}
.topbar h1{font-size:18px}
.topbar .spacer{flex:1}
.topbar .who{font-size:14px;color:var(--ink-soft);font-weight:600}
.wrap{max-width:1480px;margin:0 auto;padding:22px}

.tabs{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}
.tabs button{border:1.5px solid var(--line-strong);background:var(--panel);padding:10px 20px;
  border-radius:999px;font-weight:700;font-size:15px;color:var(--ink-soft)}
.tabs button[aria-selected="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}

.controls{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:18px}
.seg{display:inline-flex;background:var(--panel);border:1.5px solid var(--line-strong);border-radius:10px;overflow:hidden}
.seg button{border:0;background:transparent;padding:10px 16px;font-weight:700;font-size:14px;color:var(--ink-soft)}
.seg button[aria-pressed="true"]{background:var(--accent);color:var(--accent-ink)}
.nav{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:17px}
.nav button{width:36px;height:36px;border-radius:9px;border:1.5px solid var(--line-strong);
  background:var(--panel);font-size:18px;color:var(--ink-soft)}
.controls .spacer{flex:1}
.controls select{width:auto;min-width:150px}

/* ---------- department bands ---------- */
.band{margin-bottom:22px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.band-head{display:flex;align-items:center;gap:11px;padding:13px 18px;color:#fff}
.band-head h2{font-size:17px;font-weight:800}
.band-head .count{margin-left:auto;font-size:13px;font-weight:700;opacity:.9}
.scroll{overflow-x:auto}
.days{display:grid;grid-auto-flow:column;gap:0}
.day{min-width:150px;border-right:1px solid var(--line);padding:8px}
.day:last-child{border-right:0}
.day.wknd{background:#fafbf9}
.day.today{background:#fbfaef}
.day-head{display:flex;justify-content:space-between;align-items:baseline;padding:2px 4px 8px;
  font-size:13px;color:var(--ink-soft);font-weight:600}
.day-head .dnum{font-family:var(--font-display);font-weight:800;font-size:18px;color:var(--ink)}
.day-head.today .dnum{color:var(--accent)}

/* ---------- shift cards ---------- */
.shift{border-radius:10px;padding:9px 10px;margin-bottom:8px;cursor:pointer;
  border:1px solid var(--line);border-left-width:5px;background:var(--panel);transition:box-shadow .12s}
.shift:hover{box-shadow:0 2px 8px rgba(20,30,25,.12)}
.shift .time{font-family:var(--font-display);font-weight:800;font-size:16px;letter-spacing:-.01em}
.shift .loc{font-size:12px;color:var(--ink-soft);font-weight:600;margin-top:1px}
.people{display:flex;flex-wrap:wrap;gap:4px;margin-top:7px}
.chip{font-size:13px;font-weight:600;background:#eef1ec;border-radius:999px;padding:3px 9px;white-space:nowrap}
.chip.empty{background:transparent;border:1.5px dashed var(--line-strong);color:var(--ink-soft)}
.tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:7px}
.tag{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;border-radius:5px;padding:3px 7px}
.tag.lead{background:var(--lead-bg);color:var(--lead)}
.tag.warden{background:var(--warden-bg);color:var(--warden)}
.tag.note{background:#eef1ec;color:var(--ink-soft)}
.shift.bh{background:repeating-linear-gradient(45deg,#f5f6f3,#f5f6f3 7px,#eceee9 7px,#eceee9 14px);
  border-left-color:var(--line-strong)!important}
.shift.bh .time{color:var(--ink-soft);font-size:14px}
.add-shift{width:100%;border:1.5px dashed var(--line-strong);background:transparent;border-radius:9px;
  color:var(--ink-soft);padding:7px;font-size:18px;line-height:1;font-weight:700}
.add-shift:hover{border-color:var(--accent);color:var(--accent)}

.legend{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--ink-soft);
  margin-bottom:16px;font-weight:600}
.legend span{display:inline-flex;align-items:center;gap:7px}
.legend i{width:13px;height:13px;border-radius:4px;display:inline-block}

/* ---------- hours table ---------- */
.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:auto}
table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
th,td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--line);white-space:nowrap}
th{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft);
  background:#fafbf9;font-weight:700;position:sticky;top:0}
td.num{text-align:right;font-weight:600}
td.key{text-align:right;font-weight:800;font-family:var(--font-display)}
td.key.pos{color:var(--accent)} td.key.neg{color:var(--absence)}
tbody tr:hover td{background:#fbfcfa}
.group-head th{text-align:center;border-bottom:1.5px solid var(--line-strong)}

/* ---------- modal ---------- */
.scrim{position:fixed;inset:0;background:rgba(16,24,20,.45);display:none;
  align-items:flex-start;justify-content:center;padding:34px 16px;z-index:50;overflow:auto}
.scrim.show{display:flex}
.modal{background:var(--panel);border-radius:18px;width:min(560px,100%);box-shadow:0 24px 60px rgba(0,0,0,.3);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal-head h2{font-size:20px;font-weight:800}
.modal-head .x{border:0;background:transparent;font-size:26px;line-height:1;color:var(--ink-soft)}
.modal-body{padding:20px 22px;max-height:64vh;overflow:auto}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 22px;border-top:1px solid var(--line);background:#fafbf9}
.field{margin-bottom:16px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>*{flex:1;min-width:120px}
.presets{display:flex;flex-wrap:wrap;gap:8px}
.preset{border:1.5px solid var(--line-strong);background:var(--panel);border-radius:9px;
  padding:9px 13px;font-weight:700;font-size:14px;color:var(--ink);width:auto}
.preset[aria-pressed="true"]{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.picker{border:1px solid var(--line);border-radius:11px;max-height:210px;overflow:auto}
.pick{display:flex;align-items:center;gap:11px;padding:10px 13px;border-bottom:1px solid var(--line)}
.pick:last-child{border-bottom:0}
.pick input{width:auto}
.pick.away{color:var(--ink-soft)}
.pick.away .nm{text-decoration:line-through}
.pick .flag{margin-left:auto;font-size:12px;font-weight:700;color:var(--absence)}
.warn{background:var(--absence-bg);color:#7c241a;border-radius:10px;padding:11px 13px;
  font-size:14px;font-weight:600;margin-top:10px;display:none}
.warn.show{display:block}
.hint{font-size:13px;color:var(--ink-soft);margin-top:6px}

.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);background:var(--ink);
  color:#fff;padding:13px 20px;border-radius:11px;font-weight:600;font-size:14px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);opacity:0;transition:opacity .25s;pointer-events:none;
  z-index:80;max-width:540px;text-align:center}
.toast.show{opacity:1}
.empty{text-align:center;color:var(--ink-soft);padding:40px;font-weight:600}

@media(max-width:640px){
  .wrap{padding:14px}
  .topbar{padding:12px 14px}
  .controls{gap:8px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}

/* ---------- month calendar (desktop) ---------- */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-h{font-weight:700;font-size:13px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.03em;padding:4px 6px}
.cal-cell{background:var(--panel);border:1px solid var(--line);border-radius:10px;min-height:108px;padding:6px;display:flex;flex-direction:column}
.cal-cell.empty-cell{background:transparent;border:0}
.cal-cell.wknd{background:#fafbf9}
.cal-cell.today{border-color:var(--accent);box-shadow:inset 0 0 0 1.5px var(--accent)}
.cal-date{font-family:var(--font-display);font-weight:800;font-size:15px;margin-bottom:4px}
.cal-cell.today .cal-date{color:var(--accent)}
.mini{border-left:4px solid var(--line-strong);background:#fff;border-radius:6px;padding:3px 7px;margin-bottom:4px;font-size:12.5px;line-height:1.35;cursor:pointer}
.mini:hover{box-shadow:0 1px 5px rgba(20,30,25,.14)}
.mini .mt{font-weight:800}
.mini .mn{color:var(--ink-soft)}
.mini .mn i{font-style:normal;color:var(--absence);font-weight:700}
.mini.warden{background:var(--warden-bg);border-left-color:var(--warden)}
.mini.bh{background:#f2f3f0;color:var(--ink-soft)}
.cal-add{margin-top:auto;width:100%;border:1px dashed var(--line-strong);background:transparent;border-radius:6px;color:var(--ink-soft);font-weight:700;font-size:15px;line-height:1.2;padding:2px;cursor:pointer}
.cal-add:hover{border-color:var(--accent);color:var(--accent)}

/* warden shift card */
.shift.warden{background:var(--warden-bg)}
.shift.warden .time{color:var(--warden)}

/* ---------- month agenda (mobile) ---------- */
.agenda-day{margin-bottom:16px}
.agenda-head{font-family:var(--font-display);font-weight:800;font-size:16px;padding:6px 2px;border-bottom:2px solid var(--line);margin-bottom:8px}
.agenda-day.today .agenda-head{color:var(--accent)}
