@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--primary: #2563EB;--primary-hover: #1D4ED8;--primary-light: #3B82F6;--primary-50: #EFF6FF;--primary-100: #DBEAFE;--secondary: #3B82F6;--accent: #8B5CF6;--accent-light: #A78BFA;--success: #10B981;--success-light: #D1FAE5;--success-dark: #059669;--warning: #F59E0B;--warning-light: #FEF3C7;--warning-dark: #D97706;--danger: #EF4444;--danger-light: #FEE2E2;--danger-dark: #DC2626;--info: #06B6D4;--info-light: #CFFAFE;--white: #FFFFFF;--gray-50: #F8FAFC;--gray-100: #F1F5F9;--gray-200: #E2E8F0;--gray-300: #CBD5E1;--gray-400: #94A3B8;--gray-500: #64748B;--gray-600: #475569;--gray-700: #334155;--gray-800: #1E293B;--gray-900: #0F172A;--bg-primary: #F8FAFC;--bg-secondary: #FFFFFF;--bg-card: #FFFFFF;--bg-sidebar: #FFFFFF;--bg-hover: #F1F5F9;--bg-active: #EFF6FF;--text-primary: #0F172A;--text-secondary: #64748B;--text-muted: #94A3B8;--text-inverse: #FFFFFF;--border: #E2E8F0;--border-focus: #2563EB;--border-hover: #CBD5E1;--shadow-xs: 0 1px 2px 0 rgba(0,0,0,.05);--shadow-sm: 0 1px 3px 0 rgba(0,0,0,.1), 0 1px 2px -1px rgba(0,0,0,.1);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -2px rgba(0,0,0,.1);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -4px rgba(0,0,0,.1);--shadow-xl: 0 20px 25px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.1);--shadow-2xl: 0 25px 50px -12px rgba(0,0,0,.25);--shadow-card: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-glow: 0 0 20px rgba(37,99,235,.15);--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--sidebar-width: 268px;--sidebar-collapsed-width: 72px;--topbar-height: 72px;--transition-fast: all .15s ease;--transition: all .25s ease;--transition-slow: all .4s ease;--transition-bounce: all .3s cubic-bezier(.34, 1.56, .64, 1)}[data-theme=dark]{--primary: #3B82F6;--primary-hover: #2563EB;--primary-light: #60A5FA;--primary-50: #1E3A5F;--primary-100: #1E3A5F;--bg-primary: #0F172A;--bg-secondary: #1E293B;--bg-card: #1E293B;--bg-sidebar: #0F172A;--bg-hover: #334155;--bg-active: #1E3A5F;--text-primary: #F1F5F9;--text-secondary: #94A3B8;--text-muted: #64748B;--border: #334155;--border-focus: #3B82F6;--border-hover: #475569;--white: #1E293B;--gray-50: #1E293B;--gray-100: #334155;--gray-200: #475569;--gray-300: #64748B;--gray-400: #94A3B8;--gray-500: #94A3B8;--gray-600: #CBD5E1;--gray-700: #E2E8F0;--gray-800: #F1F5F9;--gray-900: #F8FAFC;--shadow-card: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.3), 0 2px 4px -2px rgba(0,0,0,.2);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.3), 0 4px 6px -4px rgba(0,0,0,.2);--shadow-xl: 0 20px 25px -5px rgba(0,0,0,.4), 0 8px 10px -6px rgba(0,0,0,.3);--success-light: rgba(16,185,129,.15);--warning-light: rgba(245,158,11,.15);--danger-light: rgba(239,68,68,.15);--info-light: rgba(6,182,212,.15)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{height:100%;font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;height:100%;transition:background-color .3s ease,color .3s ease}#root{height:100%}button,input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.app-shell{display:flex;height:100vh;overflow:hidden;background-color:var(--bg-primary)}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;left:0;top:0;height:100vh;z-index:50;overflow:hidden;transition:width .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-brand{display:flex;align-items:center;padding:0 16px;gap:12px;border-bottom:1px solid var(--border);height:var(--topbar-height);box-sizing:border-box;overflow:hidden}.brand-logo{width:40px;height:40px;min-width:40px;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:var(--radius-md);color:#fff;font-weight:800;font-size:1.1rem;box-shadow:0 4px 12px #2563eb4d}.brand-text{overflow:hidden;transition:opacity .2s ease,width .3s ease}.brand-name{font-size:1rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.brand-sub{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;font-weight:500;white-space:nowrap}.sidebar.collapsed .brand-text{opacity:0;width:0;overflow:hidden}.sidebar-toggle{margin-left:auto;min-width:30px;height:30px;display:grid;place-items:center;background:var(--bg-hover);border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast)}.sidebar-toggle:hover{background:var(--primary-100);color:var(--primary)}.sidebar-content{flex:1;overflow-y:auto;padding:12px 8px;display:flex;flex-direction:column;gap:4px}.sidebar-section-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);padding:12px 12px 4px;white-space:nowrap;overflow:hidden;transition:opacity .2s ease}.sidebar.collapsed .sidebar-section-label{opacity:0}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 12px;color:var(--text-secondary);border-radius:var(--radius-md);transition:var(--transition-fast);font-weight:500;font-size:.875rem;cursor:pointer;position:relative;white-space:nowrap;overflow:hidden;text-decoration:none}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-link.active{background:var(--primary-50);color:var(--primary)}.sidebar-link .link-icon{min-width:20px;display:flex;align-items:center;justify-content:center}.sidebar-link .link-label{transition:opacity .2s ease;overflow:hidden}.sidebar.collapsed .link-label{opacity:0;width:0;overflow:hidden}.sidebar-link .badge-count{margin-left:auto;background:var(--danger);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:var(--radius-full);display:grid;place-items:center;padding:0 4px;transition:opacity .2s ease}.sidebar.collapsed .badge-count{opacity:0}.sidebar-footer{border-top:1px solid var(--border);padding:12px 8px}.sidebar-user-card{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);background:var(--bg-hover);cursor:pointer;overflow:hidden;transition:var(--transition-fast)}.sidebar-user-card:hover{background:var(--primary-50)}.user-avatar{width:36px;height:36px;min-width:36px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary),var(--accent));display:grid;place-items:center;color:#fff;font-weight:700;font-size:.875rem;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar-lg{width:48px;height:48px;min-width:48px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary),var(--accent));display:grid;place-items:center;color:#fff;font-weight:700;font-size:1.1rem;overflow:hidden}.user-avatar-xl{width:80px;height:80px;min-width:80px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary),var(--accent));display:grid;place-items:center;color:#fff;font-weight:700;font-size:1.75rem;overflow:hidden}.user-meta{overflow:hidden;transition:opacity .2s ease}.sidebar.collapsed .user-meta{opacity:0;width:0}.user-meta-name{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-meta-role{font-size:.7rem;color:var(--text-secondary);text-transform:capitalize;white-space:nowrap}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--success);position:absolute;bottom:2px;right:2px;border:2px solid var(--bg-sidebar)}.topbar{height:var(--topbar-height);background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:40;box-shadow:var(--shadow-xs)}.topbar-title{font-size:1rem;font-weight:600;color:var(--text-primary);flex:1}.topbar-search{display:flex;align-items:center;gap:8px;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);height:40px;box-sizing:border-box;padding:0 14px;min-width:240px;transition:var(--transition-fast)}.topbar-search:focus-within{border-color:var(--primary);background:var(--bg-secondary);box-shadow:0 0 0 3px #2563eb1a}.topbar-search input{border:none;background:transparent;outline:none;font-size:.875rem;color:var(--text-primary);width:100%;padding:0}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-actions{display:flex;align-items:center;gap:8px}.icon-btn{width:40px;height:40px;display:grid;place-items:center;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);position:relative}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-btn .notif-dot{position:absolute;top:7px;right:7px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid var(--bg-secondary)}.topbar-profile-btn{display:flex;align-items:center;gap:8px;border:none;background:transparent;cursor:pointer;height:40px;box-sizing:border-box;padding:0 8px;border-radius:var(--radius-md);transition:var(--transition-fast)}.topbar-profile-btn:hover{background:var(--bg-hover)}.main-layout{margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1);flex:1;overflow-x:hidden}.main-layout.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.content-panel{flex:1;padding:28px;overflow-y:auto;max-height:calc(100vh - var(--topbar-height))}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}.page-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1.2}.page-subtitle{font-size:.875rem;color:var(--text-secondary);margin-top:4px}.page-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-card);transition:var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.card-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-card);transition:var(--transition);cursor:default;position:relative;overflow:hidden}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--kpi-color, var(--primary));opacity:0;transition:opacity .25s ease}.kpi-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--border-hover)}.kpi-card:hover:before{opacity:1}.kpi-icon{width:44px;height:44px;border-radius:var(--radius-md);display:grid;place-items:center;background:var(--kpi-bg, var(--primary-50));color:var(--kpi-color, var(--primary))}.kpi-info{display:flex;flex-direction:column;gap:2px}.kpi-label{font-size:.78rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.kpi-value{font-size:2rem;font-weight:800;color:var(--text-primary);line-height:1}.kpi-change{font-size:.75rem;font-weight:500;display:flex;align-items:center;gap:4px}.kpi-change.positive{color:var(--success)}.kpi-change.negative{color:var(--danger)}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;border:none;outline:none;transition:var(--transition-fast);white-space:nowrap;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #2563eb40}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 16px #2563eb59;transform:translateY(-1px)}.btn-secondary{background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--gray-200);border-color:var(--border-hover)}.btn-success{background:var(--success);color:#fff;box-shadow:0 2px 8px #10b98140}.btn-success:hover{background:var(--success-dark);transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 8px #ef444440}.btn-danger:hover{background:var(--danger-dark);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}.btn-outline:hover{background:var(--primary-50)}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-lg{padding:12px 24px;font-size:1rem}.btn-icon{padding:8px;border-radius:var(--radius-md)}.primary-button{@extend .btn;@extend .btn-primary;}.secondary-button{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;background:var(--bg-hover);color:var(--text-primary);border:1px solid var(--border);transition:var(--transition-fast)}.secondary-button:hover{background:var(--gray-200)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600;text-transform:capitalize}.badge-primary{background:var(--primary-100);color:var(--primary)}.badge-success{background:var(--success-light);color:var(--success-dark)}.badge-warning{background:var(--warning-light);color:var(--warning-dark)}.badge-danger{background:var(--danger-light);color:var(--danger-dark)}.badge-info{background:var(--info-light);color:var(--info)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.status-badge.pending{background:var(--warning-light);color:var(--warning-dark)}.status-badge.approved,.status-badge.present,.status-badge.completed{background:var(--success-light);color:var(--success-dark)}.status-badge.rejected,.status-badge.absent,.status-badge.blocked{background:var(--danger-light);color:var(--danger-dark)}.status-badge.leave,.status-badge.in-progress{background:var(--info-light);color:var(--info)}.status-badge.active{background:var(--success-light);color:var(--success-dark)}.status-badge.inactive{background:var(--gray-100);color:var(--gray-500)}.priority-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--radius-full);font-size:.72rem;font-weight:600}.priority-badge.high{background:var(--danger-light);color:var(--danger-dark)}.priority-badge.medium{background:var(--warning-light);color:var(--warning-dark)}.priority-badge.low{background:var(--success-light);color:var(--success-dark)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}label{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.form-control,input:not([type=checkbox]):not([type=radio]):not([type=file]),select,textarea{width:100%;padding:10px 14px;background:var(--bg-secondary);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:var(--transition-fast);outline:none}.form-control:focus,input:not([type=checkbox]):not([type=radio]):not([type=file]):focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;background:var(--bg-secondary)}input::placeholder,textarea::placeholder{color:var(--text-muted)}textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-error{color:var(--danger);font-size:.78rem;margin-top:2px}.input-group{position:relative}.input-group .input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.input-group input{padding-left:38px}.table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:.875rem}thead th{background:var(--bg-hover);color:var(--text-secondary);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:12px 16px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--border)}tbody tr{border-bottom:1px solid var(--border);transition:var(--transition-fast)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg-hover)}tbody td{padding:14px 16px;color:var(--text-primary);vertical-align:middle}.table-scroll{overflow-x:auto}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:12px;opacity:.4}.modal-backdrop,.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fadeIn .2s ease}.modal,.modal-content,.modal-card{background:var(--bg-card);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:560px;box-shadow:var(--shadow-2xl);border:1px solid var(--border);animation:slideUp .3s cubic-bezier(.34,1.56,.64,1);max-height:90vh;overflow-y:auto}.modal-lg{max-width:800px}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.modal-close{width:32px;height:32px;display:grid;place-items:center;border:none;background:var(--bg-hover);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);transition:var(--transition-fast)}.modal-close:hover{background:var(--danger-light);color:var(--danger)}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.dropdown{position:relative}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:8px;z-index:200;animation:fadeDown .2s ease}.dropdown-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:var(--transition-fast);border:none;background:transparent;width:100%;text-align:left}.dropdown-item:hover{background:var(--bg-hover)}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:var(--danger-light)}.dropdown-divider{height:1px;background:var(--border);margin:6px 0}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:20px;position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(37,99,235,.15) 0%,transparent 70%);top:-200px;right:-100px;pointer-events:none}.auth-page:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.1) 0%,transparent 70%);bottom:-100px;left:-100px;pointer-events:none}.auth-card{width:100%;max-width:440px;background:#1e293be6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-2xl);padding:44px;box-shadow:var(--shadow-2xl);position:relative;z-index:1}.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.auth-logo-icon{width:48px;height:48px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--primary),var(--accent));display:grid;place-items:center;box-shadow:0 8px 24px #2563eb66}.auth-logo-text h2{font-size:1.1rem;font-weight:700;color:#fff}.auth-logo-text span{font-size:.7rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.1em}.auth-title{font-size:1.75rem;font-weight:800;color:#fff;margin-bottom:8px}.auth-subtitle{font-size:.9rem;color:#ffffff80;margin-bottom:32px}.auth-form .form-group{margin-bottom:18px}.auth-form label{color:#ffffffb3;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;display:block}.auth-form input{background:#ffffff12;border:1.5px solid rgba(255,255,255,.1);color:#fff;padding:12px 16px}.auth-form input:focus{background:#ffffff1a;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb33}.auth-form input::placeholder{color:#ffffff4d}.auth-submit{width:100%;padding:13px;background:linear-gradient(135deg,var(--primary),var(--accent));border:none;border-radius:var(--radius-md);color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;transition:var(--transition);margin-top:8px;box-shadow:0 4px 16px #2563eb66;font-family:inherit}.auth-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px #2563eb80}.auth-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-footer{text-align:center;margin-top:24px;color:#fff6;font-size:.85rem}.dashboard-grid{display:grid;gap:24px}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.quick-actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-card);font-family:inherit}.quick-action-btn:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--primary)}.quick-action-btn:hover .qa-icon{background:var(--primary);color:#fff}.qa-icon{width:48px;height:48px;border-radius:var(--radius-md);display:grid;place-items:center;background:var(--primary-50);color:var(--primary);transition:var(--transition-fast)}.qa-label{font-size:.78rem;font-weight:600;color:var(--text-secondary);text-align:center}.kanban-board{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:start}.kanban-col{background:var(--bg-hover);border-radius:var(--radius-lg);padding:14px}.kanban-col-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.kanban-col-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}.kanban-count{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-full);font-size:.72rem;font-weight:700;padding:2px 8px;color:var(--text-secondary)}.kanban-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;margin-bottom:10px;box-shadow:var(--shadow-xs);transition:var(--transition-fast);cursor:pointer}.kanban-card:hover{box-shadow:var(--shadow-md);border-color:var(--primary)}.kanban-card-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:8px;line-height:1.4}.kanban-card-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:20px}.filter-bar input,.filter-bar select{width:auto;min-width:160px}.search-box{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:8px 14px;transition:var(--transition-fast);flex:1;min-width:200px;max-width:320px}.search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.search-box input{border:none;background:transparent;outline:none;padding:0;width:100%;font-size:.875rem}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:14px;border-radius:var(--radius-sm)}.skeleton-heading{height:24px;border-radius:var(--radius-sm)}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.skeleton-avatar{border-radius:50%}.progress-bar{width:100%;height:8px;background:var(--gray-200);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:var(--radius-full);transition:width .6s ease}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:16px;padding-bottom:20px;position:relative}.timeline-item:before{content:"";position:absolute;left:19px;top:36px;bottom:0;width:2px;background:var(--border)}.timeline-item:last-child:before{display:none}.timeline-dot{width:40px;height:40px;min-width:40px;border-radius:var(--radius-full);display:grid;place-items:center;background:var(--bg-hover);border:2px solid var(--border);color:var(--text-secondary);position:relative;z-index:1}.timeline-content{flex:1;padding-top:8px}.timeline-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.timeline-time{font-size:.75rem;color:var(--text-muted);margin-top:2px}.webcam-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--gray-900);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative;max-width:400px;margin:0 auto}.webcam-card video,.webcam-card img{width:100%;height:100%;object-fit:cover}.tabs{display:flex;gap:4px;background:var(--bg-hover);border-radius:var(--radius-md);padding:4px;margin-bottom:24px;border:1px solid var(--border)}.tab{padding:8px 16px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;color:var(--text-secondary);cursor:pointer;border:none;background:transparent;transition:var(--transition-fast);white-space:nowrap;font-family:inherit}.tab.active{background:var(--bg-card);color:var(--primary);box-shadow:var(--shadow-xs)}.tab:hover:not(.active){color:var(--text-primary)}.notif-panel{width:360px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;animation:fadeDown .2s ease}.notif-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.notif-item{display:flex;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:var(--transition-fast)}.notif-item:hover{background:var(--bg-hover)}.notif-item.unread{background:var(--primary-50)}.notif-icon{width:38px;height:38px;min-width:38px;border-radius:var(--radius-full);display:grid;place-items:center;font-size:1rem}.notif-content{flex:1}.notif-title{font-size:.85rem;font-weight:600;color:var(--text-primary)}.notif-desc{font-size:.78rem;color:var(--text-secondary);margin-top:2px}.notif-time{font-size:.72rem;color:var(--text-muted);margin-top:4px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-day-name{text-align:center;font-size:.72rem;font-weight:700;color:var(--text-muted);padding:8px 0;text-transform:uppercase}.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:.8rem;cursor:pointer;transition:var(--transition-fast);padding:4px;position:relative;border:1px solid transparent}.cal-day:hover{background:var(--bg-hover)}.cal-day.today{background:var(--primary);color:#fff;font-weight:700}.cal-day.other-month{color:var(--text-muted)}.cal-day.present{background:var(--success-light);color:var(--success-dark)}.cal-day.absent{background:var(--danger-light);color:var(--danger-dark)}.cal-day.leave{background:var(--warning-light);color:var(--warning-dark)}.cal-day.holiday{background:var(--info-light);color:var(--info)}.cal-dot{width:5px;height:5px;border-radius:50%;position:absolute;bottom:4px}.glass{background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.3)}[data-theme=dark] .glass{background:#1e293bb3;border:1px solid rgba(255,255,255,.1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-ring{0%{transform:scale(1);opacity:.7}to{transform:scale(1.5);opacity:0}}.animate-fade-in{animation:fadeIn .3s ease}.animate-slide-up{animation:slideUp .4s ease}.animate-slide-in{animation:slideIn .3s ease}.leave-balance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}.leave-balance-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;text-align:center;transition:var(--transition);box-shadow:var(--shadow-card)}.leave-balance-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.leave-balance-value{font-size:2.5rem;font-weight:800;color:var(--primary);line-height:1}.leave-balance-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}.leave-balance-used{font-size:.72rem;color:var(--text-muted);margin-top:6px}.checkin-hero{background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);border-radius:var(--radius-xl);padding:32px;color:#fff;text-align:center;position:relative;overflow:hidden}.checkin-hero:before{content:"";position:absolute;top:-50%;right:-10%;width:300px;height:300px;background:#ffffff0d;border-radius:50%}.live-clock{font-size:3.5rem;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1}.live-date{font-size:1rem;opacity:.8;margin-top:8px}.check-btn{padding:16px 40px;font-size:1.1rem;font-weight:700;border:none;border-radius:var(--radius-xl);cursor:pointer;transition:var(--transition);font-family:inherit}.check-in-btn{background:#fff;color:var(--primary)}.check-in-btn:hover{transform:scale(1.05);box-shadow:0 8px 24px #0003}.check-out-btn{background:#ffffff26;color:#fff;border:2px solid rgba(255,255,255,.4)}.check-out-btn:hover{background:#ffffff40;transform:scale(1.02)}.check-out-btn:disabled{opacity:.5;cursor:not-allowed}.profile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-card)}.profile-banner{height:120px;background:linear-gradient(135deg,var(--primary),var(--accent))}.profile-avatar-wrap{margin-top:-48px;padding:0 24px 24px;display:flex;align-items:flex-end;justify-content:space-between}.mobile-menu-btn{display:grid;width:40px;height:40px;place-items:center;border:none;background:var(--bg-hover);border-radius:var(--radius-md);cursor:pointer;color:var(--text-primary)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:45}.topbar-user-meta{display:flex;flex-direction:column;text-align:left}.topbar-user-name{font-weight:600;font-size:.8rem;line-height:1.1;color:var(--text-primary)}.topbar-user-role{font-size:.7rem;color:var(--text-secondary)}@media (max-width: 1280px){.kanban-board{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}}@media (max-width: 1024px){.kpi-grid{grid-template-columns:repeat(3,1fr)}.form-row,.charts-grid{grid-template-columns:1fr}}@media (max-width: 768px){:root{--sidebar-width: 280px}.sidebar{transform:translate(-100%);transition:transform .3s ease;width:var(--sidebar-width)!important}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay{display:block}.main-layout{margin-left:0!important}.mobile-menu-btn{display:grid}.content-panel{padding:16px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.kanban-board{grid-template-columns:1fr}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar .search-box{max-width:none}.page-header{flex-direction:column}.page-actions{width:100%}.page-actions .btn{flex:1;justify-content:center}.modal,.modal-content{padding:24px}.modal-lg{max-width:100%}.topbar-search{display:none}.topbar-user-meta{display:none!important}.charts-grid,.form-row{grid-template-columns:1fr}.leave-balance-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr 1fr}.auth-card{padding:28px 20px}.content-panel{padding:12px}.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:8px}.gap-4{gap:16px}.gap-6{gap:24px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.w-full{width:100%}.text-center{text-align:center}.font-bold{font-weight:700}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.text-primary-color{color:var(--primary)}.text-success{color:var(--success-dark)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning-dark)}.hidden{display:none}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.overflow-auto{overflow:auto}.rounded-full{border-radius:var(--radius-full)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.info-row{display:flex;gap:16px;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);font-size:.875rem}.info-row:last-child{border-bottom:none}.info-label{font-weight:600;color:var(--text-secondary);min-width:140px;font-size:.8rem}.info-value{color:var(--text-primary)}.avatar-group{display:flex}.avatar-group .user-avatar{margin-left:-10px;border:2px solid var(--bg-card)}.avatar-group .user-avatar:first-child{margin-left:0}.checkin-page{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}@media (max-width: 900px){.checkin-page{grid-template-columns:1fr}}.checkin-status-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-card)}.checkin-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:20px}.page-grid{display:grid;gap:24px}.task-card-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;transition:var(--transition-fast);cursor:pointer}.task-card-item:hover{box-shadow:var(--shadow-md);border-color:var(--primary)}.task-card-item.completed{opacity:.7}.stats-row{display:flex;gap:16px;flex-wrap:wrap}.stat-chip{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);font-size:.85rem;box-shadow:var(--shadow-xs)}.stat-chip-label{color:var(--text-secondary);font-size:.78rem}.stat-chip-value{font-weight:700;color:var(--text-primary)}.checkin-container{display:grid;grid-template-columns:1fr 1.1fr;gap:28px;align-items:start}@media (max-width: 1024px){.checkin-container{grid-template-columns:1fr}}.clock-widget{text-align:center;padding:24px;background:linear-gradient(135deg,#2563eb0d,#8b5cf60d);border-radius:var(--radius-xl);border:1px solid var(--border);margin-bottom:20px;position:relative;overflow:hidden}.clock-widget:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(37,99,235,.04) 0%,transparent 60%);pointer-events:none}.clock-time{font-family:Inter,monospace;font-size:3rem;font-weight:800;color:var(--text-primary);line-height:1.1;letter-spacing:-.02em;text-shadow:0 2px 10px rgba(37,99,235,.08)}.clock-date{font-size:.875rem;color:var(--text-secondary);font-weight:500;margin-top:6px;text-transform:uppercase;letter-spacing:.05em}.checkin-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}@media (max-width: 480px){.checkin-stats-grid{grid-template-columns:1fr}}.checkin-stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;display:flex;align-items:center;gap:12px;transition:var(--transition-bounce);box-shadow:var(--shadow-sm)}.checkin-stat-card:hover{transform:translateY(-2px);border-color:var(--primary-light);box-shadow:var(--shadow-md)}.checkin-stat-icon-wrapper{width:42px;height:42px;border-radius:var(--radius-md);display:grid;place-items:center;background:var(--bg-hover);color:var(--primary);flex-shrink:0}.checkin-stat-icon-wrapper.in{background:#10b9811a;color:var(--success)}.checkin-stat-icon-wrapper.out{background:#ef44441a;color:var(--danger)}.checkin-stat-icon-wrapper.duration{background:#2563eb1a;color:var(--primary)}.checkin-stat-icon-wrapper.breaks{background:#f59e0b1a;color:var(--warning-dark)}.checkin-stat-icon-wrapper.location{background:#8b5cf61a;color:var(--accent)}.checkin-stat-info{display:flex;flex-direction:column;gap:2px}.checkin-stat-label{font-size:.72rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.checkin-stat-value{font-size:1rem;font-weight:700;color:var(--text-primary);line-height:1.2}.viewfinder-wrapper{position:relative;width:100%;border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border);background:#090d16;aspect-ratio:16/10;box-shadow:var(--shadow-md)}.viewfinder-camera{width:100%;height:100%;object-fit:cover}.viewfinder-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;padding:16px;box-sizing:border-box}.viewfinder-bracket{position:absolute;width:16px;height:16px;border-color:#ffffff59;border-style:solid;pointer-events:none}.viewfinder-bracket.tl{top:16px;left:16px;border-width:2px 0 0 2px;border-top-left-radius:4px}.viewfinder-bracket.tr{top:16px;right:16px;border-width:2px 2px 0 0;border-top-right-radius:4px}.viewfinder-bracket.bl{bottom:16px;left:16px;border-width:0 0 2px 2px;border-bottom-left-radius:4px}.viewfinder-bracket.br{bottom:16px;right:16px;border-width:0 2px 2px 0;border-bottom-right-radius:4px}.viewfinder-crosshair{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;opacity:.4;pointer-events:none}.viewfinder-crosshair:before,.viewfinder-crosshair:after{content:"";position:absolute;background:#fff}.viewfinder-crosshair:before{top:11px;left:0;width:24px;height:2px}.viewfinder-crosshair:after{top:0;left:11px;width:2px;height:24px}.viewfinder-live-indicator{display:flex;align-items:center;gap:8px;background:#0f172ab3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 12px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;color:#fff;letter-spacing:.05em;width:fit-content;border:1px solid rgba(255,255,255,.1)}.viewfinder-live-dot{width:8px;height:8px;border-radius:50%;background:var(--danger);animation:live-blink 1.2s infinite}@keyframes live-blink{0%,to{opacity:.2;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}.viewfinder-controls{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:12px;background:#0f172ab3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:8px 16px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,.12);pointer-events:auto;box-shadow:var(--shadow-lg);z-index:10}.active-break-banner{background:linear-gradient(135deg,#f59e0b26,#d9770614);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-lg);padding:20px;text-align:center;animation:break-pulse 2s infinite ease-in-out;margin-bottom:20px}@keyframes break-pulse{0%,to{box-shadow:0 0 #f59e0b26;border-color:#f59e0b4d}50%{box-shadow:0 0 16px #f59e0b40;border-color:#f59e0b80}}.break-timer-val{font-family:Inter,monospace;font-size:2.2rem;font-weight:800;color:var(--warning-dark);line-height:1.1;margin:8px 0}.checkin-task-list{display:flex;flex-direction:column;gap:10px;margin-top:14px}.checkin-task-row{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:var(--transition-fast)}.checkin-task-row:hover{border-color:var(--border-hover);background:var(--bg-hover)}.checkin-task-row.completed{opacity:.65}.checkin-task-checkbox{width:18px;height:18px;border-radius:4px;border:2px solid var(--gray-300);display:grid;place-items:center;cursor:pointer;transition:var(--transition-fast);color:#fff;flex-shrink:0}.checkin-task-checkbox.checked{background:var(--success);border-color:var(--success)}.badge-priority{font-size:.65rem;font-weight:700;text-transform:uppercase;padding:2px 6px;border-radius:var(--radius-xs)}.badge-priority.high{background:var(--danger-light);color:var(--danger-dark)}.badge-priority.medium{background:var(--warning-light);color:var(--warning-dark)}.badge-priority.low{background:var(--primary-50);color:var(--primary)}.checkout-alert-box{display:flex;align-items:flex-start;gap:10px;background:var(--warning-light);border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-lg);padding:12px 16px;font-size:.8rem;color:var(--warning-dark);line-height:1.4;margin-bottom:16px}.selfie-id-card{border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px;background:var(--bg-secondary);display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-sm);margin-top:14px;position:relative;overflow:hidden}.selfie-id-avatar{width:56px;height:56px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);flex-shrink:0;background:var(--bg-hover)}.selfie-id-avatar img{width:100%;height:100%;object-fit:cover}.selfie-id-meta{display:flex;flex-direction:column;gap:2px;flex:1}.selfie-id-badge{position:absolute;top:8px;right:8px;font-size:.6rem;font-weight:800;background:var(--success-light);color:var(--success-dark);padding:2px 6px;border-radius:var(--radius-sm);letter-spacing:.05em;text-transform:uppercase}
