:root{--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-card:#1a1f35;--bg-card-hover:#1f2544;--bg-input:#151b2e;--bg-overlay:#0009;--border-color:#2a3150;--border-light:#1e2540;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent-primary:#6366f1;--accent-primary-hover:#818cf8;--accent-primary-glow:#6366f140;--accent-primary-subtle:#6366f11a;--success:#10b981;--success-bg:#10b9811a;--success-border:#10b9814d;--danger:#ef4444;--danger-bg:#ef44441a;--danger-border:#ef44444d;--warning:#f59e0b;--warning-bg:#f59e0b1a;--warning-border:#f59e0b4d;--info:#3b82f6;--info-bg:#3b82f61a;--sidebar-width:260px;--header-height:60px;--bottom-nav-height:70px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px var(--accent-primary-glow)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bgFloat{0%,to{transform:translate(0)rotate(0)}33%{transform:translate(30px,-30px)rotate(120deg)}66%{transform:translate(-20px,20px)rotate(240deg)}}.spin{animation:1s linear infinite spin}.loading-screen{color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 20px;display:flex}.loading-spinner{border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.loading-spinner-sm{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.login-bg{position:absolute;inset:0;overflow:hidden}.login-bg-shape{filter:blur(100px);opacity:.4;border-radius:50%;animation:20s ease-in-out infinite bgFloat;position:absolute}.login-bg-shape-1{background:var(--accent-primary);width:400px;height:400px;top:-100px;right:-100px}.login-bg-shape-2{background:#8b5cf6;width:300px;height:300px;animation-delay:-7s;bottom:-50px;left:-50px}.login-bg-shape-3{background:#06b6d4;width:250px;height:250px;animation-delay:-14s;top:50%;left:50%}.login-container{z-index:1;width:100%;max-width:420px;position:relative}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);background:#1a1f35d9;padding:40px 32px;animation:.5s slideUp}.login-header{text-align:center;margin-bottom:32px}.login-brand{margin-bottom:16px}.brand-icon-xl{border-radius:var(--radius-lg);width:68px;height:68px;box-shadow:var(--shadow-md);background:0 0;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.login-header h1{margin-bottom:4px;font-size:24px;font-weight:700}.login-header p{color:var(--text-secondary);font-size:14px}.login-form{flex-direction:column;gap:20px;display:flex}.login-footer{text-align:center;margin-top:28px}.login-footer p{color:var(--text-muted);font-size:12px}.input-group{flex-direction:column;gap:6px;display:flex}.input-group label{color:var(--text-secondary);font-size:13px;font-weight:500}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:14px}.input-wrapper input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:12px 14px 12px 42px;font-family:inherit;font-size:14px}.input-wrapper input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.input-wrapper input::placeholder{color:var(--text-muted)}.input-action{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;position:absolute;right:8px}.select-input,.date-input,.textarea-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:12px 14px;font-family:inherit;font-size:14px}.select-input:focus,.date-input:focus,.textarea-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.textarea-input{resize:vertical;min-height:80px}.alert{border-radius:var(--radius-md);align-items:center;gap:10px;padding:12px 16px;font-size:14px;font-weight:500;animation:.3s fadeIn;display:flex}.alert-error{background:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger)}.alert-success{background:var(--success-bg);border:1px solid var(--success-border);color:var(--success)}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), #818cf8);color:#fff;box-shadow:0 2px 8px var(--accent-primary-glow)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg, var(--accent-primary-hover), #a78bfa);box-shadow:0 4px 16px var(--accent-primary-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-primary)}.btn-lg{padding:14px 24px;font-size:15px}.btn-full{width:100%}.btn-loading{align-items:center;gap:8px;display:flex}.btn-icon{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;display:inline-flex}.btn-icon:hover{background:var(--bg-card);color:var(--text-primary)}.btn-icon-sm{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);justify-content:center;align-items:center;padding:8px;display:inline-flex}.btn-icon-sm:hover{background:var(--bg-card-hover);color:var(--text-primary)}.btn-clock-in{color:#fff;border-radius:var(--radius-lg);cursor:pointer;width:100%;transition:all var(--transition-normal);background:linear-gradient(135deg,#10b981,#059669);border:none;justify-content:center;align-items:center;gap:12px;padding:20px;font-size:18px;font-weight:700;display:flex;box-shadow:0 4px 20px #10b9814d}.btn-clock-in:hover{transform:translateY(-2px);box-shadow:0 8px 30px #10b98166}.btn-clock-out{color:#fff;border-radius:var(--radius-lg);cursor:pointer;width:100%;transition:all var(--transition-normal);background:linear-gradient(135deg,#ef4444,#dc2626);border:none;justify-content:center;align-items:center;gap:12px;padding:20px;font-size:18px;font-weight:700;display:flex;box-shadow:0 4px 20px #ef44444d}.btn-clock-out:hover{transform:translateY(-2px);box-shadow:0 8px 30px #ef444466}.btn-approve{background:var(--success-bg);border:1px solid var(--success-border);color:var(--success);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn-approve:hover:not(:disabled){background:#10b98133}.btn-reject{background:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn-reject:hover:not(:disabled){background:#ef444433}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:100;height:100vh;transition:transform var(--transition-normal);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-header{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:24px 20px;display:flex}.sidebar-header h2{flex:1;font-size:16px;font-weight:700}.sidebar-close{display:none}.brand-icon-lg{border-radius:var(--radius-sm);background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;overflow:hidden}.sidebar-user{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:20px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);border-radius:var(--radius-full);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:16px;font-weight:700;display:flex}.user-info{overflow:hidden}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);text-transform:capitalize;font-size:12px}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:12px 10px;display:flex;overflow-y:auto}.nav-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:11px 14px;font-family:inherit;font-size:14px;font-weight:500;text-decoration:none;display:flex}.nav-link:hover{background:var(--bg-card);color:var(--text-primary)}.nav-link-active,.nav-link-active:hover{background:var(--accent-primary-subtle);color:var(--accent-primary-hover)}.sidebar-footer{border-top:1px solid var(--border-light);padding:12px 10px}.logout-btn{color:var(--danger)!important}.logout-btn:hover{background:var(--danger-bg)!important}.sidebar-overlay,.mobile-header{display:none}.mobile-header-main{justify-content:space-between;align-items:center;gap:12px;width:100%;display:flex}.mobile-top-nav{display:none}.mobile-top-nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);white-space:nowrap;transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:6px;padding:8px 10px;font-size:12px;font-weight:600;text-decoration:none;display:inline-flex}.mobile-top-nav-item:hover{background:var(--bg-card);color:var(--text-primary)}.mobile-top-nav-active{background:var(--accent-primary-subtle);color:var(--accent-primary-hover);border-color:#4f46e538}.mobile-logout-btn{color:var(--danger)}.header-brand{align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.brand-icon{border-radius:var(--radius-sm);background:0 0;justify-content:center;align-items:center;width:32px;height:32px;display:flex;overflow:hidden}.brand-logo-image{object-fit:contain;width:100%;height:100%;display:block}.header-avatar{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);border-radius:var(--radius-full);color:#fff;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:700;display:flex}.main-content{margin-left:var(--sidebar-width);background:var(--bg-primary);flex:1;min-height:100vh}.bottom-nav{display:none}.page{max-width:1200px;margin:0 auto;padding:32px;animation:.3s fadeIn}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:28px;display:flex}.page-header h1{align-items:center;gap:10px;font-size:26px;font-weight:700;display:flex}.page-header p{color:var(--text-secondary);margin-top:4px;font-size:14px}.clock-display{text-align:center;margin-bottom:24px}.clock-time{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6, #06b6d4);-webkit-text-fill-color:transparent;letter-spacing:-1px;-webkit-background-clip:text;background-clip:text;font-size:48px;font-weight:800}.clock-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);text-align:center;margin-bottom:24px;padding:28px}.clock-card-status{color:var(--text-secondary);justify-content:center;align-items:center;gap:10px;margin-bottom:20px;font-size:14px;font-weight:500;display:flex}.status-indicator{border-radius:50%;width:10px;height:10px}.status-idle{background:var(--text-muted)}.status-working{background:var(--success);box-shadow:0 0 10px var(--success);animation:2s infinite pulse}.status-completed{background:var(--accent-primary)}.completed-badge{color:var(--success);justify-content:center;align-items:center;gap:10px;padding:16px;font-size:16px;font-weight:600;display:flex}.action-loading{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);color:var(--text-secondary);justify-content:center;align-items:center;gap:12px;margin-bottom:24px;padding:20px;display:flex}.today-summary{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:24px;animation:.4s slideUp}.today-summary h3{margin-bottom:16px;font-size:16px;font-weight:600}.summary-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.summary-item{background:var(--bg-input);border-radius:var(--radius-md);border:1px solid var(--border-light);align-items:center;gap:12px;padding:14px;display:flex}.summary-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.clock-in-icon{background:var(--success-bg);color:var(--success)}.clock-out-icon{background:var(--danger-bg);color:var(--danger)}.hours-icon{background:var(--accent-primary-subtle);color:var(--accent-primary-hover)}.location-icon{background:var(--warning-bg);color:var(--warning)}.summary-label{color:var(--text-muted);font-size:12px}.summary-value{font-size:14px;font-weight:600}.summary-meta{color:var(--text-secondary);font-size:12px;line-height:1.3}.maps-link{color:var(--accent-primary);text-underline-offset:2px;word-break:break-word;overflow-wrap:anywhere;font-size:12px;line-height:1.3;text-decoration:underline}.maps-link:hover{color:var(--accent-primary-hover)}.selfie-row{gap:12px;margin-top:16px;display:flex}.selfie-thumb{flex-direction:column;align-items:center;gap:6px;display:flex}.selfie-thumb img{object-fit:cover;border-radius:var(--radius-md);border:2px solid var(--border-color);width:64px;height:64px}.selfie-thumb span{color:var(--text-muted);font-size:11px}.month-navigator,.date-navigator{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);justify-content:center;align-items:center;gap:16px;margin-bottom:24px;padding:12px;display:flex}.month-navigator h3,.date-display{text-align:center;min-width:180px;font-size:16px;font-weight:600}.date-picker{color:var(--text-primary);text-align:center;cursor:pointer;background:0 0;border:none;outline:none;font-family:inherit;font-size:16px;font-weight:600}.date-picker::-webkit-calendar-picker-indicator{filter:invert();cursor:pointer}.stats-row{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);align-items:center;gap:12px;padding:16px;display:flex}.stat-card svg{color:var(--accent-primary)}.stat-value{font-size:20px;font-weight:700}.stat-label{color:var(--text-muted);font-size:12px}.records-list{flex-direction:column;gap:8px;display:flex}.record-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);align-items:center;gap:16px;padding:16px;display:flex}.record-card:hover{border-color:var(--accent-primary)}.record-date{background:var(--accent-primary-subtle);border-radius:var(--radius-sm);flex-direction:column;align-items:center;min-width:48px;padding:8px;display:flex}.record-day{color:var(--accent-primary-hover);font-size:20px;font-weight:700;line-height:1}.record-month{color:var(--text-muted);text-transform:uppercase;font-size:11px}.record-details{flex-wrap:wrap;flex:1;justify-content:space-between;align-items:center;gap:8px;display:flex}.record-times{gap:16px;font-size:13px;display:flex}.record-in{color:var(--success)}.record-out{color:var(--danger)}.record-meta{align-items:center;gap:12px;display:flex}.record-hours{font-size:14px;font-weight:600}.badge{border-radius:var(--radius-full);align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-working{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.badge-completed{background:var(--accent-primary-subtle);color:var(--accent-primary-hover);border:1px solid #6366f14d}.badge-default{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color)}.badge-pending{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border)}.badge-approved{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.badge-rejected{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.badge-info{background:var(--info-bg);color:var(--info);border:1px solid #3b82f64d}.leave-type-badge{background:var(--accent-primary-subtle);color:var(--accent-primary-hover);border-radius:var(--radius-full);padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.leave-form-card{margin-bottom:24px}.leave-form-card h3{margin-bottom:16px;font-size:16px}.form-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.leave-list{flex-direction:column;gap:12px;display:flex}.leave-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);overflow:hidden}.leave-card:hover{border-color:var(--accent-primary)}.leave-card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.leave-card-body{padding:14px 16px}.leave-date{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:6px;font-size:13px;display:flex}.leave-reason{color:var(--text-primary);font-size:14px;line-height:1.5}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state svg{opacity:.4;margin-bottom:16px}.empty-state h3{color:var(--text-secondary);margin-bottom:6px;font-size:18px}.empty-state-sm{text-align:center;color:var(--text-muted);padding:32px}.admin-stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;display:grid}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);transition:all var(--transition-fast);align-items:center;gap:16px;padding:22px;display:flex}.admin-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.admin-stat-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.stat-blue .admin-stat-icon{background:var(--info-bg);color:var(--info)}.stat-green .admin-stat-icon{background:var(--success-bg);color:var(--success)}.stat-red .admin-stat-icon{background:var(--danger-bg);color:var(--danger)}.stat-orange .admin-stat-icon{background:var(--warning-bg);color:var(--warning)}.admin-stat-value{font-size:28px;font-weight:800;line-height:1}.admin-stat-label{color:var(--text-muted);margin-top:4px;font-size:13px}.search-bar{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color var(--transition-fast);align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;display:flex}.search-bar:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}.search-bar svg{color:var(--text-muted);flex-shrink:0}.search-bar input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:14px}.search-bar input::placeholder{color:var(--text-muted)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);margin-bottom:20px;overflow:hidden}.card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.card-header h3{align-items:center;gap:8px;font-size:16px;font-weight:600;display:flex}.table-responsive{max-width:100%;overflow-x:auto}.table{border-collapse:collapse;width:100%}.table thead{background:var(--bg-input)}.table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:600}.table td{border-bottom:1px solid var(--border-light);white-space:nowrap;padding:14px 16px;font-size:14px}.location-cell{word-break:break-word;overflow-wrap:anywhere;min-width:260px;max-width:380px;line-height:1.35;white-space:normal!important}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:#6366f108}.employee-cell{align-items:center;gap:10px;display:flex}.employee-expand-btn{width:100%;color:inherit;font:inherit;text-align:left;cursor:pointer;background:0 0;border:none;padding:0}.employee-expand-btn:hover .employee-name,.employee-expand-btn:hover span{color:var(--accent-primary)}.employee-avatar-sm{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);border-radius:var(--radius-full);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.employee-name{font-size:14px;font-weight:600}.employee-email{color:var(--text-muted);font-size:12px}.selfie-cell{flex-wrap:wrap;gap:6px;display:flex}.selfie-mini{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color);cursor:pointer;width:36px;height:36px;transition:transform var(--transition-fast)}.selfie-mini:hover{z-index:10;transform:scale(1.5)}.image-lightbox-overlay{z-index:1200;background:#0a0a0ceb;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.image-lightbox-content{justify-content:center;align-items:center;max-width:min(92vw,920px);max-height:92vh;display:flex;position:relative}.image-lightbox-close{color:#fff;background:#ffffff1a;border:1px solid #fff3;position:absolute;top:-44px;right:-4px}.image-lightbox-image{border-radius:var(--radius-md);object-fit:contain;width:auto;max-width:100%;height:auto;max-height:92vh;box-shadow:0 18px 50px #00000073}.record-detail-row td{white-space:normal;background:var(--bg-input)}.record-detail-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.filter-tabs{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.filter-tab{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;display:inline-flex}.filter-tab:hover{background:var(--bg-card-hover);color:var(--text-primary)}.filter-tab-active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.filter-tab-active:hover{background:var(--accent-primary-hover);color:#fff}.filter-count{border-radius:var(--radius-full);background:#fff3;padding:1px 7px;font-size:11px;font-weight:700}.leave-management-list{flex-direction:column;gap:12px;display:flex}.leave-mgmt-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);transition:border-color var(--transition-fast);overflow:hidden}.leave-mgmt-card:hover{border-color:var(--accent-primary)}.leave-mgmt-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.leave-mgmt-employee{align-items:center;gap:10px;display:flex}.leave-mgmt-body{padding:16px 20px}.leave-mgmt-detail{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:8px;display:flex}.leave-mgmt-date{color:var(--text-secondary);align-items:center;gap:4px;font-size:13px;display:flex}.leave-mgmt-reason{color:var(--text-primary);font-size:14px;line-height:1.5}.leave-mgmt-actions{border-top:1px solid var(--border-light);background:var(--bg-input);gap:8px;padding:12px 20px;display:flex}.report-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}.report-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:20px;display:flex}.report-stat-card svg{color:var(--accent-primary)}.report-stat-value{font-size:24px;font-weight:800}.report-stat-label{color:var(--text-muted);font-size:12px}.camera-overlay{background:var(--bg-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.camera-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:480px;overflow:hidden}.camera-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.camera-header h3{font-size:16px;font-weight:600}.camera-error{color:var(--danger);text-align:center;padding:12px 20px;font-size:13px}.camera-start{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:48px 20px;display:flex}.camera-preview{aspect-ratio:4/3;background:#000;justify-content:center;align-items:center;width:100%;display:flex}.camera-video,.camera-photo{object-fit:cover;width:100%;height:100%}.camera-controls{justify-content:center;align-items:center;gap:24px;padding:20px;display:flex}.btn-capture{cursor:pointer;width:64px;height:64px;transition:all var(--transition-fast);background:0 0;border:4px solid #fff;border-radius:50%;justify-content:center;align-items:center;display:flex}.btn-capture:hover{border-color:var(--accent-primary)}.capture-inner{width:48px;height:48px;transition:all var(--transition-fast);background:#fff;border-radius:50%}.btn-capture:hover .capture-inner{background:var(--accent-primary)}@media (width<=1024px){.admin-stats-grid,.report-stats{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.app-layout{flex-direction:column;align-items:stretch}.sidebar{display:none!important}.mobile-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:50;flex-direction:column;justify-content:center;align-items:stretch;gap:8px;width:100%;min-height:56px;padding:8px 10px;display:flex;position:sticky;top:0}.mobile-header-main{min-height:34px}.mobile-header .header-brand{gap:8px;font-size:14px}.mobile-header .brand-icon{width:26px;height:26px;font-size:9px}.mobile-header .header-avatar{width:30px;height:30px;font-size:12px}.mobile-top-nav{scrollbar-width:thin;align-items:center;gap:6px;width:100%;padding-bottom:2px;display:flex;overflow-x:auto}.mobile-top-nav-item{flex-shrink:0;padding:7px 9px;font-size:11px}.mobile-top-nav-item svg{width:14px;height:14px}.main-content{width:100%;margin-left:0;padding-bottom:0}.page{padding:16px 12px}.page-header{margin-bottom:20px}.page-header h1{font-size:22px}.page-header p{font-size:13px}.clock-time{font-size:36px}.employee-dashboard-page .clock-card,.employee-dashboard-page .today-summary,.admin-dashboard-page .card{border-radius:var(--radius-lg)}.employee-dashboard-page .btn-clock-in,.employee-dashboard-page .btn-clock-out{padding:16px;font-size:16px}.employee-dashboard-page .action-loading{text-align:center;flex-wrap:wrap;line-height:1.4}.employee-dashboard-page .summary-item>div:last-child{min-width:0}.employee-dashboard-page .summary-value{word-break:break-word}.summary-grid{grid-template-columns:1fr}.stats-row{grid-template-columns:repeat(3,1fr)}.admin-stats-grid,.report-stats{grid-template-columns:repeat(2,1fr)}.record-details{flex-direction:column;align-items:flex-start}}@media (width<=640px){.admin-dashboard-page .card-header{gap:8px;padding:14px 16px}.admin-dashboard-page .card-header h3{font-size:15px}.admin-dashboard-page .table-responsive{overflow:visible}.admin-dashboard-page #today-activity-table,.admin-dashboard-page #today-activity-table tbody,.admin-dashboard-page #today-activity-table tr,.admin-dashboard-page #today-activity-table td{width:100%;display:block}.admin-dashboard-page #today-activity-table thead{display:none}.admin-dashboard-page #today-activity-table{border-collapse:separate;border-spacing:0 10px}.admin-dashboard-page #today-activity-table tr{background:var(--bg-input);border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden}.admin-dashboard-page #today-activity-table td{white-space:normal;border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:13px;display:flex}.admin-dashboard-page #today-activity-table td:before{content:attr(data-label);letter-spacing:.4px;text-transform:uppercase;color:var(--text-muted);flex-shrink:0;font-size:11px;font-weight:700}.admin-dashboard-page #today-activity-table td:first-child{flex-direction:column;align-items:flex-start;gap:8px}.admin-dashboard-page #today-activity-table td:first-child:before{margin-bottom:2px}.admin-dashboard-page #today-activity-table td:last-child{border-bottom:none}.admin-dashboard-page .employee-cell{width:100%;min-width:0}.admin-dashboard-page .employee-cell span{white-space:normal;word-break:break-word}.admin-dashboard-page .location-cell{text-align:right;min-width:0;max-width:100%}.admin-dashboard-page .record-detail-row td{display:block!important}.admin-dashboard-page .record-detail-row td:before{content:none}.record-detail-grid{grid-template-columns:1fr}}@media (width<=480px){.mobile-header{min-height:50px;padding:6px 10px}.mobile-header .header-brand{font-size:13px}.mobile-header .brand-icon{width:24px;height:24px;font-size:8px}.mobile-top-nav-item{padding:6px 8px}.mobile-top-nav-item span{text-overflow:ellipsis;max-width:90px;overflow:hidden}.mobile-header .header-avatar{width:28px;height:28px;font-size:11px}.stats-row,.admin-stats-grid,.report-stats{grid-template-columns:1fr}.page-header{flex-direction:column}}#root{min-height:100vh}.landing-page{background:var(--bg-primary);min-height:100vh;overflow-x:hidden}.landing-nav{z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-light);background:#0a0a14b3;padding:16px 24px;position:fixed;top:0;left:0;right:0}.landing-nav-inner{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;display:flex}.landing-brand{align-items:center;gap:10px;display:flex}.brand-icon-sm{border-radius:var(--radius-md);background:0 0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;overflow:hidden}.brand-name{color:var(--text-primary);font-size:18px;font-weight:700}.landing-nav-actions{align-items:center;gap:10px;display:flex}.btn-install-nav{border-radius:var(--radius-full);color:var(--accent-primary-hover);cursor:pointer;transition:all var(--transition-fast);background:#6366f126;border:1px solid #6366f14d;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn-install-nav:hover{background:#6366f140}.btn-sm{padding:8px 18px;font-size:13px}.landing-hero{align-items:center;gap:60px;max-width:1200px;min-height:100vh;margin:0 auto;padding:100px 24px 60px;display:flex;position:relative}.landing-hero-bg{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.hero-gradient-orb{filter:blur(120px);opacity:.3;border-radius:50%;position:absolute}.hero-orb-1{background:radial-gradient(circle,#6366f1,#0000 70%);width:600px;height:600px;animation:20s ease-in-out infinite float;top:-200px;right:-100px}.hero-orb-2{background:radial-gradient(circle,#8b5cf6,#0000 70%);width:400px;height:400px;animation:25s ease-in-out infinite reverse float;bottom:-100px;left:-100px}.hero-orb-3{background:radial-gradient(circle,#06b6d4,#0000 70%);width:300px;height:300px;animation:18s ease-in-out 5s infinite float;top:40%;left:30%}.hero-grid-overlay{background-image:linear-gradient(#6366f108 1px,#0000 1px),linear-gradient(90deg,#6366f108 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0}.landing-hero-content{z-index:1;flex:1;position:relative}.hero-badge{border-radius:var(--radius-full);color:var(--accent-primary-hover);background:#6366f11f;border:1px solid #6366f140;align-items:center;gap:8px;margin-bottom:28px;padding:8px 16px;font-size:13px;font-weight:600;animation:.6s fadeIn;display:inline-flex}.hero-title{margin-bottom:20px;font-size:clamp(36px,5vw,64px);font-weight:800;line-height:1.1;animation:.6s .1s both slideUp}.hero-gradient-text{background:linear-gradient(135deg,#6366f1,#8b5cf6,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--text-secondary);max-width:520px;margin-bottom:36px;font-size:18px;line-height:1.7;animation:.6s .2s both slideUp}.hero-actions{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:48px;animation:.6s .3s both slideUp;display:flex}.btn-install-hero{border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0f;border:1px solid #ffffff26;align-items:center;gap:8px;padding:14px 28px;font-family:inherit;font-size:15px;font-weight:600;display:inline-flex}.btn-install-hero:hover{background:#ffffff1f;border-color:#ffffff40;transform:translateY(-1px)}.hero-stats{align-items:center;gap:24px;animation:.6s .4s both slideUp;display:flex}.hero-stat{flex-direction:column;gap:4px;display:flex}.hero-stat-number{color:var(--text-primary);font-size:24px;font-weight:800}.hero-stat-label{color:var(--text-muted);font-size:13px}.hero-stat-divider{background:var(--border-color);width:1px;height:40px}.landing-hero-visual{z-index:1;flex-shrink:0;animation:.8s .3s both slideUp;position:relative}.hero-phone-mockup{perspective:1000px}.phone-frame{background:linear-gradient(145deg,#1a1a2e,#16162a);border:3px solid #6366f14d;border-radius:40px;width:280px;height:560px;transition:transform .4s;overflow:hidden;transform:rotateY(-5deg)rotateX(2deg);box-shadow:0 0 60px #6366f126,0 30px 80px #00000080,inset 0 1px #ffffff0d}.phone-frame:hover{transform:rotateY(0)rotateX(0)}.phone-notch{background:#0a0a14;border-radius:0 0 20px 20px;width:120px;height:28px;margin:0 auto}.phone-screen{padding:8px 20px 20px}.phone-status-bar{color:var(--text-secondary);justify-content:space-between;align-items:center;padding:4px 4px 16px;font-size:12px;font-weight:600;display:flex}.phone-status-icons{gap:4px;display:flex}.phone-app-content{text-align:center;padding-top:40px}.phone-greeting{color:var(--text-secondary);margin-bottom:8px;font-size:16px}.phone-clock{background:linear-gradient(135deg,#fff,#ffffffb3);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:30px;font-size:40px;font-weight:800}.phone-status-badge{border-radius:var(--radius-full);color:var(--accent-primary-hover);background:#6366f11f;border:1px solid #6366f14d;align-items:center;gap:8px;margin-bottom:40px;padding:8px 18px;font-size:13px;font-weight:600;display:inline-flex}.phone-status-dot{background:var(--text-muted);border-radius:50%;width:8px;height:8px}.phone-btn-mock{border-radius:var(--radius-lg);color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);justify-content:center;align-items:center;gap:10px;padding:16px 48px;font-size:16px;font-weight:700;display:inline-flex;box-shadow:0 8px 30px #22c55e4d}.landing-section-inner{max-width:1200px;margin:0 auto;padding:0 24px}.section-header{text-align:center;margin-bottom:56px}.section-badge{border-radius:var(--radius-full);color:var(--accent-primary-hover);background:#6366f11a;border:1px solid #6366f133;margin-bottom:16px;padding:6px 16px;font-size:13px;font-weight:600;display:inline-block}.section-title{margin-bottom:16px;font-size:clamp(28px,3.5vw,42px);font-weight:800;line-height:1.2}.section-subtitle{color:var(--text-secondary);max-width:560px;margin:0 auto;font-size:16px;line-height:1.6}.landing-features{z-index:1;padding:100px 0;position:relative}.features-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.feature-card{border:1px solid var(--border-color);border-radius:var(--radius-xl);background:#ffffff05;padding:32px;transition:all .3s;animation:.6s both fadeIn}.feature-card:hover{background:#6366f10a;border-color:#6366f14d;transform:translateY(-4px);box-shadow:0 12px 40px #6366f11a}.feature-icon{border-radius:var(--radius-lg);width:56px;height:56px;color:var(--accent-primary-hover);background:linear-gradient(135deg,#6366f126,#8b5cf626);border:1px solid #6366f133;justify-content:center;align-items:center;margin-bottom:20px;display:flex}.feature-title{margin-bottom:10px;font-size:18px;font-weight:700}.feature-description{color:var(--text-secondary);font-size:14px;line-height:1.6}.landing-steps{z-index:1;background:#ffffff03;padding:100px 0;position:relative}.steps-grid{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.step-card{text-align:center;padding:32px 20px;position:relative}.step-number{background:linear-gradient(135deg,#6366f14d,#6366f10d);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:20px;font-size:48px;font-weight:900;line-height:1}.step-title{margin-bottom:10px;font-size:17px;font-weight:700}.step-description{color:var(--text-secondary);font-size:14px;line-height:1.6}.step-connector{display:none}.landing-roles{z-index:1;padding:80px 0;position:relative}.roles-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.role-card{border-radius:var(--radius-xl);border:1px solid var(--border-color);padding:40px;transition:all .3s}.role-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px #0003}.role-card-employee{background:linear-gradient(145deg,#22c55e0a,#22c55e03);border-color:#22c55e26}.role-card-employee:hover{border-color:#22c55e59}.role-card-admin{background:linear-gradient(145deg,#6366f10a,#6366f103);border-color:#6366f126}.role-card-admin:hover{border-color:#6366f159}.role-icon-wrap{border-radius:var(--radius-lg);justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:24px;display:flex}.role-card-employee .role-icon-wrap{color:#22c55e;background:#22c55e1f}.role-card-admin .role-icon-wrap{color:var(--accent-primary-hover);background:#6366f11f}.role-card h3{margin-bottom:20px;font-size:22px;font-weight:700}.role-list{flex-direction:column;gap:14px;list-style:none;display:flex}.role-list li{color:var(--text-secondary);align-items:center;gap:10px;font-size:15px;display:flex}.role-card-employee .role-list svg{color:#22c55e;flex-shrink:0}.role-card-admin .role-list svg{color:var(--accent-primary-hover);flex-shrink:0}.landing-cta{z-index:1;padding:100px 0;position:relative}.cta-content{text-align:center;border-radius:var(--radius-xl);background:linear-gradient(145deg,#6366f114,#8b5cf60a);border:1px solid #6366f133;max-width:600px;margin:0 auto;padding:64px 40px}.cta-content h2{margin-bottom:16px;font-size:clamp(26px,3vw,36px);font-weight:800}.cta-content p{color:var(--text-secondary);margin-bottom:32px;font-size:16px;line-height:1.6}.cta-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;display:flex}.landing-footer{border-top:1px solid var(--border-color);z-index:1;padding:48px 0 24px;position:relative}.footer-content{flex-direction:column;align-items:center;gap:12px;margin-bottom:32px;display:flex}.footer-tagline{color:var(--text-muted);font-size:14px}.btn-install-footer{border-radius:var(--radius-full);color:var(--accent-primary-hover);cursor:pointer;transition:all var(--transition-fast);background:#6366f11f;border:1px solid #6366f140;align-items:center;gap:8px;margin-top:4px;padding:10px 22px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.btn-install-footer:hover{background:#6366f138}.footer-bottom{text-align:center;border-top:1px solid var(--border-light);padding-top:24px}.footer-bottom p{color:var(--text-muted);font-size:13px}@media (width<=1024px){.landing-hero{text-align:center;flex-direction:column;gap:48px;padding-top:120px}.hero-subtitle{margin:0 auto 36px}.hero-actions,.hero-stats{justify-content:center}.features-grid{grid-template-columns:repeat(2,1fr)}.steps-grid{grid-template-columns:repeat(2,1fr);gap:16px}}@media (width<=768px){.landing-nav{padding:12px 16px}.features-grid{grid-template-columns:1fr}.steps-grid{grid-template-columns:1fr;gap:8px}.step-card{padding:20px}.roles-grid{grid-template-columns:1fr}.role-card{padding:28px}.cta-content{padding:40px 24px}.phone-frame{border-radius:32px;width:240px;height:480px}.phone-clock{font-size:32px}.phone-btn-mock{padding:12px 36px;font-size:14px}.landing-hero-visual{order:-1}}@media (width<=480px){.hero-stats{gap:16px}.hero-stat-number{font-size:20px}}
