:root{
  --bg:#eef1f4; --surface:#ffffff; --surface-2:#f7f9fb; --line:#dde2e8; --line-2:#e9edf1;
  --ink:#1b2733; --muted:#62717f; --faint:#8a97a3;
  --accent:#1f5f8b; --accent-ink:#15486a; --accent-soft:#e7f0f6;
  --hard:#c0392b; --hard-bg:#fdeceb; --soft:#b06f10; --soft-bg:#fdf3e2; --ok:#2f855a; --ok-bg:#e7f4ec;
  --gold:#9a7b1e; --gold-bg:#f7f0db; --silver:#5a6b7b; --silver-bg:#eef1f4; --bronze:#8a5a3c; --bronze-bg:#f4ece6;
  --radius:8px; --shadow:0 1px 2px rgba(20,40,60,.06),0 2px 8px rgba(20,40,60,.05);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic UI","Noto Sans JP",Meiryo,"Segoe UI",sans-serif;
  background:var(--bg); color:var(--ink); font-size:14px; line-height:1.45; -webkit-font-smoothing:antialiased;
}
.tnum{font-variant-numeric:tabular-nums}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-variant-numeric:tabular-nums}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit;font-size:13px}

/* layout */
.app{display:grid;grid-template-columns:212px 1fr;min-height:100vh}
.side{background:#142433;color:#cdd8e2;padding:0;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}
.brand{padding:18px 18px 14px;border-bottom:1px solid #21384a}
.brand b{display:block;font-size:15px;color:#fff;letter-spacing:.2px}
.brand span{font-size:11px;color:#7e93a6;letter-spacing:.5px;text-transform:uppercase}
.nav{padding:10px 8px;flex:1;overflow:auto}
.nav button{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:none;border:0;color:#aebcca;
  padding:9px 11px;border-radius:6px;font-size:13.5px;margin-bottom:2px}
.nav button:hover{background:#1d3142;color:#fff}
.nav button.on{background:var(--accent);color:#fff;font-weight:600}
.nav .k{width:16px;text-align:center;opacity:.85}
.side .foot{padding:12px;border-top:1px solid #21384a;font-size:11px;color:#6c8095}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:12px;padding:12px 22px;background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.topbar h1{font-size:16px;margin:0;font-weight:700}
.topbar .spacer{flex:1}
.month-pick{display:flex;align-items:center;gap:6px}
.month-pick label{font-size:12px;color:var(--muted)}
.month-pick input{width:140px}
#tools{display:flex;align-items:center;gap:10px}
.menu-btn{display:none;background:none;border:0;font-size:22px;line-height:1;padding:4px 6px;color:var(--ink);cursor:pointer}
#scrim{display:none}
#toolsDock{display:none}
.content{padding:22px;max-width:1500px;width:100%}

/* generic */
.btn{background:var(--accent);color:#fff;border:0;border-radius:6px;padding:8px 13px;font-size:13px;font-weight:600}
.btn:hover{background:var(--accent-ink)}
.btn.ghost{background:#fff;color:var(--accent);border:1px solid var(--line)}
.btn.ghost:hover{background:var(--accent-soft)}
.btn.sm{padding:5px 9px;font-size:12px}
.btn.danger{background:#fff;color:var(--hard);border:1px solid #f0c8c4}
.btn.danger:hover{background:var(--hard-bg)}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card .hd{padding:13px 16px;border-bottom:1px solid var(--line-2);display:flex;align-items:center;gap:10px}
.card .hd h2{font-size:14px;margin:0;font-weight:700}
.card .bd{padding:14px 16px}
input[type=text],input[type=number],input[type=time],input[type=date],input[type=month],select,textarea{
  border:1px solid var(--line);border-radius:6px;padding:7px 9px;background:#fff;color:var(--ink);width:100%}
input:focus,select:focus,textarea:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}
.field{display:flex;flex-direction:column;gap:4px;margin-bottom:11px}
.field label{font-size:12px;color:var(--muted);font-weight:600}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0 14px}

/* table */
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;font-size:11px;letter-spacing:.4px;text-transform:uppercase;color:var(--faint);font-weight:700;
  padding:9px 10px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--surface);z-index:1}
td{padding:8px 10px;border-bottom:1px solid var(--line-2);vertical-align:middle}
tr:hover td{background:var(--surface-2)}
.tbl-wrap{max-height:none;overflow:auto;border-radius:var(--radius)}

/* chips & badges */
.chip{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}
.g-Gold{background:var(--gold-bg);color:var(--gold)}
.g-Silver{background:var(--silver-bg);color:var(--silver)}
.g-Bronze{background:var(--bronze-bg);color:var(--bronze)}
.rank{display:inline-block;min-width:26px;text-align:center;padding:2px 6px;border-radius:5px;font-size:11px;font-weight:800;letter-spacing:.3px}
.rk-sp{background:#3b1d6e;color:#fff}.rk-s{background:#5b3aa0;color:#fff}.rk-a{background:#1f5f8b;color:#fff}
.rk-b{background:#2f855a;color:#fff}.rk-c{background:#8a7d22;color:#fff}.rk-d{background:#9a6a2c;color:#fff}.rk-e{background:#7b8794;color:#fff}
.pill{display:inline-block;padding:2px 7px;border-radius:5px;font-size:11px;font-weight:600;background:var(--accent-soft);color:var(--accent-ink)}
.pill.visa{background:#efe6f7;color:#6c3aa0}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%}
.dot.hard{background:var(--hard)}.dot.soft{background:var(--soft)}.dot.ok{background:var(--ok)}

/* stat cards */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:20px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}
.stat .n{font-size:26px;font-weight:800;letter-spacing:-.5px}
.stat .l{font-size:12px;color:var(--muted);margin-top:2px}
.stat.alarm .n{color:var(--hard)} .stat.warn .n{color:var(--soft)} .stat.good .n{color:var(--ok)}

/* schedule grid */
.sched{display:grid;grid-template-columns:1fr;gap:0}
.dayrow{display:grid;grid-template-columns:84px 1fr;border-bottom:1px solid var(--line-2)}
.dayrow:hover{background:var(--surface-2)}
.daycell{padding:9px 10px;border-right:1px solid var(--line-2)}
.daycell .d{font-weight:800;font-size:15px}
.daycell .w{font-size:11px;color:var(--muted)}
.daycell.sat .d{color:#2563a8}.daycell.sun .d{color:#c0392b}
.daycell .tgt{font-size:10.5px;color:var(--faint);margin-top:3px}
.slots{padding:8px 10px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.assign{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);border-radius:6px;padding:4px 6px 4px 8px;font-size:12.5px}
.assign.vio{border-color:#e6b3ad;background:var(--hard-bg)}
.assign.warn{border-color:#e8c98a;background:var(--soft-bg)}
.assign .nm{font-weight:600}
.assign .tm{color:var(--muted);font-size:11px}
.assign .x{border:0;background:none;color:var(--faint);font-size:14px;line-height:1;padding:0 2px}
.assign .x:hover{color:var(--hard)}
.addslot{border:1px dashed var(--line);background:#fff;color:var(--accent);border-radius:6px;padding:4px 9px;font-size:12px;font-weight:600}
.addslot:hover{background:var(--accent-soft);border-color:var(--accent)}
.cntbadge{font-size:10.5px;color:var(--faint)}
.cntbadge.under{color:var(--soft)} .cntbadge.met{color:var(--ok)}

/* assign form inline */
.assignform{display:flex;gap:6px;align-items:center;background:var(--accent-soft);border:1px solid var(--accent);border-radius:6px;padding:5px 6px}
.assignform select{width:auto;min-width:140px;padding:5px 7px}
.assignform input[type=time]{width:88px;padding:5px 6px}

/* violation list */
.vlist{display:flex;flex-direction:column;gap:8px}
.vitem{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border-radius:7px;border:1px solid var(--line-2)}
.vitem.hard{background:var(--hard-bg);border-color:#f0c8c4}
.vitem.soft{background:var(--soft-bg);border-color:#ead9b3}
.vitem .vcode{font-size:10.5px;font-weight:800;letter-spacing:.4px;padding:2px 6px;border-radius:4px;background:rgba(0,0,0,.06)}
.vitem .vmsg{flex:1;font-size:13px}
.vitem .vmsg small{color:var(--muted);display:block;margin-top:1px}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(18,30,42,.45);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal{background:#fff;border-radius:10px;max-width:560px;width:100%;max-height:88vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal .mhd{padding:16px 20px;border-bottom:1px solid var(--line-2);display:flex;align-items:center}
.modal .mhd h3{margin:0;font-size:15px}
.modal .mbd{padding:18px 20px}
.modal .mft{padding:14px 20px;border-top:1px solid var(--line-2);display:flex;gap:10px;justify-content:flex-end}
.close{margin-left:auto;border:0;background:none;font-size:20px;color:var(--faint);cursor:pointer}

.searchbar{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.searchbar input[type=text]{max-width:260px}
.searchbar select{width:auto}
.muted{color:var(--muted)}.faint{color:var(--faint)}
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#142433;color:#fff;padding:10px 18px;border-radius:8px;font-size:13px;z-index:200;box-shadow:var(--shadow);opacity:0;transition:opacity .2s}
.toast.show{opacity:1}
.hint{font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line-2);border-radius:6px;padding:9px 12px;margin-bottom:14px}
.legend{display:flex;gap:14px;font-size:11.5px;color:var(--muted);flex-wrap:wrap}
.legend span{display:inline-flex;align-items:center;gap:5px}
@media(max-width:860px){
  .app{grid-template-columns:1fr}
  .menu-btn{display:block}
  /* off-canvas drawer */
  .side{position:fixed;top:0;left:0;height:100%;width:78vw;max-width:300px;z-index:60;transform:translateX(-100%);transition:transform .22s ease;box-shadow:0 0 40px rgba(0,0,0,.3)}
  .side.open{transform:none}
  #scrim{display:block;position:fixed;inset:0;background:rgba(10,20,30,.45);opacity:0;pointer-events:none;transition:opacity .22s;z-index:55}
  #scrim.show{opacity:1;pointer-events:auto}
  .nav button{padding:13px 14px;font-size:15px}
  #toolsDock{display:block;padding:10px 12px;border-top:1px solid #21384a}
  #toolsDock #tools{display:flex;flex-wrap:wrap;gap:8px}
  #toolsDock .lang-pick{width:100%}
  #toolsDock .lang-pick select{width:100%}
  #toolsDock .btn{flex:1;min-width:96px}
  /* compact top bar */
  .topbar{gap:8px;padding:10px 14px}
  .topbar h1{font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .month-pick label{display:none}
  .month-pick input{width:128px}
  .content{padding:14px}
  /* roomier touch targets */
  .btn{padding:10px 14px}
  .btn.sm{padding:7px 11px}
  input[type=text],input[type=number],input[type=time],input[type=date],input[type=month],select,textarea{padding:9px 10px;font-size:16px}
  /* stacking cards & stats */
  .stats{grid-template-columns:repeat(2,1fr);gap:10px}
  .stat .n{font-size:22px}
  .row .card{min-width:0!important;flex:1 1 100%!important}
  .searchbar input[type=text]{max-width:none;flex:1 1 100%}
  /* tables scroll */
  .tbl-wrap{-webkit-overflow-scrolling:touch}
  th,td{padding:8px 8px}
  /* schedule */
  .dayrow{grid-template-columns:64px 1fr}
  .daycell .d{font-size:14px}
  .assignform{flex-wrap:wrap;width:100%}
  .assignform select{flex:1 1 100%;min-width:0}
  .assignform input[type=time]{flex:1}
  /* availability matrix: tighter sticky, bigger cells */
  .avtbl td.av-name,.avtbl th.av-name{width:104px;min-width:104px;max-width:104px}
  .avtbl td.av-cnt,.avtbl th.av-cnt{left:104px}
  .av-cell{height:34px;min-width:30px}
  /* modal as bottom sheet */
  .modal-bg{align-items:flex-end;padding:0}
  .modal{max-width:none;border-radius:16px 16px 0 0;max-height:92vh}
  .modal .mft{position:sticky;bottom:0;background:#fff}
}
@media(max-width:420px){ .stats{grid-template-columns:1fr 1fr} .topbar h1{max-width:34vw} }

/* summary bars, status, lang */
.bar{display:inline-block;width:74px;height:7px;border-radius:4px;background:var(--line);vertical-align:middle;overflow:hidden;margin-right:6px}
.bar-f{height:100%;background:var(--accent);border-radius:4px}
.bar-f.over{background:var(--soft)}
.tnum.hot{color:var(--hard);font-weight:700}
.mode{font-size:11px;font-weight:700;letter-spacing:.3px}
.mode.srv{color:#8fe3b0}.mode.loc{color:#e0b36a}
.side .foot a{color:#7e93a6;cursor:pointer;text-decoration:underline}
.lang-pick{display:flex;align-items:center;gap:6px}
.lang-pick select{width:auto;padding:6px 8px}
/* availability matrix */
.avtbl{border-collapse:separate;border-spacing:0;font-size:12px}
.avtbl th,.avtbl td{border:1px solid var(--line-2)}
.avtbl thead th{position:sticky;top:0;z-index:3;background:var(--surface);padding:4px 0;text-align:center;text-transform:none;letter-spacing:0;color:var(--ink)}
.avtbl th.day{width:38px;min-width:38px;max-width:38px}
.avtbl th.day .wd{font-size:9px;color:var(--faint);font-weight:600}
.avtbl th.day.sat{color:#2563a8}.avtbl th.day.sun{color:#c0392b}
.avtbl td.av-name,.avtbl th.av-name{position:sticky;left:0;z-index:2;background:var(--surface);text-align:left;width:130px;min-width:130px;max-width:130px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;padding:4px 8px}
.avtbl thead .av-name{z-index:4}
.avtbl td.av-cnt,.avtbl th.av-cnt{position:sticky;left:130px;z-index:2;background:var(--surface);min-width:38px;text-align:center;color:var(--soft);font-weight:700}
.avtbl thead .av-cnt{z-index:4;color:var(--faint)}
/* every day column is a fixed, clipped box so the matrix never overflows; full store + hours on hover */
.av-cell{width:38px;min-width:38px;max-width:38px;height:30px;text-align:center;cursor:pointer;color:#c0392b;font-weight:700;user-select:none;overflow:hidden;padding:0}
.av-cell.we{background:var(--surface-2)}
.av-cell:hover{background:var(--accent-soft)}
.avtbl tr:hover td{background:inherit}
.avtbl td.av-cell.off{background:#142433;color:#fff}
.swatch{display:inline-block;width:12px;height:12px;border-radius:3px;border:1px solid var(--line);background:#fff;vertical-align:middle}
.swatch.off{background:#142433;border-color:#142433}
.swatch.on{background:#1f9d57;border-color:#1f9d57}
.swatch.sched{background:#2f6db0;border-color:#2f6db0}
.av-cell.sched{background:#eaf2fb;color:#23527a;font-weight:600}
.av-cell .stag{display:block;font-size:9px;line-height:1.1;max-width:38px;margin:0 auto;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 2px}
.cal td.avday.sched{background:#eaf2fb}
.cal td.avday.sched .stag{display:block;font-size:13px;line-height:1.3;color:#1d4e79;font-weight:600;white-space:normal;word-break:break-word;margin-top:4px}
.cal .cchip .hrs{display:block;font-size:9px;font-weight:400;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* login overlay */
#login{display:none;position:fixed;inset:0;z-index:200;background:linear-gradient(135deg,#0f1b2a,#16324a);align-items:center;justify-content:center;padding:20px}
body.noauth #login{display:flex}
body.noauth .app{display:none}
.login-card{width:340px;max-width:92vw;background:var(--surface,#fff);border-radius:14px;padding:26px 24px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.login-brand{text-align:center;margin-bottom:18px}.login-brand b{display:block;font-size:20px}.login-brand span{color:var(--muted,#789);font-size:12px;letter-spacing:.08em}
.login-card .field{margin-bottom:12px}.login-card label{display:block;font-size:12px;color:var(--muted,#789);margin-bottom:4px}
.login-card input{width:100%;padding:9px 11px;border:1px solid var(--line,#cdd);border-radius:8px;font-size:14px;box-sizing:border-box}
.login-err{color:#c0392b;font-size:12px;min-height:16px;margin-bottom:6px}
.login-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;gap:8px}
.login-foot select{font-size:12px;padding:3px 6px;border:1px solid var(--line,#cdd);border-radius:6px}

/* save bar / dirty */
.savebar{display:inline-flex;align-items:center;gap:6px;margin-right:4px}
.dirty-ind{font-size:11px;color:#d08200;font-weight:700;white-space:nowrap}
.btn.sm:disabled,.btn:disabled{opacity:.4;cursor:default}

/* segmented toggle */
.seg{display:inline-flex;border:1px solid var(--line,#cdd);border-radius:8px;overflow:hidden}
.segbtn{border:0;background:var(--surface-2,#f3f5f7);padding:5px 12px;font-size:12px;cursor:pointer;color:var(--muted,#789)}
.segbtn.on{background:var(--accent,#2f6db0);color:#fff}

/* calendar */
.calwrap{overflow:auto}
table.cal{width:100%;max-width:1080px;margin:0 auto;border-collapse:collapse;table-layout:fixed;min-width:560px}
table.cal th{font-size:11px;color:var(--muted,#789);padding:4px;border:1px solid var(--line-2,#e6e9ec);background:var(--surface-2,#f7f9fb)}
table.cal th.sat{color:#2563a8}table.cal th.sun{color:#c0392b}
table.cal td{vertical-align:top;border:1px solid var(--line-2,#e6e9ec);height:92px;width:14.28%;padding:3px 4px;overflow:hidden}
table.cal td.empty{background:var(--surface-2,#f7f9fb)}
table.cal td.has{cursor:pointer}table.cal td.has:hover{background:var(--accent-soft,#eaf2fb)}
table.cal td.sat .dn>span:first-child{color:#2563a8}table.cal td.sun .dn>span:first-child{color:#c0392b}
table.cal td.vio{outline:2px solid var(--hard,#c0392b);outline-offset:-2px}
.cal .dn{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:12px;margin-bottom:2px}
.cal .cnt{font-size:10px;font-weight:600;padding:0 4px;border-radius:6px;background:#e6f4ea;color:#1f7a44}
.cal .cnt.under{background:#fde9e7;color:#b03a2e}
.cal .cchip{display:block;font-size:10px;line-height:1.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 4px;border-radius:4px;background:var(--surface-2,#eef1f4);margin-bottom:1px}
.cal .cchip.vio{background:#fde9e7;color:#b03a2e}.cal .cchip.warn{background:#fdf3e0;color:#9a6a16}
.cal .cmore{font-size:10px;color:var(--muted,#789)}
.cal td.avday .dn{justify-content:flex-start}
.chkpicker{max-height:210px;overflow:auto;border:1px solid var(--line,#cdd);border-radius:8px;padding:6px;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1px 8px}
.chkitem{display:flex;align-items:center;gap:7px;padding:4px 6px;border-radius:6px;cursor:pointer;font-size:13px;line-height:1.2}
.chkitem:hover{background:var(--accent-soft,#eaf2fb)}
.chkitem input{margin:0;width:16px;height:16px;flex:none;cursor:pointer}
.chkitem span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.chk-bar{display:flex;align-items:center;gap:8px;font-size:12px;margin-bottom:6px}
.chk-bar .chk-count{font-size:13px}
.lnk{background:none;border:none;color:var(--accent,#2f6db0);cursor:pointer;font-size:12px;padding:0;text-decoration:underline}
.cal td.avday .cchip{font-size:11px;line-height:1.2;overflow:hidden}
.cal td.avday .cchip.store{background:#e3eefb;color:#1d4e79;border:1px solid #cfe0f4;font-weight:600}
.cal td.avday .cchip.off{background:#142433;color:#fff;font-weight:600}
.cal td.avday .cchip.on{background:#e6f6ec;color:#1f7a3d;border:1px solid #c7e8d2;font-weight:600}

/* day editor */
.de-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--line-2,#e6e9ec)}
.de-row .nm{font-weight:600;flex:1}.de-row .tm{color:var(--muted,#789)}
.de-add{display:flex;gap:6px;margin-top:12px;flex-wrap:wrap}
.de-add select{flex:1;min-width:140px;padding:6px;border:1px solid var(--line,#cdd);border-radius:6px}
.de-add input{padding:6px;border:1px solid var(--line,#cdd);border-radius:6px}

/* permission checkboxes */
.pgchk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px;margin-top:6px}
.pgchk{display:flex;align-items:center;gap:6px;font-size:13px;background:var(--surface-2,#f3f5f7);padding:6px 8px;border-radius:7px;cursor:pointer}
.rolechip{display:inline-block;font-size:11px;padding:1px 8px;border-radius:10px;background:var(--surface-2,#eef1f4);color:var(--muted,#566)}
.rolechip.admin{background:#e7eefb;color:#2f5fae}
.whoami{margin-bottom:4px}.whoami b{font-size:13px}

/* feature toggles */
.ftog{display:flex;justify-content:space-between;align-items:center;padding:11px 4px;border-bottom:1px solid var(--line-2,#e6e9ec);font-size:14px}
.ftog input{width:18px;height:18px}

/* history */
.hist-list{max-height:420px;overflow:auto}
.hist-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 2px;border-bottom:1px solid var(--line-2,#e6e9ec);font-size:13px}

/* popup menu */
.popmenu{position:absolute;z-index:150;background:var(--surface,#fff);border:1px solid var(--line,#cdd);border-radius:9px;box-shadow:0 12px 36px rgba(0,0,0,.18);overflow:hidden;min-width:170px}
.popmenu button{display:block;width:100%;text-align:left;border:0;background:none;padding:9px 14px;font-size:13px;cursor:pointer}
.popmenu button:hover{background:var(--accent-soft,#eaf2fb)}
.av-cell.on{background:#e6f6ec;color:#1f7a44}
.gen-ol,.gen-ul{margin:0;padding-left:20px}
.gen-ol li,.gen-ul li{line-height:1.55;margin-bottom:3px}
.gen-ol li{counter-increment:none}
@media(max-width:860px){table.cal td{height:74px}.savebar .btn{padding:5px 8px}}

/* workspace (session) switcher */
.ws-pick{display:flex;align-items:center;gap:6px}
.ws-pick select{width:auto;max-width:230px;padding:6px 8px;font-weight:600}
.ws-pick .btn{padding:6px 9px}
.ws-pick .ws-rev{font-size:10px;color:var(--faint);white-space:nowrap}
@media(max-width:860px){.ws-pick select{max-width:130px}.ws-pick .ws-rev{display:none}}

/* assignment banner + status chips */
.asg-banner{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:var(--radius);padding:9px 14px;margin:8px 0;box-shadow:var(--shadow);font-size:13px}
.asg-banner .btn{margin-left:4px}
.chip.st-assigned{background:#e7f0f6;color:#15486a}
.chip.st-submitted{background:#fdf3e2;color:#9a6a16}
.chip.st-approved{background:#e7f4ec;color:#1f7a44}
.chip.st-rejected{background:#fdeceb;color:#b03a2e}
.dirty-ind.status-saving{color:#9a6a16}
.dirty-ind.status-saved{color:#2f855a}
.dirty-ind.status-conflict,.dirty-ind.status-error{color:#c0392b;font-weight:700}

/* staff portal */
body.staff{background:var(--bg)}
.staff-auth{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#0f1b2a,#16324a)}
.staff-top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px;background:var(--surface);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10;flex-wrap:wrap}
.staff-top b{font-size:16px}
.staff-top-r{display:flex;align-items:center;gap:10px}
.staff-lang{width:auto;padding:5px 7px}
.staff-main{max-width:1000px;margin:0 auto;padding:20px}
.staff-main .cal td.avday{cursor:pointer;height:64px}
.staff-main .cal td.avday.off{background:#142433}
.staff-main .cal td.avday.off .dn>span{color:#fff}
@media(max-width:860px){.staff-main{padding:12px}.staff-main .cal td{height:56px}}
