.login-root{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-orb{display:none}.login-orb-1{background:radial-gradient(circle,#008b9859 0%,#0000 70%);width:500px;height:500px;animation-delay:0s;top:-150px;left:-100px}.login-orb-2{background:radial-gradient(circle,#00b56b40 0%,#0000 70%);width:400px;height:400px;animation-delay:-3s;bottom:-100px;right:100px}.login-orb-3{background:radial-gradient(circle,#00b56b33 0%,#0000 70%);width:300px;height:300px;animation-delay:-5s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes orbFloat{0%,to{transform:translateY(0)scale(1)}33%{transform:translateY(-30px)scale(1.05)}66%{transform:translateY(20px)scale(.95)}}.login-container{z-index:1;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:1300px;min-height:100vh;margin:0 auto;display:flex;position:relative}.login-left{color:var(--text);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px 0;display:flex}.login-brand{align-items:center;gap:16px;margin-bottom:20px;display:flex}.login-logo-icon{animation:logoSpin}.login-brand-name{color:var(--primary);letter-spacing:-1px;margin:0;font-size:2.8rem;font-weight:800}.login-tagline{color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;border-bottom:1px solid var(--border);margin:0 0 24px;padding-bottom:24px;font-size:1.1rem;font-weight:600}.login-subtitle{color:var(--text-muted);margin-bottom:36px;font-size:1.05rem;line-height:1.7}.login-features{flex-direction:column;gap:14px;margin:0 0 auto;padding:0;list-style:none;display:flex}.login-feature-item{color:var(--text);align-items:center;gap:14px;font-size:.95rem;font-weight:500;display:flex}.login-feature-icon{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;display:flex}.login-copyright{color:var(--text-muted);margin-top:48px;font-size:.85rem}.login-right{background:0 0;justify-content:center;align-items:center;width:100%;padding:0 48px 60px;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:460px;padding:48px 40px;box-shadow:0 24px 64px #0006}.login-card-header{margin-bottom:32px}.login-card-title{color:var(--text);margin:0 0 8px;font-size:1.9rem;font-weight:700}.login-card-subtitle{color:var(--text-muted);margin:0;font-size:.95rem}.login-form{flex-direction:column;gap:20px;margin-bottom:28px;display:flex}.login-error{border-radius:var(--radius-sm);color:var(--danger);background:#e170551f;border:1px solid #e1705566;align-items:center;gap:8px;padding:12px 16px;font-size:.9rem;display:flex}.login-field{flex-direction:column;gap:8px;display:flex}.login-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem;font-weight:600}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input-icon{color:var(--text-muted);pointer-events:none;align-items:center;display:flex;position:absolute;left:14px}.login-input{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:var(--transition);box-sizing:border-box;padding:13px 14px 13px 44px;font-family:inherit;font-size:.95rem}.login-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #008b9826}.login-input::placeholder{color:var(--text-muted)}.login-toggle-pw{cursor:pointer;color:var(--text-muted);transition:var(--transition);background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;right:12px}.login-toggle-pw:hover{color:var(--primary)}.login-btn{background:var(--primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);letter-spacing:.3px;border:none;justify-content:center;align-items:center;gap:10px;margin-top:4px;padding:14px;font-family:inherit;font-size:1rem;font-weight:600;display:flex}.login-btn:hover:not(:disabled){background:var(--primary-dark)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-btn-loading{align-items:center;gap:10px;display:flex}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-demo{border-top:1px solid var(--border);padding-top:24px}.login-demo-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.login-demo-title{color:var(--text);font-size:.9rem;font-weight:600}.login-demo-hint{color:var(--text-muted);font-size:.78rem}.login-demo-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.login-demo-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);padding:10px 12px;position:relative}.login-demo-item:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #008b9833}.login-demo-role{color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;font-size:.75rem;font-weight:700}.login-demo-email{color:var(--text-muted);word-break:break-all;font-size:.78rem}.login-demo-copy{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border-radius:4px;width:100%;margin-top:8px;padding:2px 8px;font-family:inherit;font-size:.7rem;display:block}.login-demo-copy:hover{border-color:var(--secondary);color:var(--secondary)}@media (width<=900px){.login-container{grid-template-columns:1fr}.login-left{display:none}.login-right{border-left:none;min-height:100vh;padding:24px}}.dashboard-page{flex-direction:column;gap:1.75rem;padding:1.75rem;animation:.45s cubic-bezier(.16,1,.3,1) fadeIn;display:flex}.dashboard-header{border-bottom:1px dashed var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.25rem;padding-bottom:1.25rem;display:flex}.dashboard-title{color:var(--text);background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;margin:0;font-size:1.75rem;font-weight:800}.dashboard-date{color:var(--text-muted);margin:.35rem 0 0;font-size:.875rem;font-weight:500}.dashboard-stats{flex-direction:column;gap:.75rem;display:flex}.stat-list-item{background:var(--surface-2);justify-content:space-between;align-items:center;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 1px 3px #00000003;border:1px solid var(--border)!important;border-radius:var(--radius)!important;padding:.75rem 1rem!important}.stat-list-item:hover{background:var(--surface-3);box-shadow:var(--shadow-sm);transform:translate(6px);border-color:var(--primary-light)!important}.dashboard-grid-2{grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:1.75rem;display:grid}.dashboard-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;overflow:hidden;box-shadow:0 4px 20px -4px #0f172a0d,0 2px 6px -2px #0f172a08}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px -4px #0f172a14,0 4px 12px -2px #0f172a0a}.dashboard-card-header{border-bottom:1px solid var(--border);background:linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.dashboard-card-title{color:var(--text);letter-spacing:-.01em;align-items:center;gap:.6rem;margin:0;font-size:.98rem;font-weight:700;display:flex}.dashboard-card-count{background:var(--surface-3);border:1px solid var(--border);color:var(--primary);letter-spacing:.02em;border-radius:100px;padding:.2rem .6rem;font-size:.72rem;font-weight:700}.announcement-item-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.875rem;transition:all .25s;padding:1.125rem!important}.announcement-item-card:hover{background:var(--surface-3);border-color:var(--primary-light);transform:translateY(-1px)}.announcement-item-card:last-child{margin-bottom:0}.birthdays-widget{border-top:none!important}.birthdays-widget .dashboard-card-header{background:var(--surface)!important;padding:0!important}.birthdays-widget .dashboard-card-header button{letter-spacing:.02em;border-bottom:3px solid #0000!important;padding:1rem .5rem!important;font-size:.875rem!important;font-weight:700!important;transition:all .2s!important}.birthdays-widget .dashboard-card-header button:hover{background:var(--surface-2)!important;color:var(--text)!important}.birthdays-widget .dashboard-card-header button.active{color:var(--primary)!important;border-bottom-color:var(--primary)!important;background:var(--surface-2)!important}.dashboard-table-wrap{overflow-x:auto}.dashboard-table{border-collapse:collapse;text-align:left;width:100%;font-size:.875rem}.dashboard-table th{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);padding:1rem 1.25rem;font-size:.72rem;font-weight:700}.dashboard-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:1rem 1.25rem;transition:background .15s}.dashboard-table tbody tr:hover td{background:var(--surface-2)!important}.dashboard-table tr:last-child td{border-bottom:none}.emp-cell{align-items:center;gap:.75rem;display:flex}.emp-avatar-sm{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 100%);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex;box-shadow:0 2px 5px #008b9833}.time-cell{color:var(--text-muted);font-family:monospace;font-size:.8rem;font-weight:500}.dashboard-empty{text-align:center;color:var(--text-muted);padding:3.5rem 1.5rem;font-size:.9rem;font-weight:500}.dashboard-leave-list{flex-direction:column;max-height:400px;display:flex;overflow-y:auto}.dashboard-leave-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;transition:background .2s;display:flex}.dashboard-leave-item:hover{background:var(--surface-2)}.dashboard-leave-item:last-child{border-bottom:none}.leave-item-left{align-items:center;gap:.875rem;min-width:0;display:flex}.leave-item-name{color:var(--text);font-size:.9rem;font-weight:700}.leave-item-type{color:var(--text-muted);margin-top:.15rem;font-size:.78rem}.leave-item-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.35rem;display:flex}.leave-item-dates{color:var(--text-muted);font-size:.78rem;font-weight:500}.leave-balance-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1.25rem;padding:1.5rem;display:grid}.leave-balance-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.6rem;padding:1rem;transition:all .2s;display:flex}.leave-balance-item:hover{background:var(--surface-3);border-color:var(--primary-light);transform:translateY(-1px)}.lb-top{justify-content:space-between;align-items:center;display:flex}.lb-type{color:var(--text);text-transform:capitalize;font-size:.8rem;font-weight:700}.lb-remaining{color:var(--primary);font-size:.75rem;font-weight:700}.lb-bar-wrap{background:var(--surface-3);border-radius:100px;height:6px;overflow:hidden}.lb-bar{background:linear-gradient(90deg, var(--primary) 0%, var(--primary-light) 100%);border-radius:100px;height:100%;transition:width .35s cubic-bezier(.4,0,.2,1)}.lb-nums{color:var(--text-muted);justify-content:space-between;font-size:.7rem;font-weight:500;display:flex}.month-summary{flex-direction:column;gap:.875rem;padding:1.5rem;display:flex}.month-summary-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:all .2s;display:flex}.month-summary-item:hover{background:var(--surface-3);transform:translate(4px)}.ms-status{align-items:center;font-weight:500;display:flex}.ms-count{color:var(--text);font-size:.85rem;font-weight:700}.dashboard-error{color:var(--danger);border-radius:var(--radius-lg);text-align:center;background:#ef444414;border:1px solid #ef444433;padding:1.5rem;font-weight:500}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%{transform:scale(.95);box-shadow:0 0 #00b89480}70%{transform:scale(1);box-shadow:0 0 0 6px #00b89400}to{transform:scale(.95);box-shadow:0 0 #00b89400}}.dashboard-card-footer{color:var(--text-muted);text-align:center;border-top:1px solid var(--border);background:var(--surface-2);padding:.85rem 1.5rem;font-size:.75rem;font-weight:600;transition:background .2s}.dashboard-card-footer:hover{background:var(--surface-3)}.employee-profile-page{max-width:1200px;margin:0 auto;padding:1.5rem}.profile-banner{background:var(--surface);border-radius:var(--radius-lg);border-top:6px solid var(--primary-light);flex-direction:column;align-items:center;margin-bottom:1.5rem;padding:2rem;display:flex;position:relative}.back-btn{position:absolute;top:1.5rem;left:1.5rem}.banner-content{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;margin-top:1rem;display:flex}.profile-avatar-large{width:120px;height:120px;color:var(--primary);background:#0596691a;border:4px solid #fff;border-radius:50%;justify-content:center;align-items:center;font-size:2.5rem;font-weight:700;display:flex;overflow:hidden;box-shadow:0 4px 10px #00000014}.profile-avatar-large img{object-fit:cover;width:100%;height:100%}.profile-name{color:var(--text);margin-bottom:.5rem;font-size:1.75rem;font-weight:700}.profile-meta-row{color:var(--text-muted);flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;font-size:.95rem;display:flex}.meta-divider{color:var(--border)}.profile-grid{grid-template-columns:2fr 1fr;align-items:start;gap:1.5rem;display:grid}.profile-section-card{margin-bottom:1.5rem;padding:1.5rem}.section-title{color:var(--text);border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding-bottom:.75rem;font-size:1.1rem;font-weight:600}.about-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.about-item{align-items:center;gap:1rem;display:flex}.about-icon{background:var(--surface-2);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex}.about-text{flex-direction:column;display:flex}.about-label{color:var(--text-muted);margin-bottom:2px;font-size:.75rem}.about-value{color:var(--text);font-size:.95rem;font-weight:500}.reporting-manager-block{background:var(--surface-2,#f8fafc);border-radius:var(--radius-lg,12px);border:1px solid var(--border,#e2e8f0);align-items:center;gap:1.5rem;padding:1rem;transition:all .2s;display:flex}.reporting-manager-block:hover{border-color:var(--primary-light,#10b981);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000000d}.manager-avatar{background:var(--primary-light,#10b981);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.25rem;font-weight:600;display:flex}.manager-info{flex:1;grid-template-columns:1fr;gap:.25rem;display:grid}.manager-name{color:var(--text,#0f172a);margin-bottom:.15rem;font-size:1.05rem;font-weight:600}.manager-role{color:var(--primary,#059669);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:500}.manager-contact{color:var(--text-muted,#64748b);flex-wrap:wrap;align-items:center;gap:1rem;margin-top:.25rem;font-size:.85rem;display:flex}.contact-item{align-items:center;gap:.25rem;display:flex}.attendance-status-block{flex-direction:column;gap:1rem;display:flex}.status-badge{border-radius:20px;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.85rem;font-weight:600;display:inline-flex}.status-badge.active{color:var(--success);background:#10b9811a}.status-badge.absent{color:var(--warning);background:#f59e0b1a}.punch-times{background:var(--surface-2);border-radius:var(--radius-sm);justify-content:space-between;padding:1rem;display:flex}.punch-time-item{flex-direction:column;align-items:center;gap:4px;display:flex}@media (width<=768px){.profile-grid,.about-grid{grid-template-columns:1fr}}:root{--primary:#008b98;--primary-dark:#006b75;--primary-light:#33a2ad;--secondary:#00b56b;--secondary-dark:#009156;--accent:#f59e0b;--bg:#f5faf8;--surface:#fff;--surface-2:#edf6f4;--surface-3:#e1efea;--border:#ddebe7;--text:#0f172a;--text-muted:#3d5f66;--text-dim:#7fa3a8;--success:#00b56b;--warning:#f59e0b;--danger:#ef4444;--info:#008b98;--radius:6px;--radius-sm:4px;--radius-lg:10px;--shadow-sm:0 1px 2px #0f172a0d;--shadow:0 2px 8px #0f172a0a;--shadow-lg:0 10px 15px -3px #0f172a14, 0 4px 6px -2px #0f172a0d;--transition:all .2s ease-in-out;--sidebar-width:250px;--topbar-height:56px;--gradient-primary:var(--primary);--gradient-accent:var(--secondary);--gradient-glow:var(--surface-2)}*{scrollbar-width:thin;scrollbar-color:var(--border) var(--surface)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background-color:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background-color:var(--primary)}.text-primary{color:var(--primary)}.text-secondary{color:var(--secondary)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-info{color:var(--info)}.text-muted{color:var(--text-muted)}.bg-surface{background:var(--surface)}.bg-surface-2{background:var(--surface-2)}.bg-surface-3{background:var(--surface-3)}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:var(--radius)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-lg{border-radius:var(--radius-lg)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.9375rem;line-height:1.6}a{color:inherit;text-decoration:none}a:hover{color:var(--primary-light)}img{max-width:100%;height:auto;display:block}button{font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{color:var(--text);font-weight:600;line-height:1.3}p{color:var(--text-muted);line-height:1.7}hr{border:none;border-top:1px solid var(--border);margin:1rem 0}.page-wrapper{max-width:1400px;padding:1.5rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.page-header h2{color:var(--primary-dark);font-size:1.35rem;font-weight:700}.page-header .page-actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.page-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.875rem}.section{margin-bottom:2rem}.section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem;font-size:1rem;font-weight:600}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.fade-in{animation:.3s forwards fadeIn}.skeleton{background:linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);border-radius:var(--radius-sm);background-size:1000px 100%;animation:1.6s linear infinite shimmer}.divider{background:var(--border);border:none;height:1px;margin:1.25rem 0}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}::selection{color:var(--text);background:#6c5ce74d}#app-layout{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:100vh;height:100vh;display:grid;overflow:hidden}#sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);z-index:200;height:100vh;transition:var(--transition);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden auto}.sidebar-logo{border-bottom:1px solid var(--border);flex-shrink:0;padding:1.5rem 1.25rem 1rem}.sidebar-logo-inner{align-items:center;gap:.75rem;display:flex}.sidebar-monogram{border-radius:var(--radius-sm);background:var(--primary);color:#fff;letter-spacing:-.5px;border:1px solid var(--primary-dark);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:.9rem;font-weight:800;display:flex}.sidebar-brand-text{flex-direction:column;display:flex}.sidebar-brand-name{color:var(--primary);font-size:1rem;font-weight:700;line-height:1.2}.sidebar-brand-sub{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:.7rem;font-weight:400}.sidebar-user{border-bottom:1px solid var(--border);flex-shrink:0;padding:1rem 1.25rem}.sidebar-user-inner{align-items:center;gap:.75rem;display:flex}.sidebar-avatar{background:var(--primary-light);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.875rem;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.sidebar-user-role{background:var(--surface-2);color:var(--primary);text-transform:capitalize;letter-spacing:.03em;border-radius:100px;align-items:center;margin-top:.2rem;padding:.15rem .5rem;font-size:.65rem;font-weight:600;display:inline-flex}.sidebar-nav{flex-direction:column;flex:1;gap:.125rem;padding:.75rem;display:flex;overflow-y:auto}.sidebar-nav-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);padding:.75rem .5rem .25rem;font-size:.65rem;font-weight:600}.nav-item{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);color:var(--text-muted);border:1px solid #0000;align-items:center;gap:.75rem;padding:.625rem .875rem;font-size:.875rem;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--surface-2);color:var(--text);border-color:var(--border)}.nav-item.active{background:var(--surface-3);color:var(--primary-dark);border-color:var(--border)}.nav-item.active:before{content:"";background:var(--primary);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-icon{text-align:center;flex-shrink:0;width:20px;font-size:1rem}.nav-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.sidebar-footer{border-top:1px solid var(--border);flex-shrink:0;padding:.75rem}.sidebar-logout{border-radius:var(--radius-sm);cursor:pointer;width:100%;transition:var(--transition);color:var(--text-muted);background:0 0;border:1px solid #0000;align-items:center;gap:.75rem;padding:.625rem .875rem;font-size:.875rem;font-weight:500;display:flex}.sidebar-logout:hover{color:var(--danger);background:#e170551a;border-color:#e1705533}#main-content{flex-direction:column;grid-column:2;height:100vh;display:flex;overflow:hidden}#topbar{height:var(--topbar-height);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:100;background:#ffffffd9;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:0 1.5rem;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:1rem;min-width:0;display:flex}.topbar-title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:1.125rem;font-weight:600;overflow:hidden}.topbar-right{flex-shrink:0;align-items:center;gap:.75rem;display:flex}#content{flex:1;overflow:hidden auto}.punch-status-bar{align-items:center;gap:.75rem;display:flex}.punch-time-display{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);align-items:center;gap:.5rem;padding:.375rem .75rem;font-size:.8rem;display:flex}.punch-time-value{color:var(--text);font-weight:600}.punch-dot{background:var(--success);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}.punch-dot.out{background:var(--text-muted);animation:none}.notif-btn{border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);cursor:pointer;width:38px;height:38px;transition:var(--transition);color:var(--text-muted);justify-content:center;align-items:center;font-size:1rem;display:flex;position:relative}.notif-btn:hover{background:var(--surface-3);color:var(--text);border-color:var(--primary)}.notif-badge{background:var(--danger);color:#fff;border:2px solid var(--surface);border-radius:100px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.65rem;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px}.user-dropdown{position:relative}.user-dropdown-trigger{border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);cursor:pointer;transition:var(--transition);align-items:center;gap:.625rem;padding:.375rem .625rem;display:flex}.user-dropdown-trigger:hover{border-color:var(--primary);background:var(--surface-3)}.topbar-avatar{background:var(--primary-light);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.75rem;font-weight:700;display:flex}.topbar-user-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:.8rem;font-weight:600;overflow:hidden}.dropdown-chevron{color:var(--text-muted);transition:var(--transition);font-size:.6rem}.user-dropdown-trigger.open .dropdown-chevron{transform:rotate(180deg)}.user-dropdown-menu{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);min-width:180px;box-shadow:var(--shadow);z-index:300;animation:.15s fadeIn;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.dropdown-item{color:var(--text-muted);cursor:pointer;transition:var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:.625rem;width:100%;padding:.75rem 1rem;font-size:.875rem;display:flex}.dropdown-item:hover{background:var(--surface-3);color:var(--text)}.dropdown-item.danger:hover{color:var(--danger);background:#e170551a}.dropdown-divider{background:var(--border);height:1px;margin:.25rem 0}@media (width<=768px){#app-layout{grid-template-columns:1fr}#sidebar{transform:translate(-100%)}#sidebar.open{transform:translate(0)}#main-content{grid-column:1}}.sidebar-resize-handle{cursor:ew-resize;z-index:250;background:0 0;width:5px;transition:background .15s,width .15s;position:absolute;top:0;bottom:0;right:0}.sidebar-resize-handle:hover,.sidebar-resize-handle.resizing{background:var(--primary);width:6px;box-shadow:0 0 10px #008b9899}.calendar-container{grid-template-columns:repeat(7,1fr);gap:1rem;display:grid}.calendar-cell{border:1px solid var(--border);background-color:var(--surface);border-radius:8px;flex-direction:column;gap:.5rem;min-height:80px;padding:.75rem;display:flex}.calendar-cell.empty{background-color:#0000;border:none}.calendar-cell-header{color:var(--text);margin-bottom:.25rem;font-size:.9rem;font-weight:600}.calendar-badge{text-align:center;border-radius:12px;width:max-content;padding:4px 12px;font-size:.85rem;font-weight:600;display:inline-block}.badge-pastel-present{color:#2e7d32;background-color:#e8f5e9}.badge-pastel-absent{color:#c62828;background-color:#ffebee}.badge-pastel-halfday{color:#e65100;background-color:#fff3e0}.badge-pastel-wfh{color:#1565c0;background-color:#e3f2fd}.badge-pastel-holiday{color:#6a1b9a;background-color:#f3e5f5}.badge-pastel-weekend{color:#512da8;background-color:#ede7f6}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:var(--transition);overflow:hidden}.card:hover{border-color:#008b9840}.card.gradient{border-top:3.5px solid var(--primary)}.card.no-hover:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:1.125rem 1.5rem;display:flex}.card-header-left{flex-direction:column;gap:.125rem;min-width:0;display:flex}.card-title{color:var(--text);font-size:1rem;font-weight:600}.card-subtitle{color:var(--text-muted);font-size:.8rem;font-weight:400}.card-header-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.card-body{padding:1.5rem}.card-body.no-padding{padding:0}.card-footer{border-top:1px solid var(--border);background:var(--surface-2);justify-content:flex-end;align-items:center;gap:.75rem;padding:.875rem 1.5rem;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;padding:.5625rem 1.125rem;font-family:inherit;font-size:.875rem;font-weight:500;line-height:1;text-decoration:none;display:inline-flex}.btn:disabled,.btn.loading{opacity:.55;cursor:not-allowed;pointer-events:none}.btn-full{width:100%}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.btn-primary:hover:not(:disabled),.btn-primary:active:not(:disabled){background:var(--primary-dark)}.btn-secondary{color:var(--secondary);border:1px solid var(--secondary);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--surface-2)}.btn-danger{color:var(--danger);background:#e1705526;border-color:#e170554d}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-ghost{color:var(--text-muted);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text);border-color:var(--border)}.btn-outline{color:var(--text);border-color:var(--border);background:0 0}.btn-outline:hover:not(:disabled){border-color:var(--primary);color:var(--primary-light);background:#008b980d}.btn-success{color:var(--success);background:#00b89426;border-color:#00b8944d}.btn-success:hover:not(:disabled){background:var(--success);color:#fff}.btn-sm{border-radius:6px;padding:.375rem .75rem;font-size:.8rem}.btn-lg{border-radius:var(--radius);padding:.75rem 1.5rem;font-size:1rem}.btn-icon{width:36px;height:36px;padding:.5625rem}.btn-icon.btn-sm{width:30px;height:30px;padding:.375rem}.btn-spinner{border:2px solid;border-top-color:#0000;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.6s linear infinite spin}.badge{white-space:nowrap;letter-spacing:.02em;border-radius:100px;align-items:center;gap:.25rem;padding:.2rem .625rem;font-size:.72rem;font-weight:600;line-height:1;display:inline-flex}.badge-success{background:var(--surface-3);color:var(--primary-dark);border:1px solid var(--border)}.badge-primary,.badge-info{background:var(--surface-2);color:var(--primary);border:1px solid #008b9840}.badge-danger{color:var(--danger);background:#e170551f;border:1px solid #e1705540}.badge-warning{color:var(--warning);background:#fdcb6e1f;border:1px solid #fdcb6e40}.badge-info{color:var(--info);background:#74b9ff1f;border:1px solid #74b9ff40}.badge-primary{color:var(--primary);background:#008b981f;border:1px solid #008b9840}.badge-secondary{color:var(--secondary);background:#00cec91f;border:1px solid #00cec940}.badge-default{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.badge-accent{color:var(--accent);background:#fd79a81f;border:1px solid #fd79a840}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.table-wrapper-scrollable{-webkit-overflow-scrolling:touch;border-radius:0 0 var(--radius,8px) var(--radius,8px);max-height:218px;overflow:auto}.table-wrapper-scrollable .table thead th{z-index:2;background:var(--surface-2);box-shadow:0 1px 0 var(--border);position:sticky;top:0}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap;padding:.75rem 1rem;font-size:.72rem;font-weight:600}.table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.table th.sortable:hover{color:var(--text);background:var(--surface-3)}.table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:.875rem 1rem}.table tr:last-child td{border-bottom:none}.table tbody tr{transition:var(--transition)}.table tbody tr:hover{background:var(--surface-2)}.table tbody tr.clickable{cursor:pointer}.table-empty{text-align:center;color:var(--text-muted);padding:3rem}.table-skeleton-row td{padding:1rem}.table-skeleton-cell{border-radius:4px;height:14px}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-height:90vh;animation:.2s slideInLeft;display:flex;position:relative}.modal-sm{max-width:420px}.modal-md{max-width:600px}.modal-lg{max-width:820px}.modal-xl{max-width:1040px}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.modal-title{color:var(--text);font-size:1.0625rem;font-weight:600}.modal-close{border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);cursor:pointer;width:30px;height:30px;transition:var(--transition);color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.modal-close:hover{background:var(--surface-3);color:var(--text);border-color:var(--primary)}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;align-items:center;gap:.75rem;padding:1rem 1.5rem;display:flex}.input-group{flex-direction:column;gap:0;display:flex}.input-label{color:var(--text-muted);margin-bottom:.375rem;font-size:.82rem;font-weight:500;display:block}.input-label .required{color:var(--danger);margin-left:2px}.input-field{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:var(--transition);appearance:none;padding:.625rem .875rem;font-size:.875rem}.input-field::placeholder{color:var(--text-dim)}.input-field:focus{border-color:var(--primary);background:var(--surface);outline:none}.input-field:disabled,select.input-field:disabled,textarea.input-field:disabled{opacity:.95;cursor:not-allowed;background-color:var(--surface-2);color:var(--text)!important;-webkit-text-fill-color:var(--text)!important}.input-field.error{border-color:var(--danger);box-shadow:0 0 0 3px #e170551f}.input-error-msg{color:var(--danger);margin-top:.3rem;font-size:.78rem}.input-hint{color:var(--text-muted);margin-top:.3rem;font-size:.78rem}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);pointer-events:none;font-size:.9rem;position:absolute;left:.875rem}.input-wrapper .input-icon~.input-field{padding-left:2.25rem}select.input-field{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238888a8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right .875rem center;background-repeat:no-repeat;padding-right:2.5rem}select.input-field option{background:var(--surface-2);color:var(--text)}textarea.input-field{resize:vertical;min-height:100px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);padding:1.375rem 1.5rem;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--primary-light)}.stat-card:before{content:"";background:var(--primary);border-radius:0 2px 2px 0;width:4px;height:100%;position:absolute;top:0;left:0}.stat-card.color-success:before{background:var(--success)}.stat-card.color-warning:before{background:var(--warning)}.stat-card.color-danger:before{background:var(--danger)}.stat-card.color-info:before{background:var(--info)}.stat-card.color-primary:before{background:var(--primary)}.stat-card.color-secondary:before{background:var(--secondary)}.stat-card-icon{opacity:.12;font-size:2rem;line-height:1;position:absolute;top:1rem;right:1rem}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;font-size:.78rem;font-weight:600}.stat-value{color:var(--text);margin-bottom:.375rem;font-size:2rem;font-weight:700;line-height:1}.stat-subtitle{color:var(--text-muted);font-size:.78rem}.stat-trend{align-items:center;gap:.25rem;margin-top:.375rem;font-size:.78rem;font-weight:600;display:inline-flex}.stat-trend.up{color:var(--success)}.stat-trend.down{color:var(--danger)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.empty-state-icon{opacity:.4;margin-bottom:1rem;font-size:3.5rem;line-height:1}.empty-state-title{color:var(--text);margin-bottom:.5rem;font-size:1.0625rem;font-weight:600}.empty-state-desc{color:var(--text-muted);max-width:360px;margin-bottom:1.5rem;font-size:.875rem;line-height:1.7}.spinner{border:2px solid var(--surface-3);border-top-color:var(--primary);border-radius:50%;flex-shrink:0;animation:.65s linear infinite spin}.spinner-sm{width:16px;height:16px}.spinner-md{border-width:3px;width:28px;height:28px}.spinner-lg{border-width:3px;width:48px;height:48px}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:.75rem;display:flex}.loading-container.fullpage{background:var(--bg);z-index:9999;position:fixed;inset:0}.loading-text{color:var(--text-muted);font-size:.875rem}.pagination{flex-wrap:wrap;align-items:center;gap:.375rem;display:flex}.pagination-info{color:var(--text-muted);margin-right:.5rem;font-size:.8rem}.page-btn{border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border);min-width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;padding:0 .5rem;font-size:.82rem;font-weight:500;display:inline-flex}.page-btn:hover:not(:disabled){background:var(--surface-3);color:var(--text);border-color:var(--primary)}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary-dark)}.page-btn:disabled{opacity:.35;cursor:not-allowed}.form-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;display:grid}.form-grid-1{grid-template-columns:1fr}.form-grid-2{grid-template-columns:repeat(2,1fr)}.form-grid-3{grid-template-columns:repeat(3,1fr)}.form-section{margin-bottom:1.5rem}.form-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.5rem;font-size:.8rem;font-weight:600}.col-span-2{grid-column:span 2}.col-span-3{grid-column:span 3}.toolbar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.toolbar-search{flex:1;min-width:200px;max-width:360px}.toolbar-filters{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.toolbar-actions{align-items:center;gap:.5rem;margin-left:auto;display:flex}.confirm-dialog-icon{border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;margin:0 auto 1rem;font-size:1.5rem;display:flex}.confirm-dialog-icon.danger{color:var(--danger);background:#e1705526}.confirm-dialog-icon.primary{color:var(--primary);background:#008b9826}.confirm-dialog-title{color:var(--text);text-align:center;margin-bottom:.5rem;font-size:1.125rem;font-weight:600}.confirm-dialog-message{color:var(--text-muted);text-align:center;font-size:.875rem;line-height:1.7}.avatar{background:var(--gradient-accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:inline-flex;overflow:hidden}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-md{width:44px;height:44px;font-size:1rem}.avatar-lg{width:64px;height:64px;font-size:1.375rem}.avatar-xl{width:96px;height:96px;font-size:2rem}.avatar img{object-fit:cover;width:100%;height:100%}.tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:1.5rem;display:flex;overflow-x:auto}.tab-item{color:var(--text-muted);cursor:pointer;transition:var(--transition);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:.75rem 1.25rem;font-size:.875rem;font-weight:500}.tab-item:hover{color:var(--text)}.tab-item.active{color:var(--primary);border-bottom-color:var(--primary)}.chip{background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:var(--transition);border-radius:100px;align-items:center;gap:.375rem;padding:.3rem .75rem;font-size:.78rem;font-weight:500;display:inline-flex}.chip:hover,.chip.active{color:var(--primary);background:#008b981a;border-color:#008b984d}.alert{border-radius:var(--radius-sm);border:1px solid;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;font-size:.875rem;display:flex}.alert-success{color:var(--success);background:#00b89414;border-color:#00b89440}.alert-danger{color:var(--danger);background:#e1705514;border-color:#e1705540}.alert-warning{color:var(--warning);background:#fdcb6e14;border-color:#fdcb6e40}.alert-info{color:var(--info);background:#74b9ff14;border-color:#74b9ff40}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;font-size:.875rem;position:absolute;left:.75rem}.search-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);transition:var(--transition);padding:.5625rem .875rem .5625rem 2.25rem;font-size:.875rem}.search-input::placeholder{color:var(--text-dim)}.search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #008b9826}@media (width<=640px){.form-grid-2,.form-grid-3{grid-template-columns:1fr}.col-span-2,.col-span-3{grid-column:span 1}.stats-grid{grid-template-columns:1fr 1fr}}
