*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-bg:#161b27;--sidebar-border:#2a3347;--sidebar-text:#8892a8;--sidebar-text-active:#4f8ef7;--sidebar-active-bg:#4f8ef71f;--sidebar-hover-bg:#1e2535;--sidebar-label:#5a6580;--sidebar-logo-sub:#5a6580;--bg:#0d1018;--bg2:#161b27;--bg3:#1e2535;--bg4:#252d3f;--border:#2a3347;--border2:#374057;--text:#e8eaf0;--text2:#8892a8;--text3:#5a6580;--accent:#4f8ef7;--accent2:#3a72d4;--accent-dim:#4f8ef71f;--green:#3ecf8e;--green-dim:#3ecf8e1f;--red:#f75f5f;--red-dim:#f75f5f1f;--yellow:#f7c948;--yellow-dim:#f7c9481f;--orange:#f79a4f;--font:"DM Sans",system-ui,sans-serif;--mono:"DM Mono",monospace;--radius:8px;--shadow:0 4px 24px #0006}:root[data-theme=light]{--sidebar-bg:#193656;--sidebar-border:#1d3f65;--sidebar-text:#44c0e8b3;--sidebar-text-active:#44c0e8;--sidebar-active-bg:#44c0e826;--sidebar-hover-bg:#ffffff12;--sidebar-label:#44c0e873;--sidebar-logo-sub:#44c0e880;--bg:#fff;--bg2:#fff;--bg3:#f4f6fa;--bg4:#e8ecf4;--border:#d0d8e4;--border2:#b8c4d4;--text:#193656;--text2:#2a4a6e;--text3:#4a6a8e;--accent:#193656;--accent2:#0f2640;--accent-dim:#1936561f;--green:#1a7a4a;--green-dim:#1a7a4a1f;--red:#c33;--red-dim:#cc33331f;--yellow:#c80;--yellow-dim:#cc88001f;--orange:#c60;--shadow:0 4px 24px #00000026}#root,body,html{-webkit-font-smoothing:antialiased;background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;height:100%;line-height:1.6}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);min-width:240px;overflow-y:auto;width:240px}.sidebar,.sidebar-logo{display:flex;flex-direction:column}.sidebar-logo{border-bottom:1px solid var(--sidebar-border);gap:5px;padding:16px 18px 14px}.sidebar-logo img{display:block;height:38px;max-width:200px;object-fit:contain;object-position:left center;width:auto}.sidebar-logo span{color:var(--sidebar-logo-sub);font-size:10px;letter-spacing:1.1px;padding-left:2px;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:10px 0}.nav-group{margin-bottom:2px}.nav-group-header{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;gap:0;padding:5px 14px 5px 20px;transition:color .12s,background .12s;width:100%}.nav-group-header:hover{background:var(--sidebar-hover-bg)}.nav-group-header.has-active,.nav-group-header:hover{color:var(--sidebar-text-active)}.nav-group-label-text{flex:1 1;font-size:10px;font-weight:600;letter-spacing:1.2px;text-align:left;text-transform:uppercase}.nav-group-active-dot{background:var(--accent);border-radius:50%;flex-shrink:0;height:5px;margin-right:6px;width:5px}.nav-group-chevron{align-items:center;display:flex;opacity:.5;transition:transform .2s ease}.nav-group-header:hover .nav-group-chevron{opacity:1}.nav-group-body{max-height:400px;opacity:1;overflow:hidden;transition:max-height .22s ease,opacity .18s ease}.nav-group-body.collapsed{max-height:0;opacity:0}.nav-link{align-items:center;border-left:2px solid #0000;color:var(--sidebar-text);display:flex;font-size:13.5px;font-weight:450;gap:10px;padding:8px 20px;text-decoration:none;transition:background .12s,color .12s,border-color .12s}.nav-link:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text-active)}.nav-link.active{background:var(--sidebar-active-bg);border-left-color:var(--sidebar-text-active);color:var(--sidebar-text-active)}.nav-link svg{flex-shrink:0;opacity:.7}.nav-link.active svg,.nav-link:hover svg{opacity:1}.sidebar-user{border-top:1px solid var(--sidebar-border);gap:7px;padding:11px 13px}.avatar,.sidebar-user{align-items:center;display:flex}.avatar{background:var(--sidebar-text-active);border-radius:50%;color:var(--sidebar-bg);flex-shrink:0;font-size:12px;font-weight:700;height:32px;justify-content:center;width:32px}.sidebar-user-info{flex:1 1;min-width:0}.sidebar-user-info .name{color:var(--sidebar-text-active);font-size:12.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-info .role{color:var(--sidebar-label);font-size:10px;text-transform:capitalize}.btn-sidebar-icon,.theme-toggle{align-items:center;background:#0000;border:1px solid var(--sidebar-border);border-radius:6px;color:var(--sidebar-text);cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:28px;justify-content:center;padding:0;transition:background .12s,color .12s;width:28px}.theme-toggle:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text-active)}.btn-sidebar-icon{border-color:#0000}.btn-sidebar-icon:hover{background:var(--sidebar-hover-bg);color:var(--red)}.main-content{background:var(--bg);flex:1 1;overflow-y:auto}.page,.page-container{margin-left:20px;max-width:100%;padding:28px 32px}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.page-header h2{color:var(--text);font-size:22px;font-weight:600;letter-spacing:-.3px}.page-header p{color:var(--text2);font-size:13px;margin-top:3px}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 1px 4px #0000000f;padding:20px}.card-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:14px}.card-title{color:var(--text);font-size:14px;font-weight:600}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));margin-bottom:24px}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 1px 4px #0000000f;padding:16px 18px}.stat-label{color:var(--text3);font-size:11px;letter-spacing:.8px;margin-bottom:6px;text-transform:uppercase}.stat-value{color:var(--text);font-family:var(--mono);font-size:26px;font-weight:700;letter-spacing:-1px}.stat-sub{color:var(--text2);font-size:12px;margin-top:4px}.stat-card.green .stat-value{color:var(--green)}.stat-card.blue .stat-value{color:var(--accent)}.stat-card.yellow .stat-value{color:var(--yellow)}.stat-card.red .stat-value{color:var(--red)}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}th{background:var(--bg3);color:var(--text3);font-size:11px;font-weight:600;letter-spacing:.8px;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}td,th{border-bottom:1px solid var(--border)}td{color:var(--text);font-size:13.5px;padding:11px 14px;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg3)}.badge{align-items:center;border-radius:4px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.5px;padding:3px 8px;text-transform:uppercase}.badge.green{background:var(--green-dim);color:var(--green)}.badge.red{background:var(--red-dim);color:var(--red)}.badge.blue{background:var(--accent-dim);color:var(--accent)}.badge.yellow{background:var(--yellow-dim);color:var(--yellow)}.badge.gray{background:#5a658026;color:var(--text2)}.badge.orange{background:#f79a4f1f;color:var(--orange)}.btn{align-items:center;border:none;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-family:var(--font);font-size:13.5px;font-weight:500;gap:6px;padding:8px 16px;text-decoration:none;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}.btn-secondary{background:var(--bg3);border:1px solid var(--border);color:var(--text)}.btn-secondary:hover{background:var(--bg4);border-color:var(--border2)}.btn-danger{background:var(--red-dim);border:1px solid #f75f5f33;color:var(--red)}.btn-danger:hover{background:#f75f5f33}.btn-ghost{background:#0000;color:var(--text2);padding:6px 10px}.btn-ghost:hover{background:var(--bg3);color:var(--text)}.btn-sm{font-size:12.5px;padding:5px 12px}.btn:disabled{cursor:not-allowed;opacity:.5}.form-group{margin-bottom:16px}.form-label{color:var(--text2);display:block;font-size:12.5px;font-weight:500;margin-bottom:6px}.form-input,.form-select,.form-textarea{-webkit-appearance:none;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:13.5px;outline:none;padding:9px 12px;transition:border-color .15s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-select{cursor:pointer}.form-select option{background:var(--bg3);color:var(--text)}.form-textarea{min-height:80px;resize:vertical}.form-input::placeholder{color:var(--text3)}.form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.form-row.three{grid-template-columns:1fr 1fr 1fr}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#000000a6;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{background:var(--bg2);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px 16px}.modal-title{font-size:16px;font-weight:600}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;padding:16px 24px}.filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.filters-bar .form-input,.filters-bar .form-select{min-width:140px;width:auto}.alert{align-items:flex-start;border-radius:var(--radius);display:flex;font-size:13.5px;gap:10px;margin-bottom:16px;padding:12px 16px}.alert.error{background:var(--red-dim);border:1px solid #f75f5f33;color:var(--red)}.alert.success{background:var(--green-dim);border:1px solid #3ecf8e33;color:var(--green)}.alert.info{background:var(--accent-dim);border:1px solid #4f8ef733;color:var(--accent)}.spinner{animation:spin .7s linear infinite;border:2px solid var(--border);border-radius:50%;border-top-color:var(--accent);display:inline-block;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.loading-center{align-items:center;display:flex;justify-content:center;padding:60px}.tabs{border-bottom:1px solid var(--border);display:flex;gap:2px;margin-bottom:20px}.tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--text2);cursor:pointer;font-family:var(--font);font-size:13.5px;font-weight:450;margin-bottom:-1px;padding:9px 16px;transition:all .15s}.tab:hover{color:var(--text)}.tab.active{border-bottom-color:var(--accent);color:var(--accent)}.empty-state{color:var(--text3);padding:48px 20px;text-align:center}.empty-state svg{margin-bottom:12px;opacity:.3}.empty-state p{font-size:14px}.text-muted{color:var(--text2)}.text-small{font-size:12px}.mono{font-family:var(--mono)}.flex{display:flex}.flex-center{align-items:center;display:flex}.gap-2{gap:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.type-work{color:var(--accent)}.type-sick_leave{color:var(--red)}.type-annual_leave{color:var(--green)}.type-public_holiday{color:var(--yellow)}.type-other_absence{color:var(--orange)}.type-training{color:#b48efa}.progress-bar-wrap{background:var(--bg4);border-radius:3px;height:6px;margin-top:6px;overflow:hidden}.progress-bar{background:var(--accent);border-radius:3px;height:100%;transition:width .5s ease}.progress-bar.over{background:var(--red)}.progress-bar.warn{background:var(--yellow)}.mobile-menu-btn{align-items:center;background:var(--sidebar-bg);border:1px solid var(--sidebar-border);border-radius:10px;box-shadow:0 2px 12px #0000004d;color:var(--sidebar-text-active);cursor:pointer;display:none;font-size:18px;height:40px;justify-content:center;left:12px;position:fixed;top:12px;transition:background .15s;width:40px;z-index:300}.mobile-menu-btn:hover{background:var(--sidebar-hover-bg)}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000008c;display:none;inset:0;position:fixed;z-index:199}@media (max-width:768px){.mobile-menu-btn{display:flex}.sidebar{box-shadow:4px 0 32px #0006;height:100vh;left:0;position:fixed;top:0;transform:translateX(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1);z-index:200}.sidebar.open{transform:translateX(0)}.sidebar-overlay.open{display:block}.main-content{width:100%}.page{padding:72px 16px 24px}.page-header{flex-direction:column;gap:12px}.page-header h2{font-size:20px}.card{padding:14px}.card-header{flex-wrap:wrap;gap:8px}.stats-grid{gap:8px;grid-template-columns:repeat(2,1fr)}.stat-value{font-size:20px}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}table{min-width:500px}td,th{font-size:12.5px;padding:9px 10px}.form-row,.form-row.three{grid-template-columns:1fr}.filters-bar{gap:8px}.filters-bar .form-input,.filters-bar .form-select{flex:1 1;min-width:0}.modal{border-radius:12px;margin:0 8px;max-width:100%}.modal-overlay{align-items:flex-end;padding:12px}.modal{border-radius:16px 16px 0 0;max-height:92vh}.btn{font-size:13px;padding:8px 14px}.btn-sm{font-size:12px;padding:5px 10px}.tabs{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.tab{padding:8px 12px;white-space:nowrap}.page-header>div:last-child{width:100%}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr 1fr}.stat-value{font-size:18px}.page{padding:68px 12px 20px}}@media (max-width:600px){.branding-grid{grid-template-columns:1fr!important}}.calendar-grid{grid-gap:14px;display:grid;flex:1 1;gap:14px;grid-template-columns:repeat(3,1fr)}@media (max-width:1300px){.calendar-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:860px){.calendar-grid{grid-template-columns:1fr}}.month-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 1px 4px #0000000f;padding:14px}.month-title{color:var(--text);font-size:14px;font-weight:700;letter-spacing:.3px;margin-bottom:10px;text-align:center}.month-grid{grid-gap:1px;display:grid;gap:1px;grid-template-columns:22px repeat(7,1fr)}.day-header{color:var(--text3);font-size:10px;font-weight:700;letter-spacing:.5px;padding:2px 0 5px;text-align:center;text-transform:uppercase}.cw-cell{color:var(--text3);font-size:9px;opacity:.7;padding:2px 0}.cw-cell,.day-cell{align-items:center;display:flex;justify-content:center}.day-cell{border-radius:5px;cursor:pointer;min-height:30px;transition:background .1s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.day-cell:hover .day-inner{background:var(--bg4);border-radius:4px}.day-cell.out-month{cursor:default;opacity:.2}.day-cell.weekend{cursor:default;opacity:.45}.day-cell.today .day-num{align-items:center;background:var(--accent);border-radius:50%;color:#fff;display:flex;font-weight:700;height:22px;justify-content:center;width:22px}.day-cell.selected .day-inner{background:var(--accent-dim);border-radius:4px;outline:1.5px solid var(--accent)}.day-cell.holiday{background:var(--yellow-dim)}.day-cell.holiday .day-num{color:var(--yellow);font-weight:700}.day-inner{align-items:center;border-radius:4px;display:flex;height:100%;justify-content:center;min-height:28px;padding:2px;width:100%}.day-num{color:var(--text2);font-size:11.5px;line-height:1}.holiday-cell .day-num{color:var(--yellow);font-weight:700}.leave-icon{font-size:13px;line-height:1}.allowance-sidebar{display:flex;flex-direction:column}.allowance-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.allowance-title{color:var(--text3);font-size:11px;font-weight:700;letter-spacing:.7px;margin-bottom:10px;text-transform:uppercase}.allowance-table{border-collapse:collapse;font-size:12px;width:100%}.allowance-table td{color:var(--text2);padding:3px 4px}.al-label{color:var(--text3)}.al-val{color:var(--text);font-weight:700;padding-right:6px!important;text-align:right}.al-remaining{align-items:center;color:var(--text2);display:flex;font-size:12px;justify-content:space-between;margin-top:8px}.al-remaining strong{font-size:20px}.dashboard-table th{font-size:11px;padding:6px 4px}.dashboard-table tbody tr:hover td{filter:brightness(1.05)}.dashboard-table{border-collapse:collapse;font-size:12.5px;min-width:700px;width:100%}.dashboard-table th{background:var(--bg3);border-bottom:1px solid var(--border);color:var(--text2);font-size:10px;font-weight:600;letter-spacing:0;padding:5px 2px;position:-webkit-sticky;position:sticky;text-transform:none;top:0;white-space:nowrap;z-index:2}.dashboard-table td{border:none;padding:0;vertical-align:middle}.project-view-desktop{display:block}.project-view-mobile{display:none}@media (max-width:900px){.project-view-desktop{display:none}.project-view-mobile{display:block}}@media (max-width:1200px) and (min-width:901px){.kpi-ytd-grid{grid-template-columns:repeat(3,1fr)!important}}@media (max-width:900px){.kpi-annual-grid,.kpi-ytd-grid{grid-template-columns:repeat(2,1fr)!important}}.cal-grid{border-collapse:initial;border-spacing:3px;table-layout:fixed;width:100%}.cal-grid th{background:#0000;border:none;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:1px;padding:6px 0;text-align:center;text-transform:uppercase}.cal-grid th.weekend{color:var(--text3)}.cal-grid th.weekday{color:var(--text2)}.cal-cell{background:var(--bg2);border:1px solid var(--border);border-radius:8px;min-height:88px;overflow:hidden;padding:0;transition:box-shadow .1s,border-color .1s;vertical-align:top}.cal-cell:hover{border-color:var(--accent);box-shadow:0 2px 8px #4f8ef71f;position:relative;z-index:1}.cal-cell.other-month{background:var(--bg3);opacity:.4}.cal-cell.weekend{background:var(--bg3)}.cal-cell.today{background:var(--bg2);border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.cal-cell.holiday{background:#f7c9480f}.cal-cell.future{opacity:.85}.cal-date-num{align-items:center;display:flex;gap:4px;justify-content:space-between;padding:5px 6px 3px}.cal-date-label{color:var(--text);font-size:12px;font-weight:500;line-height:1;min-width:20px;text-align:center}.cal-date-label.today-dot{align-items:center;background:var(--accent);border-radius:50%;color:#fff;display:flex;font-weight:700;height:22px;justify-content:center;width:22px}.cal-date-label.weekend-num{color:var(--text3)}.cal-date-label.holiday-num{color:var(--yellow)}.cal-hours-badge{border-radius:10px;font-family:var(--mono);font-size:10px;font-weight:700;line-height:1.4;padding:2px 6px;white-space:nowrap}.cal-hours-badge.full{background:var(--green-dim);color:var(--green)}.cal-hours-badge.part{background:var(--accent-dim);color:var(--accent)}.cal-holiday-label{color:var(--yellow);padding:0 6px 2px}.cal-holiday-label,.cal-leave-bar{font-size:9px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-leave-bar{border-left-style:solid;border-left-width:3px;border-radius:3px;margin:1px 5px;padding:2px 5px}.cal-records{display:flex;flex-direction:column;gap:2px;padding:3px 4px 4px}.cal-record-chip{border-left-style:solid;border-left-width:2px;border-radius:3px;cursor:default;font-size:9px;overflow:hidden;padding:2px 5px;text-overflow:ellipsis;white-space:nowrap}.cal-overflow{color:var(--text3);font-size:9px;padding:0 5px 2px}.cal-legend{align-items:center;border-top:1px solid var(--border);color:var(--text2);display:flex;flex-wrap:wrap;font-size:11px;gap:14px;margin-top:14px;padding-top:12px}.cal-legend-dot{border-radius:3px;border-style:solid;border-width:2px;flex-shrink:0;height:11px;width:11px}.cal-nav{align-items:center;display:flex;gap:12px;margin-bottom:16px}.cal-nav-title{color:var(--text);font-size:16px;font-weight:700;min-width:160px;text-align:center}.usertour-widget-beacon__core,.usertour-widget-beacon__halo{display:none!important}.usertour-widget-launcher.usertour-widget-beacon:before{background-image:url();background-position:50%;background-repeat:no-repeat;background-size:contain;content:"";cursor:pointer;display:block;height:var(--usertour-widget-beacon-size,32px);width:var(--usertour-widget-beacon-size,32px)}
/*# sourceMappingURL=main.44e3ba15.css.map*/