@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Space+Mono:wght@400;700&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#060810;--surface:#0b0f1a;--surface-2:#101525;--surface-3:#161d2e;--border:#1e2a40;--border-2:#263554;--blue:#4f8eff;--blue-dim:#2d5ccc;--blue-glow:rgba(79,142,255,.18);--green:#00d97e;--green-glow:rgba(0,217,126,.15);--red:#ff4f6a;--red-glow:rgba(255,79,106,.15);--amber:#ffb020;--purple:#a855f7;--text:#c8d8f0;--text-2:#7a95b8;--text-3:#3d5570;--font:"Plus Jakarta Sans",sans-serif;--mono:"Space Mono",monospace;--r:10px;--r-lg:16px;--r-xl:22px}[data-theme=light]{--bg:#f0f4fa;--surface:#fff;--surface-2:#f3f6fb;--surface-3:#e8edf5;--border:#d0daea;--border-2:#b8c8dc;--blue:#2563eb;--blue-dim:#1d4ed8;--blue-glow:rgba(37,99,235,.12);--green:#059669;--green-glow:rgba(5,150,105,.12);--red:#dc2626;--red-glow:rgba(220,38,38,.12);--amber:#d97706;--purple:#7c3aed;--text:#1e2d42;--text-2:#4a6080;--text-3:#8aa0bc}body,html{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:10px}::-moz-selection{background:rgba(79,142,255,.25);color:var(--text)}::selection{background:rgba(79,142,255,.25);color:var(--text)}.app-shell{display:flex;height:100vh;overflow:hidden;background:var(--bg)}.bg-orbs{position:fixed;inset:0;z-index:0;overflow:hidden}.bg-orb,.bg-orbs{pointer-events:none}.bg-orb{position:absolute;border-radius:50%;filter:blur(90px)}.orb-1{width:600px;height:600px;background:rgba(79,142,255,.055);top:-15%;left:-8%}.orb-2{width:500px;height:500px;background:rgba(0,217,126,.04);bottom:-10%;right:-5%}.orb-3{width:350px;height:350px;background:rgba(168,85,247,.035);top:45%;left:52%}.grid-overlay{position:fixed;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(79,142,255,.022) 1px,transparent 0),linear-gradient(90deg,rgba(79,142,255,.022) 1px,transparent 0);background-size:52px 52px}.sidebar{width:232px;flex-shrink:0;height:100vh;background:rgba(11,15,26,.95);border-right:1px solid var(--border);display:flex;flex-direction:column;position:relative;z-index:50;backdrop-filter:blur(20px);transition:transform .3s ease}[data-theme=light] .sidebar{background:hsla(0,0%,100%,.95);box-shadow:2px 0 16px rgba(0,0,0,.06)}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:20px 20px 18px;border-bottom:1px solid var(--border)}.sidebar-logo-icon{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--blue-dim),var(--blue));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px rgba(79,142,255,.35)}.sidebar-logo-text{font-size:.95rem;font-weight:800;color:var(--text);letter-spacing:-.01em}.sidebar-logo-ver{font-family:var(--mono);font-size:.62rem;color:var(--text-3)}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px;display:flex;flex-direction:column;gap:1px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;font-size:.85rem;font-weight:600;color:var(--text-2);text-decoration:none;cursor:pointer;border:none;background:none;width:100%;transition:color .15s,background .15s;white-space:nowrap}.nav-item:hover{color:var(--text);background:var(--surface-2)}.nav-item.active{color:var(--blue);background:var(--blue-glow)}.nav-item svg{flex-shrink:0}.nav-section-label{font-family:var(--mono);font-size:.6rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;padding:14px 12px 6px}.sidebar-footer{border-top:1px solid var(--border);padding:14px 12px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;cursor:pointer;transition:background .15s}.sidebar-user:hover{background:var(--surface-2)}.sidebar-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--blue-dim),var(--blue));display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:#fff;flex-shrink:0}.sidebar-user-name{font-size:.82rem;font-weight:700;color:var(--text)}.sidebar-user-role{font-size:.7rem;color:var(--text-3);font-family:var(--mono)}.topbar{height:56px;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:0 24px;gap:12px;background:rgba(6,8,16,.8);border-bottom:1px solid var(--border);backdrop-filter:blur(20px);position:sticky;top:0;z-index:40}[data-theme=light] .topbar{background:hsla(0,0%,100%,.9);box-shadow:0 1px 12px rgba(0,0,0,.06)}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-title{font-size:.92rem;font-weight:700;color:var(--text)}.topbar-subtitle{font-size:.75rem;color:var(--text-3);font-family:var(--mono)}.topbar-right{gap:10px}.topbar-icon-btn,.topbar-right{display:flex;align-items:center}.topbar-icon-btn{width:34px;height:34px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-2);cursor:pointer;justify-content:center;transition:all .15s}.topbar-icon-btn:hover{color:var(--text);border-color:var(--border-2);background:var(--surface-3)}.main-area{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;position:relative;z-index:1}.page-content{flex:1;overflow-y:auto;padding:28px}.page-header{margin-bottom:24px}.page-header h1{font-size:1.5rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.page-header p{font-size:.85rem;color:var(--text-2);margin-top:3px}.page-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}@media (max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.stats-grid{grid-template-columns:1fr}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px 22px;display:flex;flex-direction:column;gap:12px;transition:border-color .2s,transform .2s;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-color,var(--blue)),transparent);opacity:.6}.stat-card:hover{border-color:var(--border-2);transform:translateY(-1px)}.stat-card-top{display:flex;align-items:flex-start;justify-content:space-between}.stat-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.blue{background:linear-gradient(135deg,#1d4ed8,#3b82f6);box-shadow:0 4px 14px rgba(59,130,246,.4)}.stat-icon.green{background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 4px 14px rgba(16,185,129,.4)}.stat-icon.amber{background:linear-gradient(135deg,#d97706,#f59e0b);box-shadow:0 4px 14px rgba(245,158,11,.4)}.stat-icon.purple{background:linear-gradient(135deg,#7c3aed,#a855f7);box-shadow:0 4px 14px rgba(168,85,247,.4)}.stat-icon.red{background:linear-gradient(135deg,#dc2626,#ef4444);box-shadow:0 4px 14px rgba(239,68,68,.4)}.stat-icon svg{color:#fff}.stat-val{font-size:2rem;font-weight:700;color:var(--text);line-height:1}.stat-label,.stat-val{font-family:var(--mono)}.stat-label{font-size:.75rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em}.stat-sub{font-size:.75rem;color:var(--text-2)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.card-title{font-size:.92rem;font-weight:700;color:var(--text)}.card-body{padding:20px}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:10px 14px;margin-bottom:16px}.search-input{flex:1;min-width:180px;background:var(--surface);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:8px;font-family:var(--font);font-size:.83rem;outline:none}.search-input::-moz-placeholder{color:var(--text-3)}.search-input::placeholder{color:var(--text-3)}.search-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-glow)}.filter-select{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 12px;font-family:var(--font);font-size:.83rem;cursor:pointer;outline:none;color-scheme:dark}[data-theme=light] .filter-select{color-scheme:light}.filter-select:focus{border-color:var(--blue)}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th{padding:11px 16px;text-align:left;font-family:var(--mono);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);background:var(--surface-2);white-space:nowrap}.data-table td,.data-table th{border-bottom:1px solid var(--border)}.data-table td{padding:13px 16px;color:var(--text);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--surface-2)}.emp-cell{gap:11px}.emp-avatar,.emp-cell{display:flex;align-items:center}.emp-avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;background:var(--blue-glow);border:1px solid rgba(79,142,255,.3);justify-content:center;font-size:.72rem;font-weight:800;color:var(--blue)}.emp-name{font-size:.87rem;font-weight:700;color:var(--text)}.emp-id{color:var(--text-2)}.badge,.emp-id{font-family:var(--mono);font-size:.68rem}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:100px;font-weight:700;white-space:nowrap;letter-spacing:.04em;text-transform:uppercase}.badge-active,.badge-approved,.badge-paid,.badge-present{background:var(--green-glow);color:var(--green);border:1px solid rgba(0,217,126,.25)}.badge-absent,.badge-inactive,.badge-rejected{background:var(--red-glow);color:var(--red);border:1px solid rgba(255,79,106,.25)}.badge-pending{background:rgba(255,176,32,.15);color:var(--amber);border:1px solid rgba(255,176,32,.25)}.badge-draft{background:rgba(122,149,184,.1);color:var(--text-2);border:1px solid var(--border)}.badge-published{background:var(--blue-glow);color:var(--blue);border:1px solid rgba(79,142,255,.25)}.badge-late{background:rgba(255,176,32,.15);color:var(--amber);border:1px solid rgba(255,176,32,.25)}.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--font);font-weight:700;cursor:pointer;border:none;border-radius:var(--r);transition:all .2s;text-decoration:none;white-space:nowrap;flex-shrink:0}.btn-primary{background:var(--blue);color:#fff;padding:9px 18px;font-size:.85rem;box-shadow:0 4px 14px rgba(79,142,255,.3)}.btn-primary:hover{background:var(--blue-dim);transform:translateY(-1px);box-shadow:0 6px 20px rgba(79,142,255,.4)}.btn-secondary{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border);padding:9px 18px;font-size:.85rem}.btn-secondary:hover{color:var(--text);border-color:var(--border-2);background:var(--surface-3)}.btn-danger{background:var(--red-glow);color:var(--red);border:1px solid rgba(255,79,106,.25);padding:9px 18px;font-size:.85rem}.btn-danger:hover{background:var(--red);color:#fff}.btn-success{background:var(--green-glow);color:var(--green);border:1px solid rgba(0,217,126,.25);padding:9px 18px;font-size:.85rem}.btn-success:hover{background:var(--green);color:#000}.btn-sm{padding:6px 12px;font-size:.78rem;border-radius:7px}.btn-xs{padding:4px 9px;font-size:.72rem;border-radius:6px}.btn-icon{width:34px;height:34px;padding:0;border-radius:8px;justify-content:center;background:var(--surface-2);border:1px solid var(--border);color:var(--text-2)}.btn-icon:hover{color:var(--blue);border-color:rgba(79,142,255,.3);background:var(--blue-glow)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}.modal-box{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-xl);max-width:580px;width:100%;max-height:calc(100vh - 40px);display:flex;flex-direction:column;box-shadow:0 32px 80px rgba(0,0,0,.65);animation:modalPop .2s ease}.modal-box.modal-lg{max-width:800px}@keyframes modalPop{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:1rem;font-weight:700;color:var(--text)}.modal-close{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close:hover{color:var(--text);background:var(--surface-3)}.modal-body{flex:1;overflow-y:auto;padding:22px 24px}.modal-body::-webkit-scrollbar{width:4px}.modal-body::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}.modal-footer{padding:14px 24px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}@media (max-width:640px){.modal-overlay{align-items:flex-end;padding:0}.modal-box{border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:94vh;max-width:100%;width:100%}}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid.cols-1{grid-template-columns:1fr}@media (max-width:540px){.form-grid{grid-template-columns:1fr}}.col-span-2{grid-column:span 2}@media (max-width:540px){.col-span-2{grid-column:span 1}}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:.78rem;font-weight:600;color:var(--text-2)}.form-input,.form-select,.form-textarea{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:var(--r);padding:9px 12px;font-family:var(--font);font-size:.875rem;width:100%;transition:border-color .15s,box-shadow .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(79,142,255,.12)}.form-textarea{resize:vertical;min-height:80px}.form-select{cursor:pointer;color-scheme:dark}[data-theme=light] .form-select{color-scheme:light}.form-hint{font-size:.73rem;color:var(--text-3);line-height:1.4}.form-error{font-size:.73rem;color:var(--red)}.alert{padding:10px 14px;border-radius:var(--r);font-size:.83rem;font-weight:500}.alert-error{background:var(--red-glow);border:1px solid rgba(255,79,106,.25);color:var(--red)}.alert-success{background:var(--green-glow);border:1px solid rgba(0,217,126,.25);color:var(--green)}.toast{position:fixed;bottom:24px;right:24px;z-index:3000;background:var(--surface-2);border:1px solid var(--border);border-left:3px solid var(--blue);border-radius:10px;padding:12px 18px;font-size:.85rem;font-weight:600;color:var(--text);box-shadow:0 8px 32px rgba(0,0,0,.5);max-width:340px;animation:toastIn .3s ease}.toast.success{border-left-color:var(--green);color:var(--green)}.toast.error{border-left-color:var(--red);color:var(--red)}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border)}.pagination-info{font-family:var(--mono);font-size:.72rem;color:var(--text-2)}.pagination-btns{display:flex;gap:6px}.loading-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px}.loading-wrap p{font-family:var(--mono);font-size:.78rem;color:var(--text-3)}.spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;gap:10px}.empty-icon{color:var(--text-3)}.empty-title{font-size:.92rem;font-weight:700;color:var(--text-2)}.empty-desc{font-size:.8rem;color:var(--text-3);text-align:center}.tab-bar{display:flex;gap:4px}.tab-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text-2);border-radius:8px;padding:7px 14px;font-family:var(--font);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s}.tab-btn:hover{color:var(--text);border-color:var(--border-2)}.tab-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:45}@media (max-width:1024px){.sidebar{position:fixed;top:0;left:0;height:100vh;transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar-overlay.open{display:block}}