*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--orange: #E8471A;--orange-dark: #c73a13;--orange-soft: #fff3ee;--orange-mid: #fdddd0;--orange-glow: rgba(232,71,26,.18);--cream: #faf8f4;--cream-dark: #f3ede6;--white: #ffffff;--border: #e6ddd4;--border-mid: #d4c8bc;--text: #1a1714;--text-mid: #4a4138;--text-muted: #8c7e74;--green: #15803d;--green-soft: #dcfce7;--red: #dc2626;--red-soft: #fee2e2;--amber: #d97706;--amber-soft: #fef3c7;--blue: #2563eb;--blue-soft: #dbeafe;--purple: #7c3aed;--shadow-sm: 0 1px 3px rgba(26,23,20,.08), 0 1px 2px rgba(26,23,20,.05);--shadow-md: 0 4px 16px rgba(26,23,20,.1), 0 2px 6px rgba(26,23,20,.06);--shadow-lg: 0 12px 40px rgba(26,23,20,.14), 0 4px 14px rgba(26,23,20,.08);--shadow-orange: 0 8px 24px rgba(232,71,26,.28);--radius: 12px;--radius-sm: 7px;--radius-lg: 18px;--topbar-h: 62px;--sidebar-w: 230px}html,body,#root{height:100%;font-family:Barlow,sans-serif;background:var(--cream);color:var(--text);-webkit-font-smoothing:antialiased}.wo-shared-date-hd{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#1a1714,#2d2520 60%,#1a1714);border-radius:var(--radius);padding:14px 20px;margin-bottom:26px;box-shadow:0 6px 24px #00000038,0 0 0 1px #e8471a2e;flex-wrap:wrap}.wo-shared-date-centre{text-align:center;flex:1;min-width:180px}.wo-shared-date-day{font-family:Barlow Condensed,sans-serif;font-size:26px;font-weight:900;color:var(--orange);text-transform:uppercase;letter-spacing:2px;line-height:1}.wo-shared-date-str{font-size:13px;font-weight:600;color:#ffffffa6;margin-top:3px}.wo-date-arrow-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1.5px solid rgba(255,255,255,.18);border-radius:10px;background:#ffffff12;color:#fff;cursor:pointer;transition:all .15s;flex-shrink:0}.wo-date-arrow-btn:hover{background:var(--orange);border-color:var(--orange);transform:scale(1.1)}.wo-date-arrow-btn:active{transform:scale(.95)}.wo-shared-date-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.wo-date-picker-input{padding:7px 11px;border-radius:8px;font-size:13px;font-weight:600;border:1.5px solid rgba(255,255,255,.18);background:#ffffff1a;color:#fff;outline:none;cursor:pointer}.wo-date-picker-input:focus{border-color:var(--orange)}.wo-date-picker-input::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.wo-today-btn{padding:7px 14px;border-radius:8px;font-size:11px;font-weight:800;border:1.5px solid rgba(232,71,26,.5);background:#e8471a26;color:var(--orange);cursor:pointer;transition:all .15s;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.wo-today-btn:hover{background:var(--orange);color:#fff}.wo-weekly-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);margin-bottom:20px;box-shadow:var(--shadow-sm);overflow:hidden}.wo-weekly-card-hd{display:flex;align-items:center;gap:14px;padding:14px 20px;background:linear-gradient(135deg,#1a1714,#2d2520);border-bottom:2px solid var(--orange)}.wo-weekly-card-avatar{width:42px;height:42px;border-radius:11px;flex-shrink:0;background:#e8471a33;border:2px solid rgba(232,71,26,.4);display:flex;align-items:center;justify-content:center;font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:900;color:var(--orange)}.wo-weekly-card-name{font-family:Barlow Condensed,sans-serif;font-size:18px;font-weight:900;color:#fff;letter-spacing:.5px}.wo-weekly-card-uid{font-size:11px;color:#ffffff73;font-family:monospace;margin-top:2px}.wo-weekly-role-chip{margin-left:auto;padding:4px 12px;border-radius:20px;background:#e8471a33;border:1px solid rgba(232,71,26,.4);color:var(--orange);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.wo-weekly-table{width:100%;border-collapse:collapse;font-size:12.5px;min-width:900px}.wo-weekly-table th{padding:9px 14px;text-align:left;font-size:10px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;background:var(--cream);border-bottom:2px solid var(--border);white-space:nowrap}.wo-weekly-table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.wo-weekly-table tr:last-child td{border-bottom:none}.wo-weekly-row:hover td{background:var(--cream-dark)}.wo-weekly-today td{background:#e8471a0a}.wo-weekly-today .wo-weekly-day{color:var(--orange);font-weight:900}.wo-weekly-off td{opacity:.55;background:#f9fafb}.wo-weekly-day{font-weight:800;color:var(--text);white-space:nowrap}.wo-weekly-date{font-size:12px;color:var(--text-muted);white-space:nowrap}.wo-weekly-clocked{font-weight:700;color:var(--text)}.wo-weekly-hours{font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:800;color:var(--orange);white-space:nowrap}.wo-weekly-note{font-size:11px;color:var(--text-muted);max-width:200px}.wo-off-chip{background:#e5e7eb;color:#6b7280;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px}.wo-active-chip{background:var(--green-soft);color:var(--green);font-size:10px;font-weight:800;padding:2px 8px;border-radius:20px;animation:badgePulse 2s infinite}.wo-late-note{display:flex;flex-direction:column;gap:4px}.wo-late-note-row{display:flex;align-items:center;gap:8px}.wo-late-note-label{font-size:10px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;min-width:68px;flex-shrink:0}.wo-late-note-val{font-size:12px;font-weight:700;padding:2px 8px;border-radius:5px}.wo-late-note-actual{background:var(--red-soft);color:var(--red)}.wo-late-note-recorded{background:var(--amber-soft);color:var(--amber)}.wo-late-note-mins{background:var(--orange-soft);color:var(--orange)}.wo-splash{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--cream);display:flex;align-items:center;justify-content:center}.wo-splash-inner{text-align:center}.wo-splash-text{color:var(--text-muted);font-size:14px;font-weight:500;margin-top:12px}.wo-app{height:100vh;display:flex;flex-direction:column;overflow:hidden}.wo-layout{flex:1;display:flex;overflow:hidden;padding-top:var(--topbar-h);width:100%}.wo-topbar{position:fixed;top:0;left:0;right:0;z-index:900;height:var(--topbar-h);background:linear-gradient(135deg,#1a1714,#2d2520,#1a1714);border-bottom:2px solid var(--orange);display:flex;align-items:center;justify-content:space-between;padding:0 24px;box-shadow:0 4px 24px #0000004d,0 0 0 1px #e8471a26}.wo-topbar-brand{display:flex;align-items:center;gap:12px}.wo-topbar-logo{height:32px;width:auto;object-fit:contain;filter:brightness(1.1)}.wo-topbar-name{font-family:Barlow Condensed,sans-serif;font-size:24px;font-weight:900;color:#fff;letter-spacing:2px;text-transform:uppercase;text-shadow:0 0 20px var(--orange-glow)}.wo-topbar-name span{color:var(--orange)}.wo-topbar-actions{position:relative}.wo-topbar-menu{cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:8px;border-radius:8px;transition:background .15s}.wo-topbar-menu:hover{background:#ffffff1a}.wo-topbar-menu span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all .2s}.wo-topbar-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:#1a1714;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:220px;overflow:hidden;z-index:999}.wo-dropdown-header{padding:16px 18px 12px;border-bottom:1px solid rgba(255,255,255,.08);background:#ffffff08}.wo-dropdown-role{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13px;color:#fff}.wo-role-dot{width:8px;height:8px;border-radius:50%;background:var(--orange);box-shadow:0 0 8px var(--orange)}.wo-dropdown-item{display:flex;align-items:center;gap:10px;padding:13px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;color:#fffc}.wo-dropdown-item:hover{background:#ffffff0f}.wo-dropdown-logout{color:#fc8181}.wo-dropdown-logout svg{width:16px;height:16px}.wo-sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,#211d1a,#1a1714);border-right:1px solid rgba(232,71,26,.2);overflow-y:auto;flex-shrink:0;padding:20px 12px;box-shadow:4px 0 20px #0003}.wo-sidebar-section{font-size:10px;font-weight:800;color:#ffffff40;text-transform:uppercase;letter-spacing:1.5px;padding:0 12px;margin:16px 0 6px}.wo-nav-item{display:flex;align-items:center;gap:11px;width:100%;padding:11px 14px;border:none;background:none;cursor:pointer;border-radius:9px;text-align:left;font-family:Barlow,sans-serif;font-size:13.5px;font-weight:600;color:#ffffff8c;transition:all .2s;margin-bottom:3px;position:relative;overflow:hidden}.wo-nav-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--orange);border-radius:0 2px 2px 0;transform:scaleY(0);transition:transform .2s}.wo-nav-item:hover{background:#ffffff12;color:#ffffffe6}.wo-nav-item.active{background:linear-gradient(135deg,#e8471a40,#e8471a1a);color:#fff;border:1px solid rgba(232,71,26,.3)}.wo-nav-item.active:before{transform:scaleY(1)}.wo-nav-icon{font-size:17px;flex-shrink:0}.wo-main{flex:1;overflow-y:auto;background:var(--cream)}.wo-tab-content{padding:30px 34px;max-width:100%;width:100%}.wo-tab-heading{margin-bottom:26px}.wo-tab-heading h2{font-family:Barlow Condensed,sans-serif;font-size:32px;font-weight:900;letter-spacing:.5px;color:var(--text);text-transform:uppercase;background:linear-gradient(135deg,var(--text) 0%,var(--orange) 100%);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.wo-tab-sub{font-size:13px;color:var(--text-muted);margin-top:3px;font-weight:500}.wo-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--white);font-family:Barlow,sans-serif;font-size:13px;font-weight:700;color:var(--text-mid);cursor:pointer;transition:all .15s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;box-shadow:var(--shadow-sm),inset 0 1px #fffc;position:relative}.wo-btn:hover{background:var(--cream-dark);border-color:var(--border-mid);transform:translateY(-1px);box-shadow:var(--shadow-md)}.wo-btn:active{transform:translateY(1px);box-shadow:var(--shadow-sm)}.wo-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.wo-btn-primary{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dark) 100%);border-color:var(--orange-dark);color:#fff;box-shadow:var(--shadow-orange),inset 0 1px #fff3}.wo-btn-primary:hover{background:linear-gradient(135deg,#f05a30 0%,var(--orange) 100%);box-shadow:0 10px 30px #e8471a66,inset 0 1px #fff3;transform:translateY(-2px)}.wo-btn-3d{transform-style:preserve-3d}.wo-btn-3d:hover{transform:translateY(-3px) rotateX(3deg)}.wo-btn-3d:active{transform:translateY(2px) rotateX(-2deg)}.wo-btn-admin{background:linear-gradient(135deg,#1a1714,#2d2520);border-color:#1a1714;color:#fff;box-shadow:0 4px 12px #0000004d}.wo-btn-admin:hover{background:linear-gradient(135deg,#2d2520,#1a1714);box-shadow:0 8px 20px #0006}.wo-btn-sm{padding:7px 14px;font-size:12px}.wo-btn-full{width:100%;margin-top:10px}.wo-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1.5px solid var(--border);background:var(--white);color:var(--text-mid);cursor:pointer;transition:all .15s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--shadow-sm)}.wo-icon-btn:hover{background:var(--cream-dark);transform:translateY(-1px) scale(1.05);box-shadow:var(--shadow-md)}.wo-icon-btn:active{transform:translateY(1px) scale(.98)}.wo-icon-btn-del:hover{background:var(--red-soft);border-color:var(--red);color:var(--red)}.wo-input{width:100%;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 13px;font-family:Barlow,sans-serif;font-size:13.5px;font-weight:500;color:var(--text);outline:none;transition:all .15s;box-shadow:inset 0 2px 4px #0000000a}.wo-input:focus{border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-glow),inset 0 2px 4px #0000000a}.wo-input-sm{width:auto;min-width:140px}.wo-input-date{width:170px}.wo-search{min-width:200px}.wo-label{display:block;font-size:11px;font-weight:800;color:var(--text-mid);text-transform:uppercase;letter-spacing:.6px;margin-bottom:5px}.wo-label-opt{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-muted)}.wo-req{color:var(--red)}.wo-field-row{margin-bottom:16px}.wo-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.wo-toggle-row{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;cursor:pointer;margin-bottom:14px}.wo-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:28px}.wo-stat-grid-sm{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));margin-bottom:20px}.wo-stat-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:20px 16px;box-shadow:var(--shadow-sm);text-align:center;transition:all .2s cubic-bezier(.34,1.56,.64,1);cursor:default;position:relative;overflow:hidden}.wo-stat-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 60%,rgba(232,71,26,.04))}.wo-stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--orange-mid)}.wo-stat-icon{font-size:24px;margin-bottom:8px}.wo-stat-value{font-family:Barlow Condensed,sans-serif;font-size:30px;font-weight:900}.wo-stat-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;margin-top:3px}.wo-panel{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.wo-panel-hd{display:flex;align-items:center;gap:8px;padding:14px 20px;font-size:13px;font-weight:800;color:var(--text);border-bottom:1.5px solid var(--border);background:linear-gradient(135deg,var(--cream-dark),var(--cream));text-transform:uppercase;letter-spacing:.4px}.wo-panel-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.wo-dot-green{background:var(--green);box-shadow:0 0 6px #15803d66}.wo-dot-red{background:var(--red);box-shadow:0 0 6px #dc262666}.wo-dot-orange{background:var(--orange);box-shadow:0 0 6px var(--orange-glow)}.wo-count-pill{margin-left:auto;background:var(--orange);color:#fff;font-size:11px;font-weight:800;padding:3px 9px;border-radius:20px;box-shadow:0 2px 8px var(--orange-glow)}.wo-table{width:100%;border-collapse:collapse;font-size:13px}.wo-table th{padding:10px 14px;text-align:left;font-size:10px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;background:var(--cream);border-bottom:2px solid var(--border)}.wo-table td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text)}.wo-table tr:last-child td{border-bottom:none}.wo-table tbody tr{transition:background .1s}.wo-table tbody tr:hover{background:var(--cream-dark)}.wo-empty-row{padding:24px 20px;font-size:13px;color:var(--text-muted);font-style:italic;text-align:center}.wo-empty-state{grid-column:1/-1;text-align:center;padding:48px;color:var(--text-muted);font-size:14px}.wo-badge{display:inline-flex;align-items:center;font-size:10px;font-weight:800;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}.wo-badge-early{background:var(--blue-soft);color:var(--blue)}.wo-badge-on-time{background:var(--green-soft);color:var(--green)}.wo-badge-late{background:var(--red-soft);color:var(--red)}.wo-badge-overtime{background:var(--amber-soft);color:var(--amber)}.wo-badge-active{background:var(--green-soft);color:var(--green);animation:badgePulse 2s infinite}@keyframes badgePulse{0%,to{opacity:1}50%{opacity:.7}}.wo-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}.wo-hint-box{background:linear-gradient(135deg,var(--blue-soft),#e0f2fe);border:1px solid #bfdbfe;border-radius:var(--radius-sm);padding:10px 14px;font-size:12px;color:var(--blue);margin-bottom:16px}.wo-date-nav{display:flex;align-items:center;gap:8px;margin-bottom:18px;flex-wrap:wrap}.wo-date-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--border);border-radius:9px;background:var(--white);font-size:18px;color:var(--text-mid);cursor:pointer;transition:all .15s;line-height:1;box-shadow:var(--shadow-sm)}.wo-date-btn:hover{background:var(--orange);border-color:var(--orange);color:#fff;transform:scale(1.05);box-shadow:var(--shadow-orange)}.wo-date-display{display:flex;align-items:center;gap:10px}.wo-date-label{font-size:14px;font-weight:800;color:var(--text)}.wo-dash-date-hd{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,#1a1714,#2d2520);border-radius:var(--radius);padding:16px 24px;margin-bottom:24px;box-shadow:0 8px 24px #00000040,0 0 0 1px #e8471a33;flex-wrap:wrap}.wo-dash-date-centre{text-align:center;flex:1;min-width:160px}.wo-dash-day{font-family:Barlow Condensed,sans-serif;font-size:26px;font-weight:900;color:var(--orange);text-transform:uppercase;letter-spacing:2px;line-height:1;text-shadow:0 0 20px var(--orange-glow)}.wo-dash-date-str{font-size:13px;font-weight:600;color:#ffffffb3;margin-top:3px}.wo-dash-date-hd .wo-date-btn{background:#ffffff14;border-color:#ffffff26;color:#fff}.wo-dash-date-hd .wo-date-btn:hover{background:var(--orange);border-color:var(--orange)}.wo-dash-date-hd .wo-input{background:#ffffff1a;border-color:#ffffff26;color:#fff;width:160px}.wo-dash-date-hd .wo-btn-sm{background:#ffffff1a;border-color:#fff3;color:#fff}.wo-employee-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.wo-emp-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:14px;transition:all .2s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.wo-emp-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--orange),transparent);opacity:0;transition:opacity .2s}.wo-emp-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--orange-mid)}.wo-emp-card:hover:after{opacity:1}.wo-emp-inactive{opacity:.5}.wo-emp-avatar{width:48px;height:48px;border-radius:14px;flex-shrink:0;background:linear-gradient(135deg,var(--orange-soft),var(--orange-mid));border:2px solid var(--orange-mid);display:flex;align-items:center;justify-content:center;font-family:Barlow Condensed,sans-serif;font-size:19px;font-weight:900;color:var(--orange);box-shadow:0 4px 12px var(--orange-glow)}.wo-emp-info{flex:1;min-width:0}.wo-emp-name{font-size:14px;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wo-emp-uid{font-size:13px;font-weight:900;color:#e8471a;font-family:Barlow Condensed,monospace;letter-spacing:.5px}.wo-emp-role-badge{display:inline-block;margin-top:5px;font-size:10px;font-weight:800;padding:3px 8px;background:linear-gradient(135deg,var(--orange-soft),var(--orange-mid));color:var(--orange);border-radius:20px;text-transform:uppercase;letter-spacing:.4px;border:1px solid var(--orange-mid)}.wo-emp-actions{display:flex;align-items:center;gap:5px;flex-shrink:0}.wo-dash-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px;margin-bottom:16px}.wo-emp-dash-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm);transition:all .2s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.wo-emp-dash-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.wo-card-active{border-color:#86efac;background:linear-gradient(135deg,#fff,#f0fdf4);box-shadow:0 4px 16px #15803d1f}.wo-card-done{border-color:#c4b5fd;background:linear-gradient(135deg,#fff,#faf5ff)}.wo-card-off{opacity:.55;background:#f9fafb}.wo-card-standby{border-color:#fcd34d;background:linear-gradient(135deg,#fff,#fffbeb)}.wo-dc-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.wo-dc-avatar{width:46px;height:46px;border-radius:13px;flex-shrink:0;background:linear-gradient(135deg,var(--orange-soft),var(--orange-mid));border:2px solid var(--orange-mid);display:flex;align-items:center;justify-content:center;font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:900;color:var(--orange)}.wo-dc-info{flex:1;min-width:0}.wo-dc-name{font-size:14px;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wo-dc-role{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:1px;font-weight:700}.wo-dc-uid{font-size:13px;font-weight:900;color:#e8471a;font-family:Barlow Condensed,monospace;letter-spacing:.5px}.wo-dc-badges{display:flex;flex-direction:column;gap:3px;align-items:flex-end;flex-shrink:0}.wo-dc-row{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--text-mid);margin-bottom:5px;padding:5px 9px;background:var(--cream-dark);border-radius:7px}.wo-dc-row svg{flex-shrink:0}.wo-dc-row-live{background:var(--green-soft);color:var(--green);font-weight:700}.wo-dc-footer{margin-top:8px;padding:6px 10px;border-radius:7px;font-size:11px;font-weight:700}.wo-dc-footer-late{background:var(--red-soft);color:var(--red)}.wo-dc-footer-ot{background:var(--amber-soft);color:var(--amber)}.wo-shift-table{min-width:980px}.wo-input-cell{padding:6px 9px;font-size:12px;width:100%;min-width:0;border-radius:5px}.wo-cell-role{display:flex;align-items:center}.wo-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--orange)}.wo-row-off td{opacity:.55;background:#f9fafb}.wo-row-standby td{background:#fffbeb}.wo-total-hours-cell{font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:800;color:var(--orange)}.wo-template-add{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--cream-dark);flex-wrap:wrap}.wo-template-grid{display:flex;flex-wrap:wrap;gap:8px;padding:14px 18px;max-height:280px;overflow-y:auto}.wo-template-chip{background:var(--white);border:1.5px solid var(--border);border-radius:9px;padding:9px 13px;position:relative;min-width:150px;transition:all .15s;cursor:default;box-shadow:var(--shadow-sm)}.wo-template-chip:hover{border-color:var(--orange-mid);box-shadow:var(--shadow-md)}.wo-tpl-name{font-size:12px;font-weight:800;color:var(--text)}.wo-tpl-time{font-size:11px;color:var(--text-muted);margin-top:3px}.wo-tpl-del{position:absolute;top:5px;right:8px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--text-muted);line-height:1}.wo-tpl-del:hover{color:var(--red)}.wo-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#1a171499;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center}@media (min-width: 600px){.wo-modal-overlay{align-items:center}}.wo-modal{background:var(--white);width:100%;max-width:520px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:8px 24px 32px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg)}@media (min-width: 600px){.wo-modal{border-radius:var(--radius-lg);max-height:85vh}}.wo-modal-handle{width:40px;height:4px;border-radius:2px;background:var(--border-mid);margin:10px auto 20px}.wo-modal-title{font-family:Barlow Condensed,sans-serif;font-size:24px;font-weight:900;color:var(--text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:22px}.wo-modal-hint{background:var(--cream-dark);border-radius:var(--radius-sm);padding:10px 13px;font-size:12px;color:var(--text-muted);margin-bottom:12px}.wo-modal-uid-badge{background:var(--orange-soft);border:1.5px solid var(--orange-mid);border-radius:var(--radius-sm);padding:7px 13px;font-family:monospace;font-size:14px;font-weight:800;color:var(--orange);margin-bottom:18px;display:inline-block;letter-spacing:.5px}.wo-amend-employee{display:flex;justify-content:space-between;background:var(--cream-dark);padding:11px 13px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:13px}.wo-amend-warning{background:var(--amber-soft);border:1px solid #fde68a;border-radius:var(--radius-sm);padding:9px 13px;font-size:12px;color:var(--amber);margin-bottom:12px;font-weight:600}.wo-login{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,#faf6f0,#f2e8dc 40%,#faf8f4)}.wo-login-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(ellipse at 20% 20%,rgba(232,71,26,.12) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(232,71,26,.08) 0%,transparent 50%)}.wo-login-glow{position:absolute;top:-100px;left:50%;transform:translate(-50%);width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(232,71,26,.06),transparent 70%);pointer-events:none}.wo-login-wrap{position:relative;z-index:1;width:100%;max-width:440px;padding:0 24px}.wo-login-logo{text-align:center;margin-bottom:30px}.wo-logo-img{height:52px;width:auto;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(232,71,26,.2))}.wo-login-title{font-family:Barlow Condensed,sans-serif;font-size:36px;font-weight:900;color:var(--orange);text-transform:uppercase;letter-spacing:2px;margin-top:10px;text-shadow:0 4px 16px rgba(232,71,26,.2)}.wo-login-sub{font-size:13px;color:var(--text-muted);margin-top:2px}.wo-login-card{background:#ffffffeb;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1.5px solid rgba(255,255,255,.8);border-radius:20px;padding:28px;box-shadow:var(--shadow-lg),0 0 0 1px #e8471a0d}.wo-login-section-title{display:flex;align-items:center;gap:9px;font-size:11px;font-weight:900;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}.wo-login-section-title--toggle{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.wo-login-section-title--toggle:hover{color:var(--text)}.wo-divider{height:1.5px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:22px 0}.wo-error{font-size:12px;color:var(--red);font-weight:700;margin-bottom:12px;padding:9px 12px;background:var(--red-soft);border-radius:var(--radius-sm);border-left:3px solid var(--red)}.wo-admin-fields{display:flex;flex-direction:column;gap:10px}.wo-login-footer{text-align:center;font-size:11px;color:var(--text-muted);margin-top:24px}.wo-portal{min-height:100vh;background:linear-gradient(160deg,#faf6f0,#f2e8dc,#faf8f4);display:flex;flex-direction:column}.wo-portal-topbar{background:linear-gradient(135deg,#1a1714,#2d2520);border-bottom:2px solid var(--orange);display:flex;align-items:center;padding:0 22px;height:var(--topbar-h);gap:14px;box-shadow:0 4px 20px #00000040;position:sticky;top:0;z-index:100}.wo-portal-logo{height:30px;width:auto;object-fit:contain}.wo-portal-name{font-size:14px;font-weight:800;color:#fff;flex:1}.wo-portal-logout{display:flex;align-items:center;gap:7px;padding:7px 14px;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);background:#ffffff14;font-size:12px;font-weight:700;color:#ffffffb3;cursor:pointer;transition:all .15s}.wo-portal-logout:hover{background:var(--red-soft);color:var(--red);border-color:var(--red)}.wo-portal-body{flex:1;padding:30px 22px;max-width:500px;margin:0 auto;width:100%}.wo-portal-clock{font-family:Barlow Condensed,sans-serif;font-size:58px;font-weight:900;color:var(--text);letter-spacing:-2px;text-align:center;line-height:1;text-shadow:0 2px 8px rgba(0,0,0,.05)}.wo-portal-date{text-align:center;font-size:14px;color:var(--text-muted);font-weight:600;margin-top:4px;margin-bottom:26px}.wo-portal-emp-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 18px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-md);margin-bottom:18px}.wo-portal-emp-avatar{width:56px;height:56px;border-radius:16px;flex-shrink:0;background:linear-gradient(135deg,var(--orange-soft),var(--orange-mid));border:2px solid var(--orange-mid);display:flex;align-items:center;justify-content:center;font-family:Barlow Condensed,sans-serif;font-size:22px;font-weight:900;color:var(--orange);box-shadow:0 4px 14px var(--orange-glow)}.wo-portal-emp-name{font-size:18px;font-weight:900;color:var(--text)}.wo-portal-emp-role{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}.wo-portal-emp-id{font-size:11px;color:var(--text-muted);font-family:monospace}.wo-portal-shift{background:linear-gradient(135deg,var(--orange-soft),var(--orange-mid));border:1.5px solid var(--orange-mid);border-radius:var(--radius);padding:16px;margin-bottom:18px;text-align:center;box-shadow:0 4px 16px var(--orange-glow)}.wo-portal-shift-label{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:1px;color:var(--orange);margin-bottom:5px}.wo-portal-shift-times{font-family:Barlow Condensed,sans-serif;font-size:30px;font-weight:900;color:var(--text)}.wo-portal-shift-note{font-size:12px;color:var(--text-muted);margin-top:4px}.wo-portal-no-shift{background:var(--cream-dark);border:2px dashed var(--border-mid);border-radius:var(--radius);padding:16px;margin-bottom:18px;text-align:center;font-size:13px;color:var(--text-muted)}.wo-portal-active{background:linear-gradient(135deg,var(--green-soft),#bbf7d0);border:1.5px solid #86efac;border-radius:var(--radius);padding:14px 18px;margin-bottom:18px;display:flex;align-items:center;gap:14px;box-shadow:0 4px 16px #15803d1f}.wo-active-dot{width:11px;height:11px;border-radius:50%;background:var(--green);flex-shrink:0;animation:pulse 1.5s infinite;box-shadow:0 0 8px #15803d80}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.wo-active-label{font-size:14px;font-weight:800;color:var(--green)}.wo-active-duration{font-size:12px;color:#15803d;margin-top:2px;font-weight:600}.wo-clock-btn{width:100%;padding:20px;font-family:Barlow Condensed,sans-serif;font-size:24px;font-weight:900;letter-spacing:1px;text-transform:uppercase;border-radius:var(--radius);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .2s cubic-bezier(.34,1.56,.64,1);margin-bottom:26px}.wo-clock-btn-in{background:linear-gradient(135deg,var(--orange),var(--orange-dark));color:#fff;box-shadow:var(--shadow-orange)}.wo-clock-btn-in:hover{transform:translateY(-3px) scale(1.01);box-shadow:0 12px 36px #e8471a73}.wo-clock-btn-out{background:linear-gradient(135deg,#1a1714,#2d2520);color:#fff;box-shadow:0 6px 20px #0000004d}.wo-clock-btn-out:hover{transform:translateY(-3px) scale(1.01);box-shadow:0 12px 36px #0006}.wo-clock-btn:active{transform:translateY(2px) scale(.99)}.wo-portal-history-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);margin-bottom:12px}.wo-portal-hist-row{background:var(--white);border:1.5px solid var(--border);border-radius:9px;padding:11px 15px;margin-bottom:8px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;transition:all .15s}.wo-portal-hist-row:hover{border-color:var(--orange-mid);box-shadow:var(--shadow-sm)}.wo-portal-hist-date{font-size:11px;font-weight:800;color:var(--text-muted);min-width:80px}.wo-portal-hist-times{font-size:12px;color:var(--text);flex:1;font-weight:600}.wo-portal-hist-badges{display:flex;gap:4px;flex-wrap:wrap}.wo-nfc-wrap{padding:28px 34px;max-width:660px}.wo-nfc-header{margin-bottom:28px}.wo-nfc-title{font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:900;text-transform:uppercase;letter-spacing:.5px}.wo-nfc-sub{font-size:13px;color:var(--text-muted);margin-top:3px}.wo-nfc-puck{width:200px;height:200px;border-radius:50%;margin:0 auto 28px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.wo-nfc-puck:hover{transform:scale(1.06)}.wo-nfc-puck-idle{background:linear-gradient(135deg,var(--orange-soft),var(--orange-mid));border:4px solid var(--orange);box-shadow:var(--shadow-orange),inset 0 2px 8px #ffffff80}.wo-nfc-puck-scanning{background:linear-gradient(135deg,var(--blue-soft),#bfdbfe);border:4px solid var(--blue);animation:puckPulse 1s infinite;box-shadow:0 8px 30px #2563eb4d}.wo-nfc-puck-success{background:linear-gradient(135deg,var(--green-soft),#bbf7d0);border:4px solid var(--green);box-shadow:0 8px 30px #15803d40}.wo-nfc-puck-error{background:linear-gradient(135deg,var(--red-soft),#fecaca);border:4px solid var(--red);box-shadow:0 8px 30px #dc262640}@keyframes puckPulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.wo-nfc-ring{position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;border:2px dashed currentColor;opacity:.2;animation:spin 8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.wo-nfc-icon{font-size:46px;margin-bottom:4px}.wo-nfc-puck-label{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.wo-spin{display:inline-block;animation:spin .8s linear infinite}.wo-nfc-result{border-radius:var(--radius);padding:18px 22px;margin-bottom:22px}.wo-nfc-result-success{background:var(--green-soft);border:2px solid #86efac}.wo-nfc-result-error{background:var(--red-soft);border:2px solid #fca5a5}.wo-nfc-emp{display:flex;align-items:center;gap:13px;margin-bottom:12px}.wo-nfc-emp-avatar{width:48px;height:48px;border-radius:13px;background:var(--white);border:2px solid var(--green);display:flex;align-items:center;justify-content:center;font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:900;color:var(--green);box-shadow:0 2px 8px #15803d33}.wo-nfc-emp-name{font-size:16px;font-weight:900}.wo-nfc-emp-role{font-size:11px;color:var(--text-muted);text-transform:uppercase;font-weight:700}.wo-nfc-msg{font-size:15px;font-weight:800;margin-bottom:5px}.wo-nfc-note{font-size:12px;color:var(--text-muted);margin-bottom:5px}.wo-nfc-worked{font-family:Barlow Condensed,sans-serif;font-size:24px;font-weight:900;color:var(--orange)}.wo-nfc-reset-hint{font-size:11px;color:var(--text-muted);font-style:italic}.wo-nfc-manual{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:22px;box-shadow:var(--shadow-sm)}.wo-nfc-manual-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);margin-bottom:12px}.wo-nfc-manual-row{display:flex;gap:10px}.wo-nfc-today{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.wo-nfc-emp-list{padding:8px 0}.wo-nfc-active-row{display:flex;align-items:center;gap:9px;padding:9px 20px;font-size:13px;font-weight:700}.wo-nfc-emp-dot{width:9px;height:9px;border-radius:50%;background:var(--green);animation:pulse 1.5s infinite;box-shadow:0 0 6px #15803d66}.wo-nfc-date-hd{background:linear-gradient(135deg,#1a1714,#2d2520);border-radius:var(--radius);padding:14px 20px;margin-bottom:22px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 6px 20px #0003}.wo-nfc-date-hd-day{font-family:Barlow Condensed,sans-serif;font-size:22px;font-weight:900;color:var(--orange);text-transform:uppercase;letter-spacing:1px}.wo-nfc-date-hd-date{font-size:13px;font-weight:600;color:#ffffffb3;margin-top:2px}.wo-toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%) translateY(80px);min-width:260px;max-width:400px;border-radius:12px;padding:14px 20px;font-size:13px;font-weight:700;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:11px;transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .25s;opacity:0;z-index:9999}.wo-toast.show{transform:translate(-50%) translateY(0);opacity:1}.wo-toast--success{background:#14532d;color:#dcfce7;border-left:4px solid var(--green)}.wo-toast--error{background:#7f1d1d;color:#fee2e2;border-left:4px solid var(--red)}.wo-toast--info{background:#1e3a5f;color:#dbeafe;border-left:4px solid var(--blue)}.wo-toast-icon{font-size:16px;font-weight:900}@media (max-width: 768px){.wo-sidebar{display:none}.wo-tab-content{padding:18px}.wo-dash-card-grid{grid-template-columns:1fr}.wo-stat-grid{grid-template-columns:repeat(2,1fr)}.wo-form-row{grid-template-columns:1fr}}.wo-total-hours-actual{color:var(--green)!important}.wo-total-hours-cell{font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:900;color:var(--orange)}
