:root{--primary: #2563EB;--primary-dark: #1D4ED8;--primary-mid: rgba(37,99,235,.12);--primary-light: rgba(37,99,235,.06);--blue: #2563EB;--violet: #6366F1;--amber: #D97706;--rose: #E11D48;--red: #DC2626;--emerald: #059669;--cyan: #0284C7;--pink: #DB2777;--bg: #EEF2F7;--surface: #FFFFFF;--surface-2: #F8FAFC;--glass: #FFFFFF;--glass-2: #F8FAFC;--glass-3: #F1F5F9;--border: #E2E8F0;--border-soft: #F1F5F9;--border-hi: #CBD5E1;--text-1: #0F172A;--text-2: #334155;--text-3: #64748B;--text-4: #94A3B8;--blue-g: rgba(37,99,235,.08);--violet-g: rgba(99,102,241,.08);--amber-g: rgba(217,119,6,.08);--rose-g: rgba(225,29,72,.08);--cyan-g: rgba(2,132,199,.08);--bg-soft: #F8FAFC;--green: #2563EB;--green-dark: #1D4ED8;--green-deep: #1E40AF;--green-light: rgba(37,99,235,.08);--green-mid: rgba(37,99,235,.14);--green-faint: #F8FAFC;--green-pale: #F1F5F9;--orange: #D97706;--orange-dark: #B45309;--orange-light: rgba(217,119,6,.08);--orange-mid: rgba(217,119,6,.14);--forest: #0F172A;--forest-mid: #334155;--forest-soft: #475569;--forest-mute: #64748B;--forest-hint: #94A3B8;--white: #FFFFFF;--off-white: #F8FAFC;--red-light: rgba(220,38,38,.08);--blue-light: rgba(37,99,235,.08);--amber-light: rgba(217,119,6,.08);--org: #D97706;--sidebar-w: 260px;--header-h: 64px;--r: 12px;--r-sm: 8px;--r-md: 10px;--r-lg: 16px;--shadow: 0 1px 3px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 14px rgba(15,23,42,.09), 0 2px 4px rgba(15,23,42,.05);--shadow-lg: 0 10px 28px rgba(15,23,42,.11), 0 4px 8px rgba(15,23,42,.06)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:Inter,Plus Jakarta Sans,system-ui,sans-serif;background:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.6}h1,h2,h3,h4,h5{font-family:Plus Jakarta Sans,Inter,system-ui,sans-serif;line-height:1.25;letter-spacing:-.02em}button{font-family:Inter,sans-serif;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:Inter,sans-serif;outline:none;font-size:15px}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.app-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.4}.orb-1{width:700px;height:700px;background:radial-gradient(circle,#BFDBFE,transparent 65%);top:-250px;left:-180px}.orb-2{width:550px;height:550px;background:radial-gradient(circle,#C7D2FE,transparent 65%);top:-120px;right:-140px}.orb-3{width:450px;height:450px;background:radial-gradient(circle,#DDD6FE,transparent 65%);bottom:0;left:150px;opacity:.28}.orb-4{width:380px;height:380px;background:radial-gradient(circle,#FDE68A,transparent 65%);bottom:-80px;right:180px;opacity:.22}@keyframes drift{0%,to{transform:translate(0)}50%{transform:translate(20px,-14px)}}.dot-grid{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,rgba(37,99,235,.055) 1px,transparent 1px);background-size:28px 28px}.app-shell{display:flex;min-height:100vh;position:relative;z-index:1}.sidebar{width:var(--sidebar-w);background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;transition:transform .25s ease;overflow:hidden;box-shadow:2px 0 8px #0f172a0a}.sidebar:before,.sidebar:after{display:none}.sidebar-logo{padding:20px 22px 16px;border-bottom:1px solid var(--border)}.brand-row{display:flex;align-items:center;gap:12px}.brand-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#1d4ed8,#6366f1);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:800;color:#fff;font-size:16px;font-family:Plus Jakarta Sans,sans-serif;letter-spacing:-.03em;box-shadow:0 2px 8px #2563eb4d}.brand-bird{font-size:0}.brand-icon:after{content:"N";font-size:18px;font-weight:800;color:#fff;font-family:Plus Jakarta Sans,sans-serif}.brand-text .brand-name{font-family:Plus Jakarta Sans,sans-serif;font-weight:800;font-size:14px;letter-spacing:-.02em;color:var(--text-1)}.brand-text .brand-sub{font-size:11px;color:var(--text-4);font-weight:400;margin-top:1px}.sidebar-store{padding:10px 22px;border-bottom:1px solid var(--border)}.store-pill{display:inline-flex;align-items:center;gap:6px;background:var(--primary-light);border:1px solid rgba(37,99,235,.18);border-radius:20px;padding:5px 13px;font-size:12px;color:var(--primary);font-weight:600}.store-dot{width:6px;height:6px;border-radius:50%;background:var(--emerald)}.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.nav-group-label{padding:10px 22px 4px;font-size:10px;font-weight:700;color:var(--text-4);letter-spacing:.1em;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 22px;color:var(--text-3);cursor:pointer;transition:all .14s;font-size:14px;font-weight:500;margin:1px 10px;border-radius:8px;border-left:3px solid transparent}.nav-item:hover{background:var(--primary-light);color:var(--text-2)}.nav-item.active{background:var(--primary-light);color:var(--primary);border-left-color:var(--primary);font-weight:600}.nav-icon{font-size:17px;width:22px;text-align:center;flex-shrink:0}.nav-label{flex:1}.nav-badge{background:var(--amber);color:#fff;font-size:10px;font-weight:700;border-radius:10px;padding:2px 7px;min-width:18px;text-align:center}.sidebar-footer{padding:14px 22px;border-top:1px solid var(--border)}.user-row{display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,#6366f1);border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:12px;flex-shrink:0;box-shadow:0 2px 6px #2563eb40}.user-info .u-name{font-size:13px;color:var(--text-1);font-weight:600}.user-info .u-role{font-size:11px;color:var(--text-4);margin-top:1px}.logout-btn{margin-left:auto;width:28px;height:28px;background:#e11d480f;border-radius:7px;display:flex;align-items:center;justify-content:center;color:#e11d488c;font-size:13px;transition:all .14s;border:1px solid rgba(225,29,72,.12);cursor:pointer}.logout-btn:hover{background:#e11d481a;color:var(--rose)}.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}.page-header{background:#ffffffe6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 32px;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0f172a0d}.ph-left .ph-title{font-family:Plus Jakarta Sans,sans-serif;font-size:18px;font-weight:700;color:var(--text-1);letter-spacing:-.02em}.ph-left .ph-sub{font-size:12px;color:var(--text-4);margin-top:2px}.ph-right{display:flex;align-items:center;gap:12px}.ph-date{font-size:13px;color:var(--text-3)}.ph-green-dot{width:8px;height:8px;border-radius:50%;background:var(--emerald);animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #05966926}50%{box-shadow:0 0 0 6px #0596690d}}.page-body{padding:26px 32px;flex:1}.mobile-header{display:none;background:#fff;border-bottom:1px solid var(--border);padding:12px 18px;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200;box-shadow:var(--shadow)}.mobile-header .m-brand{display:flex;align-items:center;gap:10px}.mobile-header .m-icon{width:30px;height:30px;border-radius:8px;background:linear-gradient(135deg,#1d4ed8,#6366f1);display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;font-weight:800;font-family:Plus Jakarta Sans,sans-serif}.mobile-header .m-name{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;color:var(--text-1);font-size:16px}.hamburger{background:none;border:none;color:var(--text-3);font-size:22px;cursor:pointer;padding:2px}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:199;display:none}.sidebar-overlay.open{display:block}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);z-index:150;padding:6px 0 max(6px,env(safe-area-inset-bottom));box-shadow:0 -2px 12px #0f172a12}.bn-inner{display:flex;justify-content:space-around}.bn-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 14px;cursor:pointer;color:var(--text-4);transition:color .14s}.bn-item.active{color:var(--primary)}.bn-icon{font-size:21px}.bn-label{font-size:10px;font-weight:600}.card{background:#fff;border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--shadow);position:relative;overflow:hidden}.card:before{display:none}.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.card-title{font-family:Plus Jakarta Sans,sans-serif;font-size:15px;font-weight:700;color:var(--text-1);letter-spacing:-.01em}.card-body{padding:20px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:22px}.stat-card{background:#fff;border-radius:var(--r);border:1px solid var(--border);padding:20px;box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s;position:relative;overflow:hidden;cursor:default}.stat-card:before,.stat-card:after{display:none}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:19px;margin-bottom:14px}.si-green{background:#05966914;border:1px solid rgba(5,150,105,.18)}.si-orange{background:#d9770614;border:1px solid rgba(217,119,6,.18)}.si-red{background:#dc262614;border:1px solid rgba(220,38,38,.18)}.si-blue{background:#2563eb14;border:1px solid rgba(37,99,235,.18)}.si-amber{background:#d9770614;border:1px solid rgba(217,119,6,.18)}.stat-value{font-family:Plus Jakarta Sans,sans-serif;font-size:28px;font-weight:800;color:var(--text-1);line-height:1;letter-spacing:-.03em}.stat-label{font-size:12px;color:var(--text-3);margin-top:5px;font-weight:500}.stat-trend{font-size:12px;margin-top:6px;font-weight:600}.trend-up{color:var(--emerald)}.trend-down{color:var(--rose)}.trend-neutral{color:var(--text-4)}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--r-sm);font-size:14px;font-weight:600;transition:all .14s;cursor:pointer;border:1px solid transparent;font-family:Inter,sans-serif}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 6px #2563eb40}.btn-primary:hover{background:var(--primary-dark);box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.btn-orange{background:#fff;color:var(--amber);border-color:#d977064d}.btn-orange:hover{background:#d977060f;border-color:var(--amber)}.btn-secondary{background:#fff;color:var(--text-2);border-color:var(--border)}.btn-secondary:hover{background:var(--surface-2);color:var(--text-1);border-color:var(--border-hi)}.btn-ghost{background:transparent;color:var(--text-3);border-color:var(--border)}.btn-ghost:hover{background:var(--surface-2);color:var(--text-1)}.btn-danger{background:#fff;color:var(--rose);border-color:#e11d4840}.btn-danger:hover{background:#e11d480f;border-color:var(--rose)}.btn-sm{padding:6px 12px;font-size:12px}.btn-lg{padding:13px 26px;font-size:16px;border-radius:var(--r)}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid transparent}.badge-green{background:#05966914;color:#047857;border-color:#05966933}.badge-orange{background:#d9770614;color:#b45309;border-color:#d9770633}.badge-red{background:#dc262614;color:#b91c1c;border-color:#dc262633}.badge-amber{background:#d9770614;color:#b45309;border-color:#d9770633}.badge-blue{background:#2563eb14;color:#1d4ed8;border-color:#2563eb33}.badge-gray{background:var(--surface-2);color:var(--text-3);border-color:var(--border)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:13px;font-weight:600;color:var(--text-2);margin-bottom:6px}.form-label span{color:var(--rose);margin-left:2px}.form-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:14px;color:var(--text-1);background:#fff;transition:border .14s,box-shadow .14s}.form-input::placeholder{color:var(--text-4)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-input.has-error{border-color:var(--rose);box-shadow:0 0 0 3px #e11d4814}.form-error{font-size:12px;color:var(--rose);margin-top:5px;display:flex;align-items:flex-start;gap:5px}.form-error:before{content:"⚠";flex-shrink:0}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748B' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-hint{font-size:12px;color:var(--text-4);margin-top:4px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}thead th{background:var(--surface-2);padding:11px 16px;text-align:left;font-size:11px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border)}tbody td{padding:13px 16px;border-bottom:1px solid var(--border-soft);color:var(--text-2);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--primary-light);color:var(--text-1)}.td-primary{font-weight:700;color:var(--text-1);font-size:14px}.budget-meter{background:var(--border);border-radius:6px;height:7px;overflow:hidden}.budget-bar{height:100%;border-radius:6px;transition:width .5s ease}.budget-bar.safe{background:linear-gradient(90deg,var(--emerald),#10B981)}.budget-bar.warning{background:linear-gradient(90deg,var(--amber),#F59E0B)}.budget-bar.over{background:linear-gradient(90deg,var(--rose),#F43F5E)}.alert{border-radius:var(--r-sm);padding:12px 16px;font-size:13px;display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;border:1px solid transparent}.alert-icon{font-size:16px;flex-shrink:0;margin-top:1px}.alert-green{background:#0596690f;border-color:#0596692e;color:#065f46}.alert-amber{background:#d977060f;border-color:#d977062e;color:#92400e}.alert-red{background:#dc26260f;border-color:#dc26262e;color:#991b1b}.alert-blue{background:#2563eb0f;border-color:#2563eb2e;color:#1e40af}.alert-orange{background:#d977060f;border-color:#d977062e;color:#92400e}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:20px;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:10px 18px;font-size:14px;font-weight:500;color:var(--text-3);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .14s;white-space:nowrap;scroll-snap-align:start;flex-shrink:0}.tab:hover{color:var(--text-2)}.tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.week-nav{display:flex;align-items:center;gap:10px;background:#fff;border-radius:var(--r-sm);padding:6px 12px;border:1px solid var(--border)}.week-nav-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:7px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .14s;font-size:15px;color:var(--text-3)}.week-nav-btn:hover{background:var(--primary-light);border-color:#2563eb40;color:var(--primary)}.week-label{font-size:13px;font-weight:600;color:var(--text-1);min-width:200px;text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease;position:relative}.modal-box:before{display:none}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:Plus Jakarta Sans,sans-serif;font-size:17px;font-weight:700;color:var(--text-1);letter-spacing:-.02em}.modal-close{width:28px;height:28px;border-radius:7px;background:var(--surface-2);border:1px solid var(--border);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:all .14s}.modal-close:hover{background:var(--border);color:var(--text-1)}.modal-body{padding:22px}.modal-footer{padding:16px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.roster-grid{border-collapse:collapse;width:100%;min-width:620px}.roster-grid th{padding:8px 6px;font-size:10px;font-weight:700;color:var(--text-3);text-align:center;background:var(--surface-2);border:1px solid var(--border);text-transform:uppercase;letter-spacing:.06em}.roster-grid th.emp-col{text-align:left;min-width:110px;padding-left:12px}.roster-grid td{border:1px solid var(--border);padding:3px;vertical-align:top;min-width:88px;height:52px}.roster-grid td.emp-name-cell{padding:10px 12px;font-size:13px;font-weight:600;color:var(--text-1);background:var(--surface-2);vertical-align:middle}.roster-grid td.emp-name-cell .emp-sub{font-size:11px;color:var(--text-4);font-weight:400;margin-top:2px}.shift-cell{border-radius:7px;padding:5px 8px;font-size:12px;font-weight:600;cursor:pointer;min-height:50px;display:flex;flex-direction:column;justify-content:center;transition:opacity .14s}.shift-cell:hover{opacity:.8}.shift-cell.empty{background:var(--surface-2);border:1.5px dashed var(--border);color:var(--text-4);cursor:pointer;align-items:center;font-size:20px;justify-content:center}.shift-cell.empty:hover{background:var(--primary-light);border-color:#2563eb4d;color:var(--primary)}.shift-cell.drag-source{opacity:.4}.shift-cell.drop-target{outline:2px solid var(--primary)!important;outline-offset:-2px;background:var(--primary-light)!important}.shift-cell.morning{background:#2563eb14;color:#1d4ed8;border:1px solid rgba(37,99,235,.2)}.shift-cell.afternoon{background:#d9770614;color:#b45309;border:1px solid rgba(217,119,6,.2)}.shift-cell.evening{background:#d9770612;color:#92400e;border:1px solid rgba(217,119,6,.18)}.shift-cell.close{background:#6366f114;color:#4338ca;border:1px solid rgba(99,102,241,.2)}.shift-cell.split{background:#0284c714;color:#0369a1;border:1px solid rgba(2,132,199,.2)}.shift-cell.off{background:var(--surface-2);color:var(--text-4);border:1px solid var(--border);cursor:default}.shift-time{font-size:10px;opacity:.7;margin-top:2px;font-weight:500}.clock-hero{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);padding:26px;color:var(--text-1);position:relative;overflow:hidden;margin-bottom:18px;box-shadow:var(--shadow)}.clock-hero:before{content:"";position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.07),transparent 70%);pointer-events:none}.clock-hero:after{display:none}.hero-inner{position:relative;z-index:1}.hero-tag{display:inline-flex;align-items:center;gap:6px;background:var(--primary-light);border:1px solid rgba(37,99,235,.2);border-radius:20px;padding:4px 11px;font-size:12px;color:var(--primary);font-weight:600;margin-bottom:14px}.hero-name{font-family:Plus Jakarta Sans,sans-serif;font-size:22px;font-weight:700;color:var(--text-1);letter-spacing:-.02em}.hero-store{font-size:14px;color:var(--text-3);margin-top:3px;margin-bottom:16px}.hero-time{font-family:Plus Jakarta Sans,sans-serif;font-size:58px;font-weight:800;color:var(--text-1);letter-spacing:-2px;line-height:1}.hero-colon{color:var(--primary)}.hero-date{font-size:14px;color:var(--text-3);margin-top:5px;margin-bottom:20px}.elapsed-label{font-size:12px;color:var(--text-3);margin-bottom:3px}.elapsed-time{font-family:Plus Jakarta Sans,sans-serif;font-size:28px;font-weight:800;color:var(--primary);margin-bottom:14px}.clock-btn{width:100%;padding:16px;border-radius:var(--r);font-family:Plus Jakarta Sans,sans-serif;font-size:17px;font-weight:700;border:1.5px solid transparent;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;gap:10px}.cb-out{background:#fff;color:var(--amber);border-color:#d977064d;box-shadow:0 2px 8px #d977061f}.cb-out:hover{background:#d977060d;box-shadow:0 4px 14px #d977062e;transform:translateY(-1px)}.cb-in{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px #2563eb40}.cb-in:hover{background:var(--primary-dark);box-shadow:0 4px 14px #2563eb4d;transform:translateY(-1px)}.clock-btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.cs-row{display:flex;align-items:center;gap:8px;margin-top:12px}.cs-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.cs-dot.in{background:var(--emerald);animation:pulse 2s infinite}.cs-dot.out{background:var(--border-hi)}.cs-text{font-size:13px;color:var(--text-3)}.gps-msg{font-size:13px;color:var(--text-3);margin-top:10px}.spinner{width:17px;height:17px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:9px}.toast{background:#fff;border:1px solid var(--border);color:var(--text-1);padding:12px 18px;border-radius:var(--r-sm);font-size:13px;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease;max-width:340px}.toast.success{border-left:3px solid var(--emerald)}.toast.error{border-left:3px solid var(--rose)}.toast.info{border-left:3px solid var(--amber)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:transparent;padding:20px;position:relative;overflow:hidden}.login-page:before,.login-page:after,.c3{display:none}.login-card{width:100%;max-width:420px;background:#fff;border:1px solid var(--border);border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0f172a1f;position:relative;z-index:1}.login-card:before{display:none}.login-hero{background:linear-gradient(135deg,#1d4ed8,#4f46e5);border-bottom:1px solid rgba(255,255,255,.12);padding:32px 30px 26px;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;background:#ffffff12;pointer-events:none}.login-hero:after{content:"";position:absolute;bottom:-30px;left:-30px;width:120px;height:120px;border-radius:50%;background:#ffffff0d;pointer-events:none}.login-logo-row{display:flex;align-items:center;gap:14px;margin-bottom:16px;position:relative;z-index:1}.login-roundel{width:48px;height:48px;border-radius:12px;background:#ffffff2e;border:1.5px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:0;font-weight:800;color:#fff;font-family:Plus Jakarta Sans,sans-serif}.login-roundel:after{content:"N";font-size:22px;font-weight:800;color:#fff}.l-name{font-family:Plus Jakarta Sans,sans-serif;font-size:22px;font-weight:800;color:#fff;letter-spacing:-.02em}.l-sub{font-size:13px;color:#ffffffb3;margin-top:2px}.login-tagline{font-size:14px;color:#fffc;position:relative;z-index:1}.login-body{padding:26px 28px}.login-hint{margin-bottom:12px;padding:10px 14px;background:#2563eb0f;border:1px solid rgba(37,99,235,.18);border-radius:8px;font-size:13px;color:var(--primary);font-weight:600}.login-err{background:#e11d480f;border:1px solid rgba(225,29,72,.2);border-radius:9px;padding:11px 15px;font-size:13px;color:var(--rose);margin-bottom:16px;display:flex;align-items:center;gap:8px}.login-footer{text-align:center;padding:0 28px 22px;font-size:12px;color:var(--text-4)}.empty-state{text-align:center;padding:48px 20px;color:var(--text-3)}.empty-icon{font-size:44px;margin-bottom:12px}.empty-text{font-size:15px;color:var(--text-3)}.chip{display:inline-block;background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:3px 11px;font-size:12px;color:var(--text-2);font-weight:500}.divider{height:1px;background:var(--border);margin:18px 0}.accept-banner{background:var(--primary-light);border:1px solid rgba(37,99,235,.18);border-radius:var(--r);padding:16px 18px;margin-bottom:16px;display:flex;align-items:center;gap:14px}.accept-banner.done{background:#0596690f;border-color:#0596692e}.ab-icon{font-size:26px;flex-shrink:0}.ab-title{font-weight:700;font-size:14px;color:var(--text-1)}.ab-sub{font-size:12px;color:var(--text-3);margin-top:2px}.accept-btn{margin-left:auto;background:var(--primary);color:#fff;border:none;border-radius:var(--r-sm);padding:9px 16px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .14s;flex-shrink:0;font-family:inherit}.accept-btn:hover{background:var(--primary-dark)}.task-item{background:#fff;border:1.5px solid var(--border);border-radius:var(--r);padding:14px 16px;margin-bottom:9px;transition:box-shadow .18s,border-color .18s}.task-item:hover{box-shadow:var(--shadow-md);border-color:var(--border-hi)}.task-item.t-done{background:var(--surface-2);border-color:var(--border-soft)}.task-item.pri-high{border-left:3px solid var(--rose)}.task-item.pri-medium{border-left:3px solid var(--amber)}.task-item.pri-low{border-left:3px solid var(--primary)}.task-row{display:flex;align-items:flex-start;gap:12px}.task-check{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all .14s;margin-top:2px;font-size:13px}.task-check.checked{background:var(--emerald);border-color:var(--emerald);color:#fff}.task-ttl{font-weight:600;font-size:14px;color:var(--text-1)}.t-done .task-ttl{text-decoration:line-through;color:var(--text-4)}.task-dsc{font-size:12px;color:var(--text-3);margin-top:3px;line-height:1.5}.task-meta-row{display:flex;align-items:center;gap:7px;margin-top:8px;flex-wrap:wrap}.task-photo-thumb{width:100%;max-height:200px;object-fit:cover;border-radius:9px;margin-top:10px;border:1px solid var(--border)}.task-bar{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:box-shadow .14s,border-color .14s}.task-bar:hover{box-shadow:var(--shadow-md);border-color:var(--border-hi)}.wrc-top{background:#fff;border:1px solid var(--border);color:var(--text-1);border-radius:var(--r);padding:20px 22px;margin-bottom:18px;box-shadow:var(--shadow)}.wrc-top h2{font-family:Plus Jakarta Sans,sans-serif;font-size:18px;font-weight:700;margin-bottom:4px}.wrc-top p{font-size:13px;color:var(--text-3)}.wrc-meta{display:flex;gap:22px;margin-top:12px;flex-wrap:wrap}.wm-label{font-size:10px;color:var(--text-4);font-weight:700;text-transform:uppercase;letter-spacing:.07em}.wm-value{font-size:13px;color:var(--text-1);font-weight:600;margin-top:2px}.wrc-table{width:100%;border-collapse:collapse;font-size:14px;margin-bottom:14px}.wrc-table th{background:var(--surface-2);color:var(--text-3);padding:9px 11px;text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border:1px solid var(--border)}.wrc-table th:first-child{text-align:left;min-width:150px}.wrc-table td{padding:9px 11px;border-bottom:1px solid var(--border);text-align:center;vertical-align:middle;color:var(--text-2)}.wrc-table td:first-child{text-align:left;font-weight:600;color:var(--text-1)}.wrc-table tr:nth-child(2n) td{background:var(--surface-2)}.wrc-totrow td{background:#2563eb0f!important;color:var(--text-1)!important;font-weight:700!important}.wrc-bh{background:#d9770612!important;color:#92400e!important;font-weight:600}.wrc-sun{background:#6366f112!important;color:#4338ca!important;font-weight:600}.wrc-off{color:var(--text-4)!important}.wrc-rules{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 16px;font-size:13px;color:var(--text-2);margin-bottom:16px;line-height:1.9}.wrc-sig{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}.wrc-sig-line{border-top:1px solid var(--border);padding-top:10px;font-size:13px;color:var(--text-3)}.flag-row{display:flex;align-items:flex-start;gap:12px;padding:13px 0;border-bottom:1px solid var(--border)}.flag-row:last-child{border-bottom:none}.flag-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-light);border:1px solid rgba(37,99,235,.2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--primary);flex-shrink:0;margin-top:2px}.flag-name{font-weight:700;font-size:14px;color:var(--text-1)}.flag-times{font-size:12px;color:var(--text-3);margin-top:2px}.flag-reason{display:inline-flex;align-items:center;gap:4px;background:#d9770612;border:1px solid rgba(217,119,6,.2);border-radius:6px;padding:2px 8px;font-size:11px;color:#b45309;font-weight:600;margin-top:5px}.payroll-step{display:flex;align-items:flex-start;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}.payroll-step:last-child{border-bottom:none}.step-num{width:32px;height:32px;border-radius:50%;background:var(--primary-light);border:1px solid rgba(37,99,235,.22);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;color:var(--primary);flex-shrink:0;margin-top:2px}.step-num.locked{background:var(--surface-2);border-color:var(--border);color:var(--text-4)}.payroll-emp-row{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);gap:10px;flex-wrap:wrap}.payroll-emp-row:last-child{border-bottom:none}.ptag{display:inline-flex;align-items:center;gap:3px;border-radius:4px;padding:2px 7px;font-size:11px;font-weight:700;border:1px solid transparent}.ptag-sun{background:#6366f114;color:#4338ca;border-color:#6366f133}.ptag-bh{background:#d9770614;color:#b45309;border-color:#d9770633}.ptag-ot{background:#e11d4814;color:#be123c;border-color:#e11d4833}.tp-wrap{display:flex;align-items:center;gap:6px;background:#fff;border:1.5px solid var(--border);border-radius:var(--r-sm);padding:9px 12px}.tp-select{flex:1;font-size:24px;font-weight:800;color:var(--text-1);background:transparent;border:none;outline:none;text-align:center;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:4px 0}.tp-select:focus{color:var(--primary)}.tp-colon{font-size:28px;font-weight:800;color:var(--text-4);flex-shrink:0;line-height:1;margin:0 2px}.shift-preview{display:flex;align-items:center;justify-content:space-between;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:9px 14px;margin-top:10px}.shift-preview-hrs{font-size:20px;font-weight:800;color:var(--primary)}.task-for-badge{display:inline-flex;align-items:center;gap:4px;background:var(--primary-light);border:1px solid rgba(37,99,235,.2);border-radius:5px;padding:2px 7px;font-size:11px;color:var(--primary);font-weight:600}.task-for-mgr{background:#d9770614;border-color:#d9770638;color:#b45309}@keyframes livePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}.msg-thread{padding:13px 0;border-bottom:1px solid var(--border)}.msg-thread:last-child{border-bottom:none}.msg-subject{font-weight:700;font-size:14px;color:var(--text-1)}.msg-body{font-size:13px;color:var(--text-3);margin-top:4px;line-height:1.55}.msg-meta{font-size:11px;color:var(--text-4);margin-top:5px;display:flex;gap:11px;flex-wrap:wrap}.msg-pinned{background:#d977060f;border:1px solid rgba(217,119,6,.2);border-radius:var(--r-sm);padding:12px 15px;margin-bottom:10px}.abs-bar-track{flex:1;height:7px;background:var(--border);border-radius:4px;overflow:hidden}.abs-bar-fill{height:100%;border-radius:4px}.rtw-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}.rtw-row:last-child{border-bottom:none}@keyframes ldbar{0%{width:0%;margin-left:0}50%{width:100%}to{width:0%;margin-left:100%}}.im-thread-page{position:fixed;top:0;right:0;bottom:0;left:0;background:#fffffff7;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:95;display:flex;flex-direction:column}.im-thread-header{display:flex;align-items:center;gap:10px;padding:12px 14px;background:#fff;border-bottom:1px solid var(--border)}.im-back{width:38px;height:38px;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;font-size:19px;color:var(--text-3);cursor:pointer;flex-shrink:0}.im-back:hover{background:var(--border);color:var(--text-1)}.im-thread-body{flex:1;overflow-y:auto;padding:16px 14px;-webkit-overflow-scrolling:touch}.im-thread-composer{display:flex;align-items:flex-end;padding:10px 12px calc(10px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid var(--border)}.im-thread-composer textarea.form-input{min-height:42px;max-height:35vh;padding:10px 12px}.roster-tp-row{display:flex;gap:12px;margin-bottom:14px}@media (max-width:900px){.roster-tp-row{flex-direction:column;gap:10px}}@media (max-width:900px){.roster-unsaved-banner{position:sticky;top:60px;z-index:80;box-shadow:var(--shadow-md)}}.emp-acc-header{display:none}@media (max-width:900px){.emp-modal-tabs{display:none!important}.emp-acc-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:13px 15px;background:var(--surface-2);border:none;border-top:1px solid var(--border);border-bottom:1px solid var(--border);font-family:Inter,sans-serif;font-size:14px;font-weight:600;color:var(--text-2);text-align:left;cursor:pointer;margin:0 -14px}.emp-acc-header[aria-expanded=true]{background:var(--primary-light);color:var(--primary)}.emp-acc-header .emp-acc-chev{transition:transform .14s;font-size:12px}.emp-acc-header[aria-expanded=true] .emp-acc-chev{transform:rotate(180deg)}}.rcl-list{display:flex;flex-direction:column;gap:8px}.rcl-sortbar{display:flex;align-items:center;gap:10px;padding:4px 2px 6px}.rcl-card{display:flex;align-items:center;gap:12px;width:100%;min-height:60px;padding:11px 14px;background:#fff;border:1px solid var(--border);border-radius:11px;box-shadow:var(--shadow);cursor:pointer;text-align:left;font-family:inherit;color:inherit;transition:box-shadow .14s,border-color .14s}.rcl-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-hi)}.rcl-card:active{transform:scale(.995)}.rcl-card-main{flex:1;min-width:0}.rcl-card-primary{font-weight:700;font-size:14px;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rcl-card-secondary{font-size:12px;color:var(--text-3);margin-top:2px}.rcl-card-meta{font-size:11px;color:var(--text-4);margin-top:2px}.rcl-card-status{flex-shrink:0;display:flex;align-items:center;gap:6px}.rate-card-list{display:flex;flex-direction:column;gap:9px;padding:4px 0}.rate-card{background:#fff;border:1px solid var(--border);border-radius:11px;padding:11px 14px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px}.rate-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.rate-card-headline{display:flex;flex-wrap:wrap;align-items:center;gap:6px;min-width:0}.rate-card-eff{font-size:20px;font-weight:800;color:var(--primary);line-height:1;white-space:nowrap;flex-shrink:0}.rate-card-eff-suffix{font-size:11px;font-weight:600;color:var(--text-3);margin-left:2px}.rate-card-desc{font-size:12px;color:var(--text-3);line-height:1.4}.rate-card-meta{display:flex;flex-wrap:wrap;gap:4px 14px;font-size:12px;color:var(--text-3)}.rate-card-actions{display:flex;gap:8px;padding-top:4px}.rate-card-actions .btn{flex:1}@media (max-width:900px){.payroll-emp-row{flex-direction:column;align-items:stretch;gap:6px;padding:12px 0}.payroll-emp-row>div:last-child{justify-content:flex-start!important;gap:6px!important}.payroll-emp-row>div:last-child>span{margin-left:0!important}}.sidebar-collapse-btn{position:absolute;top:18px;right:10px;width:24px;height:24px;background:var(--surface-2);border:1px solid var(--border);border-radius:7px;color:var(--text-4);font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:background .14s,color .14s}.sidebar-collapse-btn:hover{background:var(--border);color:var(--text-2)}@media (min-width:901px){body[data-sidebar=collapsed] .sidebar{width:64px}body[data-sidebar=collapsed] .main-content{margin-left:64px}body[data-sidebar=collapsed] .brand-text,body[data-sidebar=collapsed] .sidebar-store,body[data-sidebar=collapsed] .nav-group-label,body[data-sidebar=collapsed] .nav-label,body[data-sidebar=collapsed] .nav-badge,body[data-sidebar=collapsed] .user-info,body[data-sidebar=collapsed] .logout-btn{display:none}body[data-sidebar=collapsed] .sidebar-logo{padding:18px 11px}body[data-sidebar=collapsed] .sidebar-collapse-btn{right:18px}body[data-sidebar=collapsed] .brand-row{justify-content:center}body[data-sidebar=collapsed] .nav-item{justify-content:center;padding:12px 6px;margin:1px 6px}body[data-sidebar=collapsed] .nav-icon{width:auto}body[data-sidebar=collapsed] .sidebar-footer{padding:12px 11px}body[data-sidebar=collapsed] .user-row{justify-content:center}}body[data-density=compact] tbody td{padding:7px 12px;font-size:13px;line-height:1.4}body[data-density=compact] thead th{padding:7px 12px;font-size:10px}body[data-density=compact] .td-primary{font-size:13px}body[data-density=compact] .card-body{padding:12px 15px}body[data-density=compact] .card-header{padding:10px 15px}body[data-density=compact] .stat-card{padding:13px 15px}body[data-density=compact] .stat-value{font-size:22px}body[data-density=compact] .stat-label{font-size:11px}body[data-density=compact] .page-body{padding:16px 22px}.sp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a4d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;justify-content:flex-end;animation:fadeIn .15s ease}.sp-panel{background:#fff;border-left:1px solid var(--border);height:100vh;width:520px;max-width:90vw;box-shadow:-8px 0 32px #0f172a1a;display:flex;flex-direction:column;animation:sp-slide-in .2s ease;position:relative}@keyframes sp-slide-in{0%{transform:translate(30px);opacity:0}to{transform:translate(0);opacity:1}}.sp-resize{position:absolute;left:0;top:0;bottom:0;width:5px;cursor:col-resize;background:transparent;transition:background .14s}.sp-resize:hover{background:#2563eb26}.sp-header{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border);background:#fff;position:sticky;top:0;z-index:2}.sp-header-text{flex:1;min-width:0}.sp-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:16px;color:var(--text-1);line-height:1.25;letter-spacing:-.01em}.sp-subtitle{font-size:12px;color:var(--text-3);margin-top:3px;line-height:1.4}.sp-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.sp-close{width:28px;height:28px;border-radius:7px;background:var(--surface-2);border:1px solid var(--border);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:all .14s}.sp-close:hover{background:var(--border);color:var(--text-1)}.sp-body{flex:1;overflow-y:auto;padding:20px}.sp-footer{padding:13px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}.sp-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin:0 -20px 16px;padding:0 20px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.sp-tabs::-webkit-scrollbar{display:none}.sp-tab{padding:9px 14px;font-size:13px;font-weight:500;color:var(--text-3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;transition:color .14s,border-color .14s}.sp-tab:hover{color:var(--text-2)}.sp-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.sp-tab-badge{margin-left:6px;background:var(--surface-2);color:var(--text-3);font-size:10px;font-weight:700;border-radius:10px;padding:1px 7px;min-width:16px;text-align:center}.sp-tab.active .sp-tab-badge{background:var(--primary-light);color:var(--primary)}@media (max-width:900px){.sidebar{transform:translate(-100%);box-shadow:4px 0 20px #0f172a1f}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.page-header{display:none}.mobile-header{display:flex}.bottom-nav{display:block}.page-body{padding:16px 16px 80px}.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.form-row{grid-template-columns:1fr}}@media (max-width:500px){.stat-grid{grid-template-columns:1fr 1fr}.modal-box{border-radius:var(--r)}.btn-lg{padding:12px 20px;font-size:15px}}
