/* =====================================================================
   Motherland Staff Scheduler — GDI brand styles
   ===================================================================== */
:root{
  --navy:#0B1F3A; --navy-deep:#071629; --carbon:#1E2D3D;
  --slate:#4A6280; --slate-light:#7A9BB5;
  --gold:#C8952A; --gold-dk:#A87A1F; --gold-light:#E8B84B; --gold-pale:#F5E9CC;
  --globe:#1E6FD9; --ice:#EDF2F7;
  --paper:#F2F6FA; --card:#FFFFFF; --line:#DCE5EE; --ink:#0B1F3A; --weekend:#E8EEF5;
  --ok:#2F855A; --ok-bg:#E4F2EA;
  --under:#DD6B20; --under-bg:#FBEADC;
  --over:#C53030; --over-bg:#FAE3E3;
  --leave-bg:#EAF1FA; --off-bg:#EEF1F4;
  --shadow:0 1px 2px rgba(11,31,58,.06),0 10px 28px rgba(11,31,58,.08);
  --radius:12px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--paper);color:var(--ink);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
h1,h2,h3,.brand{font-family:'Montserrat',sans-serif;letter-spacing:-.01em}
.tnum{font-variant-numeric:tabular-nums}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select{font-family:inherit;font-size:14px}
input[type=time],input[type=number],input[type=text],input[type=month],input[type=password],input[type=email],select{
  border:1px solid var(--line);border-radius:8px;padding:8px 10px;background:var(--card);color:var(--ink);width:100%}
input:focus,select:focus,button:focus-visible{outline:2px solid var(--gold);outline-offset:1px}
.hidden{display:none!important}
hr{border:none;border-top:1px solid var(--line);margin:14px 0}

/* header */
header{position:sticky;top:0;z-index:40;background:var(--navy);color:#EAF1F8;display:flex;align-items:center;gap:14px;padding:10px 18px;flex-wrap:wrap;border-bottom:2px solid var(--gold)}
.mark{width:40px;height:40px;flex:0 0 auto;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}
.brand{font-weight:800;font-size:18px;line-height:1;color:#fff}
.brand small{display:block;font-weight:600;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-light);margin-top:4px}
.header-spacer{flex:1}
.whoami{font-size:12px;color:var(--slate-light);font-weight:600}
.hbtn{color:#EAF1F8;border:1px solid rgba(255,255,255,.22);border-radius:8px;padding:8px 12px;font-weight:600;font-size:13px;display:inline-flex;gap:7px;align-items:center;text-decoration:none}
.hbtn:hover{background:rgba(255,255,255,.08)}
.hbtn.live{background:var(--gold);color:var(--navy);border-color:var(--gold);font-weight:700}
.hbtn.live:hover{background:var(--gold-light)}

.wrap{max-width:1280px;margin:0 auto;padding:18px}

/* toolbar */
.toolbar{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;margin-bottom:14px}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--slate)}
.target-chip{border:1px solid var(--gold);background:var(--gold-pale);color:var(--gold-dk);font-weight:700;border-radius:8px;padding:8px 12px}
.stores{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.stab{border:1px solid var(--line);background:var(--card);border-radius:999px;padding:8px 14px;font-weight:600;color:var(--slate);display:inline-flex;gap:8px;align-items:center}
.stab .cnt{font-size:11px;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:1px 7px;color:var(--slate)}
.stab.active{background:var(--navy);color:#EAF1F8;border-color:var(--navy)}
.stab.active .cnt{background:rgba(255,255,255,.15);border-color:transparent;color:#EAF1F8}
.addstore{border:1px dashed var(--slate-light);border-radius:999px;padding:8px 12px;font-weight:700;color:var(--gold-dk)}

/* panels + buttons */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:16px;overflow:hidden}
.panel-head{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line);background:linear-gradient(var(--card),var(--ice));flex-wrap:wrap}
.panel-head h2{margin:0;font-size:15px;font-weight:700}
.panel-head .sub{color:var(--slate);font-size:12px}
.panel-body{padding:14px 16px}
.ph-spacer{flex:1}
.btn{background:var(--gold);color:var(--navy);border-radius:8px;padding:8px 14px;font-weight:700;font-size:13px}
.btn:hover{background:var(--gold-light)}
.btn.ghost{background:transparent;color:var(--navy);border:1px solid var(--line);font-weight:600}
.btn.ghost:hover{background:var(--ice)}
.btn.tiny{padding:5px 9px;font-size:12px}
.btn.block{display:block;width:100%;text-align:center;padding:11px;margin-top:8px;text-decoration:none}
.collapse-btn{margin-left:auto;color:var(--slate);font-weight:600;font-size:13px;border:1px solid var(--line);border-radius:8px;padding:5px 10px}

/* roster */
.roster-add{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.roster-add input,.roster-add select{flex:1;min-width:160px}
.roster-add .btn{flex:0 0 auto}
.roster-list{display:flex;flex-direction:column;gap:6px}
.rrow{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--line);border-radius:9px;background:var(--paper)}
.rrow .nm{font-weight:600}
.role-chip{font-size:11px;font-weight:600;padding:2px 9px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--slate)}
.rrow .del{margin-left:auto;color:var(--over);font-weight:600;font-size:12px;border:1px solid var(--line);border-radius:7px;padding:4px 8px}
.rrow .del:hover{background:var(--over-bg)}
.empty{color:var(--slate);font-size:13px;padding:6px 2px}

/* grid */
.grid-scroll{overflow:auto;max-height:70vh;border-top:1px solid var(--line)}
table.sched{border-collapse:separate;border-spacing:0;width:100%;font-size:12.5px}
table.sched th,table.sched td{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:0;white-space:nowrap}
table.sched thead th{position:sticky;top:0;z-index:20;background:var(--ice);font-weight:600;color:var(--slate);text-align:center;padding:6px 4px;min-width:62px}
table.sched thead th.we{background:var(--weekend)}
th.namecol,td.namecol{position:sticky;left:0;z-index:15;background:var(--card);text-align:left;min-width:170px;max-width:200px;padding:8px 12px;border-right:2px solid var(--line)}
thead th.namecol{z-index:25;background:var(--ice)}
th.totcol,td.totcol{position:sticky;right:0;z-index:15;background:var(--card);min-width:150px;border-left:2px solid var(--line);border-right:none;padding:6px 10px}
thead th.totcol{z-index:25;background:var(--ice)}
td.namecol .nm{font-weight:600;display:block}
td.namecol .ro{font-size:10.5px;color:var(--slate);text-transform:uppercase;letter-spacing:.05em}
td.day{text-align:center;cursor:pointer;height:44px}
td.day:hover{background:var(--gold-pale)}
td.day.we{background:var(--weekend)}
td.day.we:hover{background:var(--gold-pale)}
td.day.c-leave{background:var(--leave-bg)}
td.day.c-off{background:var(--off-bg)}
td.day .shift{display:block;font-weight:600;color:var(--ink);line-height:1.15;font-variant-numeric:tabular-nums}
td.day .shift small{display:block;font-weight:500;color:var(--slate);font-size:10px}
td.day .tag{display:block;font-weight:700;font-size:11px;color:var(--globe)}
td.day .tag small{display:block;font-weight:500;color:var(--slate);font-size:10px}
td.day .tag.off{color:var(--slate)}
td.day .dot{color:var(--line);font-size:15px}
td.day .ov{font-size:9px;color:var(--gold-dk);font-weight:700}
.daterow th .wd{display:block;font-weight:700;color:var(--ink);font-size:11px}

.hbar{height:6px;border-radius:999px;background:var(--line);overflow:hidden;margin-top:5px}
.hbar>i{display:block;height:100%;border-radius:999px;background:var(--ok)}
.htot{font-weight:800;font-variant-numeric:tabular-nums;font-size:14px}
.hsub{display:block;font-size:10px;color:var(--slate);font-variant-numeric:tabular-nums;margin-top:1px}
.hdelta{font-size:10.5px;font-weight:700;display:block;margin-top:2px}
.ok{color:var(--ok)} .under{color:var(--under)} .over{color:var(--over)}
td.totcol.s-ok{background:var(--ok-bg)} td.totcol.s-short{background:var(--under-bg)} td.totcol.s-overtime{background:var(--over-bg)}

.legend{display:flex;gap:18px;padding:10px 16px;border-top:1px solid var(--line);font-size:12px;color:var(--slate);flex-wrap:wrap}
.legend i.lg{display:inline-block;width:12px;height:12px;border-radius:3px;vertical-align:-2px;margin-right:5px;border:1px solid var(--line)}
.legend i.shift{background:#fff} .legend i.leave{background:var(--leave-bg)} .legend i.off{background:var(--off-bg)}

/* summary */
.sum-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:14px}
.stat{border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:var(--paper)}
.stat .k{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);font-weight:700}
.stat .v{font-size:24px;font-weight:800;margin-top:3px;font-variant-numeric:tabular-nums}
.stat .v small{font-size:13px;color:var(--slate);font-weight:600}
.sumtable{width:100%;border-collapse:collapse;font-size:13px}
.sumtable th{text-align:left;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);padding:7px 10px;border-bottom:1px solid var(--line)}
.sumtable td{padding:8px 10px;border-bottom:1px solid var(--line);font-variant-numeric:tabular-nums}
.pill{font-size:11px;font-weight:700;padding:2px 9px;border-radius:999px;white-space:nowrap}
.pill.ok{background:var(--ok-bg);color:var(--ok)}
.pill.under{background:var(--under-bg);color:var(--under)}
.pill.over{background:var(--over-bg);color:var(--over)}
.store-block{margin-bottom:18px}
.store-block h3{margin:0 0 8px;font-size:15px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.store-block h3 .meta{font-weight:500;font-size:12px;color:var(--slate)}
.note{font-size:12px;color:var(--slate);background:var(--gold-pale);border:1px solid #E7D29A;border-radius:10px;padding:10px 12px;margin-top:12px}
.note b{color:var(--navy)}

/* modal */
.scrim{position:fixed;inset:0;background:rgba(7,22,41,.5);display:none;align-items:center;justify-content:center;z-index:60;padding:16px}
.scrim.show{display:flex}
.modal{background:var(--card);border-radius:14px;box-shadow:0 20px 60px rgba(7,22,41,.4);width:100%;max-width:440px;overflow:hidden;max-height:92vh;display:flex;flex-direction:column}
.modal h3{margin:0;font-size:16px}
.modal-head{padding:14px 18px;border-bottom:1px solid var(--line)}
.modal-head .who{color:var(--slate);font-size:12.5px;margin-top:2px}
.modal-body{padding:16px 18px;display:flex;flex-direction:column;gap:14px;overflow:auto}
.seg{display:flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{flex:1;padding:9px;font-weight:600;font-size:13px;color:var(--slate);background:var(--card)}
.seg button.on{background:var(--navy);color:#fff}
.time-row{display:flex;gap:10px;flex-wrap:wrap}
.time-row .field{flex:1;min-width:110px}
.hint{font-size:12px;color:var(--slate);margin:0}
.repeat fieldset{border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin:0}
.repeat legend{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);padding:0 6px}
.repeat label{display:flex;gap:8px;align-items:center;font-size:13px;padding:3px 0;cursor:pointer}
.modal-foot{padding:14px 18px;border-top:1px solid var(--line);display:flex;gap:10px;align-items:center}
.modal-foot .calc{font-weight:700;font-variant-numeric:tabular-nums}
.modal-foot .spc{flex:1}
.linkbtn{color:var(--over);font-weight:600;background:none;border:none;font-size:13px}

/* footer */
footer{background:var(--navy-deep);color:#9FB3C8;padding:20px 18px;display:flex;gap:11px;align-items:center;justify-content:center;font-size:12.5px;font-weight:500;border-top:2px solid var(--gold)}
footer .fmark{width:24px;height:24px;flex:0 0 auto}
footer b{color:var(--gold-light);font-weight:700;letter-spacing:.02em}

/* toast */
.toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--navy);color:#EAF1F8;padding:11px 18px;border-radius:10px;font-weight:600;font-size:13px;opacity:0;transition:.25s;z-index:80;box-shadow:var(--shadow);border:1px solid var(--gold)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* auth + setup */
.auth-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 600px at 50% -10%,#13325a,var(--navy));padding:20px}
.auth-card{background:var(--card);border-radius:16px;box-shadow:0 30px 80px rgba(0,0,0,.4);padding:32px;width:100%;max-width:400px;text-align:center;border-top:3px solid var(--gold)}
.auth-logo{width:72px;height:72px;margin-bottom:6px}
.auth-card h1{margin:0;font-size:22px;font-weight:800}
.auth-card .sub{color:var(--slate);margin:2px 0 18px;font-weight:600}
.auth-form{display:flex;flex-direction:column;gap:12px;text-align:left}
.auth-form label{font-size:12px;font-weight:700;color:var(--slate);display:flex;flex-direction:column;gap:5px}
.auth-form h3{margin:8px 0 0;font-size:13px;color:var(--navy)}
.auth-note{border-radius:10px;padding:10px 12px;font-size:13px;margin:10px 0;text-align:left}
.auth-note.err{background:var(--over-bg);color:var(--over)}
.auth-note.ok{background:var(--ok-bg);color:var(--ok)}
.auth-note.warn{background:var(--gold-pale);color:var(--gold-dk)}
.auth-foot{margin-top:18px;font-size:11.5px;color:var(--slate)}
.auth-foot b{color:var(--gold-dk)}
.store-cred{display:flex;gap:8px;align-items:center;margin:6px 0}
.store-cred .store-name{width:90px;font-weight:700;font-size:13px}
.store-cred input{flex:1}

@media (max-width:640px){
  .wrap{padding:12px}.brand{font-size:16px}.whoami{display:none}
  th.namecol,td.namecol{min-width:130px;max-width:140px}
}
@media print{
  header,.toolbar,.collapse-btn,.btn,.hbtn,.note,.legend,#rosterPanel,#gridPanel,footer{display:none!important}
  body{background:#fff}.panel{box-shadow:none;border:none}
}

/* ===== update: action bar, approval, training, manager view, branding ===== */
.actionbar{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.status-chip{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px}
.status-chip.ok{background:var(--ok-bg);color:var(--ok)}
.status-chip.pending{background:var(--gold-pale);color:var(--gold-dk)}
.status-chip.draft{background:var(--ice);color:var(--slate)}
.btn[disabled]{opacity:.45;cursor:not-allowed}
.btn.wa{color:#128C7E;border-color:#9fd8cf}
.btn.wa:hover{background:#e8f7f3}

/* training */
.legend i.training{background:#FBEFD8}
td.day.c-train{background:#FBEFD8}
td.day .trn,td.namecol .mtag,.trn{font-size:8px;font-weight:800;color:#A87A1F;background:#F5E9CC;border-radius:3px;padding:0 3px;vertical-align:1px}
.mtag{color:var(--navy);background:var(--gold-pale)}
.seg button[data-type=training].on{background:var(--gold-dk)}

/* branding controls in settings */
.logo-upload{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.logo-prev{width:54px;height:54px;border:1px solid var(--line);border-radius:10px;object-fit:contain;background:#fff;padding:4px}

/* Manager View full page */
#managerView{padding-top:4px}
.mv-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.mv-bar h2{margin:0;font-size:18px}
.mv-spacer{flex:1}
.mv-legend{display:flex;gap:16px;font-size:12px;color:var(--slate);margin:8px 0 16px;flex-wrap:wrap}
.mv-legend i.lg{display:inline-block;width:12px;height:12px;border-radius:3px;vertical-align:-2px;margin-right:5px;border:1px solid var(--line)}
.mv-legend i.cov-ok{background:var(--ok-bg)} .mv-legend i.cov-warn{background:var(--gold-pale)} .mv-legend i.cov-bad{background:var(--over-bg)}
.mv-store{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px;margin-bottom:16px}
.mv-store-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.mv-store-head h3{margin:0;font-size:16px}
.mv-store-head .meta{font-size:12px;color:var(--slate)}
.mv-actions{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap}
.mv-flags{display:flex;gap:14px;flex-wrap:wrap;font-size:12.5px;font-weight:600;margin-bottom:8px}
.okflag{color:var(--ok)} .badflag{color:var(--over)} .warnflag{color:var(--gold-dk)}
.mv-label{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--slate);margin:10px 0 4px}

/* coverage strip */
.cov-scroll{overflow-x:auto;border:1px solid var(--line);border-radius:8px}
.covtable{border-collapse:collapse;width:100%}
.covtable th,.covtable td{border:1px solid var(--line);text-align:center;min-width:34px;padding:3px 2px;font-size:11px}
.covtable th{background:var(--ice);color:var(--slate);font-weight:600}
.covtable th.we{background:var(--weekend)}
.covtable td.rowlbl,.covtable th.rowlbl{position:sticky;left:0;background:var(--card);text-align:left;min-width:78px;font-weight:700;color:var(--slate);font-size:11px;padding-left:8px}
.covtable .wd{display:block;font-size:9px}
td.cov .cnum{font-weight:800;font-variant-numeric:tabular-nums}
td.cov .mgr{display:inline-block;margin-left:2px;font-size:9px;font-weight:800}
td.cov .mgr.yes{color:var(--ok)} td.cov .mgr.no{color:var(--over)}
td.cov-ok{background:var(--ok-bg)} td.cov-warn{background:var(--gold-pale)} td.cov-bad{background:var(--over-bg);color:var(--over)}
.grid-scroll.ro{max-height:none}
.grid-scroll.ro td.day{cursor:default}
.grid-scroll.ro td.day:hover{background:inherit}

@media print{
  /* the on-screen app never prints directly; the one-pager opens in its own window */
  #managerView,#storeWork{display:block}
}
