@import url(https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&display=swap);html:has(.auth-page),html:has(.auth-page) body{height:100%;height:100dvh;margin:0;overflow:hidden;overscroll-behavior:none;padding:0;touch-action:none}.auth-page{background:var(--bg);display:flex;flex-direction:column;font-family:var(--font);height:100dvh;max-height:100dvh;overflow:hidden;overscroll-behavior:none;touch-action:none}.auth-brand-panel,.auth-mobile-hero{display:none!important}.auth-form-panel{align-items:center;display:flex;flex:1 1;justify-content:center;min-height:0;overflow:hidden;overscroll-behavior:none;padding:20px}.auth-form-wrap{animation:fadeUp .4s ease-out;background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-sm);max-width:420px;padding:28px 22px;width:100%}.auth-brand-logo,.auth-mobile-logo{align-items:center;display:flex;gap:10px;margin-bottom:28px}.auth-brand-logo-mark,.auth-mobile-logo-mark{align-items:center;background:var(--ink-900);border-radius:11px;color:#fff;display:flex;font-size:13px;font-weight:800;height:40px;justify-content:center;letter-spacing:-.03em;width:40px}.auth-brand-logo-name,.auth-mobile-logo-name{color:var(--text);font-size:14px;font-weight:700;letter-spacing:-.015em}.auth-hero-icon{align-items:center;background:var(--blue-50);border-radius:14px;color:var(--blue-500);display:flex;font-size:24px;height:54px;justify-content:center;width:54px}.auth-heading,.auth-hero-icon{margin-bottom:20px}.auth-heading h2{color:var(--text);font-size:26px;font-weight:800;letter-spacing:-.03em;line-height:1.15;margin:0 0 5px}.auth-heading p{color:#9ca3af;font-size:14px;line-height:1.5;margin:0}.auth-heading p strong{color:var(--text);font-weight:600}.auth-form{gap:14px}.auth-form,.field{display:flex;flex-direction:column}.field{gap:7px}.field-label{align-items:center;color:var(--text);display:flex;font-size:12.5px;font-weight:600;justify-content:space-between}.field-shell{background:var(--paper-soft);border:1px solid var(--border);height:50px;padding:0 14px;transition:background .18s,border-color .18s,box-shadow .18s}.field-shell:hover:not(:focus-within){border-color:var(--border-strong)}.field-shell:focus-within{background:#fff;border-width:1.5px;box-shadow:0 0 0 4px #1c5cff1a}.field-shell.error:focus-within{box-shadow:0 0 0 4px #dc26261a}.field-shell-icon{margin-right:10px;transition:color .18s}.field-shell.error .field-shell-icon{color:var(--bad)}.field-shell input{-webkit-text-fill-color:var(--text)!important;background:#0000;border:none;box-shadow:inset 0 0 0 1000px #0000!important;caret-color:var(--text);color:var(--text);flex:1 1;font-family:var(--font);font-size:14.5px;font-weight:500;height:100%;min-width:0;outline:none;padding:0;width:100%}.field-shell input::placeholder{color:#9ca3af;font-weight:400}.field-shell input:-webkit-autofill,.field-shell input:-webkit-autofill:active,.field-shell input:-webkit-autofill:focus,.field-shell input:-webkit-autofill:hover{-webkit-text-fill-color:var(--text)!important;-webkit-box-shadow:inset 0 0 0 1000px #fff!important;-webkit-transition:background-color 5000s ease-in-out 0s;transition:background-color 5000s ease-in-out 0s}.field-shell:not(:focus-within) input:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px var(--paper-soft) inset!important}.field-shell.error input:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px var(--bad-bg) inset!important}.field-shell-action{border-radius:6px;font-size:18px;margin-left:4px;padding:6px;transition:color .15s,background .15s}.field-shell-action:hover{background:var(--blue-50)}.field-error{align-items:center;animation:shake .3s;color:var(--bad);display:flex;font-size:12px;font-weight:500;gap:5px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}.field-helper{color:#9ca3af;font-size:12px;font-weight:400}.btn-submit{align-items:center;background:var(--blue-500);border:1.5px solid var(--blue-500);border-radius:12px;box-shadow:0 4px 14px #1c5cff38;color:#fff;cursor:pointer;display:flex;font-family:var(--font);font-size:15px;font-weight:700;gap:8px;height:50px;justify-content:center;letter-spacing:-.005em;margin-top:6px;transition:background .18s,border-color .18s,box-shadow .18s,transform .1s}.btn-submit:hover:not(:disabled){background:var(--blue-700);border-color:var(--blue-700);box-shadow:0 6px 20px #1c5cff52}.btn-submit:active:not(:disabled){transform:translateY(1px)}.btn-submit:disabled{cursor:not-allowed;opacity:.5}.spinner{animation:spin .6s linear infinite;border:2.5px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.helper-row{flex-wrap:wrap;gap:6px;justify-content:space-between;margin-top:2px}.checkbox-row,.helper-row{align-items:center;display:flex}.checkbox-row{color:#9ca3af;cursor:pointer;font-size:13px;font-weight:500;gap:8px}.checkbox-row input{accent-color:var(--blue-500);cursor:pointer;height:16px;width:16px}.link{color:var(--blue-500);font-size:13px;font-weight:600;text-decoration:none;transition:color .15s}.link:hover{color:var(--blue-700);text-decoration:underline}.auth-foot{color:#9ca3af;font-size:12.5px;line-height:1.6;margin-top:18px;text-align:center}.alert{align-items:flex-start;animation:fadeUp .25s ease;border-radius:10px;display:flex;font-size:13px;font-weight:500;gap:8px;margin-bottom:16px;padding:12px 14px}.alert-error{background:var(--bad-bg);border:1px solid #dc262633;color:var(--bad)}.alert-success{background:var(--good-bg);border:1px solid #16a34a33;color:var(--good)}.alert-info{background:var(--blue-50);border:1px solid #1c5cff33;color:var(--blue-700)}.alert-icon{flex-shrink:0;font-size:16px;margin-top:1px}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.otp-row{display:flex;gap:8px;justify-content:center;margin:12px 0}.otp-input{-webkit-text-fill-color:var(--blue-500)!important;background:#fff;border:1px solid var(--border-strong);border-radius:12px;-webkit-box-shadow:inset 0 0 0 1000px #fff!important;caret-color:var(--blue-500);color:var(--blue-500);font-family:var(--font);font-size:22px;font-weight:800;height:54px;outline:none;text-align:center;transition:background .15s,border-color .15s,box-shadow .15s,color .15s;width:46px}.otp-input:focus{border-color:var(--blue-500);border-width:1.5px;box-shadow:0 0 0 4px #1c5cff1a}.otp-input:placeholder-shown{background:var(--paper-soft);-webkit-box-shadow:0 0 0 1000px var(--paper-soft) inset!important}.otp-input.error{-webkit-text-fill-color:var(--bad)!important;background:var(--bad-bg);border-color:var(--bad);-webkit-box-shadow:0 0 0 1000px var(--bad-bg) inset!important;color:var(--bad)}.otp-resend{margin-top:12px;text-align:center}.otp-resend-btn{background:none;border:none;color:var(--blue-500);cursor:pointer;font-family:var(--font);font-size:13px;font-weight:600}.otp-resend-btn:hover{color:var(--blue-700);text-decoration:underline}.otp-resend-btn:disabled{color:#9ca3af;cursor:not-allowed;text-decoration:none}.step-pills{display:flex;gap:5px;margin-bottom:24px}.step-pill{background:var(--paper-line);border-radius:3px;flex:1 1;height:4px;transition:all .2s}.step-pill.active,.step-pill.done{background:var(--blue-500)}.success-circle{align-items:center;animation:pop .4s cubic-bezier(.175,.885,.32,1.275);background:var(--good-bg);border-radius:50%;color:var(--good);display:flex;font-size:36px;height:72px;justify-content:center;margin:0 auto 20px;width:72px}@keyframes pop{0%{transform:scale(0)}to{transform:scale(1)}}.back-btn{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:inline-flex;font-family:var(--font);font-size:13px;font-weight:500;gap:5px;margin-bottom:18px;padding:0;transition:color .15s}.back-btn:hover{color:var(--blue-500)}@media (min-width:1024px){.auth-form-panel{padding:40px 24px}.auth-form-wrap{max-width:440px;padding:32px 28px}}@media (max-width:380px){.auth-form-panel{padding:16px 14px}.auth-form-wrap{padding:20px 16px}.auth-heading h2{font-size:22px}.field-shell{height:46px}.btn-submit{font-size:14px;height:46px}.otp-input{font-size:18px;height:50px;width:40px}.otp-row{gap:5px}}@media (max-height:700px) and (max-width:1023px){.auth-form-panel{padding:10px 16px}.auth-form-wrap{padding:16px}.auth-brand-logo,.auth-mobile-logo{margin-bottom:14px}.auth-heading{margin-bottom:12px}.auth-heading h2{font-size:22px}.auth-form{gap:10px}.btn-submit{height:46px;margin-top:4px}.auth-foot{margin-top:12px}}@media (max-height:580px) and (max-width:1023px){.auth-form-wrap{padding:12px 16px}.auth-brand-logo,.auth-heading,.auth-mobile-logo{margin-bottom:10px}.auth-heading h2{font-size:20px}.auth-heading p{font-size:13px}.auth-form{gap:8px}.field-shell{height:44px}.btn-submit{font-size:14px;height:44px;margin-top:2px}.auth-foot{font-size:12px;margin-top:10px}.auth-hero-icon{font-size:20px;height:44px;margin-bottom:12px;width:44px}.otp-input{font-size:18px;height:46px;width:38px}}:root{--card:var(--surface);--green:var(--blue-500);--green2:var(--blue-700);--green3:var(--blue-50);--green4:var(--blue-100);--dark:var(--ink-900);--red:var(--bad);--redbg:var(--bad-bg);--yellow:var(--lime-600);--yellowbg:var(--lime-50);--text2:var(--text-muted);--text3:var(--text-light);--sh:var(--shadow-xs);--sh2:var(--shadow);--tr:all 0.18s ease}.dash{background:var(--bg);display:flex;flex-direction:column;font-family:var(--font);height:100vh;overflow:hidden}.nav{background:var(--surface);background:var(--card);border-bottom:1px solid var(--border);box-shadow:var(--shadow-xs);box-shadow:var(--sh);flex-shrink:0;height:50px;justify-content:space-between;padding:0 14px;z-index:50}.nav,.nav-left{align-items:center;display:flex}.nav-left{gap:8px}.nav-logo{align-items:center;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));background:linear-gradient(135deg,var(--green),var(--green2));border-radius:8px;display:flex;font-size:14px;height:30px;justify-content:center;width:30px}.nav-title{color:var(--text);font-size:14px;font-weight:800}.nav-right{align-items:center;display:flex;gap:6px}.nav-tabs{background:#f5f6f9;border-radius:8px;display:flex;gap:1px;padding:2px}.nav-tab{background:#0000;border:none;border-radius:6px;color:var(--text-light);color:var(--text3);cursor:pointer;font-family:var(--font);font-size:11.5px;font-weight:600;padding:5px 12px;position:relative;transition:all .18s ease;transition:var(--tr);white-space:nowrap}.nav-tab.active{background:var(--surface);background:var(--card);box-shadow:var(--shadow-xs);box-shadow:var(--sh);color:var(--text)}.nav-badge{background:var(--bad);background:var(--red);border-radius:10px;color:#fff;font-size:8px;font-weight:700;line-height:14px;padding:0 4px;position:absolute;right:-3px;top:-3px}.btn{background:var(--surface);background:var(--card);border:1.5px solid var(--border);border-radius:8px;color:var(--text-muted);color:var(--text2);display:flex;font-size:11px;gap:3px;padding:5px 10px;transition:all .18s ease;transition:var(--tr)}.btn:hover{color:var(--blue-500);color:var(--green)}.btn.g,.btn:hover{border-color:var(--green)}.btn.g{background:var(--blue-500);background:var(--green);color:#fff}.btn.g:hover{background:var(--blue-700);background:var(--green2)}.btn.r:hover{background:var(--bad-bg);background:var(--redbg);border-color:var(--red);color:var(--bad);color:var(--red)}.nav-avatar{align-items:center;background:var(--ink-900);background:var(--dark);border-radius:8px;color:#fff;display:flex;font-size:10px;font-weight:700;height:28px;justify-content:center;width:28px}.hamburger{background:none;border:none;color:var(--text-muted);color:var(--text2);cursor:pointer;display:flex;font-size:20px;padding:2px}.dash-body{display:flex;flex:1 1;overflow:hidden;position:relative}.sidebar-overlay{background:#0000004d;inset:0;position:absolute;z-index:90}.sidebar{background:var(--surface);background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;width:240px;z-index:95}.sidebar.mobile{bottom:0;box-shadow:4px 0 20px #0000001a;left:0;max-width:280px;position:absolute;top:0;width:80%}.sidebar-head{border-bottom:1px solid #f5f6f9;padding:12px 12px 8px}.sidebar-head-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.sidebar-head h3{color:var(--text);font-size:13px;font-weight:800;margin:0}.sidebar-count{background:var(--blue-50);background:var(--green3);border-radius:10px;color:var(--blue-500);color:var(--green);font-size:10px;font-weight:700;padding:2px 8px}.sidebar-search{margin-bottom:6px;position:relative}.sidebar-search input{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-family:var(--font);font-size:12px;outline:none;padding:7px 8px 7px 28px;transition:all .18s ease;transition:var(--tr);width:100%}.sidebar-search input:focus{background:var(--surface);background:var(--card);border-color:var(--green)}.sidebar-search-icon{color:var(--text-light);color:var(--text3);display:flex;font-size:13px;left:9px;position:absolute;top:50%;transform:translateY(-50%)}.sidebar-list{flex:1 1;overflow-y:auto;padding:4px}.sidebar-item{align-items:center;background:#0000;border:1.5px solid #0000;border-radius:9px;cursor:pointer;display:flex;font-family:var(--font);gap:9px;margin-bottom:2px;padding:8px;text-align:left;transition:all .18s ease;transition:var(--tr);width:100%}.sidebar-item:hover{background:var(--bg)}.sidebar-item.active{background:var(--blue-50);background:var(--green3);border-color:var(--green)}.sidebar-avatar{align-items:center;border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-size:10px;font-weight:700;height:30px;justify-content:center;width:30px}.sidebar-name{color:var(--text);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-sub{color:var(--text-light);color:var(--text3);font-size:9.5px}.sidebar-stat{flex-shrink:0;text-align:right}.sidebar-hrs{font-size:10.5px;font-weight:700}.sidebar-pay{color:var(--blue-500);color:var(--green);font-size:9px}.sidebar-footer{border-top:1px solid #f5f6f9;padding:8px}.main{display:flex;flex:1 1;flex-direction:column;min-width:0;overflow:hidden}.cal-head{background:var(--surface);background:var(--card);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap;justify-content:space-between;padding:8px 14px}.cal-head,.cal-nav{gap:6px}.cal-arrow,.cal-head,.cal-nav{align-items:center;display:flex}.cal-arrow{background:var(--surface);background:var(--card);border:1.5px solid var(--border);border-radius:6px;color:var(--text-muted);color:var(--text2);cursor:pointer;font-size:13px;height:26px;justify-content:center;transition:all .18s ease;transition:var(--tr);width:26px}.cal-arrow:hover{border-color:var(--green);color:var(--blue-500);color:var(--green)}.cal-title{color:var(--text);font-size:13px;font-weight:700}.cal-subtitle{color:var(--text-light);color:var(--text3);font-size:10px}.cal-stats{background:var(--blue-50);background:var(--green3);border:1px solid var(--green4);border-radius:8px;display:flex;gap:12px;padding:5px 12px}.cal-stat{text-align:center}.cal-stat-val{color:var(--text);font-size:13px;font-weight:800}.cal-stat-val.g{color:var(--blue-500);color:var(--green)}.cal-stat-label{color:var(--text-light);color:var(--text3);font-size:7.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.cal-wrap{-webkit-overflow-scrolling:touch;flex:1 1;overflow:auto}.cal-table{border-collapse:collapse;table-layout:fixed;width:100%}.cal-table th{background:var(--bg);border-bottom:2px solid var(--border);font-size:10px;padding:6px 3px;position:sticky;text-align:center;top:0;z-index:10}.cal-table th.ec{border-right:1px solid #f5f6f9;text-align:left;z-index:15}.cal-dn{color:var(--text-light);color:var(--text3);font-size:8.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.cal-dd{color:var(--text);font-size:14px;font-weight:700;margin-top:1px}.cal-dd.today{align-items:center;background:var(--blue-50);background:var(--green3);border-radius:6px;color:var(--blue-500);color:var(--green);display:inline-flex;height:26px;justify-content:center;width:26px}.cal-table td{border-bottom:1px solid #f5f6f9;cursor:pointer;height:1px;padding:2px;transition:background .1s;vertical-align:top}.cal-table td:hover{background:var(--blue-50);background:var(--green3)}.cal-table td.wk{background:#f7f8fb}.cal-table td.ec{border-right:1px solid #f5f6f9;cursor:default;left:0;padding:4px 5px;position:sticky;z-index:5}.cal-table td.ec,.cal-table td.ec:hover{background:var(--surface);background:var(--card)}.shift-block{border-left:3px solid;border-radius:6px;box-sizing:border-box;min-height:52px;padding:4px 6px}.shift-time{font-size:10px;font-weight:600}.shift-hrs{color:var(--text-muted);color:var(--text2);font-size:9px;margin-top:1px}.shift-pay{font-size:8.5px;font-weight:600;margin-top:1px}.shift-empty{align-items:center;border:1.5px dashed #d5d8e0;border-radius:6px;box-sizing:border-box;color:#e5e7ed;display:flex;font-size:16px;height:100%;justify-content:center;min-height:52px;transition:all .18s ease;transition:var(--tr)}.shift-empty:hover{background:var(--blue-50);background:var(--green3);border-color:var(--green);color:var(--blue-500);color:var(--green)}.ce{gap:5px}.ce,.ce-a{align-items:center;display:flex}.ce-a{border-radius:6px;color:#fff;flex-shrink:0;font-size:8px;font-weight:700;height:22px;justify-content:center;width:22px}.ce-n{color:var(--text);font-size:10.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ce-r{color:var(--text-light);color:var(--text3);font-size:8.5px}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a80;bottom:0!important;box-sizing:border-box;height:100vh;left:0!important;right:0!important;top:0!important;width:100vw;z-index:200}.modal-overlay.mob{padding:16px}.modal{animation:mIn .2s ease;background:var(--card);box-shadow:0 20px 60px #0f172a33;padding:24px;width:90%}.modal,.modal.mob{border-radius:16px;max-height:90vh;max-width:400px}.modal.mob{width:92%}@keyframes mIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.modal-head{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:18px}.modal-title{font-size:17px}.modal-desc{font-size:11.5px;margin-top:2px}.modal-close,.modal-desc{color:var(--text-light);color:var(--text3)}.modal-close{align-items:center;background:#f5f6f9;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;height:30px;justify-content:center;transition:all .18s ease;transition:var(--tr);width:30px}.modal-close:hover{background:var(--bad-bg);background:var(--redbg);color:var(--bad);color:var(--red)}.field{margin-bottom:12px}.field label{color:var(--text-muted);color:var(--text2);display:block;font-size:11.5px;font-weight:600;margin-bottom:4px}.field input,.field select{background:var(--surface);background:var(--card);border:1.5px solid var(--border);border-radius:9px;color:var(--text);font-family:var(--font);font-size:13.5px;outline:none;padding:9px 11px;transition:all .18s ease;transition:var(--tr);width:100%}.field input:focus,.field select:focus{border-color:var(--green);box-shadow:0 0 0 3px #2563eb14}.shift-box{background:var(--blue-50);background:var(--green3);border:1px solid var(--green4);border-radius:12px;margin-bottom:14px;padding:14px}.shift-box-title{color:var(--blue-500);color:var(--green);font-size:11px;font-weight:700;letter-spacing:.04em;margin-bottom:10px;text-transform:uppercase}.shift-box-row{display:flex;gap:12px}.shift-box-calc{align-items:center;background:var(--surface);background:var(--card);border:1px solid var(--border);border-radius:8px;display:flex;justify-content:space-between;margin-top:10px;padding:9px 12px}.shift-box-hrs{color:var(--text-muted);color:var(--text2);font-size:12px;font-weight:600}.shift-box-pay{color:var(--blue-500);color:var(--green);font-size:15px;font-weight:800}.btn-row{display:flex;gap:8px;margin-top:4px}.btn-del{background:var(--bad-bg);background:var(--redbg);border:1.5px solid #fee2e2;border-radius:9px;color:var(--bad);color:var(--red);cursor:pointer;flex:1 1;font-family:var(--font);font-size:12.5px;font-weight:600;padding:10px;transition:all .18s ease;transition:var(--tr)}.btn-del:hover{background:var(--bad);background:var(--red);color:#fff}.btn-save{background:var(--blue-500);background:var(--green);border:none;border-radius:9px;color:#fff;cursor:pointer;flex:2 1;font-family:var(--font);font-size:13px;font-weight:600;padding:10px;transition:all .18s ease;transition:var(--tr)}.btn-save:hover{background:var(--blue-700);background:var(--green2)}.btn-del:disabled,.btn-save:disabled{cursor:not-allowed;opacity:.45}.emp-section{flex:1 1;overflow:auto;padding:16px}.emp-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.emp-card{align-items:center;background:var(--surface);background:var(--card);border:1.5px solid var(--border);border-radius:12px;display:flex;gap:12px;padding:14px;transition:all .18s ease;transition:var(--tr)}.emp-card:hover{box-shadow:var(--shadow);box-shadow:var(--sh2)}.emp-card.off{opacity:.5}.emp-card-avatar{align-items:center;border-radius:9px;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:38px;justify-content:center;width:38px}.emp-card-info{flex:1 1;min-width:0}.emp-card-name{color:var(--text);font-size:13.5px;font-weight:700}.emp-card-rate{color:var(--blue-500);color:var(--green);font-size:11.5px;font-weight:600}.emp-card-status{border-radius:10px;font-size:9.5px;font-weight:600;padding:2px 8px}.emp-card-status.on{background:var(--blue-50);background:var(--green3);color:var(--blue-500);color:var(--green)}.emp-card-status.off{background:var(--bad-bg);background:var(--redbg);color:var(--bad);color:var(--red)}.emp-card-actions{display:flex;flex-shrink:0;gap:3px}.emp-card-btn{align-items:center;background:var(--surface);background:var(--card);border:1.5px solid var(--border);border-radius:6px;cursor:pointer;display:flex;font-family:var(--font);font-size:12px;padding:5px 8px;transition:all .18s ease;transition:var(--tr)}.emp-card-btn:hover{border-color:var(--green);color:var(--blue-500);color:var(--green)}.emp-card-btn.r:hover{background:var(--bad-bg);background:var(--redbg);border-color:var(--red);color:var(--bad);color:var(--red)}.user-section{flex:1 1;overflow:auto;padding:16px}.user-card{background:var(--surface);background:var(--card);border:1.5px solid var(--border);border-radius:10px;justify-content:space-between;margin-bottom:8px;padding:12px 16px}.user-card,.user-left{align-items:center;display:flex;gap:10px}.user-left{flex:1 1;min-width:0}.user-av{align-items:center;border-radius:9px;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:34px;justify-content:center;width:34px}.user-av.p{background:linear-gradient(135deg,#b0ff3d,#9bf213)}.user-av.a{background:linear-gradient(135deg,#3b7bff,#1c5cff)}.user-name{color:var(--text);font-size:12.5px;font-weight:600}.user-email,.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{color:var(--text-light);color:var(--text3);font-size:10.5px}.user-right{align-items:center;display:flex;flex-shrink:0;flex-wrap:wrap;gap:5px}.tag{border-radius:20px;font-size:10px;font-weight:600;padding:3px 9px}.tag.p{background:var(--lime-50);background:var(--yellowbg);color:var(--lime-600);color:var(--yellow)}.tag.a{background:var(--blue-50);background:var(--green3);color:var(--blue-500);color:var(--green)}.tag.d{background:var(--bad-bg);background:var(--redbg);color:var(--bad);color:var(--red)}.abtn{border:none;border-radius:7px;cursor:pointer;font-family:var(--font);font-size:11px;font-weight:600;padding:5px 10px;transition:all .18s ease;transition:var(--tr)}.abtn.ap{background:var(--blue-500);background:var(--green);color:#fff}.abtn.ap:hover{background:var(--blue-700);background:var(--green2)}.abtn.rj{background:var(--surface);background:var(--card);border:1.5px solid var(--border);color:var(--bad);color:var(--red)}.abtn.rj:hover{background:var(--bad-bg);background:var(--redbg);border-color:var(--red)}.abtn:disabled{cursor:not-allowed;opacity:.4}.sal-table{background:var(--surface);background:var(--card);border-collapse:collapse;border-radius:10px;box-shadow:var(--shadow-xs);box-shadow:var(--sh);overflow:hidden;width:100%}.sal-table thead th{background:var(--ink-900);background:var(--dark);color:#fff;font-size:11px;font-weight:600;padding:10px 12px}.sal-table tbody td{border-bottom:1px solid #f5f6f9;font-size:12px;padding:10px 12px}.sal-table tbody tr:nth-child(2n){background:#f7f8fb}.empty{padding:40px 20px}.empty-icon{font-size:36px;margin-bottom:10px;opacity:.35}.empty h3{color:var(--text-muted);color:var(--text2);font-size:15px;font-weight:600;margin-bottom:3px}.empty p{color:var(--text-light);color:var(--text3);font-size:12.5px}.loading{align-items:center;background:var(--bg);display:flex;justify-content:center;min-height:100vh}.loading-spinner{animation:spin .5s linear infinite;border:3px solid #f5f6f9;border-radius:50%;border-top:3px solid var(--green);height:28px;width:28px}.confirm-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0f172a8c;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:300}.confirm-box{animation:mIn .2s ease;background:var(--surface);background:var(--card);border-radius:16px;box-shadow:0 20px 60px #0f172a40;max-width:360px;padding:28px;text-align:center;width:90%}.confirm-icon{font-size:44px;margin-bottom:12px}.confirm-title{color:var(--text);font-size:17px;font-weight:800;margin-bottom:6px}.confirm-desc{color:var(--text-light);color:var(--text3);font-size:13px;line-height:1.5;margin-bottom:20px}.confirm-btns{display:flex;gap:10px}.confirm-btns button{border-radius:9px;cursor:pointer;flex:1 1;font-family:var(--font);font-size:13px;font-weight:600;padding:10px;transition:all .18s ease;transition:var(--tr)}.confirm-cancel{background:var(--bg);border:1.5px solid var(--border);color:var(--text-muted);color:var(--text2)}.confirm-cancel:hover{background:#f5f6f9}.confirm-ok{background:var(--bad);background:var(--red);border:none;color:#fff}.confirm-ok:hover{background:#b91c1c}@media(max-width:767px){.nav{height:46px;padding:0 8px}.nav-title{display:none}.nav-tab{font-size:10.5px;padding:4px 8px}.cal-head{padding:6px 8px}.cal-title{font-size:11.5px}.cal-table th.ec{width:130px}.cal-table td.ec{min-width:130px}.ce-n{font-size:11px;max-width:100px}.cal-table{min-width:560px}.emp-grid{grid-template-columns:1fr}.user-card{align-items:flex-start;flex-direction:column}.user-right{margin-top:6px;width:100%}.abtn{flex:1 1;text-align:center}.sal-table{min-width:420px}.shift-time{font-size:9px}.shift-hrs,.shift-pay{font-size:8px}.shift-box-row{flex-direction:column;gap:10px}.nav-right .btn:not(.r):not(.g){display:none}}.cal-table td>.shift-empty{height:100%;min-height:52px}:root{--ink-950:#050507;--ink-900:#0b0d12;--ink-800:#14171f;--ink-700:#1e2230;--ink-600:#2a2f3f;--ink-500:#3d4356;--ink-400:#5a6275;--ink-300:#8a93a6;--ink-200:#b9bfcc;--ink-100:#e2e5ec;--ink-50:#f5f6f9;--paper:#fff;--paper-soft:#f7f8fb;--paper-line:#e5e7ed;--paper-line-2:#d5d8e0;--blue-50:#e7f0ff;--blue-100:#cee0ff;--blue-200:#a3c4ff;--blue-300:#6e9eff;--blue-400:#3b7bff;--blue-500:#1c5cff;--blue-600:#0040e0;--blue-700:#0030b8;--blue-800:#002590;--blue-glow:#1c5cff59;--lime-50:#f3ffe1;--lime-100:#e0ffb4;--lime-200:#c8ff7a;--lime-300:#b0ff3d;--lime-400:#9bf213;--lime-500:#82d600;--lime-600:#6aae00;--lime-700:#517f00;--lime-glow:#9bf21366;--good:#16a34a;--good-bg:#dcfce7;--bad:#dc2626;--bad-bg:#fee2e2;--warn:#f59e0b;--warn-bg:#fef3c7;--bg:var(--paper-soft);--surface:var(--paper);--surface-soft:var(--paper-soft);--border:var(--paper-line);--border-strong:var(--paper-line-2);--text:var(--ink-900);--text-muted:var(--ink-400);--text-light:var(--ink-300);--shadow-xs:0 1px 2px #0b0d120a;--shadow-sm:0 2px 4px #0b0d120f;--shadow:0 4px 12px #0b0d1214;--shadow-md:0 10px 24px #0b0d121a;--shadow-lg:0 20px 40px #0b0d1224;--ring-blue:0 0 0 4px #1c5cff2e;--r-sm:8px;--r:12px;--r-md:16px;--r-lg:22px;--font:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}*{box-sizing:border-box}#root,body,html{margin:0;min-height:100vh;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f7f8fb;background:var(--bg);color:#0b0d12;color:var(--text)}.btn,body{font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font)}.btn{--btn-bg:#0000;--btn-fg:var(--text);--btn-bd:var(--border-strong);--btn-hover-bg:var(--ink-900);--btn-hover-fg:#fff;--btn-hover-bd:var(--ink-900);align-items:center;background:var(--btn-bg);border:1.5px solid var(--btn-bd);border-radius:12px;border-radius:var(--r);color:var(--btn-fg);cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;letter-spacing:-.005em;padding:10px 18px;text-decoration:none;transition:background .18s,color .18s,border-color .18s,transform .1s,box-shadow .18s;-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:hover:not(:disabled){background:var(--btn-hover-bg);border-color:var(--btn-hover-bd);color:var(--btn-hover-fg)}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{cursor:not-allowed;opacity:.5}.btn:focus-visible{box-shadow:0 0 0 4px #1c5cff2e;box-shadow:var(--ring-blue);outline:none}.btn-primary{--btn-bg:var(--blue-500);--btn-fg:#fff;--btn-bd:var(--blue-500);--btn-hover-bg:var(--blue-700);--btn-hover-fg:#fff;--btn-hover-bd:var(--blue-700)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 14px #1c5cff59;box-shadow:0 4px 14px var(--blue-glow)}.btn-accent{--btn-bg:var(--lime-400);--btn-fg:var(--ink-900);--btn-bd:var(--lime-400);--btn-hover-bg:var(--lime-500);--btn-hover-fg:var(--ink-900);--btn-hover-bd:var(--lime-500)}.btn-accent:hover:not(:disabled){box-shadow:0 4px 14px #9bf21366;box-shadow:0 4px 14px var(--lime-glow)}.btn-outline{--btn-bg:#0000;--btn-fg:var(--text);--btn-bd:var(--border-strong);--btn-hover-bg:var(--ink-900);--btn-hover-fg:#fff;--btn-hover-bd:var(--ink-900)}.btn-outline-blue{--btn-bg:#0000;--btn-fg:var(--blue-500);--btn-bd:var(--blue-500);--btn-hover-bg:var(--blue-500);--btn-hover-fg:#fff;--btn-hover-bd:var(--blue-500)}.btn-outline-lime{--btn-bg:#0000;--btn-fg:var(--lime-700);--btn-bd:var(--lime-400);--btn-hover-bg:var(--lime-400);--btn-hover-fg:var(--ink-900);--btn-hover-bd:var(--lime-400)}.btn-ghost{--btn-bg:#0000;--btn-fg:var(--text-muted);--btn-bd:#0000;--btn-hover-bg:var(--paper-soft);--btn-hover-fg:var(--text);--btn-hover-bd:var(--border)}.btn-danger{--btn-bg:#0000;--btn-fg:var(--bad);--btn-bd:var(--bad);--btn-hover-bg:var(--bad);--btn-hover-fg:#fff;--btn-hover-bd:var(--bad)}.btn-warn{--btn-bg:#0000;--btn-fg:var(--warn);--btn-bd:var(--warn);--btn-hover-bg:var(--warn);--btn-hover-fg:#fff;--btn-hover-bd:var(--warn)}.btn-sm{border-radius:9px;font-size:13px;padding:7px 13px}.btn-lg{font-size:15px;padding:13px 24px}.btn-block{width:100%}.form-input,.input{background:#fff;background:var(--surface);border:1.5px solid #d5d8e0;border:1.5px solid var(--border-strong);border-radius:12px;border-radius:var(--r);color:#0b0d12;color:var(--text);font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font);font-size:14.5px;outline:none;padding:12px 14px;transition:border-color .15s,box-shadow .15s;width:100%}.form-input::placeholder,.input::placeholder{color:#8a93a6;color:var(--text-light)}.form-input:hover:not(:focus),.input:hover:not(:focus){border-color:#5a6275;border-color:var(--ink-400)}.form-input:focus,.input:focus{border-color:#1c5cff;border-color:var(--blue-500);box-shadow:0 0 0 4px #1c5cff2e;box-shadow:var(--ring-blue)}select.input{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a6275' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;cursor:pointer;padding-right:38px}.label{color:#0b0d12;color:var(--text);display:block;font-size:13px;font-weight:600;letter-spacing:-.005em;margin-bottom:6px}.field-shell{align-items:center;background:#fff;background:var(--surface);border:1.5px solid #d5d8e0;border:1.5px solid var(--border-strong);border-radius:12px;border-radius:var(--r);display:flex;position:relative;transition:border-color .15s,box-shadow .15s,background .15s}.field-shell:hover:not(:focus-within){border-color:#5a6275;border-color:var(--ink-400)}.field-shell:focus-within{border-color:#1c5cff;border-color:var(--blue-500);box-shadow:0 0 0 4px #1c5cff2e;box-shadow:var(--ring-blue)}.field-shell.error{background:#fee2e2;background:var(--bad-bg);border-color:#dc2626;border-color:var(--bad)}.field-shell-icon{align-items:center;color:#8a93a6;color:var(--text-light);display:flex;flex-shrink:0;font-size:18px;height:48px;justify-content:center;pointer-events:none;width:44px}.field-shell:focus-within .field-shell-icon{color:#1c5cff;color:var(--blue-500)}.field-shell input,.field-shell select{background:#0000;border:none;color:#0b0d12;color:var(--text);flex:1 1;font-family:Plus Jakarta Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font);font-size:14.5px;height:48px;min-width:0;outline:none;padding:0 4px 0 0;width:100%}.field-shell input::placeholder,.field-shell-action{color:#8a93a6;color:var(--text-light)}.field-shell-action{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:48px;justify-content:center;transition:color .15s;width:44px}.field-shell-action:hover{color:#1c5cff;color:var(--blue-500)}.card{background:#fff;background:var(--surface);border:1px solid #e5e7ed;border:1px solid var(--border);border-radius:16px;border-radius:var(--r-md);box-shadow:0 1px 2px #0b0d120a;box-shadow:var(--shadow-xs);padding:24px}.page{background:#f7f8fb;background:var(--bg);min-height:100vh;padding:28px 24px}.page-container{margin:0 auto;max-width:1280px}.page-header{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.page-title{color:#0b0d12;color:var(--text);font-size:26px;font-weight:800;letter-spacing:-.025em;line-height:1.15;margin:0}.page-subtitle{color:#5a6275;color:var(--text-muted);font-size:14px;margin:4px 0 0}.topbar{background:#fff;background:var(--surface);border-bottom:1px solid #e5e7ed;border-bottom:1px solid var(--border);box-shadow:0 1px 2px #0b0d120a;box-shadow:var(--shadow-xs);gap:12px;justify-content:space-between;padding:14px 24px;position:sticky;top:0;z-index:50}.topbar,.topbar-left{align-items:center;display:flex}.topbar-left{gap:16px;min-width:0}.topbar-brand{color:#0b0d12;color:var(--text);font-size:15px;gap:10px;letter-spacing:-.015em;text-decoration:none}.topbar-brand,.topbar-brand-mark{align-items:center;display:flex;font-weight:800}.topbar-brand-mark{background:#0b0d12;background:var(--ink-900);border-radius:10px;color:#9bf213;color:var(--lime-400);flex-shrink:0;font-size:13px;height:36px;justify-content:center;letter-spacing:-.02em;width:36px}.topbar-rest-pill,.topbar-right{align-items:center;display:flex;gap:8px}.topbar-rest-pill{background:#f7f8fb;background:var(--paper-soft);border:1.5px solid #e5e7ed;border:1.5px solid var(--border);border-radius:999px;color:#0b0d12;color:var(--text);cursor:pointer;font-size:13px;font-weight:600;max-width:220px;padding:5px 12px 5px 5px;transition:border-color .15s,background .15s}.topbar-rest-pill:hover{background:#e7f0ff;background:var(--blue-50);border-color:#6e9eff;border-color:var(--blue-300)}.topbar-rest-pill img{border-radius:7px;height:26px;object-fit:cover;width:26px}.topbar-rest-pill-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chip{align-items:center;background:#f7f8fb;background:var(--paper-soft);border:1.5px solid #e5e7ed;border:1.5px solid var(--border);border-radius:999px;cursor:pointer;display:flex;gap:10px;padding:4px 12px 4px 4px;transition:border-color .15s}.user-chip:hover{border-color:#5a6275;border-color:var(--ink-400)}.user-chip-avatar{align-items:center;background:#0b0d12;background:var(--ink-900);border-radius:50%;color:#9bf213;color:var(--lime-400);display:flex;flex-shrink:0;font-size:12px;font-weight:800;height:32px;justify-content:center;width:32px}.user-chip-name{font-size:13px;font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chip-role{color:#5a6275;color:var(--text-muted);font-size:10px;letter-spacing:.6px;margin-top:-1px}.pill,.user-chip-role{font-weight:700;text-transform:uppercase}.pill{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;letter-spacing:.02em;padding:3px 10px}.pill-success{background:#dcfce7;background:var(--good-bg);color:#16a34a;color:var(--good)}.pill-warning{background:#fef3c7;background:var(--warn-bg);color:#f59e0b;color:var(--warn)}.pill-danger{background:#fee2e2;background:var(--bad-bg);color:#dc2626;color:var(--bad)}.pill-blue{background:#e7f0ff;background:var(--blue-50);color:#0030b8;color:var(--blue-700)}.pill-lime{background:#e0ffb4;background:var(--lime-100);color:#517f00;color:var(--lime-700)}.pill-dark{background:#0b0d12;background:var(--ink-900);color:#9bf213;color:var(--lime-400)}.role-chip{align-items:center;border-radius:6px;display:inline-flex;font-size:10.5px;font-weight:700;letter-spacing:.04em;padding:2px 8px;text-transform:uppercase}.role-chip.role-owner{background:#0b0d12;background:var(--ink-900);color:#9bf213;color:var(--lime-400)}.role-chip.role-manager{background:#cee0ff;background:var(--blue-100);color:#0030b8;color:var(--blue-700)}.role-chip.role-employee{background:#f7f8fb;background:var(--paper-soft);border:1px solid #e5e7ed;border:1px solid var(--border)}.empty,.role-chip.role-employee{color:#5a6275;color:var(--text-muted)}.empty{padding:56px 20px;text-align:center}.empty-icon{font-size:56px;margin-bottom:16px;opacity:.5}.empty-title{color:#0b0d12;color:var(--text);font-size:18px;font-weight:700;margin-bottom:8px}.empty-text{color:#5a6275;color:var(--text-muted);font-size:14px}.modal-overlay{align-items:center;animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0b0d1299;display:flex;inset:0;justify-content:center;overflow-y:auto;padding:16px;position:fixed;z-index:100}.modal{animation:slideUp .25s cubic-bezier(.34,1.36,.64,1);background:#fff;background:var(--surface);border-radius:22px;border-radius:var(--r-lg);box-shadow:0 20px 40px #0b0d1224;box-shadow:var(--shadow-lg);max-height:calc(100vh - 32px);max-width:460px;overflow-y:auto;padding:26px;width:100%}.modal-title{color:#0b0d12;color:var(--text);font-size:19px;font-weight:800;letter-spacing:-.02em;margin:0 0 6px}.modal-text{color:#5a6275;color:var(--text-muted);font-size:14px;line-height:1.5;margin:0 0 20px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.grid{grid-gap:16px;display:grid;gap:16px}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.user-row{align-items:center;display:flex;gap:14px;padding:14px 18px}.user-row-actions{display:flex;flex-shrink:0;gap:6px}@media (max-width:1024px){.topbar-rest-pill{max-width:160px}}@media (max-width:768px){.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}.page{padding:16px 12px}.page-title{font-size:22px}.page-header{gap:12px;margin-bottom:18px}.topbar{gap:8px;padding:10px 12px}.topbar-brand-text{display:none}.topbar-rest-pill{font-size:12px;max-width:130px;padding:4px 10px 4px 4px}.topbar-rest-pill img{height:22px;width:22px}.user-chip-name,.user-chip-role{display:none}.user-chip{padding:3px}.modal{border-radius:18px;padding:20px}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}.btn{font-size:13.5px;padding:9px 15px}.btn-sm{font-size:12.5px;padding:6px 11px}.card{border-radius:14px;padding:18px}.user-row{flex-wrap:wrap;gap:10px;padding:12px}.user-row-actions{justify-content:flex-end;width:100%}}@media (max-width:380px){.page{padding:12px 8px}.topbar{padding:8px 10px}.topbar-rest-pill{font-size:11px;max-width:100px}.modal{padding:16px}}
/*# sourceMappingURL=main.144e8266.css.map*/