@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_f367f3;font-style:normal;font-weight:100 900;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_Fallback_f367f3;src:local("Arial");ascent-override:90.49%;descent-override:22.56%;line-gap-override:0.00%;size-adjust:107.06%}.__className_f367f3{font-family:__Inter_f367f3,__Inter_Fallback_f367f3;font-style:normal}.__variable_f367f3{--font-inter:"__Inter_f367f3","__Inter_Fallback_f367f3"}:root{--bg:#f4f6f8;--card:#fff;--text:#101828;--muted:#667085;--line:#e7eaee;--green:#12b76a;--yellow:#fdb022;--red:#f04438;--dark:#111827;--shadow:0 10px 26px rgba(16,24,40,.06);--radius:18px;--sidebar:270px;--sidebar-c:90px}*{box-sizing:border-box}body,html{height:100%}body{margin:0;font-family:var(--font-inter),system-ui,-apple-system,Segoe UI,Roboto,Arial,"Noto Sans";background:var(--bg);color:var(--text);font-weight:400;line-height:1.4}.semibold,b{font-weight:600}.muted{color:#98a2b3;font-weight:500}.muted i{font-size:12px;vertical-align:-1px}.layout,.sidebar{display:flex;min-height:100vh}.sidebar{width:var(--sidebar);flex:0 0 var(--sidebar);min-width:var(--sidebar);background:#fff;border-right:1px solid var(--line);padding:16px 14px;flex-direction:column;gap:14px;position:-webkit-sticky;position:sticky;top:0;align-self:stretch;transition:width .22s ease}.sidebar.collapsed{width:var(--sidebar-c);flex:0 0 var(--sidebar-c);min-width:var(--sidebar-c)}.sidebar.collapsed .sb-txt{display:none}.sidebar.collapsed .sb-toggle{position:absolute;right:-14px;top:18px}.sb-header{display:flex;align-items:center;justify-content:space-between;gap:10px;position:relative}.sb-logo{width:50px;height:50px;border-radius:16px;display:grid;place-items:center;overflow:hidden;background:rgba(18,183,106,.12);color:#0c8a5a;font-weight:700;letter-spacing:.6px}.sb-logo img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.sb-menu{display:flex;flex-direction:column;gap:6px;margin-top:6px;flex:1 1 auto;min-height:0;overflow-y:auto}.sb-link{display:flex;align-items:center;gap:12px;padding:12px;border-radius:14px;text-decoration:none;color:var(--muted);font-weight:500;transition:background .14s ease,color .14s ease}.sb-link:hover{background:#f6f7f9;color:#253043}.sb-link.active{background:rgba(18,183,106,.12);color:#0c8a5a;font-weight:600}.sb-ic{width:24px;display:inline-flex;align-items:center;justify-content:center}.sb-ic i{font-size:18px;line-height:1}.sb-group{width:100%;background:transparent;border:none;text-align:left;cursor:pointer;font:inherit;color:inherit}.sb-caret{margin-left:auto;opacity:.6;display:inline-flex;align-items:center}.sb-caret,.sb-caret i{font-size:12px}.sb-sub{display:none;flex-direction:column;gap:4px;padding-left:12px}.sb-sub.open{display:flex}.sb-sub .sb-link{padding:10px 12px;font-size:13px}.sidebar.collapsed .sb-caret,.sidebar.collapsed .sb-sub{display:none}.sb-footer{margin-top:auto}.meeting{border:1px solid var(--line);border-radius:var(--radius);padding:14px;background:linear-gradient(180deg,#f8fbff,#fff);box-shadow:0 10px 22px rgba(16,24,40,.04)}.meeting-avatars{display:flex;margin-bottom:10px}.av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#d1fadf,#b2ddff);border:2px solid #fff;margin-left:-8px}.av:first-child{margin-left:0}.meeting-title{font-weight:600}.meeting-sub{color:var(--muted);font-size:12px;margin:4px 0 10px}.main{flex:1 1;min-width:0;padding:18px 18px 26px}.topbar{justify-content:space-between;gap:14px;padding:10px 10px 18px}.search,.topbar{display:flex;align-items:center}.search{gap:10px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 14px;width:100%;max-width:560px;box-shadow:0 10px 22px rgba(16,24,40,.04)}.search input{width:100%;border:none;outline:none;font-size:14px;background:transparent;color:var(--text)}.search .s-ic{opacity:.6;display:inline-flex;align-items:center}.search .s-ic i{font-size:14px}.search-sm{max-width:240px;padding:8px 12px}.top-actions{display:flex;align-items:center;gap:10px}.icon-btn{width:42px;height:42px;border-radius:999px;border:1px solid var(--line);background:#fff;cursor:pointer;box-shadow:0 10px 22px rgba(16,24,40,.04);display:grid;place-items:center}.icon-btn.small{width:34px;height:34px;box-shadow:none}.icon-btn:hover{transform:translateY(-1px)}.icon-btn i{font-size:18px;line-height:1}.icon-btn.small i{font-size:14px}.notif,.notif-btn{position:relative}.notif-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#d92d20;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.notif-menu{position:absolute;right:0;top:52px;width:320px;max-width:calc(100vw - 32px);background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:12px;display:none;z-index:90}.notif-menu.show{display:block}.notif-head{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:13px;font-weight:700;margin-bottom:8px}.notif-meta{font-weight:500;font-size:11px;color:var(--muted)}.notif-list{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow:auto;padding-right:2px}.notif-item{display:flex;gap:10px;align-items:flex-start;padding:10px;border-radius:12px;text-decoration:none;color:var(--text)}.notif-item:hover{background:#f6f7f9}.notif-body{display:flex;flex-direction:column;gap:2px}.notif-title{font-size:13px;font-weight:600}.notif-desc{font-size:12px;color:var(--muted)}.notif-count{min-width:32px;height:24px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;background:#344054}.notif-item.warning .notif-count{background:#f79009}.notif-item.danger .notif-count{background:#d92d20}.notif-item.info .notif-count{background:#2e90fa}.notif-empty{padding:14px;text-align:center;font-size:12px;color:var(--muted)}.notif-empty.error{color:#b42318}.user{position:relative;display:flex;align-items:center;gap:10px;padding:6px 8px;border:1px solid var(--line);border-radius:999px;background:#fff;box-shadow:0 10px 22px rgba(16,24,40,.04);z-index:60}.user-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#b2ddff,#d1fadf);display:grid;place-items:center;overflow:hidden;color:#475467;font-weight:700;font-size:14px}.user-av img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.user-meta{line-height:1.1}.user-name{font-weight:600;font-size:14px}.user-role{color:var(--muted);font-size:12px;font-weight:400}.dropdown{position:absolute;right:10px;top:54px;width:170px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;display:none;z-index:80}.dropdown a,.dropdown.show{display:block}.dropdown a{padding:10px;border-radius:12px;text-decoration:none;color:var(--text);font-weight:500;font-size:13px}.dropdown a:hover{background:#f6f7f9}.dropdown .danger{color:var(--red)}.dropdown .sep{height:1px;background:var(--line);margin:6px 0}.btn{border-radius:12px;border:none;padding:10px 14px;font-weight:600;cursor:pointer;font-size:13px}.btn,.btn:active,.btn:focus,.btn:hover,.btn:visited{text-decoration:none}.btn-primary{background:#12b76a;color:#fff;box-shadow:var(--shadow)}.btn-dark{background:#111827;color:#fff}.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--text)}.btn-sm{padding:8px 12px;border-radius:10px}.btn:hover{transform:translateY(-1px)}.btn-icon{display:inline-flex;align-items:center;gap:6px}.btn-icon i{font-size:12px}.btn-icon-only{width:34px;height:34px;padding:0;display:inline-flex;align-items:center;justify-content:center}.btn-icon-only i{font-size:14px}.lock-on{color:#12b76a}.lock-off{color:#f04438}.w-full{width:100%}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.card-title{font-weight:700}.card-right{display:flex;align-items:center;gap:12px}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:12px;gap:12px}.link-card{display:block;text-decoration:none;color:inherit;transition:transform .12s ease,box-shadow .12s ease}.link-card .card-head{margin-bottom:0}.link-card:hover{transform:translateY(-1px);box-shadow:0 14px 28px rgba(16,24,40,.08)}.kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:12px;gap:12px}.kpi{padding:14px}.kpi-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.kpi-title{color:var(--muted);font-weight:600;font-size:13px}.kpi-body{display:flex;align-items:flex-end;gap:10px}.kpi-value{font-size:38px;font-weight:700}.kpi-desc{color:var(--muted);font-size:13px}.pill{padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600}.pill-green{background:rgba(18,183,106,.12);color:#0c8a5a}.pill-yellow{background:rgba(253,176,34,.12);color:#ab7105}.pill-red{background:rgba(240,68,56,.12);color:#9d1c15}.spark{display:flex;gap:4px;align-items:flex-end;height:46px;margin-top:12px}.spark .sp{width:8px;border-radius:999px;background:#d9e1ec}.spark .sp:nth-child(odd){opacity:.7}.progress{background:#f1f4f8;border-radius:999px;height:10px;margin-top:14px}.progress .bar{height:100%;border-radius:999px;background:rgba(240,68,56,.9)}.content{display:flex;flex-direction:column;gap:12px}.grid-bot,.grid-mid{display:grid;grid-template-columns:2fr 1fr;grid-gap:12px;gap:12px}.grid-bot{grid-template-columns:1.1fr 1.6fr}.dashboard-card .card-title{font-size:16px}.dashboard-card .card-head{gap:10px}.dashboard-leave .li-title{font-size:14px}.dashboard-leave .li-sub{font-size:12px}.dashboard-attendance .chart-wrap,.dashboard-card{max-width:100%;overflow:hidden}.dashboard-attendance canvas{display:block;max-width:100%}.dashboard-leave .li-left,.dashboard-leave .li-txt{min-width:0}.dashboard-leave .li-sub,.dashboard-leave .li-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend{display:flex;gap:12px;color:var(--muted);font-size:12px}.legend .dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px}.legend .g{background:#12b76a}.legend .y{background:#fdb022}.legend .r{background:#f04438}.chart-wrap{position:relative}#chartLabels{display:grid;grid-template-columns:repeat(9,1fr);grid-gap:2px;gap:2px;text-align:center;color:var(--muted);font-size:12px;margin-top:14px}.list{display:flex;flex-direction:column;gap:10px}.li{justify-content:space-between;padding:12px;border:1px solid var(--line);border-radius:14px}.li,.li-left{display:flex;align-items:center;gap:10px}.li-av{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#d1fadf,#b2ddff)}.li-title{font-weight:600}.li-sub{color:var(--muted);font-size:13px}.badge{padding:6px 12px;border-radius:999px;font-weight:700;font-size:12px;text-transform:capitalize}.badge.approved{background:rgba(18,183,106,.12);color:#0c8a5a}.badge.pending{background:rgba(253,176,34,.12);color:#ab7105}.badge.rejected{background:rgba(217,45,32,.12);color:#b42318}.badge.cancelled{background:rgba(152,162,179,.16);color:#475467}.notice{flex-direction:column}.notice,.notice-card{display:flex;gap:10px}.notice-card{align-items:center;justify-content:space-between;padding:12px;border:1px solid var(--line);border-radius:14px}.notice-title{font-weight:700}.notice-sub{color:var(--muted);font-size:13px}.star{background:rgba(255,214,102,.2);border:1px solid #ffd666;border-radius:12px;padding:8px 10px;font-size:18px;cursor:pointer;transition:transform .12s ease}.star:hover{transform:scale(1.05)}.star.active{background:#fdb022;color:#5c4205}.star i{line-height:1}.table-wrap{width:100%;overflow:auto}.table{width:100%;border-collapse:collapse;font-size:13px}.table td,.table th{padding:12px 10px;text-align:left;border-bottom:1px solid var(--line);color:#253043}.table th.th-icon{width:60px;text-align:center}.cell-actions{text-align:center}.table td,.table th{font-size:inherit}.table th{color:var(--muted);font-weight:600}.table tbody tr:hover{background:#f8fafc}.tav{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,#d1fadf,#b2ddff);display:inline-block}.inline-icon{margin-right:6px;vertical-align:-2px}.table-tools{display:flex;align-items:center;gap:10px}.table-meta{color:var(--muted);font-size:12px}.table-pagination{justify-content:space-between;gap:10px;margin-top:10px;flex-wrap:wrap}.pager,.table-pagination{display:flex;align-items:center}.pager{gap:6px}.page-btn{min-width:34px;height:32px;border-radius:10px;border:1px solid var(--line);background:#fff;color:#1d2939;font-size:12px;cursor:pointer;display:grid;place-items:center}.page-btn.active{background:#1d2939;color:#fff;border-color:#1d2939}.page-btn:disabled{opacity:.5;cursor:not-allowed}.data-page{display:flex;flex-direction:column;gap:14px}.data-head{justify-content:space-between;gap:12px;flex-wrap:wrap}.data-actions,.data-head{display:flex;align-items:center}.data-actions{gap:8px}.data-grid{display:flex;flex-direction:column;gap:12px}.data-card .table td,.data-card .table th{font-size:13px}.data-meta{color:var(--muted);font-size:12px;margin-top:4px}.data-empty{color:var(--muted)}.data-empty,.data-error{padding:12px;font-size:13px}.data-error{border:1px solid rgba(240,68,56,.25);background:rgba(240,68,56,.08);color:#b42318;border-radius:12px}.data-success{border:1px solid rgba(18,183,106,.2);background:rgba(18,183,106,.08);color:#0c8a5a;border-radius:12px;padding:12px;font-size:13px}.toast{position:fixed;top:18px;right:18px;z-index:2000;display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:14px;box-shadow:0 16px 30px rgba(16,24,40,.12);font-size:13px}.toast i{font-size:16px}.toast-success{background:#12b76a;color:#fff}.modal-backdrop{position:fixed;inset:0;background:rgba(16,24,40,.35);display:flex;align-items:center;justify-content:center;padding:18px;z-index:1600}.modal-card{width:min(420px,100%);background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 24px 48px rgba(16,24,40,.18);padding:18px}.modal-title{font-size:16px;font-weight:700;color:#101828;margin-bottom:6px}.modal-desc{font-size:13px;color:var(--muted);margin-bottom:16px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.modal-card.modal-wide{width:min(760px,100%)}.modal-media{display:flex;flex-direction:column;gap:12px}.modal-media img{width:100%;max-height:60vh;object-fit:contain;border-radius:14px;border:1px solid var(--line);background:#f8fafc}.modal-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--muted)}.page-card{display:flex;flex-direction:column;gap:8px}.page-title{font-size:22px;font-weight:700}.page-sub{color:var(--muted);font-size:13px}.input-hint{color:#98a2b3;font-size:12px;margin-top:6px}.settings-form{display:flex;flex-direction:column;gap:12px}.settings-section{padding:16px;border-radius:18px}.settings-section-head{margin-bottom:12px}.settings-toggle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:10px;gap:10px}.toggle-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-radius:14px;border:1px solid #e4e7ec;background:#f8fafc}.toggle-title{font-weight:600;font-size:13px;color:#101828}.toggle-desc{font-size:11px;color:#98a2b3;margin-top:2px}.toggle-switch{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:42px;height:24px;border-radius:999px;background:#e4e7ec;border:1px solid #d0d5dd;position:relative;cursor:pointer;transition:all .2s ease}.toggle-switch:before{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 2px 4px rgba(16,24,40,.2);transition:transform .2s ease}.toggle-switch:checked{background:#12b76a;border-color:#12b76a}.toggle-switch:checked:before{transform:translateX(18px)}.settings-logo-grid{display:flex;flex-wrap:wrap;gap:16px;align-items:center}.settings-logo-preview{width:180px;height:180px;border-radius:18px;border:1px solid var(--line);background:#f8fafc;display:flex;align-items:center;justify-content:center;overflow:hidden}.settings-logo-preview img{width:100%;height:100%;object-fit:cover}.logo-placeholder{color:#98a2b3;font-weight:600}.file-input{padding:8px 12px;height:auto}.page-hint{margin-top:6px;padding:12px;border-radius:12px;border:1px dashed var(--line);background:#f8fafc;color:#344054;font-size:12px}.md-grid{margin-top:16px;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:12px;gap:12px}.md-card{border:1px solid var(--line);border-radius:14px;padding:14px;text-decoration:none;color:inherit;background:#fff;transition:transform .12s ease,box-shadow .12s ease}.md-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.md-card-title{font-weight:700}.md-card-sub{color:var(--muted);font-size:12px;margin-top:6px}.md-card-link{margin-top:10px;font-size:12px;color:#0c8a5a;font-weight:600}.form-card{border:1px solid var(--line);border-radius:14px;padding:14px;margin-top:12px;background:#fff}.profile-photo-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.profile-photo{width:96px;height:96px;border-radius:22px;background:linear-gradient(135deg,#e3fcef,#dbeafe);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden;color:#667085;font-weight:700;font-size:28px}.profile-photo img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.profile-photo-meta{display:flex;flex-direction:column;gap:6px}.profile-photo-title{font-weight:600}.profile-photo-sub{font-size:12px;color:var(--muted)}.profile-photo-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.input-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.form-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.form-title{font-weight:700}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:12px;gap:12px}.form-field{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#344054}.form-input,.form-textarea{border:1px solid rgba(16,24,40,.14);border-radius:12px;padding:10px 12px;font-size:14px;background:linear-gradient(180deg,#fff,#f4f7fb);color:#101828;box-shadow:inset 0 1px 0 hsla(0,0%,100%,.9),0 8px 14px rgba(16,24,40,.06);transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease,transform .15s ease}.form-input{height:44px}.form-input:hover,.form-textarea:hover{border-color:rgba(18,183,106,.35);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.9),0 10px 18px rgba(16,24,40,.08)}.form-input:focus,.form-textarea:focus{outline:none;border-color:rgba(18,183,106,.65);box-shadow:0 0 0 3px rgba(18,183,106,.16),0 8px 16px rgba(16,24,40,.08)}.form-input:disabled,.form-textarea:disabled{background:#f3f4f6;border-color:#e4e7ec;color:#98a2b3;box-shadow:none;cursor:not-allowed}.form-input[type=date]{position:relative;padding-right:46px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2398a2b3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='5' width='18' height='16' rx='2'/><path d='M16 3v4M8 3v4M3 11h18'/></svg>"),radial-gradient(circle at right 20px center,rgba(16,24,40,.08) 0,rgba(16,24,40,.08) 16px,transparent 17px),linear-gradient(180deg,#fff,#f4f7fb);background-position:calc(100% - 18px) 50%,calc(100% - 18px) 50%,0 0;background-size:16px 16px,34px 34px,100% 100%;background-repeat:no-repeat;color:#101828;-webkit-text-fill-color:#101828}.form-input[type=date]::-webkit-datetime-edit,.form-input[type=date]::-webkit-datetime-edit-day-field,.form-input[type=date]::-webkit-datetime-edit-fields-wrapper,.form-input[type=date]::-webkit-datetime-edit-month-field,.form-input[type=date]::-webkit-datetime-edit-text,.form-input[type=date]::-webkit-datetime-edit-year-field{color:#101828;opacity:1}.form-input[type=date]:invalid,.form-input[type=date]:invalid::-webkit-datetime-edit{color:#98a2b3;-webkit-text-fill-color:#98a2b3}.form-input[type=date]::-webkit-calendar-picker-indicator{opacity:0;cursor:pointer;position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.form-input[type=date]::-webkit-inner-spin-button{display:none}.form-select{--select-arrow:#1f2a37;--select-chip:rgba(16,24,40,.08);-moz-appearance:none;appearance:none;-webkit-appearance:none;border-radius:12px;font-size:14px;height:44px;padding:10px 46px 10px 12px;border:1px solid rgba(16,24,40,.14);background-color:#fff;background-image:linear-gradient(45deg,transparent 50%,var(--select-arrow) 50%),linear-gradient(135deg,var(--select-arrow) 50%,transparent 50%),radial-gradient(circle at right 20px center,var(--select-chip) 0,var(--select-chip) 16px,transparent 17px),linear-gradient(180deg,#fff 0,#f4f7fb 100%);background-position:calc(100% - 20px) 50%,calc(100% - 14px) 50%,calc(100% - 18px) 50%,0 0;background-size:7px 7px,7px 7px,34px 34px,100% 100%;background-repeat:no-repeat;box-shadow:inset 0 1px 0 hsla(0,0%,100%,.9),0 8px 14px rgba(16,24,40,.06);transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease,transform .15s ease}.form-select:hover{border-color:rgba(18,183,106,.35);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.9),0 10px 18px rgba(16,24,40,.08)}.form-select:focus{outline:none;--select-chip:rgba(18,183,106,.16);border-color:rgba(18,183,106,.65);box-shadow:0 0 0 3px rgba(18,183,106,.16),0 8px 16px rgba(16,24,40,.08)}.form-select:disabled{--select-arrow:#98a2b3;--select-chip:rgba(152,162,179,.2);background-color:#f3f4f6;border-color:#e4e7ec;color:#98a2b3;box-shadow:none;cursor:not-allowed}.form-select option{color:#101828}.permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:12px;gap:12px;margin-top:12px}.permission-card{padding:14px}.permission-list{display:flex;flex-direction:column;gap:8px;max-height:320px;overflow:auto;padding-right:4px}.permission-item{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:12px;background:#f8fafc;border:1px solid #e4e7ec;cursor:pointer}.permission-item input{margin-top:3px;width:16px;height:16px;accent-color:#12b76a}.permission-label{font-size:13px;font-weight:600;color:#101828}.permission-code{font-size:11px;color:#98a2b3}.date-field{position:relative}.date-input{border:1px solid rgba(16,24,40,.14);border-radius:12px;font-size:14px;height:44px;width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;background-color:#fff;padding:10px 46px 10px 12px;cursor:pointer;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2398a2b3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='5' width='18' height='16' rx='2'/><path d='M16 3v4M8 3v4M3 11h18'/></svg>"),radial-gradient(circle at right 20px center,rgba(16,24,40,.08) 0,rgba(16,24,40,.08) 16px,transparent 17px),linear-gradient(180deg,#fff,#f4f7fb);background-position:calc(100% - 20px) 50%,calc(100% - 18px) 50%,0 0;background-size:16px 16px,34px 34px,100% 100%;background-repeat:no-repeat;color:#101828;box-shadow:inset 0 1px 0 hsla(0,0%,100%,.9),0 8px 14px rgba(16,24,40,.06);transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease,transform .15s ease}.date-input:hover{border-color:rgba(18,183,106,.35);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.9),0 10px 18px rgba(16,24,40,.08)}.date-input.is-open,.date-input:focus-visible{outline:none;border-color:rgba(18,183,106,.65);box-shadow:0 0 0 3px rgba(18,183,106,.16),0 8px 16px rgba(16,24,40,.08)}.date-input:disabled{background:#f3f4f6;border-color:#e4e7ec;color:#98a2b3;box-shadow:none;cursor:not-allowed}.date-placeholder{color:#98a2b3}.date-popover{position:absolute;top:calc(100% + 8px);left:0;min-width:260px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px;box-shadow:var(--shadow);z-index:40}.date-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.date-nav-title{font-weight:600;color:#101828;font-size:13px}.date-nav-btn{width:32px;height:32px;border-radius:10px;border:1px solid var(--line);background:#f8fafc;color:#1f2937;font-size:16px;cursor:pointer}.date-nav-btn:hover{background:#eef2f6}.date-weekdays{font-size:11px;color:#98a2b3;text-align:center}.date-grid,.date-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:4px;gap:4px}.date-grid{margin-top:6px}.date-cell{width:36px;height:36px;border-radius:10px;border:1px solid transparent;background:#f8fafc;color:#344054;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.date-cell:hover{background:#e6f7ef;border-color:rgba(18,183,106,.35)}.date-cell.is-muted{color:#98a2b3;background:#f1f5f9}.date-cell.is-today{border-color:rgba(18,183,106,.6)}.date-cell.is-selected{background:#12b76a;color:#fff;border-color:#12b76a}.date-cell:disabled{cursor:not-allowed;opacity:.45}.date-actions{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:8px}.date-action{border:1px solid var(--line);background:#fff;border-radius:10px;padding:6px 10px;font-size:12px;font-weight:600;cursor:pointer}.date-action:hover{background:#f8fafc}.date-action--danger{color:#d92d20;border-color:rgba(217,45,32,.25);background:rgba(217,45,32,.04)}.month-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px;margin-top:8px}.month-cell{height:40px;border-radius:12px;border:1px solid transparent;background:#f8fafc;color:#344054;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.month-cell:hover{background:#e6f7ef;border-color:rgba(18,183,106,.35)}.month-cell.is-selected{background:#12b76a;color:#fff;border-color:#12b76a}.month-cell:disabled{cursor:not-allowed;opacity:.45}.select-root{position:relative;width:100%}.select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:12px;min-height:44px;border:1px solid rgba(16,24,40,.14);background:linear-gradient(180deg,#fff,#f4f7fb);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.9),0 8px 14px rgba(16,24,40,.06);color:#101828;font-size:14px;font-family:inherit;cursor:pointer;text-align:left;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.select-trigger:hover{border-color:rgba(18,183,106,.35);box-shadow:inset 0 1px 0 hsla(0,0%,100%,.9),0 10px 18px rgba(16,24,40,.08)}.select-trigger.open{border-color:rgba(18,183,106,.65);box-shadow:0 0 0 3px rgba(18,183,106,.16),0 12px 18px rgba(16,24,40,.1)}.select-trigger:focus-visible{outline:none;border-color:rgba(18,183,106,.6);box-shadow:0 0 0 3px rgba(18,183,106,.16),0 10px 16px rgba(16,24,40,.08)}.select-trigger:disabled{cursor:not-allowed;color:#98a2b3;border-color:#e4e7ec;background:#f3f4f6;box-shadow:none}.select-value{flex:1 1}.select-value.placeholder{color:#98a2b3}.select-chevron{width:26px;height:26px;border-radius:10px;display:grid;place-items:center;background:rgba(16,24,40,.08);color:#1f2a37;transition:transform .15s ease,background-color .15s ease}.select-trigger.open .select-chevron{transform:rotate(180deg);background:rgba(18,183,106,.16);color:#0c8a5a}.select-chevron svg{width:14px;height:14px}.select-menu{position:absolute;left:0;right:0;top:calc(100% + 6px);background:#fff;border:1px solid rgba(16,24,40,.12);border-radius:14px;box-shadow:0 18px 32px rgba(16,24,40,.14);padding:8px;z-index:2000;display:flex;flex-direction:column;gap:8px}.select-search{width:100%;border:1px solid #e5e7eb;border-radius:10px;padding:8px 10px;font-size:13px;background:#f9fafb;color:#101828}.select-search:focus{outline:none;border-color:rgba(18,183,106,.65);box-shadow:0 0 0 3px rgba(18,183,106,.12)}.select-list{display:flex;flex-direction:column;gap:4px;overflow:auto;padding-right:2px}.select-option{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:10px;font-size:13px;color:#101828;cursor:pointer;transition:background-color .12s ease,color .12s ease}.select-option:hover{background:#f2f4f7}.select-option.active{background:#eef4ff}.select-option.selected{background:rgba(18,183,106,.12);color:#0c8a5a;font-weight:600}.select-mark{width:8px;height:8px;border-radius:999px;background:#12b76a;opacity:0}.select-option.selected .select-mark{opacity:1}.select-empty{padding:10px;text-align:center;color:#98a2b3;font-size:13px}.form-textarea{min-height:90px;resize:vertical}.form-check{display:flex;align-items:center;gap:8px;font-size:13px;color:#344054;margin-top:6px}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.table-actions{display:flex;align-items:center;gap:6px}.btn-danger{background:rgba(240,68,56,.12);color:#b42318;border:1px solid rgba(240,68,56,.2)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;position:relative;overflow:hidden;background:radial-gradient(700px 420px at 12% 8%,rgba(18,183,106,.14),transparent 60%),radial-gradient(800px 520px at 90% 12%,rgba(59,130,246,.16),transparent 60%),linear-gradient(135deg,#f6f7fb,#eef6ff)}.auth-orb{position:absolute;border-radius:999px;pointer-events:none;opacity:.8;animation:float 12s ease-in-out infinite}.auth-orb.orb-1{width:420px;height:420px;top:-140px;left:-120px;background:radial-gradient(circle at 30% 30%,rgba(18,183,106,.35),rgba(18,183,106,0))}.auth-orb.orb-2{width:520px;height:520px;bottom:-180px;right:-160px;background:radial-gradient(circle at 30% 30%,rgba(59,130,246,.32),rgba(59,130,246,0));animation-direction:reverse}.auth-shell{width:min(1120px,100%);display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);grid-gap:32px;gap:32px;align-items:stretch;position:relative;z-index:1}.auth-hero{position:relative;padding:32px;border-radius:26px;background:hsla(0,0%,100%,.92);border:1px solid rgba(226,232,240,.9);box-shadow:0 30px 70px rgba(15,23,42,.12);display:flex;flex-direction:column;gap:16px;overflow:hidden;animation:fadeUp .5s ease both}.auth-hero:before{width:240px;height:240px;top:-90px;right:-90px;background:radial-gradient(circle at 30% 30%,rgba(18,183,106,.35),rgba(18,183,106,0))}.auth-hero:after,.auth-hero:before{content:"";position:absolute;border-radius:50%}.auth-hero:after{width:280px;height:280px;bottom:-130px;left:-110px;background:radial-gradient(circle at 30% 30%,rgba(59,130,246,.25),rgba(59,130,246,0))}.auth-brand{display:flex;align-items:center;gap:14px}.auth-brand-title{font-weight:700;font-size:16px;color:#0f172a}.auth-brand-sub{color:var(--muted);font-size:12px}.auth-headline{font-size:28px;font-weight:700;line-height:1.2;color:#0f172a;margin:0}.auth-copy{color:var(--muted);font-size:14px;margin:0}.auth-badges{display:flex;flex-wrap:wrap;gap:8px}.auth-chip{padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;background:rgba(18,183,106,.12);color:#0c8a5a;border:1px solid rgba(18,183,106,.2)}.auth-features{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.auth-feature{display:flex;gap:10px;align-items:flex-start;padding:12px;border-radius:14px;background:#f8fafc;border:1px solid var(--line);font-size:13px;color:#344054}.auth-feature-ic{width:30px;height:30px;border-radius:10px;background:rgba(14,165,233,.12);display:grid;place-items:center;font-size:16px;flex:0 0 auto}.auth-feature-ic i{color:#0ea5e9;line-height:1}.auth-feature-title{font-weight:600;color:#0f172a}.auth-feature-sub{margin-top:2px}.auth-feature-sub,.auth-foot{font-size:12px;color:var(--muted)}.auth-foot{margin-top:auto}.auth-foot strong{color:#0f172a;font-weight:600}.auth-panel{display:flex;align-items:center;justify-content:center;animation:fadeUp .55s ease both}.auth-card{width:100%;max-width:420px;padding:24px;border-radius:22px}.auth-head{gap:14px;margin-bottom:18px}.auth-head,.auth-mark{display:flex;align-items:center}.auth-mark{gap:12px}.auth-title{font-size:20px;font-weight:700}.auth-sub{color:var(--muted);font-size:13px}.auth-form{gap:12px}.auth-field,.auth-form{display:flex;flex-direction:column}.auth-field{gap:6px;font-size:13px;font-weight:600;color:#344054}.auth-captcha{display:flex;flex-direction:column;gap:8px;padding:12px;border-radius:14px;border:1px dashed var(--line);background:#f8fafc}.auth-captcha-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.auth-captcha-question{font-size:13px;font-weight:600;color:#0f172a}.auth-input{border:1px solid var(--line);border-radius:12px;padding:10px 12px;font-size:14px;background:#fff}.auth-row{justify-content:space-between;gap:10px;font-size:12px}.auth-check,.auth-row{display:flex;align-items:center}.auth-check{gap:8px;color:#344054}.auth-link{color:#0c8a5a;text-decoration:none}.auth-link:hover{text-decoration:underline}.auth-notice{margin-top:8px;border-radius:12px;border:1px solid var(--line);padding:10px 12px;font-size:12px;color:#344054;background:#f8fafc}.auth-notice.loading{background:#f6f7fb;color:#344054}.auth-notice.error{background:rgba(240,68,56,.08);border-color:rgba(240,68,56,.25);color:#b42318}.auth-notice.success{background:rgba(18,183,106,.1);border-color:rgba(18,183,106,.2);color:#0c8a5a}.btn[disabled]{opacity:.65;cursor:not-allowed;transform:none}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.pill .icon{margin-right:4px}.separator{height:1px;background:var(--line);margin:10px 0}@media(max-width:1200px){.grid-bot,.grid-mid{grid-template-columns:1fr}}@media(max-width:980px){.layout{flex-direction:column}.sidebar{position:relative;width:100%;height:auto;border-right:none;border-bottom:1px solid var(--line)}.sidebar.collapsed .sb-txt{display:inline}.sidebar.collapsed{width:100%}.main{padding:12px}.kpi-row{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-shell{grid-template-columns:1fr}.auth-hero{order:2}.auth-panel{order:1}.search{max-width:100%}.top-actions{width:100%;flex-wrap:wrap;justify-content:flex-start}.user{width:100%;justify-content:space-between}.card-head{flex-direction:column;align-items:flex-start}.card-right{width:100%;justify-content:flex-start}.card-right,.legend,.table-tools{flex-wrap:wrap}.table-tools{justify-content:flex-start}.table-tools .search-sm{max-width:100%;flex:1 1 220px}.table-pagination{gap:8px}}@media(max-width:840px){.li,.notice-card{flex-direction:column;align-items:flex-start}.li-left{width:100%}.badge{align-self:flex-start}#chartLabels{grid-template-columns:repeat(6,1fr)}}@media(max-width:720px){.kpi-row{grid-template-columns:1fr}.kpi-value{font-size:32px}.kpi-title{font-size:12px}.card{padding:14px}}@media(max-width:640px){.topbar{flex-direction:column;align-items:flex-start}.search{width:100%}.data-head{flex-direction:column;align-items:flex-start}.data-actions{width:100%;flex-wrap:wrap}.table td,.table th{padding:10px 8px}.table{font-size:12px}.sidebar{padding:12px 12px 6px}.sidebar.collapsed .sb-footer,.sidebar.collapsed .sb-menu,.sidebar.collapsed .sb-txt{display:none}.sb-menu{max-height:calc(100vh - 110px);overflow-y:auto}.sb-footer{display:none}.dashboard-card{padding:12px;padding:14px}.dashboard-card .card-title{font-size:15px}.dashboard-card .card-head{margin-bottom:10px}.dashboard-card .btn-sm{padding:7px 12px;font-size:12px}.dashboard-attendance .card-right{width:100%;flex-direction:column;align-items:flex-start;gap:6px}.dashboard-attendance .legend{gap:10px;font-size:12px}.dashboard-leave .li{padding:12px}.dashboard-leave .li-av{width:36px;height:36px}.dashboard-leave .li-title{font-size:14px}.dashboard-leave .li-sub{font-size:12px}.dashboard-leave .list .li:nth-child(n+4){display:none}#chartLabels{grid-template-columns:repeat(3,1fr);font-size:10px;margin-top:10px}#chartLabels div{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-page{padding:20px}.auth-hero{padding:22px}.auth-headline{font-size:24px}.auth-features{grid-template-columns:1fr}}@media(max-width:520px){.topbar{gap:10px;padding:10px 10px 18px}.icon-btn{width:38px;height:38px}.user-av{width:34px;height:34px}.btn{font-size:12px}.table-tools{gap:8px}.dashboard-card{padding:14px}.dashboard-card .card-title{font-size:15px}.dashboard-attendance .legend{font-size:12px}.dashboard-attendance .legend .dot{width:9px;height:9px;margin-right:4px}.dashboard-leave .li{padding:12px}.dashboard-leave .li-title{font-size:14px}.dashboard-leave .li-sub{font-size:12px}#chartLabels{font-size:10px}}.tracking-map-card{display:flex;flex-direction:column;gap:16px;position:relative;z-index:2;overflow:visible}.tracking-filter-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;gap:12px}.tracking-filter-grid--compact{margin-bottom:12px}.tracking-map-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);grid-gap:16px;gap:16px;align-items:stretch}.tracking-map-root{position:relative;width:100%;height:420px;border-radius:16px;overflow:hidden;border:1px solid rgba(16,24,40,.12);background:#f8fafc;z-index:1}.tracking-map-canvas{width:100%;height:100%}.tracking-map-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:16px;background:rgba(15,23,42,.35);color:#f8fafc;font-weight:600;text-align:center;z-index:20}.tracking-map-panel{background:#f8fafc;border:1px solid rgba(16,24,40,.12);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px}.tracking-panel-title{font-size:14px;font-weight:700;color:#0f172a}.tracking-panel-body{display:flex;flex-direction:column;gap:10px}.tracking-panel-item{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;font-size:12px;color:#475569}.tracking-panel-item strong{font-size:13px;color:#0f172a;text-align:right}.tracking-panel-muted{font-size:12px;color:#94a3b8}.tracking-panel-error{font-size:12px;color:#ef4444}.tracking-legend{display:flex;flex-wrap:wrap;gap:10px 12px;font-size:12px;color:#475569}.tracking-legend-item{display:flex;align-items:center;gap:6px}.tracking-dot{width:10px;height:10px;border-radius:999px;display:inline-block;background:#64748b}.tracking-dot.attendance{background:#2563eb}.tracking-dot.patrol{background:#7c3aed}.tracking-dot.cleaning{background:#14b8a6}.tracking-dot.driver{background:#f59e0b}.tracking-marker{display:flex;align-items:center;justify-content:center;width:16px;height:16px}.tracking-marker-dot{width:12px;height:12px;border-radius:999px;background:#64748b;border:2px solid #fff;box-shadow:0 6px 12px rgba(15,23,42,.35)}.tracking-marker--attendance .tracking-marker-dot{background:#2563eb}.tracking-marker--patrol .tracking-marker-dot{background:#7c3aed}.tracking-marker--cleaning .tracking-marker-dot{background:#14b8a6}.tracking-marker--driver .tracking-marker-dot{background:#f59e0b}.tracking-marker--default .tracking-marker-dot{background:#64748b}.tracking-marker.is-selected .tracking-marker-dot{transform:scale(1.15);box-shadow:0 0 0 4px rgba(37,99,235,.2),0 8px 14px rgba(15,23,42,.4)}.tracking-popup{font-size:12px;color:#0f172a}.tracking-popup-title{font-weight:700;margin-bottom:4px}.tracking-popup-meta{color:#64748b;font-size:11px}.leaflet-container{font-family:inherit}@media(max-width:1024px){.tracking-map-grid{grid-template-columns:1fr}.tracking-map-root{height:360px}}@media(max-width:640px){.tracking-filter-grid{grid-template-columns:1fr}.tracking-map-root{height:320px}}