:root{--brand:#1c3aa3;--brand-2:#162e80;--blue:#2a51d4;--blue-strong:#1f43c2;--blue-bright:#3f63e6;--blue-tint:#eaeffc;--blue-tint-2:#dde6fb;--blue-ring:rgba(42,81,212,.22);--ink:#1a2236;--muted:#5c6678;--muted-2:#8a94a6;--line:#e3e8f1;--line-2:#eef1f7;--paper:#f3f5fb;--card:#fff;--green:#188a55;--green-dark:#0f6b41;--green-tint:#e7f4ed;--amber:#a96f12;--amber-tint:#fbf0db;--red:#bf3b30;--red-tint:#fbeae8;--radius:10px;--shadow:0 1px 2px rgba(16,30,70,.05), 0 2px 6px rgba(16,30,70,.05);--shadow-lg:0 12px 34px rgba(16,30,70,.14);--teal-tint:var(--green-tint)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased}h1,h2,h3,h4,button{font-family:Inter,sans-serif}.mono{font-family:IBM Plex Mono,monospace;font-size:12.5px}::selection{background:var(--blue-tint-2)}.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,var(--brand),var(--brand-2));color:#fff;padding:22px 0;display:flex;flex-direction:column}.brand{padding:0 20px 20px;border-bottom:1px solid rgba(255,255,255,.13);margin-bottom:14px}.brand .logo{font-weight:800;font-size:18px;line-height:1.2;letter-spacing:-.2px}.brand .logo em{font-style:normal;color:#9db6ff}.brand .sub{font-size:10.5px;color:#a7b8e8;margin-top:5px;letter-spacing:1px;text-transform:uppercase;font-weight:600}.nav{display:flex;flex-direction:column;gap:2px;padding:0 10px}.nav button{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:10px 14px;color:#c8d3f0;background:none;border:none;font-size:13.5px;font-weight:500;border-radius:8px;cursor:pointer;transition:background .12s,color .12s}.nav button:hover{background:#ffffff12;color:#fff}.nav button.on{background:#ffffff24;color:#fff;font-weight:600;box-shadow:inset 3px 0 #9db6ff}.sidebar .me{margin-top:auto;padding:15px 20px 2px;border-top:1px solid rgba(255,255,255,.13);font-size:13px;display:flex;align-items:center;gap:10px}.avatar{width:34px;height:34px;border-radius:9px;background:#9db6ff;color:var(--brand-2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12.5px;flex-shrink:0}.me small{display:block;color:#a7b8e8;font-size:11px}.linkish{background:none;border:none;color:#a7b8e8;font-size:11px;cursor:pointer;text-decoration:underline;padding:0}main{padding:28px 32px;overflow-x:auto}.page-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:12px}.page-top h2{font-size:23px;font-weight:700;letter-spacing:-.4px}.page-top .sub{font-size:13px;color:var(--muted);margin-top:4px}.btn{font-size:13px;font-weight:600;padding:9px 15px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--ink);cursor:pointer;transition:background .12s,border-color .12s,box-shadow .12s}.btn:hover{background:#fafbff;border-color:#cdd5e3}.btn.primary{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 1px 2px var(--blue-ring)}.btn.primary:hover{background:var(--blue-strong);border-color:var(--blue-strong)}.btn.danger{color:var(--red);border-color:#f0cfcb}.btn.danger:hover{background:var(--red-tint)}.btn:disabled{opacity:.5;cursor:default}.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;margin-bottom:18px;box-shadow:var(--shadow)}.panel h3{font-size:13.5px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;gap:8px;letter-spacing:-.1px}.panel h4{font-size:13px;font-weight:700}.count{background:var(--blue);color:#fff;font-size:11px;border-radius:999px;padding:2px 8px;font-weight:600}table{width:100%;border-collapse:collapse}th{font-size:10.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted-2);text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}td{padding:11px 12px;font-size:13.5px;border-bottom:1px solid var(--line-2);vertical-align:middle}tbody tr{transition:background .1s}tr:last-child td{border-bottom:none}input,select,textarea{font-family:Inter,sans-serif;font-size:13.5px;padding:9px 11px;border:1px solid var(--line);border-radius:8px;background:#fff;width:100%;color:var(--ink);transition:border-color .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-ring)}label{font-size:12px;font-weight:600;color:var(--muted);display:block;margin-bottom:5px}.field{margin-bottom:13px}.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.chip{font-size:11px;font-weight:600;border-radius:6px;padding:3px 9px;white-space:nowrap;display:inline-block;letter-spacing:.1px}.chip.ok{background:var(--green-tint);color:var(--green-dark)}.chip.pend{background:var(--amber-tint);color:var(--amber)}.chip.deny{background:var(--red-tint);color:var(--red)}.chip.vac{background:var(--blue-tint);color:var(--blue)}.chip.sick{background:var(--red-tint);color:var(--red)}.grid-wrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:auto;margin-bottom:22px;box-shadow:var(--shadow)}table.sched{min-width:860px}.sched th{background:#fbfcfe}.sched th small{display:block;font-family:Inter;font-weight:500;text-transform:none;letter-spacing:0;color:var(--ink);font-size:12.5px;margin-top:2px}.sched td{border-right:1px solid var(--line-2);padding:7px;min-width:104px}.sched td:last-child{border-right:none}.sched .who{font-weight:600;font-size:13.5px;white-space:nowrap;background:#fbfcfe;border-right:1px solid var(--line)}.sched .who small{display:block;font-weight:500;font-size:11px;color:var(--muted);margin-top:2px}.sched .closed{background:#f5f7fa;color:#aab4c4;text-align:center;font-size:11px}.sched .closed small{display:block;color:#b7c0cd;font-size:10px;margin-top:2px}.sched th small.holi{font-weight:700;font-size:10.5px;margin-top:3px;color:var(--blue);letter-spacing:0}.sched th small.holi.closed{color:var(--red)}.holi-list{border:1px solid var(--line);border-radius:10px;overflow:hidden}.holi-row{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;border-bottom:1px solid var(--line-2)}.holi-row:last-child{border-bottom:none}.holi-row .hd b{font-family:IBM Plex Mono,monospace;font-size:12px;margin-right:8px;color:var(--muted)}.holi-row .hd span{font-size:13px}.holi-row .ha{display:flex;align-items:center;gap:8px}.pill{border:1px solid var(--line);background:#fff;border-radius:999px;padding:3px 11px;font-size:11.5px;font-weight:600;cursor:pointer;transition:background .12s}.pill.open{color:var(--muted)}.pill.open:hover{background:#f5f7fa}.pill.closed{color:var(--red);border-color:#f0cfcb;background:var(--red-tint)}.holi-row .x{border:none;background:none;color:var(--red);cursor:pointer;font-size:12px}.cal-legend{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px;font-size:12px;color:var(--muted)}.cal-legend span{display:flex;align-items:center;gap:6px}.cal-legend .dot{width:10px;height:10px;border-radius:3px;display:inline-block}.dot.in{background:var(--green-tint);border:1px solid #bfe0cd}.dot.pto{background:var(--blue-tint);border:1px solid #c3d4ec}.dot.holi{background:#fff;border:1px solid var(--blue)}.dot.closed{background:#eef1f5;border:1px solid #b7c0cd}.cal{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.cal-head{display:grid;grid-template-columns:repeat(7,1fr);background:#fbfcfe;border-bottom:1px solid var(--line)}.cal-head div{padding:9px 10px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2);text-align:left}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}.cal-cell{min-height:106px;border-right:1px solid var(--line-2);border-bottom:1px solid var(--line-2);padding:6px;display:flex;flex-direction:column;gap:3px}.cal-cell:nth-child(7n){border-right:none}.cal-cell.out{background:#fafbfd}.cal-cell.out .cal-date span{color:#c3ccd9}.cal-cell.today{background:var(--blue-tint)}.cal-cell.today .cal-date span{background:var(--blue);color:#fff;border-radius:6px;padding:0 6px}.cal-cell.closed-day{background:#f5f7fa}.cal-date{display:flex;justify-content:space-between;align-items:baseline;gap:6px;margin-bottom:1px}.cal-date span{font-size:12.5px;font-weight:700;color:var(--ink)}.cal-date em{font-style:normal;font-size:9.5px;font-weight:700;text-align:right;line-height:1.15;color:var(--blue)}.cal-date em.holi.closed{color:var(--red)}.cal-closed{font-size:11px;font-weight:600;color:#aab4c4;text-align:center;margin-top:8px}.cal-muted{font-size:10.5px;color:#aab4c4;text-align:center}.cal-chip{font-size:11px;line-height:1.3;border-radius:6px;padding:2px 6px;font-weight:500}.cal-chip.in{background:var(--green-tint);color:var(--green-dark);border:1px solid #bfe0cd}.cal-chip.pto{background:var(--blue-tint);color:var(--blue);border:1px solid #c3d4ec}.cal-chip.bday{background:#fbf0db;color:#a96f12;border:1px solid #ecd6a8}.dot.bday{background:#fbf0db;border:1px solid #ecd6a8}.shift-card{border-radius:8px;padding:6px 8px;font-size:12px;line-height:1.35;border:1px solid #bfe0cd;background:var(--green-tint);color:var(--green-dark);margin-bottom:5px;position:relative}.shift-card b{font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:600;display:block}.shift-card .x{position:absolute;top:2px;right:5px;border:none;background:none;color:var(--red);cursor:pointer;font-size:11px;display:none}.shift-card:hover .x{display:block}.shift-card.pto{background:var(--blue-tint);border-color:#c3d4ec;color:var(--blue)}.addcell{width:100%;border:1px dashed var(--line);background:none;border-radius:8px;color:var(--muted-2);font-size:11px;padding:5px 0;cursor:pointer;transition:border-color .12s,color .12s}.addcell:hover{border-color:var(--blue);color:var(--blue)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14224680;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:50;padding:16px}.modal{background:#fff;border-radius:14px;padding:24px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.modal h3{font-size:16px;margin-bottom:16px;font-weight:700}.modal .foot{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:linear-gradient(150deg,var(--brand),var(--brand-2))}.login-card{background:#fff;border-radius:16px;padding:34px;width:100%;max-width:380px;box-shadow:var(--shadow-lg)}.login-card .logo{font-weight:800;font-size:21px;line-height:1.2;letter-spacing:-.3px}.login-card .logo em{font-style:normal;color:var(--blue)}.login-card .sub{font-size:11px;color:var(--muted);margin:5px 0 24px;text-transform:uppercase;letter-spacing:1px;font-weight:600}.err{background:var(--red-tint);color:var(--red);font-size:12.5px;border-radius:8px;padding:9px 12px;margin-bottom:12px}.emp-shell{max-width:560px;margin:0 auto;min-height:100vh;background:#fff;border-left:1px solid var(--line);border-right:1px solid var(--line);display:flex;flex-direction:column}.emp-top{background:linear-gradient(150deg,var(--brand),var(--brand-2));color:#fff;padding:22px 20px 54px;position:relative}.emp-top .hello{font-size:20px;font-weight:700;letter-spacing:-.3px}.emp-top .date{font-size:12.5px;color:#a7b8e8;margin-top:3px}.emp-top .out{position:absolute;right:18px;top:22px;background:#ffffff29;border:none;color:#fff;font-size:11.5px;border-radius:8px;padding:7px 12px;cursor:pointer;font-weight:600}.next-shift{margin:-36px 18px 0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}.eyebrow{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--blue)}.next-shift .big{font-size:17px;font-weight:700;margin-top:5px}.next-shift .meta{font-size:13px;color:var(--muted);margin-top:3px}.emp-body{padding:22px 18px;flex:1}.pto-row{display:flex;gap:10px;margin:18px 0 22px}.pto-card{flex:1;background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 15px;box-shadow:var(--shadow)}.pto-card .n{font-size:21px;font-weight:800;letter-spacing:-.5px}.pto-card .l{font-size:11.5px;color:var(--muted);margin-top:2px}.emp-body h4{font-size:13.5px;font-weight:700;margin-bottom:10px}.shift-line{display:flex;align-items:center;gap:10px;font-size:13.5px;padding:11px 0;border-bottom:1px solid var(--line-2)}.shift-line:last-child{border-bottom:none}.shift-line .d{font-weight:600;min-width:92px}.cta{width:100%;font-size:13.5px;font-weight:700;padding:14px;border-radius:10px;cursor:pointer;border:none;background:var(--blue);color:#fff;margin:16px 0 22px;box-shadow:0 1px 2px var(--blue-ring)}.cta:hover{background:var(--blue-strong)}.empty{color:var(--muted);font-size:13px;padding:8px 0}@media (max-width:900px){.shell{grid-template-columns:1fr}.sidebar{flex-direction:row;align-items:center;padding:10px 12px;overflow-x:auto;gap:4px}.brand{border:none;padding:0 12px 0 0;margin:0}.brand .sub{display:none}.nav{flex-direction:row;padding:0}.nav button{white-space:nowrap;padding:9px 12px;width:auto}.nav button.on{box-shadow:inset 0 -3px #9db6ff}.sidebar .me{margin:0 0 0 auto;border:none;padding:0}.me small,.me .nm{display:none}main{padding:18px 14px}.row2{grid-template-columns:1fr}}.logo svg{vertical-align:middle;margin-right:9px}.login-card .logo svg{display:block;margin:0 auto 12px}
