:root{--primary:#1b6ca8;--primary-light:#2a85cc;--primary-dark:#0f4c7a;--accent:#e8f4fd;--accent2:#fff3cd;--accent3:#d4edda;--bg:#f5f7fb;--bg2:#fff;--surf:#fff;--surf2:#f0f4f8;--bdr:#dde4ed;--txt:#1a2332;--txt2:#3d5168;--muted:#6c7e95;--dim:#98aaba;--cyan:#1b6ca8;--violet:#7c3aed;--green:#16a34a;--amber:#d97706;--red:#dc2626;--orange:#ea580c;--r:12px;--rs:8px;--sh:0 2px 16px #1b6ca81a;--sh2:0 8px 32px #1b6ca824;--tr:.25s ease;--fd:"Poppins", sans-serif;--fb:"Open Sans", sans-serif}html{scroll-behavior:smooth}.page-index{background:var(--bg);min-height:100vh;color:var(--txt);font-family:var(--fb);font-size:16px;line-height:1.7;overflow-x:hidden}.nav{z-index:500;background:var(--primary-dark);padding:0;position:sticky;top:0;box-shadow:0 2px 16px #0f4c7a4d}.ni{align-items:center;gap:6px;max-width:1280px;height:64px;margin:0 auto;padding:0 28px;display:flex}.logo{flex-shrink:0;align-items:center;gap:10px;margin-right:8px;text-decoration:none;display:flex}.logo-icon{background:#fff;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:flex;overflow:hidden}.logo-text{flex-direction:column;line-height:1.2;display:flex}.logo-main{font-family:var(--fd);color:#fff;letter-spacing:1px;font-size:18px;font-weight:800}.logo-sub{color:#ffffffa6;letter-spacing:.4px;font-size:10px;font-weight:400}.nav-tabs{gap:4px;list-style:none;display:flex}.tab-btn{color:#ffffffb8;font-family:var(--fb);border-radius:var(--rs);cursor:pointer;transition:var(--tr);white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;padding:8px 14px;font-size:13.5px;font-weight:500;display:flex}.tab-btn:hover{color:#fff;background:#ffffff1f}.tab-btn.on{color:#fff;background:#ffffff2e;font-weight:600}.nav-right{align-items:center;gap:8px;margin-left:auto;display:flex}.admin-btn{color:#ffffffd9;font-family:var(--fb);cursor:pointer;transition:var(--tr);background:#ffffff1f;border:1px solid #ffffff38;border-radius:50px;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:600;display:flex}.admin-btn:hover{color:#fff;background:#ffffff38}.admin-logged{align-items:center;gap:10px;display:flex}.admin-badge{color:#7c2d00;letter-spacing:.5px;background:#fbbf24;border-radius:50px;padding:3px 10px;font-size:11px;font-weight:700}.logout-btn{color:#ffffffa6;font-family:var(--fb);cursor:pointer;transition:var(--tr);background:0 0;border:1px solid #fff3;border-radius:50px;padding:5px 13px;font-size:12px}.logout-btn:hover{color:#fca5a5;border-color:#fca5a5}.hero-strip{background:linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 50%, var(--primary-light) 100%);text-align:center;padding:40px 28px 44px;position:relative;overflow:hidden}.hero-strip:before{content:"";background:#ffffff0d;border-radius:50%;width:260px;height:260px;position:absolute;top:-60px;right:-60px}.hero-strip:after{content:"";background:#ffffff0a;border-radius:50%;width:200px;height:200px;position:absolute;bottom:-80px;left:-40px}.hero-inner{z-index:1;max-width:700px;margin:0 auto;position:relative}.hero-badge{color:#fff;letter-spacing:.5px;background:#ffffff26;border:1px solid #ffffff40;border-radius:50px;margin-bottom:16px;padding:5px 14px;font-size:12px;font-weight:600;display:inline-block}.hero-title{font-family:var(--fd);color:#fff;letter-spacing:-.5px;margin-bottom:10px;font-size:clamp(24px,4vw,40px);font-weight:800;line-height:1.2}.hero-desc{color:#ffffffb8;font-size:15px;font-weight:300}.stats-bar{background:var(--surf);border-bottom:1px solid var(--bdr);box-shadow:var(--sh);flex-wrap:wrap;justify-content:center;display:flex}.stat-item{border-right:1px solid var(--bdr);flex-direction:column;flex:1;align-items:center;min-width:140px;max-width:220px;padding:22px 16px;display:flex}.stat-item:last-child{border-right:none}.stat-val{font-family:var(--fd);color:var(--primary);margin-bottom:4px;font-size:28px;font-weight:800;line-height:1}.stat-label{color:var(--muted);text-align:center;font-size:12px}.section-wrap{max-width:1280px;margin:0 auto;padding:40px 28px}.section-head{margin-bottom:28px}.sec-tag{letter-spacing:2px;text-transform:uppercase;color:var(--primary);background:var(--accent);border-radius:50px;margin-bottom:10px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-block}.sec-title{font-family:var(--fd);color:var(--txt);letter-spacing:-.5px;font-size:clamp(20px,3vw,28px);font-weight:800;line-height:1.2}#content-holidays,#content-policy,#content-empstatus{display:none}#content-holidays.active,#content-policy.active,#content-empstatus.active{display:block}.cal-filters{flex-wrap:wrap;gap:10px;margin-bottom:24px;display:flex}.cf-btn{background:var(--surf);border:1.5px solid var(--bdr);color:var(--muted);font-family:var(--fb);cursor:pointer;transition:var(--tr);border-radius:50px;padding:7px 18px;font-size:13px;font-weight:500;box-shadow:0 1px 4px #0000000d}.cf-btn:hover,.cf-btn.on{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 4px 12px #1b6ca833}.hol-table-wrap{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}.hol-table{border-collapse:collapse;width:100%}.hol-table th{background:var(--primary);text-align:left;letter-spacing:1px;text-transform:uppercase;color:#ffffffd9;padding:13px 18px;font-size:12px;font-weight:600}.hol-table td{border-bottom:1px solid var(--bdr);color:var(--txt2);padding:13px 18px;font-size:14px}.hol-table tr:last-child td{border-bottom:none}.hol-table tr:hover td{background:var(--accent)}.ht-no{color:var(--muted);font-size:13px;font-weight:700}.ht-date{color:var(--primary);font-weight:700}.ht-day{color:var(--muted);font-size:13px}.ht-name{color:var(--txt);font-weight:600}.ht-past{opacity:.45}.hol-badge{letter-spacing:.5px;white-space:nowrap;border-radius:50px;padding:3px 10px;font-size:11px;font-weight:700}.hb-fixed{color:var(--primary);background:#1b6ca81a}.hb-vebbox{color:var(--violet);background:#7c3aed1a}.hb-float{color:var(--amber);background:#d977061a}.lp-grid{grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:28px;display:grid}.lp-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);transition:var(--tr);box-shadow:var(--sh);padding:26px 22px;position:relative;overflow:hidden}.lp-card:hover{border-color:var(--lca,var(--primary));box-shadow:var(--sh2);transform:translateY(-3px)}.lp-strip{background:var(--lca,var(--primary));border-radius:var(--r) var(--r) 0 0;width:100%;height:4px;position:absolute;top:0;left:0}.lp-icon{margin-bottom:10px;font-size:28px}.lp-type{font-family:var(--fd);color:var(--txt);margin-bottom:6px;font-size:16px;font-weight:700}.lp-days{font-family:var(--fd);color:var(--lca,var(--primary));margin-bottom:12px;font-size:30px;font-weight:800;line-height:1}.lp-days span{color:var(--muted);font-size:13px;font-weight:400}.lp-note{color:var(--muted);font-size:13px;line-height:1.65}.policy-note{background:var(--accent);border:1px solid #1b6ca833;border-left:4px solid var(--primary);border-radius:var(--r);padding:24px 28px}.policy-note h4{font-family:var(--fd);color:var(--primary);align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.policy-note ul{flex-direction:column;gap:10px;list-style:none;display:flex}.policy-note li{color:var(--txt2);align-items:flex-start;gap:10px;font-size:14px;font-weight:400;line-height:1.6;display:flex}.policy-note li:before{content:"→";color:var(--primary);flex-shrink:0;margin-top:1px;font-weight:700}.emp-cards-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.emp-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--sh);transition:var(--tr);overflow:hidden}.emp-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}.emp-card-head{background:linear-gradient(135deg, var(--primary-dark), var(--primary));align-items:center;gap:14px;padding:18px 20px;display:flex}.emp-avatar{width:44px;height:44px;font-family:var(--fd);color:#fff;background:#fff3;border:2px solid #fff6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex}.emp-card-name{font-family:var(--fd);color:#fff;font-size:15px;font-weight:700}.emp-card-sub{color:#ffffffa6;margin-top:2px;font-size:11px}.emp-card-body{padding:18px 20px}.emp-summary{gap:10px;margin-bottom:16px;display:flex}.es-pill{background:var(--surf2);border-radius:var(--rs);text-align:center;flex:1;padding:10px 12px}.es-val{font-family:var(--fd);margin-bottom:2px;font-size:20px;font-weight:800;line-height:1}.es-label{color:var(--muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px}.month-grid{grid-template-columns:repeat(6,1fr);gap:5px;display:grid}.month-cell{background:var(--surf2);text-align:center;border:1px solid var(--bdr);transition:var(--tr);border-radius:6px;padding:6px 4px}.month-cell:hover{border-color:var(--primary)}.mc-name{color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px;font-size:9px;font-weight:600}.mc-val{font-family:var(--fd);font-size:13px;font-weight:700}.mc-val.has-leave{color:var(--red)}.mc-val.no-leave{color:var(--green)}.mc-val.future{color:var(--dim)}.leave-progress{margin-top:14px}.lp-row{align-items:center;gap:10px;margin-bottom:6px;display:flex}.lp-lbl{color:var(--muted);flex-shrink:0;width:60px;font-size:12px}.lp-bar-bg{background:var(--surf2);border-radius:4px;flex:1;height:7px;overflow:hidden}.lp-bar-fill{border-radius:4px;height:100%;transition:width .6s}.lp-num{text-align:right;flex-shrink:0;width:28px;font-size:12px;font-weight:700}.emp-search-bar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;display:flex}.search-input{background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--rs);min-width:200px;font-family:var(--fb);color:var(--txt);transition:var(--tr);outline:none;flex:1;padding:9px 16px;font-size:14px}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1b6ca81f}.sort-select{background:var(--surf);border:1.5px solid var(--bdr);border-radius:var(--rs);font-family:var(--fb);color:var(--txt);cursor:pointer;outline:none;padding:9px 14px;font-size:13px}.admin-gate{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);max-width:420px;box-shadow:var(--sh2);text-align:center;margin:60px auto;padding:44px 40px}.ag-icon{margin-bottom:14px;font-size:42px}.ag-title{font-family:var(--fd);color:var(--txt);margin-bottom:6px;font-size:22px;font-weight:800}.ag-sub{color:var(--muted);margin-bottom:28px;font-size:14px}.aform{flex-direction:column;gap:14px;display:flex}.fg{text-align:left;flex-direction:column;gap:6px;display:flex}.fg label{color:var(--txt2);font-size:13px;font-weight:600}.fg input{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rs);font-family:var(--fb);color:var(--txt);transition:var(--tr);outline:none;padding:10px 14px;font-size:14px}.fg input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1b6ca81a}.fg input::placeholder{color:var(--dim)}.aerr{border-radius:var(--rs);color:var(--red);background:#fef2f2;border:1px solid #fecaca;padding:9px 13px;font-size:13px;display:none}.aerr.show{display:block}.btn-primary{background:var(--primary);color:#fff;font-family:var(--fb);border-radius:var(--rs);cursor:pointer;transition:var(--tr);border:none;width:100%;padding:12px 28px;font-size:14px;font-weight:700}.btn-primary:hover{background:var(--primary-dark)}.demo-hint{background:var(--accent);border-radius:var(--rs);color:var(--muted);text-align:left;border:1px solid #1b6ca826;margin-top:16px;padding:11px 14px;font-size:12.5px}.demo-hint strong{color:var(--primary)}#adminGate{display:block}#adminPanel{display:none}#adminPanel.show{display:block}.admin-toolbar{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--sh);flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:28px;padding:16px 20px;display:flex}.at-label{color:var(--txt2);flex-shrink:0;font-size:13px;font-weight:600}.at-select{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rs);font-family:var(--fb);color:var(--txt);cursor:pointer;min-width:180px;transition:var(--tr);outline:none;padding:8px 14px;font-size:14px}.at-select:focus{border-color:var(--primary)}.at-divider{background:var(--bdr);width:1px;height:28px}.save-btn{background:var(--green);color:#fff;font-family:var(--fb);border-radius:var(--rs);cursor:pointer;transition:var(--tr);border:none;align-items:center;gap:7px;margin-left:auto;padding:9px 22px;font-size:13px;font-weight:700;display:flex}.save-btn:hover{background:#15803d}.save-msg{color:var(--green);opacity:0;font-size:13px;font-weight:600;transition:opacity .4s}.save-msg.show{opacity:1}.admin-table-wrap{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--sh);overflow-x:auto}.admin-table{border-collapse:collapse;width:100%;min-width:700px}.admin-table th{background:var(--primary-dark);text-align:center;letter-spacing:.8px;text-transform:uppercase;color:#ffffffd9;white-space:nowrap;padding:13px 16px;font-size:12px;font-weight:600}.admin-table th:first-child{text-align:left;min-width:160px}.admin-table td{border-bottom:1px solid var(--bdr);text-align:center;vertical-align:middle;padding:11px 14px;font-size:14px}.admin-table td:first-child{text-align:left;color:var(--txt);font-weight:600}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--accent)}.leave-input{text-align:center;background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rs);width:60px;font-family:var(--fb);color:var(--txt);transition:var(--tr);outline:none;padding:6px;font-size:14px;font-weight:600}.leave-input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #1b6ca81a}.leave-input:disabled{background:var(--surf2);color:var(--dim);cursor:not-allowed;border-color:#0000}.total-cell{font-family:var(--fd);color:var(--primary);font-size:15px;font-weight:800}.taken-cell{font-family:var(--fd);color:var(--red);font-weight:800}.pending-cell{font-family:var(--fd);color:var(--green);font-weight:800}.month-header{position:relative}.month-header.editable{color:#fff}.month-header.locked{color:#ffffff80}.lock-icon{margin-top:2px;font-size:10px;display:block}.toast{background:var(--primary-dark);color:#fff;opacity:0;z-index:9999;white-space:nowrap;border-radius:50px;padding:12px 28px;font-size:14px;font-weight:600;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .35s;position:fixed;bottom:28px;left:50%;transform:translate(-50%)translateY(80px);box-shadow:0 8px 24px #0003}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}footer{background:var(--primary-dark);text-align:center;margin-top:40px;padding:24px 28px}footer p{color:#ffffff8c;font-size:13px}footer strong{color:#ffffffd9}@media (width<=900px){.lp-grid{grid-template-columns:repeat(2,1fr)}.emp-cards-grid{grid-template-columns:1fr 1fr}}@media (width<=600px){.lp-grid,.emp-cards-grid{grid-template-columns:1fr}.nav-tabs{gap:2px}.tab-btn{padding:7px 8px;font-size:12px}.ni{padding:0 12px}.section-wrap{padding:24px 14px}.hol-table th,.hol-table td{padding:10px;font-size:13px}.admin-gate{margin:30px 14px;padding:28px 18px}.admin-toolbar{gap:10px}}:root{--primary:#1b6ca8;--pl:#2a85cc;--pd:#0f4c7a;--bg:#f5f7fb;--surf:#fff;--bdr:#dde4ed;--txt:#1a2332;--txt2:#3d5168;--muted:#6c7e95;--red:#dc2626;--rbg:#fef2f2;--rbdr:#fecaca;--green:#16a34a;--gbg:#f0fdf4;--gbdr:#bbf7d0;--amber:#d97706;--abg:#fffbeb;--abdr:#fde68a;--violet:#7c3aed;--r:12px;--rs:8px;--sh:0 2px 16px #1b6ca81a;--sh2:0 8px 32px #1b6ca826;--tr:.25s ease}.page-admin{background:var(--bg);min-height:100vh;color:var(--txt);min-height:100vh;font-family:Open Sans,sans-serif}.hdr-l{align-items:center;gap:14px;display:flex}.hdr-logo{background:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.hdr-brand{color:#fff;letter-spacing:1px;font-family:Poppins,sans-serif;font-size:18px;font-weight:800}.hdr-badge{color:#7c2d00;letter-spacing:.5px;background:#fbbf24;border-radius:50px;padding:3px 12px;font-size:11px;font-weight:700}.hdr-r{align-items:center;gap:14px;display:flex}.hdr-user{color:#fffc;font-size:13px}.btn-out{border-radius:var(--rs);color:#fff;cursor:pointer;transition:var(--tr);background:#ffffff1f;border:1px solid #ffffff40;padding:7px 16px;font-family:Poppins,sans-serif;font-size:13px;font-weight:500}.btn-cal{border-radius:var(--rs);color:#ffffffd9;cursor:pointer;transition:var(--tr);background:#ffffff14;border:1px solid #fff3;align-items:center;gap:6px;padding:7px 16px;font-family:Poppins,sans-serif;font-size:13px;text-decoration:none;display:flex}.btn-cal:hover{color:#fff;background:#ffffff2e}.pg-title{margin-bottom:4px;font-family:Poppins,sans-serif;font-size:22px;font-weight:700}.stats{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--surf);border-radius:var(--r);box-shadow:var(--sh);border-left:4px solid var(--primary);transition:var(--tr);padding:20px 22px}.stat-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}.stat-card.pending{border-left-color:var(--amber)}.stat-card.approved{border-left-color:var(--green)}.stat-card.rejected{border-left-color:var(--red)}.stat-label{text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:8px;font-size:11px;font-weight:700}.stat-val{color:var(--primary);font-family:Poppins,sans-serif;font-size:34px;font-weight:800;line-height:1}.stat-card.pending .stat-val{color:var(--amber)}.stat-card.approved .stat-val{color:var(--green)}.stat-card.rejected .stat-val{color:var(--red)}.filters{background:var(--surf);border-radius:var(--r);box-shadow:var(--sh);flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:20px;padding:16px 20px;display:flex}.filters label{color:var(--muted);margin-bottom:4px;font-size:12px;font-weight:600;display:block}.filters select,.filters input[type=month]{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rs);color:var(--txt);transition:var(--tr);outline:none;padding:8px 12px;font-family:Open Sans,sans-serif;font-size:13px}.filters select:focus,.filters input[type=month]:focus{border-color:var(--primary)}.btn-reset{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rs);color:var(--muted);cursor:pointer;transition:var(--tr);margin-top:auto;padding:8px 16px;font-size:13px}.btn-reset:hover{border-color:var(--primary);color:var(--primary)}th{text-align:left;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);border-bottom:1px solid var(--bdr);white-space:nowrap;background:#f8fafc;padding:12px 14px;font-size:11px;font-weight:700}.badge{border-radius:20px;align-items:center;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.b-lop{color:#ea580c;background:#fff7ed;border:1px solid #fed7aa}.btn-apply-emp{background:var(--primary);color:#fff;border-radius:var(--rs);cursor:pointer;transition:var(--tr);border:none;align-items:center;gap:6px;padding:8px 16px;font-family:Poppins,sans-serif;font-size:13px;font-weight:600;display:flex}.btn-apply-emp:hover{background:var(--pd)}.bal-info{background:var(--bg);border-radius:var(--rs);color:var(--txt2);margin-bottom:14px;padding:10px 14px;font-size:12px;line-height:1.9;display:none}.bal-info.show{display:block}.fg select,.fg input[type=date]{border:1.5px solid var(--bdr);border-radius:var(--rs);width:100%;color:var(--txt);transition:var(--tr);background:#f8fafc;outline:none;padding:10px 13px;font-family:Open Sans,sans-serif;font-size:14px}.fg select:focus,.fg input[type=date]:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #1b6ca81a}.lop-modal-note{border-radius:var(--rs);color:#ea580c;background:#fff7ed;border:1px solid #fed7aa;margin-bottom:14px;padding:9px 12px;font-size:12px;display:none}.lop-modal-note.show{display:block}.rej-flag{color:var(--red);background:var(--rbg);border:1px solid var(--rbdr);border-radius:4px;margin-left:5px;padding:2px 6px;font-size:10px;font-weight:700;display:inline-flex}.btn-approve,.btn-reject{border-radius:var(--rs);cursor:pointer;transition:var(--tr);border:none;padding:6px 14px;font-size:12px;font-weight:700}.btn-approve{background:var(--gbg);color:var(--green);border:1px solid var(--gbdr)}.btn-approve:hover{background:var(--green);color:#fff}.btn-reject{background:var(--rbg);color:var(--red);border:1px solid var(--rbdr);margin-left:6px}.btn-reject:hover{background:var(--red);color:#fff}@keyframes up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mod-close{width:32px;height:32px;color:var(--muted);cursor:pointer;background:#f1f4f8;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:18px;display:flex}.mod-info{background:var(--bg);border-radius:var(--rs);color:var(--txt2);margin-bottom:16px;padding:14px;font-size:13px;line-height:1.8}.mod-info strong{color:var(--txt)}.fg textarea{border:1.5px solid var(--bdr);border-radius:var(--rs);width:100%;color:var(--txt);transition:var(--tr);resize:vertical;background:#f8fafc;outline:none;min-height:80px;padding:10px 13px;font-family:Open Sans,sans-serif;font-size:14px}.fg textarea:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #1b6ca81a}.btn-row{gap:10px;display:flex}.btn-act{border-radius:var(--rs);cursor:pointer;transition:var(--tr);border:none;flex:1;padding:12px;font-family:Poppins,sans-serif;font-size:14px;font-weight:700}.btn-act.approve{background:var(--green);color:#fff}.btn-act.approve:hover{background:#15803d}.btn-act.reject{background:var(--red);color:#fff}.btn-act.reject:hover{background:#b91c1c}.btn-act:disabled{opacity:.65;cursor:not-allowed}.toast{z-index:999;border-radius:10px;align-items:center;gap:10px;padding:13px 20px;font-size:14px;font-weight:600;display:none;position:fixed;bottom:24px;right:24px;box-shadow:0 8px 30px #00000026}@media (width<=900px){.stats{grid-template-columns:repeat(2,1fr)}.hdr{padding:0 16px}.main{padding:20px 16px}}@media (width<=600px){.stats{grid-template-columns:repeat(2,1fr)}.hdr{height:56px;padding:0 12px}.hdr-r{gap:8px}.hdr-user,.btn-cal{display:none}.main{padding:16px 12px}.admin-tabs{width:100%}.atab{flex:1;padding:8px 10px;font-size:12px}.filters{flex-direction:column;gap:10px}.filters>div,.filters select,.filters input[type=month],.btn-reset{width:100%}}.admin-tabs{background:var(--surf);border-radius:var(--r);box-shadow:var(--sh);gap:6px;width:fit-content;margin-bottom:24px;padding:6px;display:flex}.atab{border-radius:var(--rs);color:var(--muted);cursor:pointer;transition:var(--tr);background:0 0;border:none;padding:9px 20px;font-family:Poppins,sans-serif;font-size:13px;font-weight:600}.atab.on{background:var(--primary);color:#fff;box-shadow:0 2px 8px #1b6ca84d}.tab-section{display:none}.tab-section.on{display:block}.emp-mgr{grid-template-columns:340px 1fr;align-items:start;gap:20px;display:grid}@media (width<=900px){.emp-mgr{grid-template-columns:1fr}}.emp-form-card{background:var(--surf);border-radius:var(--r);box-shadow:var(--sh);padding:24px}.emp-form-title{color:var(--txt);margin-bottom:16px;font-family:Poppins,sans-serif;font-size:15px;font-weight:700}.efg{margin-bottom:13px}.efg label{color:var(--txt2);margin-bottom:5px;font-size:12px;font-weight:600;display:block}.efg input,.efg select{border:1.5px solid var(--bdr);border-radius:var(--rs);width:100%;color:var(--txt);transition:var(--tr);background:#f8fafc;outline:none;padding:9px 12px;font-family:Open Sans,sans-serif;font-size:13px}.efg input:focus,.efg select:focus{border-color:var(--primary);background:#fff}.btn-add{background:var(--green);color:#fff;border-radius:var(--rs);cursor:pointer;width:100%;transition:var(--tr);border:none;margin-top:4px;padding:11px;font-family:Poppins,sans-serif;font-size:14px;font-weight:700}.btn-add:hover{background:#15803d}.btn-add:disabled{opacity:.65;cursor:not-allowed}.ef-alert{border-radius:var(--rs);margin-bottom:12px;padding:9px 12px;font-size:12px;display:none}.ef-alert.error{background:var(--rbg);border:1px solid var(--rbdr);color:var(--red)}.ef-alert.success{background:var(--gbg);border:1px solid var(--gbdr);color:var(--green)}.cred-box{background:var(--abg);border:1px solid var(--abdr);border-radius:var(--rs);color:#7c4a00;margin-top:10px;padding:10px 12px;font-size:12px;line-height:1.8;display:none}.emp-list-card{background:var(--surf);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}.emp-list-head{border-bottom:1px solid var(--bdr);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.emp-list-title{color:var(--txt);font-family:Poppins,sans-serif;font-size:15px;font-weight:700}.emp-count{color:var(--muted);background:var(--bg);border-radius:20px;padding:3px 10px;font-size:12px}.emp-list-tbl{border-collapse:collapse;width:100%}.emp-list-tbl th{text-align:left;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);border-bottom:1px solid var(--bdr);background:#f8fafc;padding:10px 16px;font-size:11px;font-weight:700}.emp-list-tbl td{vertical-align:middle;border-bottom:1px solid #f1f4f8;padding:12px 16px;font-size:13px}.emp-list-tbl tr:last-child td{border-bottom:none}.btn-del{background:var(--rbg);color:var(--red);border:1px solid var(--rbdr);border-radius:var(--rs);cursor:pointer;transition:var(--tr);padding:5px 12px;font-size:12px;font-weight:700}.btn-del:hover{background:var(--red);color:#fff}:root{--primary:#1b6ca8;--pl:#2a85cc;--pd:#0f4c7a;--bg:#f5f7fb;--surf:#fff;--bdr:#dde4ed;--txt:#1a2332;--txt2:#3d5168;--muted:#6c7e95;--red:#dc2626;--rbg:#fef2f2;--rbdr:#fecaca;--green:#16a34a;--gbg:#f0fdf4;--gbdr:#bbf7d0;--amber:#d97706;--abg:#fffbeb;--abdr:#fde68a;--violet:#7c3aed;--orange:#ea580c;--obg:#fff7ed;--obdr:#fed7aa;--r:12px;--rs:8px;--sh:0 2px 16px #1b6ca81a;--sh2:0 8px 32px #1b6ca826;--tr:.25s ease}.page-employee{background:var(--bg);min-height:100vh;color:var(--txt);min-height:100vh;font-family:Open Sans,sans-serif}.hdr{background:linear-gradient(135deg,var(--pd) 0%,var(--primary) 100%);z-index:100;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 20px #0003}.hdr-l{align-items:center;gap:12px;min-width:0;display:flex}.hdr-logo{background:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.hdr-logo img{object-fit:contain;width:28px;height:28px}.hdr-brand{color:#fff;letter-spacing:1px;white-space:nowrap;font-family:Poppins,sans-serif;font-size:17px;font-weight:800}.hdr-badge{color:#ffffffe6;letter-spacing:.5px;white-space:nowrap;background:#ffffff26;border:1px solid #ffffff40;border-radius:50px;padding:3px 10px;font-size:10px;font-weight:600}.hdr-r{flex-shrink:0;align-items:center;gap:10px;display:flex}.hdr-user{color:#fffc;white-space:nowrap;font-size:13px}.hdr-user strong{color:#fff}.btn-out{border-radius:var(--rs);color:#fff;cursor:pointer;transition:var(--tr);white-space:nowrap;background:#ffffff1f;border:1px solid #ffffff40;padding:7px 14px;font-family:Poppins,sans-serif;font-size:13px;font-weight:500}.btn-out:hover{background:#ffffff38}.main{max-width:1100px;margin:0 auto;padding:28px 20px}.pg-title{color:var(--txt);margin-bottom:4px;font-family:Poppins,sans-serif;font-size:20px;font-weight:700}.pg-sub{color:var(--muted);margin-bottom:24px;font-size:13px}.bal-row{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px;display:grid}.bal-card{background:var(--surf);border-radius:var(--r);box-shadow:var(--sh);border-top:4px solid var(--primary);transition:var(--tr);padding:22px}.bal-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}.bal-card.sl{border-top-color:var(--violet)}.bal-card.lop{border-top-color:var(--orange)}.bal-label{text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:10px;font-size:11px;font-weight:700}.bal-nums{align-items:baseline;gap:6px;margin-bottom:8px;display:flex}.bal-big{color:var(--primary);font-family:Poppins,sans-serif;font-size:34px;font-weight:800}.bal-card.sl .bal-big{color:var(--violet)}.bal-card.lop .bal-big{color:var(--orange)}.bal-of{color:var(--muted);font-size:14px}.bal-bar{background:#e9ecf0;border-radius:3px;height:6px;overflow:hidden}.bal-fill{background:var(--primary);border-radius:3px;height:100%;transition:width .6s}.bal-card.sl .bal-fill{background:var(--violet)}.bal-card.lop .bal-fill{background:var(--orange)}.bal-hint{color:var(--muted);margin-top:6px;font-size:12px}.lop-warn{background:var(--obg);border:1px solid var(--obdr);border-radius:var(--rs);color:var(--orange);align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:13px;font-weight:600;display:none}.lop-warn.show{display:flex}.sec-hdr{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:18px;display:flex}.sec-title{color:var(--txt);font-family:Poppins,sans-serif;font-size:16px;font-weight:700}.btn-apply{background:var(--primary);color:#fff;border-radius:var(--rs);cursor:pointer;transition:var(--tr);white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;font-family:Poppins,sans-serif;font-size:14px;font-weight:600;display:flex}.btn-apply:hover{background:var(--pd);transform:translateY(-1px);box-shadow:0 4px 16px #1b6ca84d}.tbl-wrap{background:var(--surf);border-radius:var(--r);box-shadow:var(--sh);overflow-x:auto}table{border-collapse:collapse;width:100%;min-width:600px}th{text-align:left;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);border-bottom:1px solid var(--bdr);background:#f8fafc;padding:11px 14px;font-size:11px;font-weight:700}td{vertical-align:middle;border-bottom:1px solid #f1f4f8;padding:12px 14px;font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:#f8fafc}.cell-ellipsis{text-overflow:ellipsis;white-space:nowrap;max-width:160px;overflow:hidden}.badge{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.b-pending{background:var(--abg);color:var(--amber);border:1px solid var(--abdr)}.b-approved{background:var(--gbg);color:var(--green);border:1px solid var(--gbdr)}.b-rejected{background:var(--rbg);color:var(--red);border:1px solid var(--rbdr)}.b-cl{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}.b-sl{color:var(--violet);background:#f5f3ff;border:1px solid #ddd6fe}.b-lop{background:var(--obg);color:var(--orange);border:1px solid var(--obdr)}.empty{text-align:center;color:var(--muted);padding:50px 20px;font-size:14px}.overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0a14288c;justify-content:center;align-items:center;padding:16px;display:none;position:fixed;inset:0}.overlay.open{display:flex}.modal{background:var(--surf);border-radius:18px;width:100%;max-width:480px;animation:.25s up;box-shadow:0 20px 60px #0003}.mod-head{justify-content:space-between;align-items:center;padding:22px 24px 0;display:flex}.mod-title{color:var(--txt);font-family:Poppins,sans-serif;font-size:17px;font-weight:700}.mod-close{width:32px;height:32px;color:var(--muted);cursor:pointer;transition:var(--tr);background:#f1f4f8;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:18px;display:flex}.mod-close:hover{background:var(--bdr)}.mod-body{padding:18px 24px 24px}.fg{margin-bottom:15px}.fg label{color:var(--txt2);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.fg input,.fg select,.fg textarea{border:1.5px solid var(--bdr);border-radius:var(--rs);width:100%;color:var(--txt);transition:var(--tr);background:#f8fafc;outline:none;padding:10px 13px;font-family:Open Sans,sans-serif;font-size:14px}.fg textarea{resize:vertical;min-height:80px}.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #1b6ca81a}.frow{grid-template-columns:1fr 1fr;gap:12px;display:grid}.mod-alert{border-radius:var(--rs);margin-bottom:14px;padding:10px 13px;font-size:13px;display:none}.mod-alert.error{background:var(--rbg);border:1px solid var(--rbdr);color:var(--red)}.mod-alert.success{background:var(--gbg);border:1px solid var(--gbdr);color:var(--green)}.mod-alert.warning{background:var(--obg);border:1px solid var(--obdr);color:var(--orange)}.btn-full{background:var(--primary);color:#fff;border-radius:var(--rs);cursor:pointer;width:100%;transition:var(--tr);border:none;margin-top:4px;padding:12px;font-family:Poppins,sans-serif;font-size:15px;font-weight:600}.btn-full:hover{background:var(--pd)}.btn-full:disabled{opacity:.65;cursor:not-allowed}.lop-note{background:var(--obg);border:1px solid var(--obdr);border-radius:var(--rs);color:var(--orange);margin-bottom:14px;padding:9px 12px;font-size:12px;display:none}.lop-note.show{display:block}.toast{z-index:999;border-radius:10px;align-items:center;gap:10px;max-width:calc(100vw - 32px);padding:13px 18px;font-size:14px;font-weight:600;animation:.25s toastIn;display:none;position:fixed;bottom:20px;right:16px;box-shadow:0 8px 30px #00000026}.toast.show{display:flex}.toast.success{background:var(--green);color:#fff}.toast.error{background:var(--red);color:#fff}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=700px){.bal-row{grid-template-columns:1fr 1fr}.bal-card.lop{grid-column:span 2}}@media (width<=600px){.hdr{height:58px;padding:0 14px}.hdr-brand{font-size:15px}.hdr-badge,.hdr-user{display:none}.main{padding:18px 14px}.bal-big{font-size:26px}.frow{grid-template-columns:1fr}table{min-width:500px}th,td{padding:10px;font-size:12px}.btn-apply{padding:9px 14px;font-size:13px}}@media (width<=400px){.bal-row{grid-template-columns:1fr}.bal-card.lop{grid-column:span 1}}:root{--primary:#1b6ca8;--primary-light:#2a85cc;--primary-dark:#0f4c7a;--bg:#f5f7fb;--surf:#fff;--bdr:#dde4ed;--txt:#1a2332;--txt2:#3d5168;--muted:#6c7e95;--red:#dc2626;--green:#16a34a;--r:12px;--rs:8px;--sh2:0 8px 40px #1b6ca82e;--tr:.25s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.page-login{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 60%,var(--primary-light) 100%);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:24px;font-family:Open Sans,sans-serif;display:flex}.wrap{width:100%;max-width:420px}.brand{text-align:center;margin-bottom:32px}.brand-logo{background:#fff;border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:14px;display:inline-flex;box-shadow:0 4px 16px #0003}.brand-logo img{object-fit:contain;width:40px;height:40px}.brand-name{color:#fff;letter-spacing:1px;font-family:Poppins,sans-serif;font-size:26px;font-weight:800}.brand-sub{color:#ffffffa6;margin-top:4px;font-size:13px}.card{background:var(--surf);box-shadow:var(--sh2);border-radius:18px;padding:36px 32px}.card-title{color:var(--txt);margin-bottom:6px;font-family:Poppins,sans-serif;font-size:20px;font-weight:700}.card-sub{color:var(--muted);margin-bottom:28px;font-size:13px}.form-group{margin-bottom:18px}label{color:var(--txt2);margin-bottom:7px;font-size:13px;font-weight:600;display:block}input{border:1.5px solid var(--bdr);border-radius:var(--rs);width:100%;color:var(--txt);transition:var(--tr);background:#f8fafc;outline:none;padding:11px 14px;font-family:Open Sans,sans-serif;font-size:14px}input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #1b6ca81a}.btn{background:var(--primary);color:#fff;border-radius:var(--rs);cursor:pointer;width:100%;transition:var(--tr);border:none;margin-top:8px;padding:13px;font-family:Poppins,sans-serif;font-size:15px;font-weight:600}.btn:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 16px #1b6ca84d}.btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.alert{border-radius:var(--rs);margin-bottom:16px;padding:11px 14px;font-size:13px;display:none}.alert.error{color:var(--red);background:#fef2f2;border:1px solid #fecaca}.hint{border-radius:var(--rs);color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;margin-top:16px;padding:11px 14px;font-size:12.5px}.hint strong{font-weight:700}.back{text-align:center;color:#ffffffb3;margin-top:20px;font-size:13px}.back a{color:#fff;font-weight:600;text-decoration:none}.back a:hover{text-decoration:underline}.box{background:var(--surf);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}.box-hdr{border-bottom:1px solid var(--bdr);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:16px 20px;display:flex}.box-title{color:var(--txt);font-family:Poppins,sans-serif;font-size:16px;font-weight:700}.btn-punch{background:var(--green);color:#fff;border-radius:var(--rs);cursor:pointer;transition:var(--tr);white-space:nowrap;border:none;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:700;display:flex}.btn-punch:hover{background:#15803d}.btn-punch.punched-in{background:var(--orange)}.btn-punch.punched-in:hover{background:#c2410c}.btn-punch:disabled{opacity:.6;cursor:not-allowed}.att-table{border-collapse:collapse;width:100%;min-width:800px}.att-table th,.att-table td{border-bottom:1px solid var(--bdr);text-align:left;padding:12px 16px;font-size:13px}.att-table th{text-transform:uppercase;color:var(--muted);background:#f8fafc;font-size:11px;font-weight:700}.att-warn{background:var(--rbg);color:var(--red);border:1px solid var(--rbdr);border-radius:4px;margin-top:4px;padding:2px 6px;font-size:11px;font-weight:700;display:inline-block}
