/* ShiftPlan — premium design system
   Palette: Orange #FF5A2C · Ink #111111 · Cream #F8F5F2 · Gray #F5F5F5
   Type: Inter (UI) + mono for operational data (times, IDs, hours) */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  --orange:#FF5A2C; --orange-600:#E8461A; --orange-tint:#FFF1EC;
  --ink:#111111; --ink-2:#3a3a3c; --muted:#8a8a8e;
  --line:#ececec; --bg:#F8F5F2; --panel:#FFFFFF; --gray:#F5F5F5;
  --green:#1E8E5A; --green-tint:#E9F6EF;
  --amber:#E08A00; --amber-tint:#FEF4E2;
  --red:#C0392B; --red-tint:#FCEBE9;
  --radius:16px; --radius-sm:12px;
  --shadow:0 1px 2px rgba(17,17,17,.04), 0 8px 24px rgba(17,17,17,.06);
  --shadow-lg:0 12px 40px rgba(17,17,17,.12);
  --sidebar-w:248px; --topbar-h:64px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}
[data-theme="dark"]{
  --ink:#f5f5f7; --ink-2:#d4d4d8; --muted:#8e8e93;
  --line:#2a2a2e; --bg:#0d0d0f; --panel:#161618; --gray:#1c1c1f;
  --orange-tint:#2a1a12;
  --green-tint:#10261c; --amber-tint:#2a2010; --red-tint:#2a1715;
  --shadow:0 1px 2px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.4);
  --shadow-lg:0 12px 40px rgba(0,0,0,.6);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* ---------- layout ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:var(--sidebar-w);position:fixed;inset:0 auto 0 0;z-index:40;
  background:var(--panel);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 14px;
  transition:transform .25s ease}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 20px}
.brand .mark{width:30px;height:30px;border-radius:9px;background:var(--orange);
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px;
  box-shadow:0 4px 12px rgba(255,90,44,.35)}
.brand b{font-size:16px;font-weight:700;letter-spacing:-.02em}
.brand span{color:var(--muted);font-size:11px;display:block;font-weight:500;margin-top:-2px}
.nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);
  font-weight:600;padding:14px 10px 6px}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;
  color:var(--ink-2);font-weight:500;font-size:13.5px;margin-bottom:2px;transition:.15s}
.nav a svg{width:17px;height:17px;stroke-width:1.9;color:var(--muted);transition:.15s}
.nav a:hover{background:var(--gray);color:var(--ink)}
.nav a:hover svg{color:var(--ink)}
.nav a.active{background:var(--orange-tint);color:var(--orange-600);font-weight:600}
.nav a.active svg{color:var(--orange)}
.sidebar-foot{margin-top:auto;padding:10px;border-top:1px solid var(--line)}

.main{flex:1;margin-left:var(--sidebar-w);min-width:0}
.topbar{height:var(--topbar-h);position:sticky;top:0;z-index:30;
  background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 28px}
.search{flex:1;max-width:420px;position:relative}
.search input{width:100%;height:40px;border:1px solid var(--line);background:var(--panel);
  border-radius:11px;padding:0 14px 0 38px;font-size:13.5px;color:var(--ink);font-family:var(--font)}
.search input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-tint)}
.search svg{position:absolute;left:12px;top:11px;width:17px;height:17px;color:var(--muted)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.icon-btn{width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:var(--panel);
  display:grid;place-items:center;cursor:pointer;color:var(--ink-2);transition:.15s}
.icon-btn:hover{background:var(--gray);color:var(--ink)}
.icon-btn svg{width:18px;height:18px}
.avatar{width:40px;height:40px;border-radius:12px;background:var(--ink);color:#fff;
  display:grid;place-items:center;font-weight:600;font-size:13px}

.content{padding:28px}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.page-head h1{font-size:26px;font-weight:700;letter-spacing:-.025em}
.page-head p{color:var(--muted);font-size:14px;margin-top:3px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 16px;border-radius:11px;
  font-weight:600;font-size:13.5px;cursor:pointer;border:1px solid var(--line);background:var(--panel);
  color:var(--ink);transition:.15s;font-family:var(--font)}
.btn:hover{background:var(--gray)}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--orange);border-color:var(--orange);color:#fff;
  box-shadow:0 4px 14px rgba(255,90,44,.3)}
.btn-primary:hover{background:var(--orange-600);border-color:var(--orange-600)}
.btn-ghost{background:transparent;border-color:transparent}

/* ---------- cards / kpis ---------- */
.grid{display:grid;gap:16px}
.kpis{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);transition:transform .18s ease, box-shadow .18s ease}
.kpi{padding:20px}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.kpi .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.kpi .ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center}
.kpi .ic svg{width:18px;height:18px}
.ic-o{background:var(--orange-tint);color:var(--orange)}
.ic-g{background:var(--green-tint);color:var(--green)}
.ic-a{background:var(--amber-tint);color:var(--amber)}
.ic-r{background:var(--red-tint);color:var(--red)}
.kpi .val{font-size:30px;font-weight:700;letter-spacing:-.03em;font-family:var(--mono)}
.kpi .lab{color:var(--muted);font-size:13px;margin-top:2px;font-weight:500}
.kpi .delta{font-size:11.5px;font-weight:600;padding:2px 7px;border-radius:20px}
.delta.up{background:var(--green-tint);color:var(--green)}
.delta.down{background:var(--red-tint);color:var(--red)}

.card-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.card-head h3{font-size:15px;font-weight:650;letter-spacing:-.01em}
.card-head .sub{color:var(--muted);font-size:12.5px}
.card-body{padding:20px}

/* ---------- shift coverage board (signature) ---------- */
.shift-board{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.shift-col{border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;background:var(--panel)}
.shift-col header{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid var(--line)}
.shift-col header .t{font-weight:650;font-size:14px}
.shift-col header .time{font-family:var(--mono);font-size:11.5px;color:var(--muted)}
.shift-col .bar{height:6px;background:var(--gray)}
.shift-col .bar i{display:block;height:100%;background:var(--orange);transition:width .6s cubic-bezier(.2,.8,.2,1)}
.shift-col .body{padding:14px 16px}
.shift-col .pct{font-size:26px;font-weight:700;font-family:var(--mono);letter-spacing:-.02em}
.shift-col .meta{color:var(--muted);font-size:12.5px;margin-top:2px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}
.dot.m{background:var(--orange)} .dot.e{background:#7a5cff} .dot.n{background:var(--ink)}

/* ---------- tables ---------- */
.tbl-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--line);background:var(--panel)}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{text-align:left;padding:12px 16px;background:var(--gray);color:var(--muted);
  font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em;
  border-bottom:1px solid var(--line);position:sticky;top:0}
tbody td{padding:12px 16px;border-bottom:1px solid var(--line);color:var(--ink-2)}
tbody tr:last-child td{border-bottom:none}
tbody tr{transition:background .12s}
tbody tr:hover{background:var(--gray)}
td.emp,td.num{font-family:var(--mono);color:var(--ink)}
.w-name{color:var(--ink);font-weight:600}

/* ---------- badges / pills ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:7px;
  font-size:11.5px;font-weight:600;font-family:var(--mono)}
.badge-m{background:var(--orange-tint);color:var(--orange-600)}
.badge-e{background:#efeaff;color:#5a3fdd}
.badge-n{background:#e9e9ee;color:var(--ink)}
.badge-off{background:var(--gray);color:var(--muted)}
[data-theme="dark"] .badge-e{background:#211b3a}
[data-theme="dark"] .badge-n{background:#222}
.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:8px;
  font-size:12px;font-weight:600}
.tag.green{background:var(--green-tint);color:var(--green)}
.tag.amber{background:var(--amber-tint);color:var(--amber)}
.tag.red{background:var(--red-tint);color:var(--red)}
.tag.gray{background:var(--gray);color:var(--muted)}
.scarce{color:var(--red);font-weight:600}

/* ---------- roster grid ---------- */
.roster-grid{font-size:11.5px}
.roster-grid th,.roster-grid td{padding:7px 6px;text-align:center;white-space:nowrap}
.roster-grid td.lbl{text-align:left;font-weight:600;color:var(--ink);position:sticky;left:0;background:var(--panel)}
.cell{display:inline-block;width:26px;border-radius:6px;font-family:var(--mono);font-weight:600;padding:3px 0}
.cell.M{background:var(--orange-tint);color:var(--orange-600)}
.cell.E{background:#efeaff;color:#5a3fdd}
.cell.N{background:#e9e9ee;color:var(--ink)}
.cell.OFF{background:transparent;color:var(--muted)}

/* ---------- alerts ---------- */
.alert-row{display:flex;gap:14px;padding:14px 16px;border-bottom:1px solid var(--line);align-items:flex-start}
.alert-row:last-child{border-bottom:none}
.alert-row .ai{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:none}
.alert-row .ai svg{width:16px;height:16px}
.alert-row .txt b{display:block;font-size:13px;margin-bottom:1px}
.alert-row .txt span{color:var(--muted);font-size:13px}

/* ---------- forms ---------- */
label.fl{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
input[type=text],input[type=password],input[type=date],input[type=number],select,input[type=file]{
  width:100%;height:42px;border:1px solid var(--line);border-radius:11px;padding:0 13px;
  font-size:13.5px;font-family:var(--font);background:var(--panel);color:var(--ink)}
input:focus,select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-tint)}
.demand-grid input{height:36px;text-align:center;font-family:var(--mono);padding:0 6px}
.notice{padding:13px 15px;border-radius:11px;font-size:13px;font-weight:500;margin-bottom:18px}
.notice.green{background:var(--green-tint);color:var(--green)}
.notice.red{background:var(--red-tint);color:var(--red)}

/* ---------- auth ---------- */
.auth{min-height:100vh;display:grid;place-items:center;background:
  radial-gradient(1200px 500px at 50% -10%, var(--orange-tint), transparent), var(--bg)}
.auth .box{width:360px;background:var(--panel);border:1px solid var(--line);border-radius:20px;
  padding:32px;box-shadow:var(--shadow-lg)}
.auth .mark{width:44px;height:44px;border-radius:13px;background:var(--orange);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:20px;margin-bottom:18px;
  box-shadow:0 6px 18px rgba(255,90,44,.4)}
.auth h1{font-size:21px;letter-spacing:-.02em;margin-bottom:4px}
.auth p{color:var(--muted);font-size:13px;margin-bottom:22px}
.auth label.fl{margin-top:14px}

/* ---------- responsive ---------- */
.menu-btn{display:none}
@media(max-width:1024px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:var(--shadow-lg)}
  .main{margin-left:0}
  .menu-btn{display:grid}
  .shift-board{grid-template-columns:1fr}
}
@media(max-width:640px){
  .content{padding:18px}
  .page-head h1{font-size:22px}
  .search{display:none}
}
.scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:35}
.scrim.show{display:block}
