:root{--green:#3CB043;--green-dark:#2A8A30;--green-deep:#1E6B24;--green-light:#D8F0D8;--green-mid:#B8E0B8;--green-faint:#F5FBF5;--green-pale:#EAF7EA;--orange:#FF8C00;--orange-dark:#E07800;--orange-light:#FFF0D0;--orange-mid:#FFD88A;--forest:#1A3A1A;--forest-mid:#2A5A2A;--forest-soft:#4A7A4A;--forest-mute:#6A9A6A;--forest-hint:#9ABA9A;--white:#FFFFFF;--off-white:#F8FDF8;--border:#C0E0C0;--border-soft:#D8EED8;--red:#DC2626;--red-light:#FEE2E2;--amber:#D97706;--amber-light:#FEF3C7;--blue:#2563EB;--blue-light:#DBEAFE;--sidebar-w:260px;--header-h:64px;--r:14px;--r-sm:10px;--r-lg:20px;--shadow:0 1px 4px rgba(26,58,26,.08);--shadow-md:0 4px 16px rgba(26,58,26,.1);--shadow-lg:0 12px 32px rgba(26,58,26,.12);--bg-soft: var(--green-faint);--r-md: 10px;--org: var(--orange)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:Inter,sans-serif;background:var(--off-white);color:var(--forest);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-size:17px;line-height:1.65;letter-spacing:-.01em}h1,h2,h3,h4,h5{font-family:Plus Jakarta Sans,sans-serif;line-height:1.2;letter-spacing:-.03em}button{font-family:Inter,sans-serif;cursor:pointer;border:none;outline:none}input,select,textarea{font-family:Inter,sans-serif;outline:none;font-size:16px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--green-mid);border-radius:3px}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--forest);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;transition:transform .25s ease;overflow:hidden}.sidebar:before{content:"";position:absolute;top:-80px;right:-80px;width:240px;height:240px;border-radius:50%;background:#3cb0431f;pointer-events:none}.sidebar:after{content:"";position:absolute;top:60px;right:-40px;width:140px;height:140px;border-radius:50%;background:#3cb04314;pointer-events:none}.sidebar-logo{padding:22px 22px 18px;border-bottom:1px solid rgba(255,255,255,.07);position:relative;z-index:1}.brand-row{display:flex;align-items:center;gap:12px}.brand-icon{width:42px;height:42px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;overflow:hidden}.brand-icon:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.3),transparent 70%)}.brand-bird{font-size:18px;position:relative;z-index:1}.brand-text .brand-name{font-family:Plus Jakarta Sans,sans-serif;font-weight:800;color:#fff;font-size:18px;letter-spacing:-.3px}.brand-text .brand-sub{font-size:12px;color:#ffffff73;font-weight:400;margin-top:1px}.sidebar-store{padding:12px 22px;border-bottom:1px solid rgba(255,255,255,.07);position:relative;z-index:1}.store-pill{display:inline-flex;align-items:center;gap:6px;background:#3cb04333;border:1px solid rgba(60,176,67,.35);border-radius:20px;padding:6px 14px;font-size:14px;color:var(--green-light);font-weight:600}.store-dot{width:6px;height:6px;border-radius:50%;background:var(--green)}.sidebar-nav{flex:1;padding:14px 0;overflow-y:auto;position:relative;z-index:1}.nav-group-label{padding:10px 22px 4px;font-size:12px;font-weight:700;color:#ffffff4d;letter-spacing:.1em;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 22px;color:#ffffff8c;cursor:pointer;transition:all .15s;font-size:16px;font-weight:500;border-left:3px solid transparent;margin:1px 0}.nav-item:hover{background:#ffffff0f;color:#ffffffd9}.nav-item.active{background:#3cb04326;color:var(--green-light);border-left-color:var(--green)}.nav-icon{font-size:18px;width:22px;text-align:center;flex-shrink:0}.nav-label{flex:1}.nav-badge{background:var(--orange);color:#fff;font-size:11px;font-weight:700;border-radius:10px;padding:2px 7px;min-width:20px;text-align:center}.sidebar-footer{padding:18px 22px;border-top:1px solid rgba(255,255,255,.07);position:relative;z-index:1}.user-row{display:flex;align-items:center;gap:11px}.user-avatar{width:38px;height:38px;border-radius:50%;background:var(--green);border:2px solid rgba(60,176,67,.5);display:flex;align-items:center;justify-content:center;font-family:Plus Jakarta Sans,sans-serif;font-weight:700;color:#fff;font-size:14px;flex-shrink:0}.user-info .u-name{font-size:15px;color:#fff;font-weight:600}.user-info .u-role{font-size:12px;color:#fff6;margin-top:1px}.logout-btn{margin-left:auto;width:32px;height:32px;background:#dc262626;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#ffa0a0cc;font-size:14px;transition:all .15s;border:none;cursor:pointer}.logout-btn:hover{background:#dc262673;color:#fff;transform:scale(1.05)}.main-content{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}.page-header{background:var(--white);border-bottom:1px solid var(--border-soft);padding:0 32px;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.ph-left .ph-title{font-family:Plus Jakarta Sans,sans-serif;font-size:22px;font-weight:800;color:var(--forest)}.ph-left .ph-sub{font-size:14px;color:var(--forest-mute);margin-top:2px}.ph-right{display:flex;align-items:center;gap:12px}.ph-date{font-size:14px;color:var(--forest-mute)}.ph-green-dot{width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px #3cb04333;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 3px #3cb04333}50%{box-shadow:0 0 0 6px #3cb0431a}}.page-body{padding:28px 32px;flex:1}.mobile-header{display:none;background:var(--forest);padding:14px 18px;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200}.mobile-header .m-brand{display:flex;align-items:center;gap:10px}.mobile-header .m-icon{width:34px;height:34px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-size:14px}.mobile-header .m-name{font-family:Plus Jakarta Sans,sans-serif;font-weight:800;color:#fff;font-size:18px}.hamburger{background:none;border:none;color:#fff;font-size:22px;cursor:pointer;padding:2px}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:199;display:none}.sidebar-overlay.open{display:block}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--forest);border-top:1px solid rgba(255,255,255,.1);z-index:150;padding:8px 0 max(8px,env(safe-area-inset-bottom))}.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:#fff6;transition:color .15s}.bn-item.active{color:var(--green)}.bn-icon{font-size:22px}.bn-label{font-size:11px;font-weight:600}.card{background:var(--white);border-radius:var(--r);border:1px solid var(--border-soft);box-shadow:var(--shadow)}.card-header{padding:18px 22px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}.card-title{font-family:Plus Jakarta Sans,sans-serif;font-size:17px;font-weight:700;color:var(--forest)}.card-body{padding:22px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--white);border-radius:var(--r);border:1px solid var(--border-soft);padding:22px;box-shadow:var(--shadow);transition:box-shadow .2s;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:-30px;right:-30px;width:100px;height:100px;border-radius:50%;background:var(--green-faint)}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px;position:relative;z-index:1}.si-green{background:var(--green-light)}.si-orange{background:var(--orange-light)}.si-red{background:var(--red-light)}.si-blue{background:var(--blue-light)}.si-amber{background:var(--amber-light)}.stat-value{font-family:Plus Jakarta Sans,sans-serif;font-size:32px;font-weight:800;color:var(--forest);line-height:1;position:relative;z-index:1}.stat-label{font-size:15px;color:var(--forest-mute);margin-top:5px;font-weight:500;position:relative;z-index:1}.stat-trend{font-size:13px;margin-top:6px;font-weight:600;position:relative;z-index:1}.trend-up{color:var(--green)}.trend-down{color:var(--red)}.trend-neutral{color:var(--forest-hint)}.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:var(--r-sm);font-size:16px;font-weight:600;transition:all .15s;cursor:pointer;border:none;font-family:Inter,sans-serif}.btn-primary{background:var(--green);color:#fff;box-shadow:0 2px 8px #3cb0434d}.btn-primary:hover{background:var(--green-dark);box-shadow:0 4px 16px #3cb04366;transform:translateY(-1px)}.btn-orange{background:var(--orange);color:#fff;box-shadow:0 2px 8px #ff8c004d}.btn-orange:hover{background:var(--orange-dark);transform:translateY(-1px)}.btn-secondary{background:var(--green-faint);color:var(--forest-mid);border:1px solid var(--border)}.btn-secondary:hover{background:var(--green-light)}.btn-ghost{background:transparent;color:var(--forest-soft);border:1px solid var(--border-soft)}.btn-ghost:hover{background:var(--green-faint)}.btn-danger{background:var(--red-light);color:var(--red);border:1px solid #FCA5A5}.btn-danger:hover{background:var(--red);color:#fff}.btn-sm{padding:8px 14px;font-size:14px}.btn-lg{padding:17px 30px;font-size:18px;border-radius:var(--r)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.badge{display:inline-flex;align-items:center;gap:4px;padding:5px 11px;border-radius:20px;font-size:13px;font-weight:700}.badge-green{background:var(--green-light);color:var(--green-dark)}.badge-orange{background:var(--orange-light);color:var(--orange-dark)}.badge-red{background:var(--red-light);color:var(--red)}.badge-amber{background:var(--amber-light);color:var(--amber)}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-gray{background:var(--green-faint);color:var(--forest-mute)}.form-group{margin-bottom:18px}.form-label{display:block;font-size:15px;font-weight:600;color:var(--forest-mid);margin-bottom:7px}.form-label span{color:var(--red);margin-left:2px}.form-input{width:100%;padding:13px 15px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-size:16px;color:var(--forest);background:var(--white);transition:border .15s}.form-input:focus{border-color:var(--green);box-shadow:0 0 0 3px #3cb0431f}.form-input::placeholder{color:var(--forest-hint)}.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='%234A7A4A' 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:16px}.form-hint{font-size:12px;color:var(--forest-hint);margin-top:5px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:15px}thead th{background:var(--green-faint);padding:13px 16px;text-align:left;font-size:13px;font-weight:700;color:var(--forest-soft);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--border-soft)}tbody td{padding:15px 16px;border-bottom:1px solid var(--green-faint);color:var(--forest-mid);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--green-faint)}.td-primary{font-weight:700;color:var(--forest);font-size:16px}.budget-meter{background:var(--green-faint);border-radius:6px;height:10px;overflow:hidden}.budget-bar{height:100%;border-radius:6px;transition:width .5s ease}.budget-bar.safe{background:var(--green)}.budget-bar.warning{background:var(--amber)}.budget-bar.over{background:var(--red)}.alert{border-radius:var(--r-sm);padding:15px 17px;font-size:15px;display:flex;align-items:flex-start;gap:10px;margin-bottom:14px}.alert-icon{font-size:17px;flex-shrink:0;margin-top:1px}.alert-green{background:var(--green-light);border:1px solid var(--green-mid);color:var(--forest-mid)}.alert-amber{background:var(--amber-light);border:1px solid #FDE68A;color:#92400e}.alert-red{background:var(--red-light);border:1px solid #FCA5A5;color:var(--red)}.alert-blue{background:var(--blue-light);border:1px solid #93C5FD;color:var(--blue)}.alert-orange{background:var(--orange-light);border:1px solid var(--orange-mid);color:var(--orange-dark)}.tabs{display:flex;border-bottom:2px solid var(--border-soft);margin-bottom:22px;gap:0}.tab{padding:13px 22px;font-size:16px;font-weight:600;color:var(--forest-mute);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.tab:hover{color:var(--forest-mid)}.tab.active{color:var(--green);border-bottom-color:var(--green)}.week-nav{display:flex;align-items:center;gap:12px;background:var(--green-faint);border-radius:var(--r-sm);padding:7px 12px;border:1px solid var(--border)}.week-nav-btn{background:var(--white);border:1px solid var(--border);border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;font-size:16px;color:var(--forest-soft)}.week-nav-btn:hover{background:var(--green-light);border-color:var(--green);color:var(--green)}.week-label{font-family:Plus Jakarta Sans,sans-serif;font-size:15px;font-weight:700;color:var(--forest);min-width:200px;text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a3a1a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);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:var(--white);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}@keyframes slideUp{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:Plus Jakarta Sans,sans-serif;font-size:20px;font-weight:800;color:var(--forest)}.modal-close{width:30px;height:30px;border-radius:8px;background:var(--green-faint);border:none;cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;color:var(--forest-mute)}.modal-close:hover{background:var(--green-light);color:var(--forest)}.modal-body{padding:24px}.modal-footer{padding:18px 24px;border-top:1px solid var(--border-soft);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:11px;font-weight:700;color:var(--forest-soft);text-align:center;background:var(--green-faint);border:1px solid var(--border-soft);text-transform:uppercase;letter-spacing:.05em}.roster-grid th.emp-col{text-align:left;min-width:110px;padding-left:12px}.roster-grid td{border:1px solid var(--border-soft);padding:3px;vertical-align:top;min-width:88px;height:52px}.roster-grid td.emp-name-cell{padding:10px 12px;font-size:13px;font-weight:700;color:var(--forest);background:var(--green-faint);vertical-align:middle}.roster-grid td.emp-name-cell .emp-sub{font-size:11px;color:var(--forest-mute);font-weight:400;margin-top:2px}.shift-cell{border-radius:8px;padding:5px 8px;font-size:12px;font-weight:700;cursor:pointer;min-height:50px;display:flex;flex-direction:column;justify-content:center;transition:opacity .15s}.shift-cell:hover{opacity:.8}.shift-cell.empty{background:var(--green-faint);border:1.5px dashed var(--border);color:var(--forest-hint);cursor:pointer;align-items:center;font-size:20px;justify-content:center}.shift-cell.empty:hover{background:var(--green-light);border-color:var(--green);color:var(--green)}.shift-cell.morning{background:#dbeafe;color:#1d4ed8;border:1px solid #BFDBFE}.shift-cell.afternoon{background:var(--amber-light);color:#92400e;border:1px solid #FDE68A}.shift-cell.evening{background:var(--orange-light);color:var(--orange-dark);border:1px solid var(--orange-mid)}.shift-cell.close{background:#f3e8ff;color:#6d28d9;border:1px solid #DDD6FE}.shift-cell.split{background:var(--green-light);color:var(--green-dark);border:1px solid var(--green-mid)}.shift-cell.off{background:var(--green-faint);color:var(--forest-hint);border:1px solid var(--border-soft);cursor:default}.shift-time{font-size:10px;opacity:.8;margin-top:2px;font-weight:500}.clock-hero{background:var(--forest);border-radius:var(--r-lg);padding:28px;color:#fff;position:relative;overflow:hidden;margin-bottom:20px}.clock-hero:before{content:"";position:absolute;top:-70px;right:-70px;width:220px;height:220px;border-radius:50%;background:var(--green);opacity:.25}.clock-hero:after{content:"";position:absolute;top:-30px;right:-30px;width:140px;height:140px;border-radius:50%;background:var(--green);opacity:.2}.hero-inner{position:relative;z-index:1}.hero-tag{display:inline-flex;align-items:center;gap:6px;background:#3cb04340;border:1px solid rgba(60,176,67,.4);border-radius:20px;padding:5px 12px;font-size:12px;color:var(--green-light);font-weight:600;margin-bottom:16px}.hero-name{font-family:Plus Jakarta Sans,sans-serif;font-size:26px;font-weight:800;color:#fff;letter-spacing:-.4px}.hero-store{font-size:16px;color:#fff9;margin-top:3px;margin-bottom:18px}.hero-time{font-family:Plus Jakarta Sans,sans-serif;font-size:62px;font-weight:800;color:#fff;letter-spacing:-2px;line-height:1}.hero-colon{color:var(--green)}.hero-date{font-size:16px;color:#ffffff8c;margin-top:5px;margin-bottom:22px}.elapsed-label{font-size:13px;color:#ffffff80;margin-bottom:3px}.elapsed-time{font-family:Plus Jakarta Sans,sans-serif;font-size:32px;font-weight:700;color:var(--green-light);margin-bottom:16px}.clock-btn{width:100%;padding:19px;border-radius:var(--r);font-family:Plus Jakarta Sans,sans-serif;font-size:20px;font-weight:800;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px}.cb-out{background:var(--orange);color:#fff;box-shadow:0 4px 20px #ff8c0080}.cb-out:hover{background:var(--orange-dark);transform:translateY(-1px)}.cb-in{background:var(--red);color:#fff;box-shadow:0 4px 20px #dc262666}.cb-in:hover{background:#b91c1c;transform:translateY(-1px)}.clock-btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.cs-row{display:flex;align-items:center;gap:8px;margin-top:14px}.cs-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cs-dot.in{background:var(--green);box-shadow:0 0 0 3px #3cb04340;animation:pulse 2s infinite}.cs-dot.out{background:#ffffff4d}.cs-text{font-size:15px;color:#ffffff8c}.gps-msg{font-size:14px;color:#fff9;margin-top:10px}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.toast-wrap{position:fixed;bottom:28px;right:28px;z-index:2000;display:flex;flex-direction:column;gap:10px}.toast{background:var(--forest);color:#fff;padding:15px 20px;border-radius:var(--r-sm);font-size:15px;font-weight:500;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease;max-width:360px}.toast.success{border-left:4px solid var(--green)}.toast.error{border-left:4px solid var(--red)}.toast.info{border-left:4px solid var(--orange)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--green-faint);padding:20px;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-120px;right:-120px;width:400px;height:400px;border-radius:50%;background:var(--green-light)}.login-page:after{content:"";position:absolute;top:-60px;right:-60px;width:260px;height:260px;border-radius:50%;background:var(--green-mid);opacity:.7}.c3{position:absolute;bottom:-100px;left:-100px;width:350px;height:350px;border-radius:50%;background:var(--green-light);opacity:.5}.login-card{width:100%;max-width:420px;background:var(--white);border-radius:24px;overflow:hidden;box-shadow:0 24px 60px #1a3a1a2e;position:relative;z-index:1}.login-hero{background:var(--green);padding:32px 30px 28px;position:relative;overflow:hidden}.login-hero:before{content:"";position:absolute;top:-50px;right:-50px;width:180px;height:180px;border-radius:50%;background:#ffffff1f}.login-hero:after{content:"";position:absolute;top:10px;right:10px;width:110px;height:110px;border-radius:50%;background:#ffffff14}.login-logo-row{display:flex;align-items:center;gap:14px;margin-bottom:18px;position:relative;z-index:1}.login-roundel{width:52px;height:52px;border-radius:50%;background:#fff3;border:2px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;font-size:22px}.l-name{font-family:Plus Jakarta Sans,sans-serif;font-size:26px;font-weight:900;color:#fff;letter-spacing:-.5px}.l-sub{font-size:15px;color:#ffffffb3;margin-top:2px}.login-tagline{font-size:16px;color:#ffffffbf;position:relative;z-index:1}.login-body{padding:30px 32px}.login-hint{margin-bottom:12px;padding:10px 14px;background:#f0fdf4;border:1px solid #BBF7D0;border-radius:8px;font-size:13px;color:#16a34a;font-weight:600}.login-err{background:var(--red-light);border:1px solid #FCA5A5;border-radius:10px;padding:13px 16px;font-size:15px;color:var(--red);margin-bottom:18px;display:flex;align-items:center;gap:8px}.login-footer{text-align:center;padding:0 30px 26px;font-size:14px;color:var(--forest-hint)}.empty-state{text-align:center;padding:48px 20px;color:var(--forest-hint)}.empty-icon{font-size:48px;margin-bottom:12px}.empty-text{font-size:17px;color:var(--forest-mute)}.chip{display:inline-block;background:var(--green-faint);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:14px;color:var(--forest-soft);font-weight:500}.divider{height:1px;background:var(--border-soft);margin:20px 0}.form-hint{font-size:13px;color:var(--forest-hint);margin-top:5px}@media (max-width:800px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding-bottom:68px}.mobile-header{display:flex}.page-header{display:none}.bottom-nav{display:block}.page-body{padding:12px 12px 16px}.stat-grid{grid-template-columns:1fr 1fr}.form-row{grid-template-columns:1fr}.hero-time{font-size:46px}.accept-banner{flex-wrap:wrap;padding:14px 16px;gap:10px}.wrc-sig{grid-template-columns:1fr}.card-header{padding:14px 16px}.roster-grid{min-width:540px}.roster-grid th{padding:6px 4px;font-size:10px}.roster-grid th.emp-col{min-width:80px;padding-left:8px}.roster-grid td{min-width:70px;height:46px}.roster-grid td.emp-name-cell{padding:8px;font-size:12px}.emp-sub{font-size:10px}.shift-cell{padding:3px 4px!important;min-height:34px!important;font-size:10px!important}.shift-time{font-size:9px!important}.modal-overlay{padding:8px}.modal-box{border-radius:14px;max-height:93vh}.modal-body{padding:14px!important}.modal-header{padding:12px 14px!important}.modal-footer{padding:10px 14px!important}.bn-item{padding:4px 6px}.bn-icon{font-size:20px}.bn-label{font-size:10px}.table-wrap{position:relative}.table-wrap:after{content:"";position:absolute;right:0;top:0;bottom:0;width:20px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.85));pointer-events:none}.week-label{font-size:12px;padding:4px 6px}}.accept-banner{background:linear-gradient(135deg,#1e6b24,#2a5a2a);border-radius:var(--r);padding:18px 20px;margin-bottom:18px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-md)}.accept-banner.done{background:var(--green-faint);border:1.5px solid var(--green-mid);box-shadow:none}.ab-icon{font-size:28px;flex-shrink:0}.ab-title{font-family:Sora,sans-serif;font-weight:800;font-size:16px;color:#fff}.ab-sub{font-size:13px;color:#ffffffa6;margin-top:2px}.accept-banner.done .ab-title{color:var(--green-dark)}.accept-banner.done .ab-sub{color:var(--forest-mute)}.accept-btn{margin-left:auto;background:#fff;color:var(--green-dark);border:none;border-radius:var(--r-sm);padding:11px 18px;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}.accept-btn:hover{background:var(--green-light)}.task-item{background:var(--white);border:1.5px solid var(--border-soft);border-radius:var(--r);padding:16px 18px;margin-bottom:10px;transition:box-shadow .2s}.task-item:hover{box-shadow:var(--shadow-md)}.task-item.t-done{background:var(--green-faint);border-color:var(--green-mid)}.task-item.pri-high{border-left:4px solid var(--red)}.task-item.pri-medium{border-left:4px solid var(--amber)}.task-item.pri-low{border-left:4px solid var(--green)}.task-row{display:flex;align-items:flex-start;gap:12px}.task-check{width:26px;height:26px;border-radius:50%;border:2.5px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all .15s;margin-top:2px;font-size:14px}.task-check.checked{background:var(--green);border-color:var(--green);color:#fff}.task-ttl{font-weight:700;font-size:16px;color:var(--forest)}.t-done .task-ttl{text-decoration:line-through;color:var(--forest-mute)}.task-dsc{font-size:14px;color:var(--forest-mute);margin-top:3px;line-height:1.5}.task-meta-row{display:flex;align-items:center;gap:8px;margin-top:8px;flex-wrap:wrap}.task-photo-thumb{width:100%;max-height:220px;object-fit:cover;border-radius:10px;margin-top:10px;border:1px solid var(--border-soft)}.task-bar{background:var(--white);border:1px solid var(--border-soft);border-radius:var(--r);padding:14px 18px;margin-bottom:18px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:box-shadow .15s}.task-bar:hover{box-shadow:var(--shadow-md)}.wrc-top{background:var(--forest);color:#fff;border-radius:var(--r);padding:22px 24px;margin-bottom:20px}.wrc-top h2{font-family:Sora,sans-serif;font-size:20px;font-weight:800;margin-bottom:4px}.wrc-top p{font-size:14px;color:#ffffffa6}.wrc-meta{display:flex;gap:24px;margin-top:14px;flex-wrap:wrap}.wm-label{font-size:11px;color:#ffffff80;font-weight:700;text-transform:uppercase;letter-spacing:.07em}.wm-value{font-size:14px;color:#fff;font-weight:600;margin-top:2px}.wrc-table{width:100%;border-collapse:collapse;font-size:14px;margin-bottom:16px}.wrc-table th{background:var(--forest);color:#fff;padding:10px 11px;text-align:center;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.wrc-table th:first-child{text-align:left;min-width:150px}.wrc-table td{padding:10px 11px;border-bottom:1px solid var(--border-soft);text-align:center;vertical-align:middle}.wrc-table td:first-child{text-align:left;font-weight:600;color:var(--forest)}.wrc-table tr:nth-child(2n) td{background:var(--green-faint)}.wrc-totrow td{background:var(--forest)!important;color:#fff!important;font-weight:800!important}.wrc-bh{background:#fef3c7!important;color:#92400e!important;font-weight:700}.wrc-sun{background:#ede9fe!important;color:#6d28d9!important;font-weight:700}.wrc-off{color:var(--forest-hint)!important}.wrc-rules{background:var(--green-faint);border:1px solid var(--border);border-radius:var(--r-sm);padding:14px 18px;font-size:13px;color:var(--forest-mid);margin-bottom:18px;line-height:1.9}.wrc-sig{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:28px}.wrc-sig-line{border-top:2px solid var(--forest);padding-top:10px;font-size:13px;color:var(--forest-mid)}@media print{.no-print{display:none!important}#signoff-report{display:block!important}@page{size:A4 landscape;margin:10mm}.sidebar,.bottom-nav,.mobile-header,.page-header{display:none!important}.main-content{margin-left:0!important}.page-body{padding:4px 12px!important}.wrc-top,.wrc-table th,.wrc-totrow td{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.flag-row{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--border-soft)}.flag-row:last-child{border-bottom:none}.flag-avatar{width:38px;height:38px;border-radius:50%;background:var(--green-light);border:2px solid var(--green-mid);display:flex;align-items:center;justify-content:center;font-family:Sora,sans-serif;font-weight:700;font-size:13px;color:var(--green-dark);flex-shrink:0;margin-top:2px}.flag-name{font-weight:700;font-size:15px;color:var(--forest)}.flag-times{font-size:13px;color:var(--forest-mute);margin-top:2px}.flag-reason{display:inline-flex;align-items:center;gap:4px;background:var(--amber-light);border:1px solid #FDE68A;border-radius:6px;padding:2px 8px;font-size:12px;color:#92400e;font-weight:600;margin-top:5px}.payroll-step{display:flex;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid var(--border-soft)}.payroll-step:last-child{border-bottom:none}.step-num{width:34px;height:34px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-family:Sora,sans-serif;font-weight:800;font-size:14px;color:#fff;flex-shrink:0;margin-top:2px}.step-num.locked{background:var(--forest-hint)}.payroll-emp-row{display:flex;align-items:center;padding:11px 0;border-bottom:1px solid var(--border-soft);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}.ptag-sun{background:#ede9fe;color:#6d28d9}.ptag-bh{background:#fef3c7;color:#92400e}.ptag-ot{background:var(--red-light);color:var(--red)}.tp-wrap{display:flex;align-items:center;gap:6px;background:var(--green-faint);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:10px 12px}.tp-select{flex:1;font-family:Sora,sans-serif;font-size:28px;font-weight:800;color:var(--forest);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(--green-dark)}.tp-colon{font-family:Sora,sans-serif;font-size:32px;font-weight:800;color:var(--forest-mute);flex-shrink:0;line-height:1;margin:0 2px}.shift-preview{display:flex;align-items:center;justify-content:space-between;background:var(--white);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:10px 14px;margin-top:10px}.shift-preview-hrs{font-family:Sora,sans-serif;font-size:22px;font-weight:800;color:var(--green-dark)}.task-for-badge{display:inline-flex;align-items:center;gap:4px;background:#eff6ff;border:1px solid #BFDBFE;border-radius:5px;padding:2px 7px;font-size:11px;color:#1d4ed8;font-weight:600}.task-for-mgr{background:#fff7ed;border-color:#fed7aa;color:#c2410c}@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-soft)}.msg-thread:last-child{border-bottom:none}.msg-subject{font-weight:700;font-size:15px;color:var(--forest)}.msg-body{font-size:14px;color:var(--forest-mid);margin-top:4px;line-height:1.55}.msg-meta{font-size:12px;color:var(--forest-hint);margin-top:6px;display:flex;gap:12px;flex-wrap:wrap}.msg-pinned{background:var(--amber-light);border:1px solid #FDE68A;border-radius:var(--r-sm);padding:13px 16px;margin-bottom:10px}.abs-bar-track{flex:1;height:8px;background:var(--border-soft);border-radius:4px;overflow:hidden}.abs-bar-fill{height:100%;border-radius:4px}.rtw-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--border-soft)}.rtw-row:last-child{border-bottom:none}@keyframes ldbar{0%{width:0%;margin-left:0}50%{width:100%}to{width:0%;margin-left:100%}}
